Skip to content

Latest commit

 

History

History
69 lines (51 loc) · 3.93 KB

README.md

File metadata and controls

69 lines (51 loc) · 3.93 KB

Gateway Utility Board Rev. 2 (GUB2)

Warning

This is currently a proof of concept project to verify that the ESP32 will work for our needs! Future commits will clean up the project and follow better codding standards.

Introduction

The Gateway Utility Board Rev. 2 (GUB2) is responsible for recording all the CAN messages sent on the bike and logging them for future debugging. The board utilizes an esp32s3 for creating a wifi access point to remotely retrieve logs.

Current Progress

  • setup simple project and install toolchain
  • get UART logging working
  • get CANbus through MCP251863 to UART working
  • get SD card file writing with raw CAN message dumps
  • get wifi ap working - maybe wifi station + AP
  • simple http server for listing and reading sd card contents
  • clean up code
  • generate vectorblf files for CAN logs

Build Tools Setup Steps

Important

This project does not use the standard EVT-core abstraction layer and corresponding built tools!

Before building this project, the ESP-IDF tool chains needs to be installed. There is an install guide provided by Espressif that should be referenced if any issue arise. First, install Visual Studio Code and the "ESP-IDF" extension. Once installed click on the "ESP-IDF: Explorer" icon on the left side bar. Then the "Configure ESP-IDF Extension" option under the commands. In this menu, click on "Express" and under the ESP-IDF version, select v5.1.1 (release). Once installed, the rest of the project can be built and flashed to the board.

If you encounter esp_lcd_panel_rgb.c:747:1: internal compiler error: Segmentation fault, pray it goes away.

Once the build tools are setup, clone this repository with:

git clone --recurse-submodules https://github.com/RIT-EVT/GUB2.git

Once the repository is cloned, the project can be built in VSCode using the ESP-IDF extension and pressing the build button on the bottom status bar. The project can also be built with cmake build from the ESP-IDF Terminal.

Development Setup

The GUB software was developed and tested with the ESP32-S3-DevKitC-1. This board consists of an ESP32-S3-WROOM-1 with 8 MB Flash and 512KB of SRAM along with a NEOPIXEL on pin 48. The software has only been tested with a single CAN cip, but support for multiple has been added.

Debugging

For debugging the board you will likely have to launch openocd manually as it will oftentimes fail. To do so open the ESP-IDF terminal and enter one of the two following commands depending on the board.

For the ESP32-S3-DevKitC-1 board or built in usb debugger: openocd -f "board/esp32s3-builtin.cfg"
For the GUB: openocd -s share/openocd/scripts -f interface/ftdi/esp32_devkitj_v1.cfg -f board/esp32s3-ftdi.cfg

Additional notes

The Freertos tick rate has been set to 1000 Hz (1ms). This is the smallest unit of delay a task can wait for! Current project has about a 1-2sec startup time.

Future Features

  • Log CAN errors
  • Better logging file format
  • GPS Logging
  • LoRa data broadcasts.

Current Issues

Many have been fixed, but SD card handling will likely cause issues. The code has been tested up to ~1800 messages per second while logging without loading the file list and can be pushed to ~2100 messages per second with some loss. Another issue is the SD card getting stuck into a persistent error state of 0x107. A full power cycle may fix this issue or it may just be an issue with my breadboard setup.

A future addition should be a better logging format than a csv since a CAN message with 4 bytes of data takes up 32 bytes of file space at say 1800 messages per second is 57.6 KB/s of space.