1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/cpu/sam0_common/include/vendor
Marian Buschsieweke b42b1998ec
cpu/sam0_common: fix vendor header files
Ran the `fix_headers.sh` to fix the vendor header files and removed
the no longer needed work around for them.
2024-01-31 14:46:23 +01:00
..
samd10/include cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
samd20 cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
samd21 cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
samd51/include cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
same54/include cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
saml10/include cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
saml11/include cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
saml21 cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
samr21/include cpu/sam0_common: fix vendor header files 2024-01-31 14:46:23 +01:00
samr30/include cpu/sam0_common: fix vendor header files 2024-01-31 14:46:23 +01:00
samr34/include cpu/sam0_common: fix vendor header files 2023-07-18 12:24:07 +02:00
fix_headers.sh cpu/sam0_common: Update script to fix vendor headers 2024-01-31 14:46:23 +01:00
README.md cpu/sam0_common: Update script to fix vendor headers 2024-01-31 14:46:23 +01:00

CMSIS from Atmel Software Foundation (ASF)

The include files in this directory tree are copied from Atmel sources. Most of the sam0 files are from ASF (Atmel Software Foundation, version 3.35.1). The SAML10 and SAML11 files are from, so called, atpacks.

The sam0 files

The directory tree was copied "as is" from ASF path sam0/utils/cmsis/ and its structure is as follows:

cmsis
├── samd21
│   ├── include
│   │   ├── component
│   │   ├── instance
│   │   └── pio
│   └── source
│       ├── gcc
│       └── iar
.
.
.
├── samr21
│   ├── include
│   │   ├── component
│   │   ├── instance
│   │   └── pio
.   └── source
.       ├── gcc
.       └── iar

However, as only the header files in include and its subfolders are required, all source folders are removed.

Be aware that if you want to make changes to any file in this tree that the changes will be lost when a new ASF release is going to be used.

C++ compatibility (with LLVM)

Many of the header files where generated with an outdated version of SVDConv that adds the __I qualifier to anonymous bit fields, which clang++ won't compile. Run the script fix_headers.sh in this directory whenever you add or update vendor header filers until Microchips starts using a fixed version of SVDConv.

compatibility with tinyDTLS and <endian.h>

Both tinyDTLS as well as <endian.h> expect LITTLE_ENDIAN to be a magic number to compare the byte order (as provided by the compiler) against. The vendor header files provide the macro with the wrong magic number without ever using this macro. We can just strip using the fix_headers.sh script in this directory.

sam0.h

A SAM based CPU should include sam0.h in this directory, which will resolve any CPU family specific includes required.

SAMD10 files

samd10: Atmel.SAMD10_DFP.1.1.77.atpack

SAMD20 files

samd20: Atmel.SAMD20_DFP.1.3.165.atpack

Each atpack has an include subdirectory with the files we copy into RIOT. The files are copied unmodified.

SAMD21 files

samd21: Atmel.SAMD21_DFP.1.3.395.atpack

Each atpack has an include subdirectory with the files we copy into RIOT. The files are copied unmodified.

SAML10/SAML11 files

Since 2019 the necessary variant files are available in atpacks at

http://packs.download.atmel.com/

saml10: Atmel.SAML10_DFP.1.0.142.atpack saml11: Atmel.SAML11_DFP.1.0.91.atpack

Each atpack has an include subdirectory with the files we copy into RIOT. The files are copied unmodified.

SAML21 files

saml21: Atmel.SAML21_DFP.1.2.125.atpack

Each atpack has an include subdirectory with the files we copy into RIOT. The files are copied unmodified.

SAMR21 files

samr21: Atmel.SAMR21_DFP.1.1.72.atpack

Each atpack has an include subdirectory with the files we copy into RIOT. The following replacements were done for compatibility with newlib:

find -name '*.h' -exec sed -ie 's/_U(/_U_(/g' {} \;
find -name '*.h' -exec sed -ie 's/_L(/_L_(/g' {} \;

SAMR30 files

samr30: Atmel.SAMR30_DFP.1.1.35.atpack

Each atpack has an include subdirectory with the files we copy into RIOT.

The PIN_($pin)_EIC_EXTINT_NUM macos and integer literal macros (L() etc) were added manually. It is expected for those to appear in the next atpack release by Microchip.

If *_EIC_EXTINT_NUM macros are missing after an update, GPIO interrupts not work. See 93d536f76 for how to generate them.

SAMR34 files

samr34: Atmel.SAMR34_DFP.1.0.11.atpacks

Each atpack has an include subdirectory with the files we copy into RIOT. The files are copied unmodified.

sam23.h

A SAML1x based CPU should include sam23.h in this directory, which will resolve any CPU family specific includes required.

Usage and porting for SAM based CPUs

If other CPUs are needed, copy the include files from ASF or atpack for the respective CPU family here and adapt sam0.h or sam23.h accordingly.