* 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/158e3/158e3ba8a004eac508376e12d633030da9eb18be" alt=""
|
||
|
||
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/f3c8b/f3c8b1496f5287064d465e4f51e475593ff9179a" alt=""
|
||
|
||
* Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/5c2a2/5c2a2733dd4f227fc97904693aae49716e4de495" alt=""
|
||
|
||
* Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/a0b64/a0b642150c1e81b053f3544b391befe296dfe82b" alt=""
|
||
|
||
* Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/21ab5/21ab55499bd25e5de8287c20cabe6d739a58f1e4" alt=""
|
||
|
||
* Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/07d49/07d491c14fdf1d991d468c876dde57033d1c1abb" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/0f7eb/0f7eb51e8e5a1e7628f56b25fdec9fdadf44ad56" alt=""
|
||
|
||
* Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/8d2ce/8d2ce6675aa0e3e0dc0e274ecb71b4e9f8571303" alt=""
|
||
|
||
* Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/dba7d/dba7d8c8d06c3f2902f985161054e527a1f4ae69" alt=""
|
||
|
||
* Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/14eb1/14eb1d14153a70c21b1b7614eed3895cdb2bcf2a" alt=""
|
||
|
||
* Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/ff634/ff6341436e5c256f72a4961041d05cd51c62ce94" 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/ea551/ea551f7295ffa5b2c4efda5cb2983efee81e445e" alt=""
|
||
|
||
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/3988e/3988ec604eaecb2a063aac510b712a2f15d09022" alt=""
|
||
|
||
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
||
|
||
data:image/s3,"s3://crabby-images/f3b03/f3b036b6483afc6a3e1bad8ee8df0c28ba516854" alt=""
|
||
|
||
* Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/9566f/9566fb0b458916ed4ebfcdbe1bc3387db723adda" alt=""
|
||
|
||
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/15f33/15f337b12aeaec6dd29e2317da30e1df46b8f86c" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/c3539/c3539077beaab5da8d34af95072757812907eef2" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/58b33/58b33712e40ee20c20bea6c93ab4371c464b2c8e" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/7bd08/7bd084b6863b6ef2f7c40cb4ba1f40b3f7734249" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/a8432/a843280fdb50cf3d213b33b4d1648db74908c211" 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/e56cb/e56cbf88515210347a07fa7574e749cc0be4083f" alt=""
|
||
|
||
* Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/53bdd/53bdd0c819a7c0a50a19765d96b4acb97f94c249" alt=""
|
||
|
||
* Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/b7a7b/b7a7bbb20918c352219a7ff3dc198d14d5439228" alt=""
|
||
|
||
* Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/85e68/85e68be8ba59b3a0cf70a9f4822bf23b9421fda3" alt=""
|
||
|
||
* Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/59d8e/59d8efc046370a8c41c6017db2c321421a4c6217" alt=""
|
||
|
||
* Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/ebe93/ebe93f794029bb8006c1e236ac12e73fd674dcd8" 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/e5ed8/e5ed80802c1ff68d5670c3a004fa13681fedac7d" alt=""
|
||
|
||
* Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/dcbaa/dcbaa0dd2176bd0e6b2a81c2aa13842e371a66d6" alt=""
|
||
|
||
* Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/64667/6466704db8755fc217e2ce982d6a149a3286aaa0" alt=""
|
||
|
||
* Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/fb6b7/fb6b765f6d285bd2b1c69bf5b8eeaeaa844c36ed" alt=""
|
||
|
||
* Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/67419/674197c9068db25c8245b54cc1b854d615334a8f" alt=""
|
||
|
||
* Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/bd74a/bd74a8e940c01c87c6df7cf1f7c00911356d9da6" alt=""
|
||
|
||
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/28c35/28c355afed98ae6dad4160bece514fca9b03f512" alt=""
|
||
|
||
* Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/8b163/8b163fdf57878ed2e076432678823c9f05bb99b5" alt=""
|
||
|
||
* Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/6cde5/6cde5243e533340ce7d7860607367122a84681aa" alt=""
|
||
|
||
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/642d3/642d32d00721e42d614bf4bbf38e4eafe9813704" alt=""
|
||
|
||
* Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/58abd/58abde6946295e6309adc94c7a1aafb83a472fc3" alt=""
|
||
|
||
# 4. Reconfigure MCU BSP
|
||
|
||
* Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/0aec7/0aec7756560a948c414123ecdc5fe94df7edcaa7" alt=""
|
||
|
||
* Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/4629d/4629d4e01b30430a293068ac636f71d51d73fe6c" 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/d6d68/d6d68b1066b6ea6bda8d9c815d563f8c9bf8feb4" alt=""
|
||
data:image/s3,"s3://crabby-images/49700/49700a0fc9f40a7f6b5d5bec41d1a0d12b1a451e" 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 |