rusefi_documentation/Developing-On-Linux.md

73 lines
2.9 KiB
Markdown
Raw Normal View History

2022-01-25 17:01:06 -08:00
# Developing On Linux
2021-11-19 11:02:18 -08:00
# Compiling
2022-01-24 14:57:52 -08:00
Download the latest ARM GCC from ARM itself: [ARM GCC toolchain](https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads)
2021-11-19 11:02:18 -08:00
These can be extracted under your home directory; just add the `bin` directory to your path.
TODO: You probably need to install additional packages but I don't remember what they are.
2021-11-19 12:01:04 -08:00
Then to compile the firmware,
```
cd firmware
make PROJECT_BOARD=nucleo_h743 PROJECT_CPU=ARCH_STM32H7 -j4
```
Edit according to your environment.
To compile the simulator,
```
cd simulator
./compile.sh
```
To compile the unit tests,
```
cd unit_tests
make -j4
```
2021-11-19 11:46:14 -08:00
# Working with STM32 Dev/Nucleo boards
These boards are convenient as they include an ST-Link onboard which aids debugging. I believe the main difference is a Development board includes a bunch of peripherals that you may or may not care about, while a Nucleo board is much more stripped down. Some (all?) boards will be powered when you connect to the ST-Link USB board. The ST-Link will include, among other things, a virtual com port, which can be used to run either the console or TunerStudio. However, by default the ports are not accessible by regular users. You can solve this with:
```
sudo chmod 666 /dev/ttyACM*
```
Adapt as necessary depending on the permissions you choose to expose.
## Working with OpenOCD
2021-11-19 11:02:18 -08:00
Depending on how new your dev board is, you may need to upgrade OpenOCD. For example, a nucleo-h743 requires OpenOCD 0.11+. Luckily you can download and run the latest version from your local home directory. Unofficial binaries are available here:
2022-01-24 14:57:52 -08:00
[OpenOCD-Xpack releases](https://github.com/xpack-dev-tools/openocd-xpack/releases)
2021-11-19 11:02:18 -08:00
To get started, plug the ST-Link side of the dev board into your computer. Generally this should power the whole board.
2021-11-19 15:13:01 -08:00
OpenOCD can be left running in the background while you develop in other windows. It will provide a GDB server, a telnet connection for issuing commands, and a TCL interface. We'll just ignore the last one for now. To start OpenOCD, you need to pass in a board configuration file. Luckily they exist for most any off the shelf board you care about.
```
sudo ~/openocd/xpack-openocd-0.11.0-2/bin/openocd -f ~/openocd/xpack-openocd-0.11.0-2/scripts/board/st_nucleo_h743zi.cfg
```
Adjust as necessary; you may need `sudo` if you don't normally have access to USB devices.
2021-11-19 11:02:18 -08:00
To reprogram, simply do:
```
telnet localhost 4444
2021-11-19 14:24:39 -08:00
program build/rusefi.elf reset
2021-11-19 11:02:18 -08:00
exit
```
2021-11-19 15:13:01 -08:00
Or, if you prefer a one-liner:
```
(echo "program build/rusefi.elf reset"; echo exit) | nc localhost 4444
```
2021-11-19 11:49:35 -08:00
Conveniently, OpenOCD will retain a history of commands, allowing you to use up-arrows to retrieve previous commands.
2021-11-19 11:02:18 -08:00
On a nucleo-h743, I don't seem to get much indication this worked, but if you connect via gdb:
```
gdb build/rusefi.elf
target remote :3333
```
then you might end up in the middle of the ChibiOS idle function, a good indication you've succeeded.