tsl/cereal
Kacper Rączy 8315623257 paramsd: remove usages of llk nested structures (#33317)
* Remove usages of llk nested structures

* Rename to debugFitlerState

* Semicolon

* Initial parameters debugFilterState
old-commit-hash: 51fae363e4
2024-08-16 14:25:42 -07:00
..
include Split cereal into cereal/msgq (#32631) 2024-06-06 14:31:56 -07:00
messaging Fix msgq context overrides (#33014) 2024-07-18 20:19:39 -07:00
README.md Update cereal README.md 2024-06-11 16:17:25 -07:00
SConscript Restructure msgq (#32652) 2024-06-09 17:44:34 -07:00
__init__.py Split cereal into cereal/msgq (#32631) 2024-06-06 14:31:56 -07:00
car.capnp carState: add invalid sensors field (#33266) 2024-08-11 23:12:42 -07:00
custom.capnp Split cereal into cereal/msgq (#32631) 2024-06-06 14:31:56 -07:00
legacy.capnp Split cereal into cereal/msgq (#32631) 2024-06-06 14:31:56 -07:00
log.capnp paramsd: remove usages of llk nested structures (#33317) 2024-08-16 14:25:42 -07:00
maptile.capnp Split cereal into cereal/msgq (#32631) 2024-06-06 14:31:56 -07:00
services.py qlog: remove mag and less CAN 2024-07-29 14:44:03 -07:00

README.md

What is cereal?

cereal is the messaging system for openpilot. It uses msgq as a pub/sub backend, and Cap'n proto for serialization of the structs.

Messaging Spec

You'll find the message types in log.capnp. It uses Cap'n proto and defines one struct called Event.

All Events have a logMonoTime and a valid. Then a big union defines the packet type.

Best Practices

  • All fields must describe quantities in SI units, unless otherwise specified in the field name.
  • In the context of the message they are in, field names should be completely unambiguous.
  • All values should be easy to plot and be human-readable with minimal parsing.

Maintaining backwards-compatibility

When making changes to the messaging spec you want to maintain backwards-compatibility, such that old logs can be parsed with a new version of cereal. Adding structs and adding members to structs is generally safe, most other things are not. Read more details here.

Custom forks

Forks of openpilot might want to add things to the messaging spec, however this could conflict with future changes made in mainline cereal/openpilot. Rebasing against mainline openpilot then means breaking backwards-compatibility with all old logs of your fork. So we added reserved events in custom.capnp that we will leave empty in mainline cereal/openpilot. If you only modify those, you can ensure your fork will remain backwards-compatible with all versions of mainline openpilot and your fork.

Example

import cereal.messaging as messaging

# in subscriber
sm = messaging.SubMaster(['sensorEvents'])
while 1:
  sm.update()
  print(sm['sensorEvents'])

# in publisher
pm = messaging.PubMaster(['sensorEvents'])
dat = messaging.new_message('sensorEvents', size=1)
dat.sensorEvents[0] = {"gyro": {"v": [0.1, -0.1, 0.1]}}
pm.send('sensorEvents', dat)