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/d8ef4/d8ef42c29532c2442809c3a1655218e9b310e384" alt=""
|
||
|
||
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/0defa/0defafca5a8771fccb5b9f7ba1823f818bcaf9a8" alt=""
|
||
|
||
* Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/8cad9/8cad93f96fba8b74040bc4690c68496ede284b13" alt=""
|
||
|
||
* Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/4c4bf/4c4bfb8c62030fc4ba882c331d66b54026b38636" alt=""
|
||
|
||
* Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/5f98f/5f98fbb1c548fb73be6cb471b86c5da98392f92f" alt=""
|
||
|
||
* Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/89222/892220e1ea9c09a340929622a794d725b1c7048b" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/878f4/878f438eec7d5ba15faec636f58d3edb8c0e5fa9" alt=""
|
||
|
||
* Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/ebab8/ebab86a9c5de5567f19128b02b777ba88421b938" alt=""
|
||
|
||
* Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/1dfdf/1dfdfac362acc311ab10b6f20694cd5d05622141" alt=""
|
||
|
||
* Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/b43a4/b43a4e939958a3bed6782f229216135abacb7b41" alt=""
|
||
|
||
* Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/ef6d5/ef6d5d99e47916204f0641dc9d56fa052d40c549" 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/97f93/97f93bfdfb3845a0ca81ac6e4e7ba99c061ec22f" alt=""
|
||
|
||
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/43746/43746921088a1dfac686ba1238a7a9b15fdc3bcf" alt=""
|
||
|
||
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
||
|
||
data:image/s3,"s3://crabby-images/adfce/adfce891dabc7f878a78dd07074de797de00094a" alt=""
|
||
|
||
* Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/f6814/f6814fbf969fbdcf9fccc391fd19042776a5cc68" alt=""
|
||
|
||
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/5b126/5b126ae8de21e713acfe80cbdd8b743ab93b1345" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/8075a/8075a747fca3a97bac9619b4613a16d8b81396b2" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/816ce/816cebff7b2e110781c8f79033ff11a0b9e3c76f" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/c6552/c6552cee5f922c8a98bdc2820c51465f4e38388b" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/5e478/5e47829184f0e885d12e83d4ba4283fc12ca4851" 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/download.html#download-rt-thread-env-tool>
|
||
|
||
data:image/s3,"s3://crabby-images/77da2/77da2a34d8e268808ff35bd08708015a0f3c9bc5" alt=""
|
||
|
||
* Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/5fbcb/5fbcbfea4d8c3c7eb976c93676d016db7909e382" alt=""
|
||
|
||
* Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/36f20/36f2016ba8f81f70ab01fb2eddfc91e46500d0c8" alt=""
|
||
|
||
* Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/7c96d/7c96d49fb264546175f7e3b3f917fa598bfb8d04" alt=""
|
||
|
||
* Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/e8d4a/e8d4a8b2eaa8580da76039ef027bc6720edf5c87" alt=""
|
||
|
||
* Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/18ef4/18ef48980648641a0a00d9ff28ca385d7aac2d5d" 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/6e24e/6e24e7517c60ab2497e380c279aa3ad49fc05280" alt=""
|
||
|
||
* Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/48ff0/48ff0d2070159809fd5a0cd33b55264ed07cb720" alt=""
|
||
|
||
* Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/6d54e/6d54ebbea5958d4987d4ff9e151fd1958c6c4185" alt=""
|
||
|
||
* Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/f2a09/f2a0930e9e2ad1401080b6d00291032b19c81122" alt=""
|
||
|
||
* Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/f39e9/f39e9419176c6d39112990bd8e71a216de321cf0" alt=""
|
||
|
||
* Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/93ecf/93ecfebf24147d86fbb2318e9e6278c4eaf88ef1" alt=""
|
||
|
||
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/92bad/92bad1118e98ba90934d2da7bb52e0e151d8cea3" alt=""
|
||
|
||
* Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/cce03/cce034e5e42f4b583313d02146c56b27bdd0a324" alt=""
|
||
|
||
* Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/b9258/b9258699f899a32fcb42ede8891cfa60cc07d729" alt=""
|
||
|
||
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/53716/5371681320d0092ab9c23325dff38cda86df720d" alt=""
|
||
|
||
* Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/93e2e/93e2ed8b36e61f947d6b7978115cad4732ed0076" alt=""
|
||
|
||
# 4. Reconfigure MCU BSP
|
||
|
||
* Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/da79b/da79bc71bfddc0dfb71c937731d8f46598706e1c" alt=""
|
||
|
||
* Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/ac283/ac2834bf0a8836a87de86e9c7fe2c4c1e3843e2f" 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/efbdd/efbdd0fd7178e01767bfd4977b141c494fa321f2" alt=""
|
||
data:image/s3,"s3://crabby-images/ecafb/ecafbbdbe839b738e07fe715b587ffdf0ccfed2a" 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 |