Each product we make has embedded

Storing Vital Product Data with TLV-C

submited by
Style Pass
2025-01-13 07:00:03

Each product we make has embedded "vital product data" - information which the firmware uses to introspect the multiple hardware revisions or variants it may be running on with a single binary.

In this article, we share how vital product data is stored using TLV-C, as well as the integrity and flexibility that the format provides.

Are you working with CAN devices and need to simplify integration with your compute? Have a look at our range of CAN interface cards. Need something tailored to your needs? Contact us to discuss how we can apply our engineering talent to your problem space.

Type-Length-Value encoding is nothing new; however, the checksum approach that the Oxide Computer Company has taken with their TLV-C crate is unique.

At the start of each chunk, there is a header containing the tag, length, and header checksum. The variable-length value in the chunk also has its own checksum. These chunks are serialized into a stream of chunks, suitable for storing in memory and transmission over any serial interface.

If the header checksum of the chunk is valid, the length of the value within the chunk is ensured. Even if the value data has become corrupted, it can be safely skipped because the start of the next chunk is known.

Leave a Comment