canable-fw/README.md

67 lines
2.7 KiB
Markdown
Raw Normal View History

2018-12-31 11:32:22 -08:00
# CANable Firmware
2015-01-14 07:09:08 -08:00
2018-12-31 11:32:22 -08:00
This repository contains sources for the slcan CANable firmware, based off of the CANtact firwmare. This firmware should still compile and run on the CANtact.
2015-01-28 13:10:41 -08:00
## Supported Commands
- `O` - Open channel
- `C` - Close channel
- `S0` - Set bitrate to 10k
- `S1` - Set bitrate to 20k
- `S2` - Set bitrate to 50k
- `S3` - Set bitrate to 100k
- `S4` - Set bitrate to 125k
- `S5` - Set bitrate to 250k
- `S6` - Set bitrate to 500k
- `S7` - Set bitrate to 750k
- `S8` - Set bitrate to 1M
- `M0` - Set mode to normal mode (default)
- `M1` - Set mode to silent mode
- `A0` - Disable automatic retransmission
- `A1` - Enable automatic retransmission (default)
- `TIIIIIIIILDD...` - Transmit data frame (Extended ID) [ID, length, data]
- `tIIILDD...` - Transmit data frame (Standard ID) [ID, length, data]
- `RIIIIIIIIL` - Transmit remote frame (Extended ID) [ID, length]
- `rIIIL` - Transmit remote frame (Standard ID) [ID, length]
- `V` - Returns firmware version and remote path as a string
Note: Channel configuration commands must be sent before opening the channel. The channel must be opened before transmitting frames.
This firmware currently does not provide any ACK/NACK feedback for serial commands.
2015-01-14 07:09:08 -08:00
## Building
2015-01-28 13:10:41 -08:00
Firmware builds with GCC. Specifically, you will need gcc-arm-none-eabi, which
is packaged for Windows, OS X, and Linux on
[Launchpad](https://launchpad.net/gcc-arm-embedded/+download). Download for your
2015-01-14 07:09:08 -08:00
system and add the `bin` folder to your PATH.
2018-12-31 11:32:22 -08:00
Your Linux distribution may also have a prebuilt package for `arm-none-eabi-gcc`, check your distro's repositories to see if a build exists.
2015-01-14 07:09:08 -08:00
2018-12-31 11:32:22 -08:00
- If you have a CANable device, compile with `make INTERNAL_OSCILLATOR=1`.
- If you have a CANtact device, you can compile using `make`.
## Flashing with the Bootloader
Simply plug in your CANable with the BOOT jumper enabled (or depress the boot button on the CANable Pro while plugging in). Next, type `make flash` and your CANable will be updated to the latest firwmare. Unplug/replug the device after moving the boot jumper back, and your CANable will be up and running.
## Debugging
2015-01-14 07:09:08 -08:00
2015-01-28 13:10:41 -08:00
Debugging and flashing can be done with any STM32 Discovery board as a
2018-12-31 11:32:22 -08:00
programmer, or an st-link. You can also use other tools that support SWD.
2015-01-14 07:09:08 -08:00
To use an STM32 Discovery, run [OpenOCD](http://openocd.sourceforge.net/) using
the stm32f0x.cfg file: `openocd -f fw/stm32f0x.cfg`.
With OpenOCD running, arm-none-eabi-gdb can be used to load code and debug.
2015-01-28 13:46:46 -08:00
## Contributors
2018-12-31 11:32:22 -08:00
- [Ethan Zonca](https://github.com/normaldotcom) - Makefile fixes and code size optimization, updates for CANable
2015-05-06 11:45:08 -07:00
- [onejope](https://github.com/onejope) - Fixes to extended ID handling
2015-05-15 11:38:53 -07:00
- Phil Wise - Added dfu-util compatibility to Makefile
2015-01-28 13:46:46 -08:00
2015-01-14 07:09:08 -08:00
## License
See LICENSE.md