configuration_json
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
configuration_json [ 25.11.2024 18:55] – [type] lars | configuration_json [ 23.02.2025 15:27] (current) – [project_type] lars | ||
---|---|---|---|
Line 3: | Line 3: | ||
====== File format specification of configuration definition ====== | ====== File format specification of configuration definition ====== | ||
- | this describes the possible elements of a configuration description in json format. | + | this describes the possible elements of a configuration description in JSON format. |
- | The json format is defined here: https:// | + | {{odt> |
+ | |||
+ | The JSON format is defined here: https:// | ||
All elements not listed as essential are optional. Being optional means that they can be missing and the configuration is still valid. | All elements not listed as essential are optional. Being optional means that they can be missing and the configuration is still valid. | ||
Line 27: | Line 29: | ||
==== general settings ==== | ==== general settings ==== | ||
- | general settings | + | general settings |
==== peripheral settings ==== | ==== peripheral settings ==== | ||
Line 59: | Line 61: | ||
Keys like *digital_output* and *SPI* represent group names and are taken from a predefined set of group names understood by MBSP. Keys nested within them are arbitrary user-defined names for a instance in that group. In those instances the keys are from the defined set specific for that group. | Keys like *digital_output* and *SPI* represent group names and are taken from a predefined set of group names understood by MBSP. Keys nested within them are arbitrary user-defined names for a instance in that group. In those instances the keys are from the defined set specific for that group. | ||
+ | |||
+ | ===== general settings ===== | ||
+ | |||
+ | these are settings on the top layer that effect the whole project. | ||
- | ===== vendor_name | + | ==== vendor_name ==== |
- | Name of the company that sells the micro controller. As listed on chipselect.org | + | Name of the company that sells the micro controller. As listed on https://chipselect.org |
- | type: string | + | **type**: string |
- | ===== chip_name | + | ==== chip_name ==== |
- | model number of the micro controller. | + | Model number of the micro controller. |
- | type: string | + | **type**: string |
Model number is truncated so that it only contains relevant differences for code generation: flash and ram sizes are relevant, temperature range or package are not. | Model number is truncated so that it only contains relevant differences for code generation: flash and ram sizes are relevant, temperature range or package are not. | ||
+ | |||
+ | |||
+ | ==== project_type ==== | ||
+ | |||
+ | what type of project to generate. | ||
+ | |||
+ | **type**: string | ||
+ | |||
+ | **default**: | ||
+ | |||
+ | Possible values are: | ||
+ | * "hal only" : only creates the hardware driver files (in the hal/ folder) and hardware definitions (in the hal/hw/ folder) | ||
+ | * " | ||
+ | * " | ||
===== clock group ===== | ===== clock group ===== | ||
- | configuration of the used cocks | + | configuration of the used clocks |
TBD | TBD | ||
Line 103: | Line 123: | ||
* open drain | * open drain | ||
- | type: enum | + | **type**: enum |
- | default: push pull | + | **default**: push pull |
==== pad ==== | ==== pad ==== | ||
Line 111: | Line 131: | ||
defines the chip pad that the signal should be output on. | defines the chip pad that the signal should be output on. | ||
- | type: string | + | **type**: string |
+ | |||
+ | **default**: | ||
+ | |||
+ | ==== invert ==== | ||
+ | |||
+ | If this setting is set to " | ||
+ | |||
+ | If this setting is set to " | ||
+ | |||
+ | **type**: string | ||
+ | |||
+ | **default**: | ||
===== digital_input group ===== | ===== digital_input group ===== | ||
Line 124: | Line 157: | ||
defines the chip pad that the signal should be read from. | defines the chip pad that the signal should be read from. | ||
- | type: string | + | **type**: string |
Line 150: | Line 183: | ||
===== UART group ===== | ===== UART group ===== | ||
- | TBD | + | This group defines all used UART interfaces. |
+ | |||
+ | Each UART is a sub group with the UART name as the group name. | ||
+ | |||
+ | < | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | }, | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | } | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | |||
+ | ==== pads ==== | ||
+ | |||
+ | defines the used signal pins. At least one pin must be present(either TX or RX). Pins that are not present will not be used/ are not available for functionality. | ||
+ | |||
+ | === TX === | ||
+ | |||
+ | The UART will send data on this pin. (Idle = High). | ||
+ | |||
+ | === RX === | ||
+ | |||
+ | The UART will receive (read) signals on this pin. | ||
+ | |||
+ | === CTS === | ||
+ | |||
+ | Clear to send signal for flow control. | ||
+ | |||
+ | === RTS === | ||
+ | |||
+ | Request to Send signal for flow control. | ||
+ | |||
+ | |||
+ | ==== bits_per_packet ==== | ||
+ | |||
+ | defines the number of data bits. Possible values are: | ||
+ | * 7 | ||
+ | * 8 | ||
+ | * 9 | ||
+ | |||
+ | **type**: enum | ||
+ | |||
+ | **default**: | ||
+ | |||
+ | ==== parity ==== | ||
+ | |||
+ | defines the parity bit. Possible values are: | ||
+ | * None : no parity bit used. | ||
+ | * Odd : the parity bits value makes sure that the packet contains an **__odd__** number of bits with value " | ||
+ | * Even : the parity bits value makes sure that the packet contains an **__even__** number of bits with value " | ||
+ | |||
+ | **type**: enum | ||
+ | |||
+ | **default**: | ||
+ | |||
+ | |||
+ | ==== stop_bits ==== | ||
+ | |||
+ | defines the number of stop bits. Possible values are: | ||
+ | * 1 | ||
+ | * 1,5 | ||
+ | * 2 | ||
+ | |||
+ | **type**: enum | ||
+ | |||
+ | **default**: | ||
+ | |||
+ | |||
+ | ==== baud_rate ==== | ||
+ | |||
+ | defines the number of bits send per second. | ||
+ | |||
+ | **type**: int | ||
+ | |||
+ | **default**: | ||
+ | |||
+ | |||
+ | ==== hardware_flow_control ==== | ||
+ | |||
+ | defines if the Request to Send (RTS) and Clear to send (CTS) signals should be used for flow control. Possible values are: | ||
+ | * off (RTS and CTS pins are not used. | ||
+ | * RTS only | ||
+ | * CTS only | ||
+ | * on (RTS and CTS signals are used) | ||
+ | |||
+ | **type**: enum | ||
+ | |||
+ | **default**: | ||
+ | ==== receive_buffer_size ==== | ||
+ | |||
+ | defines the number of bytes in the receive buffer of the driver. | ||
+ | |||
+ | **type**: int | ||
+ | |||
+ | **default**: | ||
+ | |||
+ | ==== send_buffer_size ==== | ||
+ | |||
+ | defines the number of bytes in the send buffer of the driver. | ||
+ | |||
+ | **type**: int | ||
+ | |||
+ | **default**: | ||
Line 293: | Line 441: | ||
TBD | TBD | ||
- | |||
- | ===== ... group ===== | ||
- | |||
- | TBD | ||
- | |||
- | |||
- | |||
- | |||
- | |||
- | |||
configuration_json.1732557307.txt.gz · Last modified: 25.11.2024 18:55 by lars