mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-03-03 01:15:27 +08:00
* 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/01fd8/01fd89549bf466154833137bd49ab3676e8605bf" alt=""
|
||
|
||
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/abd68/abd6834fa25e42ab443de30ef8720a8b2a762c3d" alt=""
|
||
|
||
* Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/04ffd/04ffda833a2ac1486c18865079eae40d5a7bd253" alt=""
|
||
|
||
* Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/14c90/14c9034a5de175126aa43b1ac2e15bd94b1e4595" alt=""
|
||
|
||
* Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/1ce18/1ce186083e3774e52cc24a8272578fae3cc9e1e0" alt=""
|
||
|
||
* Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/32e4f/32e4fa1a8f2212f0d885c55ed58ea2f0b6755ea8" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/619b5/619b5fd4d5b29ff584c11ae42e0d2eaf7d03d0d2" alt=""
|
||
|
||
* Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/26291/2629153a9367e923bdf7e1fe4780c00c1cab9f78" alt=""
|
||
|
||
* Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/df066/df06657bb6f5d30c45f517bccb0ad2a18dcd8af6" alt=""
|
||
|
||
* Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/460ec/460ecb3aca3f832558fc0e79885ab8f42dde49a4" alt=""
|
||
|
||
* Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/f714f/f714f66ac11fd5dae66eb8b625048b594610d1d1" 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/afb82/afb8292e121aad106ad40bcf6f76534dac02ecbd" alt=""
|
||
|
||
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/a252a/a252aa3dd7c75733ed83b76f00e0c2acf527cdab" alt=""
|
||
|
||
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
||
|
||
data:image/s3,"s3://crabby-images/f9650/f96502f1555fc0ab6eb266ca14bcf6062bc82be1" alt=""
|
||
|
||
* Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/425bb/425bb2eb5bc684012dbc1a9e6adc28020fd61dfc" alt=""
|
||
|
||
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/3ee7e/3ee7ec98d7bc96523f401b7a0611811eb68cbedb" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/6b3be/6b3bedc0f6eaf4dd5fd11d1937962f97f0566355" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/27782/277826ee420ac155884e5e72ae26109292940ae8" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/62083/6208374ac79676a2f3c8e5f39f113a4def508cbc" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/70158/70158d7c3ebbc84d4823dceb7bef113cb9fd3eba" 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/66daf/66daf00cc7172bd37a1a6480896c389077e340c6" alt=""
|
||
|
||
* Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/b8ddd/b8ddddce6c3e659cee81a3b68fee7176745d9d1e" alt=""
|
||
|
||
* Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/c2911/c2911c4628a94e6e442295bc3c21dbe62f9474ad" alt=""
|
||
|
||
* Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/4e464/4e46485d605b738223c43d29a802086f5af61f08" alt=""
|
||
|
||
* Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/48979/48979fb4a6c6472f933b9b4e79573af396d08fd9" alt=""
|
||
|
||
* Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/00f96/00f96c0ce2936457a19e01892bfe81d4f3dcb3e3" 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/e6509/e650921453ef888b1cc26bba0d220617efc4e191" alt=""
|
||
|
||
* Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/c0aeb/c0aeb81e31db658d418ec91601c41f9ca16c2a90" alt=""
|
||
|
||
* Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/56ffc/56ffc0b9e497e87356ae525adb54a192dbce8afd" alt=""
|
||
|
||
* Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/5b638/5b638ed990f6193316ad0d306a8c4a8316af311c" alt=""
|
||
|
||
* Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/8840a/8840a45c76c3ab63bb8020deabb855d96ad5d25a" alt=""
|
||
|
||
* Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/8415a/8415a60d24ddc0385384531f0e4767069b0016fa" alt=""
|
||
|
||
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/8e01f/8e01f7dc6ff36df2f08dabca1c8d0d5f5f0ff129" alt=""
|
||
|
||
* Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/b9227/b92275445ff79ed28f323af48b15d73d4fa035ce" alt=""
|
||
|
||
* Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/d0187/d018799208dedfcdd365097e4cbcc98ff9e14044" alt=""
|
||
|
||
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/f106f/f106fabd1781c82c871090fcb06ae828ef4e5758" alt=""
|
||
|
||
* Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/cffbc/cffbc1c1d4bbc85e405c6473f20b7a3176af6155" alt=""
|
||
|
||
# 4. Reconfigure MCU BSP
|
||
|
||
* Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/07908/07908ca3e5e2f5f192961a199f45263237ed7965" alt=""
|
||
|
||
* Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/fc8fa/fc8fa21d2d6ab593c30964bac7cf9b89e71a5f6f" 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/bd43f/bd43f67abf6a36082c7cf8302e17ba1f71e93258" alt=""
|
||
data:image/s3,"s3://crabby-images/cdc51/cdc51f7f4b9ca871ee0e13cd3353bd80b8a9c900" 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 |