HwData Structures » Historie » Revision 7
Revision 6 (Redmine Admin, 14.12.2021 15:48) → Revision 7/16 (Redmine Admin, 14.12.2021 16:58)
h1. HW-Data 
Each Board (with MCU) should have an I2C EEPROM containung some "production" information.
|_.Offset|_.Type |
|0x00 | Production-Data |
|0x20 | Board-Config |
|0x40 | Config 1 |
|0x60 | Config 2 |
If EEPROM is not available, an sector in internal flash can be used.
The area within the flash should be handled by the "retain"-class from libbiwak. It
already handles header version and CRC.
"Magic"s do not make much sense. Its not supposed to be human readable.
|_.Section |_.Offset|_.Type |_.Size|_.Decription |_.Example |_.Retain Version |
|Main |0x00 | ui16 ui8 | 2 1 | Articles Code Magic 'H' | 0x0020 'H' | 4.0. 3.0. |
| |0x02 |0x01 | ui8 ui16 | 1 2 | Articles Variant ID | 01 0020 | 4.0. 3.0. |
| |0x03 | ui8 | 1 | Article Version | 01 | 4.0. |
|Board |0x04 | ui16 | 2 | Board Code ID; unique | 01 0020 | 4.0. 3.0. |
| |0x06 |Version |0x05 | ui8 | 1 | major version | 0 | 4.0. 3.0. |
| |0x07 |0x06 | ui8 | 1 | minor verison | 4 | 4.0. 3.0. |
| |0x08 |0x07 | ui8 | 1 | patch verison; assembly option 1) | 0 | 4.0. 3.0. |
|Production|0x08 | ui32 | 4 | Serial number | 0001 | 3.0. |
| |0x0c | ui32 | 4 | Variant/Flags 2) | 0 | 3.0. |
| |0x10 | ui8 | 1 | Production year (+2000) | 21 | 3.0. |
| |0x11 | ui8 | 1 | Production month | 10 | 3.0. |
| |0x12 | ui8 | 1 | Production day | 21 | 3.0. |
| |0x13 | ui8 | 1 | Production site | 3 | 3.0. |
| |0x14 | ui32 | 4 | reserved | 0 | 3.0. |
| |0x18 | Struct | 8 | Retain information; Version, counter, CRC| {-} | 3.0. |
1) although circuit might be changed afterwards, assembly option at time of production
is relevant. To compare with errata-page.
2) Things that might be relevant for running software like used transceivers. Product specific.
Its only related to the board directly, not connected periphery.
Things like production site, version of horo-firmware etc. can be stored off-device.
        
        
    Each Board (with MCU) should have an I2C EEPROM containung some "production" information.
|_.Offset|_.Type |
|0x00 | Production-Data |
|0x20 | Board-Config |
|0x40 | Config 1 |
|0x60 | Config 2 |
If EEPROM is not available, an sector in internal flash can be used.
The area within the flash should be handled by the "retain"-class from libbiwak. It
already handles header version and CRC.
"Magic"s do not make much sense. Its not supposed to be human readable.
|_.Section |_.Offset|_.Type |_.Size|_.Decription |_.Example |_.Retain Version |
|Main |0x00 | ui16 ui8 | 2 1 | Articles Code Magic 'H' | 0x0020 'H' | 4.0. 3.0. |
| |0x02 |0x01 | ui8 ui16 | 1 2 | Articles Variant ID | 01 0020 | 4.0. 3.0. |
| |0x03 | ui8 | 1 | Article Version | 01 | 4.0. |
|Board |0x04 | ui16 | 2 | Board Code ID; unique | 01 0020 | 4.0. 3.0. |
| |0x06 |Version |0x05 | ui8 | 1 | major version | 0 | 4.0. 3.0. |
| |0x07 |0x06 | ui8 | 1 | minor verison | 4 | 4.0. 3.0. |
| |0x08 |0x07 | ui8 | 1 | patch verison; assembly option 1) | 0 | 4.0. 3.0. |
|Production|0x08 | ui32 | 4 | Serial number | 0001 | 3.0. |
| |0x0c | ui32 | 4 | Variant/Flags 2) | 0 | 3.0. |
| |0x10 | ui8 | 1 | Production year (+2000) | 21 | 3.0. |
| |0x11 | ui8 | 1 | Production month | 10 | 3.0. |
| |0x12 | ui8 | 1 | Production day | 21 | 3.0. |
| |0x13 | ui8 | 1 | Production site | 3 | 3.0. |
| |0x14 | ui32 | 4 | reserved | 0 | 3.0. |
| |0x18 | Struct | 8 | Retain information; Version, counter, CRC| {-} | 3.0. |
1) although circuit might be changed afterwards, assembly option at time of production
is relevant. To compare with errata-page.
2) Things that might be relevant for running software like used transceivers. Product specific.
Its only related to the board directly, not connected periphery.
Things like production site, version of horo-firmware etc. can be stored off-device.