* Add SAML10 Cortex-M23 series support 1. Add SAML10 Cortex-M23 series support; 2. remove STDIO related code of same54 series, no need any more; 3. update rtconfig.py to support output bin & map file containing DEVICE PART info.
225 lines
6.2 KiB
Markdown
225 lines
6.2 KiB
Markdown
# 1. Microchip BSP Introduction
|
||
|
||
Supported Microchip SAM (ARM Cortex-Mx Core) MCU is as following:
|
||
|
||
## 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
|
||
|
||
## 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/76d44/76d44d26a95faf925a831cb87660b4e245bc2b85" alt=""
|
||
|
||
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/93044/930441562de6d80012e5240d12452803efcd2199" alt=""
|
||
|
||
* Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/6f380/6f3804c768e1b921ce30b2435d61f58be8e74684" alt=""
|
||
|
||
* Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/92a37/92a37ef9a6f914f2c1cff91982a8ab109902d32b" alt=""
|
||
|
||
* Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/ef26e/ef26eb1244909393b25dcda66d661f1e834813a1" alt=""
|
||
|
||
* Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/98fb3/98fb30324220c1458582d634d98306e2c1ef6241" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/4b246/4b2464851f0854674de59841deed2752507ef678" alt=""
|
||
|
||
* Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/9d161/9d1611a79454f4a490b96220f4ebace11d69f2ba" alt=""
|
||
|
||
* Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/c0fc9/c0fc9ec428d982886868b48bcc5b6dc1c61800bd" alt=""
|
||
|
||
* Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/f56bc/f56bcfd749df1777009dca266662d7afcc0af55f" alt=""
|
||
|
||
* Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/78733/78733e2505fd15450a320724e77375a99ecfd097" 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/4e557/4e557723c8c74b05c269f7d00dcc24d1c4c2c9b0" alt=""
|
||
|
||
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/d498c/d498c03d926b1f42037e5a1dce59077abdbac1cd" alt=""
|
||
|
||
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
||
|
||
data:image/s3,"s3://crabby-images/20f0c/20f0c74905b48cfc904cda5f360a4821b25a9ff3" alt=""
|
||
|
||
* Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/1fa14/1fa145da82eb3117448bec1d00c3d5689774b656" alt=""
|
||
|
||
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/bf144/bf1445a901bc39796303d4e3b43a647b54a61ea6" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/9db32/9db32a74ba2cbb02c005ae028dc83775df55498c" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/cded2/cded2de26ae2f0d19994ea19cb8eb97636f5e445" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/d2a83/d2a8399ede18ba142a5aef5d18d1a1884348f69a" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/23f81/23f811b2f1cdda971404e5382964ef88eaf7b43a" 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/17099/1709982ae1ebaed4c6b233156310925b024654f7" alt=""
|
||
|
||
* Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/d22df/d22dfd70c6bd0314523413bac6414da216cf32ca" alt=""
|
||
|
||
* Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/ac52d/ac52d3e2e4719eb1b74a9f7f3c87fcd0f474f141" alt=""
|
||
|
||
* Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/fe2e4/fe2e405c675c3a6f1df7064fadc734439e17c461" alt=""
|
||
|
||
* Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/02a89/02a89b83770d9dc95ad63b42b68a5a9b9a0a04cd" alt=""
|
||
|
||
* Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/05b76/05b76ebd5bd38e2779ba27ed2aeb7cc99c45344c" 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/31955/31955234ea5c60484ced584646e6859be2c379e9" alt=""
|
||
|
||
* Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/69295/69295af4bd8041a3fc1bf6d7187f7d49ce08b9b8" alt=""
|
||
|
||
* Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/15d2a/15d2a0ef2402ea58d21a1d3d5c0ea7cda0f95989" alt=""
|
||
|
||
* Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/0d4cd/0d4cd3264bc9473cf79bdd40db99bb417064bfd7" alt=""
|
||
|
||
* Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/eaac6/eaac6e5636f99a649bdcb893171982da17b5ac86" alt=""
|
||
|
||
* Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/b8557/b855797cd4040b27c378d7867657f87fe072f675" alt=""
|
||
|
||
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/bb643/bb6431b1cc7a1233e699f25d1a25eed158d51dbb" alt=""
|
||
|
||
* Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/79214/7921447afc5c23a73ce8dba5c7db6ac2836a1332" alt=""
|
||
|
||
* Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/b5d7b/b5d7b4c6c5fa08d260b6f0d47b002e50db0119c3" alt=""
|
||
|
||
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/3444a/3444a1dea030ed55dc283b9289d888a14218f7f1" alt=""
|
||
|
||
* Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/04280/04280d3871974113092962d62f4efe755785842b" alt=""
|
||
|
||
# 4. Reconfigure MCU BSP
|
||
|
||
* Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/2f9eb/2f9eb1d32d7ddf09a4fb16e0eb12c43c05f15b0d" alt=""
|
||
|
||
* Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/b8e63/b8e633b898445e5a0deed221825ab2f5f3f992c5" 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/a57d3/a57d3d7e21e15878d838b84b55dc71fb3525d64e" alt=""
|
||
data:image/s3,"s3://crabby-images/23a4c/23a4c1e2ef3f6f0f4447b3afda9c9defa29dc859" 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 |