OpenFPGA/libs/libopenfpgacapnproto/README.md

75 lines
2.9 KiB
Markdown
Raw Permalink Normal View History

2024-09-27 04:21:24 -05:00
Capnproto usage in Openfpga
2024-09-25 05:42:04 -05:00
======================
Capnproto is a data serialization framework designed for portabliity and speed.
2024-09-27 04:21:24 -05:00
In Openfpga, capnproto is used to provide binary formats for internal data
2024-09-25 05:42:04 -05:00
structures that can be computed once, and used many times. Specific examples:
2024-09-27 04:21:24 -05:00
- preload unique blocks
2024-09-25 05:42:04 -05:00
What is capnproto?
==================
capnproto can be broken down into 3 parts:
- A schema language
- A code generator
- A library
The schema language is used to define messages. Each message must have an
explcit capnproto schema, which are stored in files suffixed with ".capnp".
The capnproto documentation for how to write these schema files can be found
here: https://capnproto.org/language.html
The schema by itself is not especially useful. In order to read and write
messages defined by the schema in a target language (e.g. C++), a code
generation step is required. Capnproto provides a cmake function for this
purpose, `capnp_generate_cpp`. This generates C++ source and header files.
These source and header files combined with the capnproto C++ library, enables
C++ code to read and write the messages matching a particular schema. The C++
library API can be found here: https://capnproto.org/cxx.html
2024-09-27 04:21:24 -05:00
Contents of libopenfpgacapnproto
2024-09-25 05:42:04 -05:00
===========================
2024-09-27 04:21:24 -05:00
libopenfpgacapnproto should contain two elements:
- Utilities for working capnproto messages in Openfpga
- Generate source and header files of all capnproto messages used in Openfpga
2024-09-25 05:42:04 -05:00
I/O Utilities
-------------
Capnproto does not provide IO support, instead it works from arrays (or file
2024-09-27 04:21:24 -05:00
descriptors). To avoid re-writing this code, libopenfpgacapnproto provides two
2024-09-25 05:42:04 -05:00
utilities that should be used whenever reading or writing capnproto message to
2024-09-27 04:21:24 -05:00
disk. These two files are copied :
2024-09-25 05:42:04 -05:00
- `serdes_utils.h` provides the writeMessageToFile function - Writes a
capnproto message to disk.
- `mmap_file.h` provides MmapFile object - Maps a capnproto message from the
disk as a flat array.
Capnproto schemas
-----------------
2024-09-27 04:21:24 -05:00
libopenfpgacapnproto should contain all capnproto schema definitions used within
2024-10-08 04:59:20 -05:00
Openfpga. To add a new schema:
2024-09-27 04:21:24 -05:00
1. Add the schema to git in `libs/libopenfpgacapnproto/`
2024-09-25 05:42:04 -05:00
2. Add the schema file name to `capnp_generate_cpp` invocation in
2024-09-27 04:21:24 -05:00
`libs/libopenfpgacapnproto/CMakeLists.txt`.
2024-09-25 05:42:04 -05:00
The schema will be available in the header file `schema filename>.h`. The
actual header file will appear in the CMake build directory
2024-09-27 04:21:24 -05:00
`libs/libopenfpgacapnproto` after `libopenfpgacapnproto` has been rebuilt.
2024-09-25 05:42:04 -05:00
Writing capnproto binary files to text
======================================
The `capnp` tool (found in the CMake build directiory
2024-09-27 04:21:24 -05:00
`/vtr-verilog-to-routing/libs/EXTERNAL/capnproto/c++/src/capnp`) can be used to convert from a binary
2024-09-25 05:42:04 -05:00
capnp message to a textual form.
2024-09-27 04:21:24 -05:00
Example converting UniqueBlockCompactInfo from binary to text:
2024-09-25 05:42:04 -05:00
```
2024-09-27 04:21:24 -05:00
capnp convert binary:text unique_blocks_uxsdcxx.capnp UniqueBlockCompactInfo \
< test.bin > test.txt
2024-09-25 05:42:04 -05:00
```