Code Generation Tools and Editor for Memory Maps

Przemyslaw Plutecki, Bartosz Przemyslaw Bielawski, Andrew Butterworth, Schaa, Volker RW (Ed.), White, Karen S. (Ed.), Dyer, Philip S. (Ed.), Brown, Kevin A. (Ed.)
Cheburashka, a toolset created in the Radio Frequency Group at CERN, has become an essential part of our hardware and software developments. Due to changing requirements, this toolset has been recently rewritten in C++ and Python. A hardware developer, using the graphical editor, defines a memory map, which is subsequently used to ensure consistency between software and hardware. The memory map file is an input for a variety of tools used by the hardware engineers, such as VHDL code generators.
more » ... DL code generators. In addition to aiding the firmware development, our tools generate C++ wrapper libraries. The wrapper provides a simple interface on top of a Linux device driver to read and write registers by exposing memory map nodes in a hierarchical way, performing all low-level bit manipulations and checks internally. To interact with the hardware, a software that runs on a front-end computer is needed. Cheburashka allows us to generate FESA (Front-End Software Architecture) classes with parts of the operational interface already present. This paper describes the evolution of the graphical editor and the Python tools used for C++ code generation, along with a description of their main features.
doi:10.18429/jacow-icalepcs2019-mopha115 fatcat:247w7adwtjbx5fxmtqpeojk5j4