Skip to content

Latest commit

 

History

History
269 lines (209 loc) · 16.5 KB

README.md

File metadata and controls

269 lines (209 loc) · 16.5 KB

Project-Star: Survey and Terrain Analysis Robot (STAR)

Documentation Status

STAR (Survey and Terrain Analysis Robot) is an advanced terrain-mapping robot designed to autonomously navigate and create detailed 3D mesh topology maps of various landscapes, including hills and valleys. This repository contains the firmware for the ESP32 microcontroller that powers STAR. You can find comprehensive information, including hardware specifications, software architecture, and API documentation, on the project's dedicated documentation site hosted on GitHub Pages.

Table of Contents

Features

  • Terrain Mapping: Generates detailed 3D mesh topology maps of diverse terrains.
  • Autonomous Navigation: Designed to traverse hills, valleys, and other challenging landscapes.
  • Sensor Suite: Equipped with a comprehensive set of sensors for data acquisition:
    • Environmental: DHT22 (Temperature & Humidity), BH1750 (Ambient Light), SEN-CCS811 & MQ135 (Air Quality).
    • Motion & Orientation: MPU6050 (Accelerometer & Gyroscope), QMC5883L (Magnetometer).
    • Localization: GY-NEO6MV2 (GPS).
    • Imaging: OV7670 Camera (controlled by DE10-Lite FPGA).
  • Data Storage: Utilizes a Micro-SD card for onboard data logging.
  • Remote Communication: Implements Wi-Fi connectivity for data transmission and potential remote control.
  • Modular Design: Built using ESP-IDF with a modular component structure for easy maintenance and expansion.
  • JTAG Debugging: Supports JTAG debugging for development and troubleshooting.
  • Interrupt-Driven Sensor Handling: The MPU6050 sensor implementation uses interrupts for efficient data acquisition.

Hardware

The core of STAR is an ESP32 microcontroller. It interacts with the following hardware components:

  • Microcontroller: ESP32
  • Sensors:
    • DHT22 (Temperature & Humidity)
    • MPU6050 (Accelerometer & Gyroscope)
    • BH1750 (Ambient Light)
    • QMC5883L (Magnetometer)
    • OV7670 (Camera, controlled by DE10-Lite)
    • SEN-CCS811 (Air Quality - eCO2, TVOC)
    • MQ135 (Air Quality - various gases)
    • GY-NEO6MV2 (GPS)
  • Storage: Micro-SD Card Module
  • Actuators: Motors controlled via PCA9685 PWM Driver
  • Communication: Wi-Fi (ESP32 built-in)
  • Power: 3.3V power supply for most components, with potential external power for motors
  • FPGA (External): DE10-Lite (for camera control)
  • JTAG Debugger: CJMCU-4232 (optional, for debugging)

Schematics:

Refer to the images below for the schematics of the robot:

Print Schematic-2 Print Schematic-3 Print Schematic-4 Print Schematic-5

Software

The firmware is developed using the ESP-IDF framework and written primarily in C. It utilizes FreeRTOS for task management.

Software Components:

  • components/: Contains modular components:
    • camera/: Hardware Abstraction Layer (HAL) for the OV7670 camera.
    • common/: I2C, SPI, and UART communication drivers.
    • controllers/: HAL for the PCA9685 PWM driver.
    • sensors/: HALs for each sensor (BH1750, DHT22, MPU6050, QMC5883L, GY-NEO6MV2, CCS811, MQ135).
    • storage/: HAL for SD card interactions.
  • main/:
    • include/managers/: Time management and file writing utilities.
    • include/tasks/: Task definitions for motor control, sensor data acquisition, Wi-Fi management, and web server communication.
    • main.c: Main application entry point.

Dependencies:

  • ESP-IDF: v4.4 or later (check idf.py --version)
  • cJSON: For JSON data formatting.
  • FATFS: For SD card file system operations.

