2022-04-14 10:54:53 +08:00
|
|
|
|
# 1. Microchip BSP Introduction
|
|
|
|
|
|
|
|
|
|
Supported Microchip SAM (ARM Cortex-Mx Core) MCU is as following:
|
|
|
|
|
|
2022-04-27 09:24:56 +08:00
|
|
|
|
## ARM Cortex-M23 Series
|
|
|
|
|
- saml10 | 3.3V Cortex-M23 with ultra low power
|
|
|
|
|
- saml11 | 3.3V Cortex-M23 with ultra low power and trust-zone
|
|
|
|
|
|
2022-04-14 10:54:53 +08:00
|
|
|
|
## ARM Cortex-M0+ Series
|
|
|
|
|
- samc21 | 5V Cortex-M0+ with 2 CAN-FD support
|
|
|
|
|
- saml21 | 3.3V low power Cortex-M0+
|
|
|
|
|
- samd21 | 3.3V industrial level Cortex-M0+
|
|
|
|
|
|
|
|
|
|
## ARM Cortex-M4 Series
|
|
|
|
|
- same54 | 3.3V 120MHz Cortex-M4F core with CAN-FD/USB/Ethernet support
|
|
|
|
|
|
|
|
|
|
## ARM Cortex-M7 Series
|
|
|
|
|
- same70 | 3.3V 300MHz Cortex-M7 core with CAN-FD/High speed USB/Ethernet support
|
|
|
|
|
|
|
|
|
|
## Directory description:
|
|
|
|
|
* 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
|
|
|
|
|
|
|
|
|
|
# 2. RT-Thread porting guide of Microchip SAM MCU
|
|
|
|
|
|
|
|
|
|
## 2.1 Configure project BSP on Atmel Start
|
|
|
|
|
|
|
|
|
|
* Visit <https://start.atmel.com/#> and click CREATE NEW PROJECT.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5e3c2/5e3c24f1b92e1eceac7de9779e13a04801d6009d" alt=""
|
|
|
|
|
|
|
|
|
|
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/aa5ed/aa5edc12b2fb0819cb7ce63dd141712b87367dbe" alt=""
|
|
|
|
|
|
|
|
|
|
* Add STDIO and other driver/middleware to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f10d9/f10d9623e9680fa0c138d5f067164079986587a2" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure STDIO driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6f429/6f4299f2cc7775e0a29fcb73b31d98bce3d9354c" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module clock.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a9a54/a9a54b4196dfe3314000725470c90d0bb80d37ea" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7dfb1/7dfb17468195814208f437e6669ca0929bbdf595" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0a581/0a5816316680046d0572ae5eb3b7ac8f1722d41a" alt=""
|
|
|
|
|
|
|
|
|
|
* Add LED pin description.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e795d/e795d7fd7ff52a47f4b592819fab3b2ef1df3928" alt=""
|
|
|
|
|
|
|
|
|
|
* Rename project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e7b80/e7b80c4cc2907cf810a4cf8217436db76a48e511" alt=""
|
|
|
|
|
|
|
|
|
|
* Save project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bf9ad/bf9ada8f0af052691556cf3f5b4403fed60a7ec0" alt=""
|
|
|
|
|
|
|
|
|
|
* Export project source code.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/93e83/93e831f0113182e6e1aaaa753d41b43cbd8c5c2d" alt=""
|
|
|
|
|
|
|
|
|
|
## 2.2 Add project to RT-Thread source code
|
|
|
|
|
|
|
|
|
|
* Link: <https://github.com/RT-Thread/rt-thread> and download RT souce code.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/97c08/97c0836b83ea9e0f53b58a6a6c5fea4d06c27cf5" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/97038/970386ec2d45b58858345192de2841e4019996fa" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/36ae9/36ae9f7a7444f7918738e16737ea8fe9ee951d10" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter same70q20 directory and remove all files except SConscript file.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4254c/4254cb806b2e52c4188488f78cbdf187b6a54f35" alt=""
|
|
|
|
|
|
|
|
|
|
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fb147/fb147040b322c2e7054f4f17f522ed692d60b426" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8de5e/8de5e93d48af28b03dbe03aef5160b8f3a417cc0" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/826ea/826ea0c4345dd81cd5f3cba77ce4c3a2df3f288b" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5e203/5e2034415b67e7855706058ee49e1a0a69c544d2" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6ebba/6ebba264f1b3e02ca45ceb80d7b5f3eede578f86" alt=""
|
|
|
|
|
|
|
|
|
|
* Alright, now you can use RT-Thread env tools to compile the project.
|
|
|
|
|
|
|
|
|
|
## 2.3 Compile project with RT-Thread env tools
|
|
|
|
|
|
|
|
|
|
About RT-Thread env tools, click [Here](https://github.com/RT-Thread/rt-thread/blob/master/documentation/env/env.md).
|
|
|
|
|
|
|
|
|
|
* Download RT-Thread env tools <https://www.rt-thread.org/page/download.html>
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9791e/9791eed287f9ec0711bf7d4f4580f86c753aa1f0" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded file and run env.exe.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c60b1/c60b1dcd87a9dfa5c6e25cadc3b35a8154d1d82a" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter your project directory and run scons command to compile it.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/58c66/58c66fa6bd2f1b2d42929a94c6d696240ea7f625" alt=""
|
|
|
|
|
|
|
|
|
|
* Compile error you may have and proposed solution.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fb9eb/fb9ebc67ba5be08157117c0f6c71f0b70eddc4ab" alt=""
|
|
|
|
|
|
|
|
|
|
* Fix compiling error
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/25164/25164b84367b03abfda4e5702be419eeac526597" alt=""
|
|
|
|
|
|
|
|
|
|
* Compiling success
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2348c/2348c37542963360163017ba25db1e47b9286dae" alt=""
|
|
|
|
|
|
|
|
|
|
* In the following chapter I will show you how to debug RT-Thread with Studio 7.
|
|
|
|
|
|
|
|
|
|
# 3. RT-Thread debugging with Microchip IDE
|
|
|
|
|
|
|
|
|
|
* Link: <https://www.microchip.com/en-us/tools-resources/develop/microchip-studio>, download & install Microchip Studio 7.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d7805/d7805f73333df55ef0d6db270b6f9925cb58cd10" alt=""
|
|
|
|
|
|
|
|
|
|
* Open installed Microchip Studio 7 and open object file for debugging.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/62942/62942897030eea7758c0c8bc50f228bacb9269d3" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose object file, fill project name and select where to save this project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d32ec/d32ec567cc0995aeee55a7f90932cc59d62cc444" alt=""
|
|
|
|
|
|
|
|
|
|
* Select the right part number and complete object set up.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/be77c/be77cee97e6f5b24790c177ed5d822fb0625c4ec" alt=""
|
|
|
|
|
|
|
|
|
|
* Object file import complete and you can see related files are linked to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cf496/cf4967fb6c8419acccb5cdcde436b33dbb0e9aaa" alt=""
|
|
|
|
|
|
|
|
|
|
* Right click the project and choose the debug tools in project propertities setting.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4861e/4861e8aaa0304c246d4d5c91ac311669bbfe3268" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c020e/c020e7ac2465405b60440424f082e98dbc083db1" alt=""
|
|
|
|
|
|
|
|
|
|
* Press debugging button and enjoy your debugging journey.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c0b22/c0b22a3315c9c0f439006998de1e5778e690280e" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging start and you can add breakpoint.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1d586/1d586078f2be8b76ff617d2ba353ff3ee506dec0" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/304a8/304a8371e1ad4b8dc3fb47aeacb0fba88f6e8c45" alt=""
|
|
|
|
|
|
2022-04-19 14:32:02 +08:00
|
|
|
|
* Debugging message output.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c0800/c0800bba512236473954a40f3cd968b145b7a093" alt=""
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
# 4. Reconfigure MCU BSP
|
|
|
|
|
|
|
|
|
|
* Visit <https://start.atmel.com/#> and upload project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bb041/bb041fbc4b3f14c467cab59ef57194b23f4bccb5" alt=""
|
|
|
|
|
|
|
|
|
|
* Now you can reconfigure your project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/871a9/871a90941c8ce686e19e007712bfd598f6b05085" alt=""
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 5. Microchip SAM MCU BSP configuration and user guide
|
|
|
|
|
|
|
|
|
|
* Please refer to <ASF4 API Reference Manual> for more details
|
|
|
|
|
[ASF4 API Reference Manual](https://ww1.microchip.com/downloads/en/DeviceDoc/50002633B.pdf)
|
|
|
|
|
|
|
|
|
|
## 5.1 SAMC2x/E5x/E70 CAN Driver
|
|
|
|
|
|
|
|
|
|
* CAN driver configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f683d/f683d100ebfc9efa6c12fcb10a321c9d61572f7d" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/0560f/0560f857289ec55c06ee6f360c52c2504610e567" alt=""
|
|
|
|
|
|
|
|
|
|
* CAN driver user guide - see <ASF4 API Reference Manual.pdf> P121 for more details.
|
|
|
|
|
|
|
|
|
|
* To be continued.
|
|
|
|
|
|
|
|
|
|
# 6. Contact Info
|
|
|
|
|
|
|
|
|
|
- [Kevin Liu](https://github.com/klmchp)
|
|
|
|
|
|
|
|
|
|
* https://github.com/klmchp && kevin.liu.mchp@gmail.com
|