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/b8de4/b8de4abcc5c7e532c5988ea3cc2d4d6f66c6254a" 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/9d4d7/9d4d73a204f1e085a008711f0f7b40c8f7047a46" 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/415c2/415c2baf8cf07bf53903d49e5009d24de5cc7480" 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/28785/28785126ae450bc5add1ba72bafffe0a6657db42" 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/b07c1/b07c157090fe7fed192f9f15c994509bbd981a94" 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/14e06/14e06cc3bc6d3ee091e838711071ebd3f0d4e286" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bd96a/bd96a9ad34fabce8ca2a80c00c5f88cb1eee38c1" 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/c093f/c093f87450beca577bb61ecec3395628cffedebb" 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/5f999/5f9993c749078f8328413292d31eba23db53e8b7" 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/25728/257289316eb3a9d4131fe9d81242e2b520cb3189" 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/72992/72992958844b085e69f5dda825b405551a283828" 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/e1f1b/e1f1baa28dc8785d63f254e5fc47ea388a98603e" 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/3d1de/3d1de71d2c6f87963451d2cf9e11996bcf1490e7" 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/424c9/424c97e4a08da1618e3b57770f8329fa226a646f" 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/dce1e/dce1e50e67d646c66aeb27b6e1e29dfd00cb2394" 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/aa0eb/aa0eb79ba671c7cbd5a877056ad6604fb09a30aa" 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/c4720/c472013c4faf59e8f07e84860038f735b905cca3" 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/2e6bc/2e6bc1db984950794bc8a97d293bbc8fec0ff4ab" 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/ecb7b/ecb7b62b0cbe50dd4acef6cc7713884a4f0d9951" 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/9545e/9545e13f328402eeaa6f9f7dd847f3594408a433" 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/7c0b5/7c0b5f9c5899b8e23aced59e7af763c1fe70153e" 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/db430/db430b6da71fe75535ff19c5084fbc4cd2261df1" 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/bca36/bca3675abec6ebfea7c290d59ce7129858ae15aa" 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/48d49/48d493f316464d6a91bd11a034a7a5fd09898d54" 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/cb776/cb7762f243412191b3f344da65451034b239feef" 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/cfead/cfead48a78f177ac8cf0df86493ac95f86d55c10" 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/350a6/350a6a1db7279ba9fc23bdf9e3f19dfd69db272e" 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/38ff0/38ff063884e8d25237d962528e8be3e1d022abef" 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/51734/5173446311f3cfd170bb48fdda8bcf933c914c0a" 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/e937b/e937b8416d285311c8e2fe26789420bbd61fcd51" 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/63032/63032a96779ff3aad3df36255591368a0edb3f9c" 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/b6e60/b6e6015ea3bc90fda3dc1096e1521e720b366e5d" 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/6ae35/6ae350ef439ced2cde04883e7a6ac7e4aa04f4cb" 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/1753e/1753ebf3dc6badd473c55a12eaf52ee8a7f9898a" 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/07d5a/07d5aece9cd339490e3896d46554d613025e3d40" 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/f8465/f846579e3c746bbb9883235ea5ff00d732946776" 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/8d969/8d969a18a0ad1cd8f882293e3ea4070fcbf1ca59" 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/fc7de/fc7dea24807fc6d9f822130c5107557f79d2cd3c" 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/2d2dc/2d2dc7c9e3ef4a901a161132a19b1c3dcb98c46b" 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/da2a0/da2a020dd89a574f21a7f6d8546b66bc0bbe61bf" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/b263d/b263ddb5eb82a7a1ae3a20805aa6719e9ce6285e" 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>
|