Installation

  1. Install ESP-IDF: Follow the official ESP-IDF installation instructions: https://docs.espressif.com/projects/esp-idf/en/latest/esp32/get-started/index.html

  2. Clone the Repository:

    git clone https://github.com/Topographic-Robot/Project-Star.git
    cd Project-Star
  3. Configure Wi-Fi Credentials:

    • Copy the main/include/tasks/include/wifi_credentials.txt file to main/include/tasks/include/wifi_credentials.h.
    • Edit wifi_credentials.h and replace the placeholder values for wifi_ssid and wifi_pass with your actual Wi-Fi network credentials. Do not commit this file to Git.
  4. Configure Webserver URL (Optional):

    • If you intend to send sensor data to a web server, copy the main/include/tasks/include/webserver_info.txt file to main/include/tasks/include/webserver_info.h.
    • Edit webserver_info.h and replace the placeholder value for webserver_url with your server's URL. Do not commit this file to Git.
  5. Build and Flash:

    idf.py set-target esp32
    idf.py build
    idf.py -p /dev/ttyUSB0 flash monitor  # Replace /dev/ttyUSB0 with your ESP32's port

Wiring

The Wiring.txt file in the repository provides detailed pin connections between the ESP32 and each component. Here's a summary:

Important: Always double-check the pin connections in Wiring.txt before powering on the robot.

Component Component Pin ESP32 Pin Notes
DHT22 DATA GPIO_NUM_4 (D4) Temperature and humidity sensor.
MPU6050 SDA GPIO_NUM_21 (D21) Accelerometer and gyroscope. Uses I2C.
SCL GPIO_NUM_22 (D22)
INT GPIO_NUM_26 (D26) Interrupt pin for motion detection, data ready, etc.
BH1750 SDA GPIO_NUM_21 (D21) Ambient light sensor. Uses I2C.
SCL GPIO_NUM_22 (D22)
QMC5883L SDA GPIO_NUM_21 (D21) Magnetometer. Uses I2C.
SCL GPIO_NUM_22 (D22)
DRDY GPIO_NUM_18 (D18) Data Ready pin (currently marked as TODO in the Wiring.txt).
OV7670 SDA GPIO_NUM_21 (D21) Camera module. Uses I2C for configuration. Data and control signals are managed by the DE10-Lite FPGA.
SCL GPIO_NUM_22 (D22)
Micro-SD Reader MOSI GPIO_NUM_23 (D23) Uses SPI.
MISO GPIO_NUM_19 (D19)
CLK GPIO_NUM_14 (D14)
CS GPIO_NUM_5 (D5)
SEN-CCS811 SDA GPIO_NUM_21 (D21) Air quality sensor (eCO2, TVOC). Uses I2C.
SCL GPIO_NUM_22 (D22)
WAKE GPIO_NUM_33 (D33)
RST GPIO_NUM_32 (D32)
INT GPIO_NUM_25 (D25)
MQ135 A0 GPIO_NUM_34 (D34) Air quality sensor (various gases). Analog output.
D0 GPIO_NUM_35 (D35) Digital output (optional).
GY-NEO6MV2 TX GPIO_NUM_16 (RX2) GPS module. Uses UART.
RX GPIO_NUM_17 (TX2)
PCA9685 SDA GPIO_NUM_21 (D21) PWM driver (for motor control). Uses I2C.
SCL GPIO_NUM_22 (D22)
OE GPIO_NUM_15 (D15) Output Enable.

JTAG Debugging

JTAG (Joint Test Action Group) debugging is crucial for in-depth troubleshooting and development. It allows you to step through code, set breakpoints, inspect memory, and diagnose issues that might be difficult to identify otherwise. This project supports JTAG debugging using a CJMCU-4232 debugger, OpenOCD (Open On-Chip Debugger), and GDB.

Hardware Setup:

  1. CJMCU-4232 Debugger: This project uses the CJMCU-4232, a low-cost FT2232-based USB to JTAG interface.

  2. Connections: Connect the CJMCU-4232 to the ESP32 according to the following table, which is also found in the JTAG-info.txt file:

    CJMCU-4232 Pin ESP32 Pin JTAG Signal
    AD0 D13 TCK (Test Clock)
    AD1 D12 TDI (Test Data In)
    AD2 D15 TDO (Test Data Out)
    AD3 D14 TMS (Test Mode Select)
    GND GND Ground
    3V3 3V3 Power

Software Setup:

  1. Install OpenOCD: If you don't have OpenOCD installed, follow the installation instructions for your operating system. You can usually find it in your system's package manager (e.g., apt-get on Ubuntu/Debian, brew on macOS). If you installed the ESP-IDF, you should already have OpenOCD.

  2. Install GDB: You need the Xtensa-specific GDB for debugging the ESP32. If you installed the ESP-IDF, then it should be in your path. Test this by running xtensa-esp32-elf-gdb --version

