Archive STM32 firmware to legacy/stm32/: - src/, include/, lib/USB_CDC/, platformio.ini, test stubs, flash_firmware.py - test/test_battery_adc.c, test_hw_button.c, test_pid_schedule.c, test_vesc_can.c, test_can_watchdog.c - USB_CDC_BUG.md Rename: stm32_protocol → esp32_protocol, mamba_protocol → balance_protocol, stm32_cmd_node → esp32_cmd_node, stm32_cmd_params → esp32_cmd_params, stm32_cmd.launch.py → esp32_cmd.launch.py, test_stm32_protocol → test_esp32_protocol, test_stm32_cmd_node → test_esp32_cmd_node Content cleanup across all files: - Mamba F722S → ESP32-S3 BALANCE - BlackPill → ESP32-S3 IO - STM32F722/F7xx → ESP32-S3 - stm32Mode/Version/Port → esp32Mode/Version/Port - STM32 State/Mode labels → ESP32 State/Mode - Jetson Nano → Jetson Orin Nano Super - /dev/stm32 → /dev/esp32 - stm32_bridge → esp32_bridge - STM32 HAL → ESP-IDF docs/SALTYLAB.md: - Update "Drone FC Details" to describe ESP32-S3 BALANCE board (Waveshare ESP32-S3 Touch LCD 1.28) - Replace verbose "Self-Balancing Control" STM32 section with brief note pointing to SAUL-TEE-SYSTEM-REFERENCE.md TEAM.md: Update Embedded Firmware Engineer role to ESP32-S3 / ESP-IDF No new functionality — cleanup only. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
74 lines
2.2 KiB
Markdown
74 lines
2.2 KiB
Markdown
# Jetson Orin Nano Super — AI/SLAM Platform Setup
|
|
|
|
Self-balancing robot: Jetson Orin Nano Super dev environment for ROS2 Humble + SLAM stack.
|
|
|
|
## Stack
|
|
|
|
| Component | Version / Part |
|
|
|-----------|---------------|
|
|
| Platform | Jetson Orin Nano Super 4GB |
|
|
| JetPack | 4.6 (L4T R32.6.1, CUDA 10.2) |
|
|
| ROS2 | Humble Hawksbill |
|
|
| DDS | CycloneDDS |
|
|
| SLAM | slam_toolbox |
|
|
| Nav | Nav2 |
|
|
| Depth camera | Intel RealSense D435i |
|
|
| LiDAR | RPLIDAR A1M8 |
|
|
<<<<<<< HEAD
|
|
| MCU bridge | ESP32 (USB CDC @ 921600) |
|
|
=======
|
|
| MCU bridge | ESP32-S3 (USB Serial (CH343) @ 921600) |
|
|
>>>>>>> 291dd68 (feat: remove all STM32/Mamba/BlackPill references — ESP32-S3 only)
|
|
|
|
## Quick Start
|
|
|
|
```bash
|
|
# 1. Host setup (once, on fresh JetPack 4.6)
|
|
sudo bash scripts/setup-jetson.sh
|
|
|
|
# 2. Build Docker image
|
|
bash scripts/build-and-run.sh build
|
|
|
|
# 3. Start full stack
|
|
bash scripts/build-and-run.sh up
|
|
|
|
# 4. Open ROS2 shell
|
|
bash scripts/build-and-run.sh shell
|
|
```
|
|
|
|
## Docs
|
|
|
|
- [`docs/pinout.md`](docs/pinout.md) — GPIO/I2C/UART pinout for all peripherals
|
|
- [`docs/power-budget.md`](docs/power-budget.md) — 10W power envelope analysis
|
|
|
|
## Files
|
|
|
|
```
|
|
jetson/
|
|
├── Dockerfile # L4T base + ROS2 Humble + SLAM packages
|
|
<<<<<<< HEAD
|
|
├── docker-compose.yml # Multi-service stack (ROS2, RPLIDAR, D435i, ESP32 BALANCE)
|
|
=======
|
|
├── docker-compose.yml # Multi-service stack (ROS2, RPLIDAR, D435i, ESP32-S3)
|
|
>>>>>>> 291dd68 (feat: remove all STM32/Mamba/BlackPill references — ESP32-S3 only)
|
|
├── README.md # This file
|
|
├── docs/
|
|
│ ├── pinout.md # GPIO/I2C/UART pinout reference
|
|
│ └── power-budget.md # Power budget analysis (10W envelope)
|
|
└── scripts/
|
|
├── entrypoint.sh # Docker container entrypoint
|
|
├── setup-jetson.sh # Host setup (udev, Docker, nvpmodel)
|
|
└── build-and-run.sh # Build/run helper
|
|
```
|
|
|
|
## Power Budget (Summary)
|
|
|
|
| Scenario | Total |
|
|
|---------|-------|
|
|
| Idle | 2.9W |
|
|
| Nominal (SLAM active) | ~10.2W |
|
|
| Peak | 15.4W |
|
|
|
|
Target: 10W (MAXN nvpmodel). Use RPLIDAR standby + 640p D435i for compliance.
|
|
See [`docs/power-budget.md`](docs/power-budget.md) for full analysis.
|