2023-09-22 18:08:23 +08:00
|
|
|
|
# Microchip BSP
|
|
|
|
|
|
|
|
|
|
## 1. Microchip BSP Introduction
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
Supported Microchip SAM (ARM Cortex-Mx Core) MCU is as following:
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### ARM Cortex-M23 Series
|
|
|
|
|
|
2022-04-27 09:24:56 +08:00
|
|
|
|
- saml10 | 3.3V Cortex-M23 with ultra low power
|
|
|
|
|
- saml11 | 3.3V Cortex-M23 with ultra low power and trust-zone
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### ARM Cortex-M0+ Series
|
|
|
|
|
|
2022-04-14 10:54:53 +08:00
|
|
|
|
- samc21 | 5V Cortex-M0+ with 2 CAN-FD support
|
|
|
|
|
- saml21 | 3.3V low power Cortex-M0+
|
|
|
|
|
- samd21 | 3.3V industrial level Cortex-M0+
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### ARM Cortex-M4 Series
|
|
|
|
|
|
2022-04-14 10:54:53 +08:00
|
|
|
|
- same54 | 3.3V 120MHz Cortex-M4F core with CAN-FD/USB/Ethernet support
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### ARM Cortex-M7 Series
|
|
|
|
|
|
2022-04-14 10:54:53 +08:00
|
|
|
|
- same70 | 3.3V 300MHz Cortex-M7 core with CAN-FD/High speed USB/Ethernet support
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### Directory description:
|
|
|
|
|
|
2022-04-14 10:54:53 +08:00
|
|
|
|
* applications:
|
|
|
|
|
* user main function entrance,
|
|
|
|
|
* driver example - like i2c, can, adc ...
|
|
|
|
|
* application example
|
|
|
|
|
* board:
|
|
|
|
|
* user board initialization
|
|
|
|
|
* user driver adpater code, like console device, ethernet device
|
|
|
|
|
* bsp:
|
|
|
|
|
* MCU BSP files - startup file, peripheral drivers, configuation headers and linker script
|
|
|
|
|
* generated from start.atmel.com - DO NOT modify it
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
## 2. RT-Thread porting guide of Microchip SAM MCU
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### 2.1 Configure project BSP on Atmel Start
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Visit <https://start.atmel.com/#> and click CREATE NEW PROJECT.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a7af9/a7af9d66994c39faf3267dea332af8ef9b6cca8f" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Input MCU part number and then select device, click CREATE NEW PROJECT.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b0d38/b0d3821a24dc23c27461fc6d1d589e194a81f9ac" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Add STDIO and other driver/middleware to project.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9558f/9558f1e01b7719767f7e20a87cb2f6e4856fa64c" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Configure STDIO driver.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/da2ac/da2ac79eccc0c1f0552d50c91f3f2c3bdd00f295" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Configure CAN module clock.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/96244/962443c11a1a35727c0de9ecd02facaf8fca535c" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Configure CAN module driver.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ac62f/ac62f085ca9a2bf3155965b2320a4b5e91ca51af" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/842e1/842e14f9c5dda44e8a3dc28eb34f9f45f8c542c1" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Add LED pin description.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/490d6/490d63f0f74910f65456991e3f9a84cc191b4164" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Rename project.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ae96d/ae96dcd17dd0a6aa75460cea12fb1f10e6017022" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Save project configuration.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5a0e7/5a0e76e147a7a3493ed66073bdb599157e81adcf" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Export project source code.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c066e/c066e56e13db619c3b5e233c7e9650c21352a4d1" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### 2.2 Add project to RT-Thread source code
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Link: <https://github.com/RT-Thread/rt-thread> and download RT souce code.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2cec3/2cec385f26f5a94ddb866431fdeb9f3764cdb124" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Unzip downloaded RT-Thread and SAME70 CAN Example
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f3281/f32816b730730bd1594ad56dd0ded41d7d9421b4" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Enter *rt-thread-xxx/bsp/microchip* directory and copy **same70** folder and rename it to **same70q20**.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/101ea/101eaeb68df3e135440cbac560382b5bb3b2f87f" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Enter same70q20 directory and remove all files except SConscript file.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8396e/8396eb9517f3c8346cceb2921222d31bef50a73d" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b5ab5/b5ab58ebc3a4857f5221cac345b48507987a1247" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/032e6/032e6d3b125302cd737f1bf0e2c6f768613ea192" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0294c/0294cd8e71fc5c1b47de8cadfa0c86df6e070538" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/73c99/73c997d76fe4ddac6178111c2e87bfb69fa7b0ed" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c803e/c803e65de92b942077eb6747e45f56b00726e9df" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Alright, now you can use RT-Thread env tools to compile the project.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### 2.3 Compile project with RT-Thread env tools
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
About RT-Thread env tools, click [Here](https://github.com/RT-Thread/rt-thread/blob/master/documentation/env/env.md).
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Download RT-Thread env tools <https://www.rt-thread.org/download.html#download-rt-thread-env-tool>
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/50e9e/50e9e260b14d5c6ab68ed392dfd911748949c12e" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Unzip downloaded file and run env.exe.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c9f6f/c9f6f49fc269b600010cbf670603ef067f6ee32b" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Enter your project directory and run scons command to compile it.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b28ec/b28ecbcb39558580dcdd09968ea95ed27bf0cc6d" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Compile error you may have and proposed solution.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7c0e3/7c0e361557035c92ff1616501d7b8d7a1054db67" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Fix compiling error
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7a676/7a67694f2f0b7b1020a745605e3fc52dd43df010" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Compiling success
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/881f1/881f115305c240b06eaba83ae2f1f05f8c84f0dd" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
In the following chapter I will show you how to debug RT-Thread with Studio 7.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
## 3. RT-Thread debugging with Microchip IDE
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Link: <https://www.microchip.com/en-us/tools-resources/develop/microchip-studio>, download & install Microchip Studio 7.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4b7d7/4b7d715c4a74f167a5f92568b3630005e04123d8" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Open installed Microchip Studio 7 and open object file for debugging.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c69ca/c69cab2bb7a8f7da947cddd126f0fd1f6f1f893b" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Choose object file, fill project name and select where to save this project.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f8e70/f8e70578a92fede6c55aa18633da426e60c238db" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Select the right part number and complete object set up.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/953fa/953fafb0c51842778b33eae81d846baa674a6711" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Object file import complete and you can see related files are linked to project.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/16b7f/16b7f71be962a1918bcca314eaa7722edf07794d" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Right click the project and choose the debug tools in project propertities setting.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/65d5b/65d5b112715cf008ca75d592bac3527b7b9bb9ae" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Choose debugger/programmer and debugger interface - SWD or JTGA.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dcfe0/dcfe00d083080ffd37b41c5c453da7c615e502b2" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Press debugging button and enjoy your debugging journey.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7858c/7858c8615a1a5510c29022d746207ce534365daf" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Debugging start and you can add breakpoint.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/47d5f/47d5f2e389ae466619649cec4a3ca7d50c60513e" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8ba08/8ba08f5cd6ad84057a1543cccab9744416b20e8a" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Debugging message output.
|
2022-04-19 14:32:02 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/98405/98405d402ba8549853f5a44eaed72d2108e4c5f3" alt=""
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
## 4. Reconfigure MCU BSP
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Visit <https://start.atmel.com/#> and upload project configuration.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/72233/72233e4daf921bfcf69c9a3976a93687d272ea44" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Now you can reconfigure your project.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b06b6/b06b6b2b8c28b2f7173aef89090956ee9f7e0182" alt=""
|
|
|
|
|
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
## 5. Microchip SAM MCU BSP configuration and user guide
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
Please refer to [ASF4 API Reference Manual](https://ww1.microchip.com/downloads/en/DeviceDoc/50002633B.pdf) for more details
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
### 5.1 SAMC2x/E5x/E70 CAN Driver
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
CAN driver configuration.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/aa5c2/aa5c2c2527d6afabe3f1f8cda76472cbca7ea136" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/cc218/cc218bf2fa25c90dff20624cbbc0217b3c597dde" alt=""
|
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
CAN driver user guide - see [ASF4 API Reference Manual](https://ww1.microchip.com/downloads/en/DeviceDoc/50002633B.pdf) P121 for more details.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
To be continued.
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
## 6. Contact Info
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
2023-09-22 18:08:23 +08:00
|
|
|
|
- [Kevin Liu](https://github.com/klmchp), email: <kevin.liu.mchp@gmail.com>
|
|
|
|
|
- [luhuadong](https://github.com/luhuadong), email: <luhuadong@163.com>
|