Debugging Steps:

  1. Identify the ESP32 (Optional but Recommended):

    • Run lsusb (on Linux/macOS) or the equivalent command on your OS to list connected USB devices.
    • Look for the entry corresponding to the CJMCU-4232 or a similar FTDI device.
    • Note the Vendor ID (VID) and Product ID (PID). You might need these values for OpenOCD configuration. Example output, which identifies the VID:PID as 0403:6011:
      Bus 000 Device 004: ID 0403:6011 Future Technology Devices International Limited Quad RS232-HS
      
  2. Start OpenOCD:

    • Open a terminal and run the following command:

      openocd -f board/esp32-wrover-kit-3.3v.cfg -c "ftdi_vid_pid 0x0403 0x6011"
      • -f board/esp32-wrover-kit-3.3v.cfg: This specifies the configuration file for the ESP32-WROVER-KIT board, which has similar JTAG settings. You can adapt this to other ESP32 boards if needed.
      • -c "ftdi_vid_pid 0x0403 0x6011": This sets the VID and PID for the CJMCU-4232. Replace 0x0403 and 0x6011 with the values you identified in step 1 if they are different.
    • You should see output indicating that OpenOCD has started successfully and is listening on port 3333 for GDB connections. Example Output:

      Info : clock speed 20000 kHz
      Info : JTAG tap: esp32.esp32.tap0 tap/device found: 0x120034e5 (mfg: 0x272 (Tensilica), part: 0x2003, ver: 0x1)
      Info : JTAG tap: esp32.esp32.tap1 tap/device found: 0x120034e5 (mfg: 0x272 (Tensilica), part: 0x2003, ver: 0x1)
      Info : esp32.cpu0: Debug controller was reset.
      Info : esp32.cpu0: Core was reset.
      Info : esp32.cpu1: Debug controller was reset.
      Info : esp32.cpu1: Core was reset.
      Info : Listening on port 3333 for gdb connections
      
  3. Connect with GDB:

    • Open another terminal.

    • Navigate to your project directory.

    • Run the following command to start GDB and connect to OpenOCD:

      xtensa-esp32-elf-gdb -ex "target remote localhost:3333" build/Topographic-Robot.elf
      • Assuming the project's ELF file is named Topographic-Robot.elf and is located in the build directory. Adjust the path if necessary.
    • You should now be in the GDB prompt, connected to your ESP32.

Basic GDB Commands:

  • monitor reset halt: Reset and halt the ESP32.
  • b <function_name or file:line_number>: Set a breakpoint.
  • c: Continue execution.
  • p <variable_name>: Print the value of a variable.
  • n: Step to the next line.
  • s: Step into a function.
  • q: Quit GDB.

Example Debugging Session:

  1. Start OpenOCD (as described above).

  2. Connect with GDB (as described above).

  3. Set a breakpoint at the beginning of your app_main function:

    (gdb) b app_main
    Breakpoint 1 at 0x400d1234: file main/main.c, line 123.
    
  4. Continue execution:

    (gdb) c
    Continuing.
    
  5. The program will run until it hits the breakpoint at app_main.

  6. You can now step through the code, inspect variables, and use other GDB commands to debug your program.

Important Notes:

  • Make sure your ESP32 is not being flashed or monitored by another program when using JTAG, as this can cause conflicts.
  • Consult the OpenOCD documentation for more advanced configuration options and troubleshooting: http://openocd.org/
  • Refer to the GDB documentation for a comprehensive list of commands: https://sourceware.org/gdb/current/onlinedocs/gdb/

Documentation

For more detailed information about the project, including hardware specifications, software architecture, and API documentation, please refer to the online documentation hosted on GitHub Pages:

https://topographic-robot.github.io/Topographic-Robot-Documentation/html/index.html

Contributing

Contributions to Project-Star are welcome! Please follow these guidelines:

  1. Fork the repository.
  2. Create a new branch for your feature or bug fix.
  3. Write clear and concise code with proper comments.
  4. Test your changes thoroughly.
  5. Submit a pull request with a detailed description of your changes.

License

This project is licensed under the MIT License - see the LICENSE file for details.