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/35c00/35c00b965625f58f32a0ce221035d97716bdc5fa" 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/15b3a/15b3ae8ae78306d93893e2d0a386fe36c54de1ac" 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/eda6e/eda6e79be7555f3b6a3b8da9f2d64134d300ff5c" 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/f8cd6/f8cd69b27b2cc8a316607b97b5836d35b1cfdf60" 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/80c8d/80c8df5d2725ed6ad7b9870ec87b3fa4f3dacf7c" 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/b3aee/b3aeeaf2ac809374fe25a07fa05fd20808234630" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8d4f0/8d4f0d6cb82e73bcd647ce8463046f6ee52712b7" 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/f7c04/f7c0478d668b4fd95e9bdc7f5be526e9af98fda2" 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/e72cb/e72cb43df762ae996063e0044249c7a4c2df47f7" 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/5d3fc/5d3fcf8edcf064260180118dfb58ac007fb8fb02" 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/e21b2/e21b21f2b8c6c14010561eca2ce8a6f4b6af5c91" 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/ce997/ce99765862c47f872e3f43320bc75f06fa036d7e" 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/c9221/c9221acb3112161d53700d6a5cce31cdae2a0c7c" 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/7c5f0/7c5f0dd564bdc8ab554a6f29fc0ce35d2b69f7b4" 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/ccec9/ccec9d396e03bb244054d9134827663cf4c540c0" 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/d6655/d66554e19bd5bfe0f4cd58c64935062061987c26" 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/bc05d/bc05d5c4d04e9211d2e17fea72ecc2607f14d977" 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/dd8d1/dd8d14f001d500ab59c0cd59107f4c2e7be75b89" 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/29f7c/29f7c30e44142652d0044f8580c05212a74edba6" 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/6275e/6275e3857e0c36991d384526fa0bb5aaa1165e6a" 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/4e1df/4e1df67a42de92b031022313beb2fa38c6deb83f" 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/f9a8c/f9a8c96220d32256913603d0344965af82a6ac1a" 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/414b2/414b24ca9089c285e0fe6cee1acea33b3bb1dcdd" 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/f98c2/f98c2c6e4d66974bdfe2c2fc13969eb9df1d7e80" 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/27866/27866eef54c5b043ed07dee25d20c3d0c0d4b78f" 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/10b13/10b1367df0105128333cdd026e00699e6ef7c669" 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/c999c/c999c0b7dd7c706f984f94aac72618a9c7880f9c" 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/dca8b/dca8b75fa5f45e2abce78b8bf0355e39d7314e0a" 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/ed15c/ed15c101d3f82b6409ef4aad936b2aaef3390bdc" 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/cdf15/cdf1583323f0672e4617cde363961b318cbcf208" 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/7a7ad/7a7ad80c6bc6d32cbd2b0407c4e1827bc136e574" 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/56e29/56e291fe53eed8b1dd2bd23b8a1c27be935a6b08" 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/80340/8034045b070dabb3308a36baf630927883f7cf91" 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/24a28/24a28c6018245cf3a50c4cc6ffd4a0690e7a0384" 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/2f1ee/2f1ee6c1d965110aa4cd9f314e170d1b50fa8d50" 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/a6231/a623141c675cf94d405822b38ce2ff494e46c117" 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/1991f/1991fb8010723c464cf5cd842dce1c60fb0f4fa3" 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/cc03d/cc03dc1609c873b1a462cd365f7aa8013d7b4254" 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/b34ab/b34ab89054a4a859558eb58e0503bdd36cee7169" 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/5c1b8/5c1b81cf044ca52612d68175104cf35320af4d39" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/5e7f6/5e7f6539259769d46a950a13473e1f494bb4b4fb" 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>
|