panda/README.md

120 lines
5.3 KiB
Markdown
Raw Normal View History

2017-04-06 19:11:36 -06:00
Welcome to panda
======
2017-06-28 23:20:38 -06:00
[panda](http://github.com/commaai/panda) is the nicest universal car interface ever.
2017-04-06 19:11:36 -06:00
2019-01-02 23:00:21 -07:00
<a href="https://comma.ai/shop/products/panda-obd-ii-dongle"><img src="https://github.com/commaai/panda/blob/master/panda.png">
2017-04-06 19:56:25 -06:00
2017-07-07 00:37:14 -06:00
<img src="https://github.com/commaai/panda/blob/master/buy.png"></a>
2017-07-07 00:30:20 -06:00
2017-06-28 23:21:20 -06:00
It supports 3x CAN, 2x LIN, and 1x GMLAN. It also charges a phone. On the computer side, it has both USB and Wi-Fi.
2017-04-06 19:11:36 -06:00
2017-06-28 23:22:12 -06:00
It uses an [STM32F413](http://www.st.com/en/microcontrollers/stm32f413-423.html?querycriteria=productId=LN2004) for low level stuff and an [ESP8266](https://en.wikipedia.org/wiki/ESP8266) for Wi-Fi. They are connected over high speed SPI, so the panda is actually capable of dumping the full contents of the busses over Wi-Fi, unlike every other dongle on amazon. ELM327 is weak, panda is strong.
2017-04-06 19:11:36 -06:00
It is 2nd gen hardware, reusing code and parts from the [NEO](https://github.com/commaai/neo) interface board.
2018-04-07 11:05:30 -06:00
[![CircleCI](https://circleci.com/gh/commaai/panda.svg?style=svg)](https://circleci.com/gh/commaai/panda)
2017-11-12 16:31:25 -07:00
Usage (Python)
2017-04-06 19:14:15 -06:00
------
2017-04-06 19:23:26 -06:00
2017-06-20 16:40:34 -06:00
To install the library:
```
# pip install pandacan
```
2017-12-13 16:24:57 -07:00
See [this class](https://github.com/commaai/panda/blob/master/python/__init__.py#L80) for how to interact with the panda.
2017-04-06 19:23:26 -06:00
For example, to receive CAN messages:
```
>>> from panda import Panda
2017-04-06 19:28:59 -06:00
>>> panda = Panda()
2017-04-06 19:23:26 -06:00
>>> panda.can_recv()
```
2017-04-06 19:28:59 -06:00
And to send one on bus 0:
```
>>> panda.can_send(0x1aa, "message", 0)
```
2018-03-13 10:47:39 -06:00
Find user made scripts on the [wiki](https://community.comma.ai/wiki/index.php/Panda_scripts)
2017-04-06 19:14:15 -06:00
2019-09-25 08:55:46 -06:00
Note that you may have to setup [udev rules](https://community.comma.ai/wiki/index.php/Panda#Linux_udev_rules) for Linux, such as
```
sudo -i
echo 'SUBSYSTEMS=="usb", ATTR{idVendor}=="bbaa", ATTR{idProduct}=="ddcc", MODE:="0666"' > /etc/udev/rules.d/11-panda.rules
exit
```
Usage (JavaScript)
-------
See [PandaJS](https://github.com/commaai/pandajs)
2017-06-26 00:01:41 -06:00
Software interface support
------
As a universal car interface, it should support every reasonable software interface.
2018-07-12 11:08:34 -06:00
- [User space](https://github.com/commaai/panda/tree/master/python)
- [socketcan in kernel](https://github.com/commaai/panda/tree/master/drivers/linux) (alpha)
- [ELM327](https://github.com/commaai/panda/blob/master/boardesp/elm327.c)
- [Windows J2534](https://github.com/commaai/panda/tree/master/drivers/windows)
2017-06-26 00:01:41 -06:00
2017-04-06 19:11:36 -06:00
Directory structure
------
- board -- Code that runs on the STM32
- boardesp -- Code that runs on the ESP8266
2017-06-26 00:01:41 -06:00
- drivers -- Drivers (not needed for use with python)
- python   -- Python userspace library for interfacing with the panda
2017-04-06 19:11:36 -06:00
- tests -- Tests and helper programs for panda
2017-04-06 19:30:45 -06:00
Programming (over USB)
2017-04-06 19:11:36 -06:00
------
2017-11-10 03:27:25 -07:00
[Programming the Board (STM32)](board/README.md)
[Programming the ESP](boardesp/README.md)
2017-04-06 19:11:36 -06:00
2017-04-17 16:28:28 -06:00
Debugging
------
To print out the serial console from the STM32, run tests/debug_console.py
2017-04-29 01:09:08 -06:00
To print out the serial console from the ESP8266, run PORT=1 tests/debug_console.py
2017-07-17 11:48:16 -06:00
Safety Model
------
When a panda powers up, by default it's in `SAFETY_NOOUTPUT` mode. While in no output mode, the buses are also forced to be silent. In order to send messages, you have to select a safety mode. Currently, setting safety modes is only supported over USB.
2017-07-17 11:48:16 -06:00
Safety modes optionally supports `controls_allowed`, which allows or blocks a subset of messages based on a customizable state in the board.
Code Quality
------
When compiled from an [EON Dev Kit](https://comma.ai/shop/products/eon-gold-dashcam-devkit), the panda FW is configured and optimized (at compile time) for its use in
conjuction with [openpilot](https://github.com/commaai/openpilot). The panda FW, through its safety model, provides and enforces the
[openpilot Safety](https://github.com/commaai/openpilot/blob/devel/SAFETY.md). Due to its critical function, it's important that the application code rigor within the `board` folder is held to high standards.
These are the [CI regression tests](https://circleci.com/gh/commaai/panda) we have in place:
- A generic static code analysis is performed by [Cppcheck](https://github.com/danmar/cppcheck/).
- In addition, [Cppcheck](https://github.com/danmar/cppcheck/) has a specific addon to check for [MISRA C:2012](https://www.misra.org.uk/MISRAHome/MISRAC2012/tabid/196/Default.aspx) violations. See [current coverage](https://github.com/commaai/panda/blob/master/tests/misra/coverage_table).
- Compiler options are relatively strict: the flags `-Wall -Wextra -Wstrict-prototypes -Werror` are enforced on board and pedal makefiles.
- The [safety logic](https://github.com/commaai/panda/tree/master/board/safety) is tested and verified by [unit tests](https://github.com/commaai/panda/tree/master/tests/safety) for each supported car variant.
- A recorded drive for each supported car variant is [replayed through the safety logic](https://github.com/commaai/panda/tree/master/tests/safety_replay)
to ensure that the behavior remains unchanged.
- An internal Hardware-in-the-loop test, which currently only runs on pull requests opened by comma.ai's organization members, verifies the following functionalities:
- compiling the code in various configuration and flashing it both through USB and WiFi.
- Receiving, sending and forwarding CAN messages on all buses, over USB and WiFi.
2017-07-17 11:48:16 -06:00
2017-04-06 19:23:26 -06:00
Hardware
------
2017-04-27 21:32:16 -06:00
2017-04-06 19:23:26 -06:00
Check out the hardware [guide](https://github.com/commaai/panda/blob/master/docs/guide.pdf)
2017-04-06 19:11:36 -06:00
Licensing
------
2017-04-06 19:53:43 -06:00
panda software is released under the MIT license unless otherwise specified.