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/af73b/af73b897fdb3438a4820cd86d2a8feaa83c34d03" alt=""
|
|
|
|
|
|
|
|
|
|
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/36715/367157ee21684383888e38b367fd133ff345bcaf" alt=""
|
|
|
|
|
|
|
|
|
|
* Add STDIO and other driver/middleware to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/28b12/28b1239e623f1cc2d6126a24485aa6f6f267b1e5" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure STDIO driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/fc0f0/fc0f060cf65b729368ebe331455d9318c408640a" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module clock.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2ad8a/2ad8a7465963ada99e659b80dc2457af5f510df4" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c3715/c3715dd317d5e20490796109fca02a35b3f90b4e" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/99e24/99e2439c9445125dfa6ff2fdaf7c787a948a6f9b" alt=""
|
|
|
|
|
|
|
|
|
|
* Add LED pin description.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/05f69/05f69802038047b49062ded067dc9607c0a4bbfe" alt=""
|
|
|
|
|
|
|
|
|
|
* Rename project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/456aa/456aa4313dd90c611bfb3f933e46665f022f8eab" alt=""
|
|
|
|
|
|
|
|
|
|
* Save project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6110b/6110b0d7ee76f3ebdcdab1fbc508237c0586474a" alt=""
|
|
|
|
|
|
|
|
|
|
* Export project source code.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2e063/2e0639a82a93ffb2f1f7dce678e078a10d74be98" 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/858f0/858f0173cd13af6721a6d07325584edf6aa9ce62" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/afba3/afba39c7babcb7f4d8a1576508606daecbe0f4ba" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/99d63/99d63d00d4d3c12efb4602c647992f5bde1aef07" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter same70q20 directory and remove all files except SConscript file.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/da5a2/da5a223775da549949b65a9d83dc45da3e8d29a3" alt=""
|
|
|
|
|
|
|
|
|
|
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7c0a5/7c0a5aaf82bb2db5f52b44a3cea6e868481c3615" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/230ad/230adf94d3d395b1c94a75f8fc213b53b828109a" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/7aa62/7aa624ccb7db349b81bd7f9e69cc7a4b6adc2391" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1f47a/1f47a2eb7d4564712266b2e573d27b29b6d46070" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/13a3e/13a3e56569dbd929b108b63096f98484cb20f61f" 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/59b03/59b037407857a6be9ee841b1598b0e97fc56c953" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded file and run env.exe.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4e48a/4e48abfd99132497776d7f8d05c068383f303f78" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter your project directory and run scons command to compile it.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4035f/4035fb54364c81a7d3410831d00c98c988d568a3" alt=""
|
|
|
|
|
|
|
|
|
|
* Compile error you may have and proposed solution.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/01bc3/01bc3c9680e90295360fb1bebf5b6f95c961abb8" alt=""
|
|
|
|
|
|
|
|
|
|
* Fix compiling error
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a6dfb/a6dfbafa369a32ce6ae844a09b4d656a70623749" alt=""
|
|
|
|
|
|
|
|
|
|
* Compiling success
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0f670/0f6708a595efe8cd973c0da8ac5840eed7c4a9d8" 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/83e28/83e288a40d8e6ee9ddea250b0200de10c5b29efb" alt=""
|
|
|
|
|
|
|
|
|
|
* Open installed Microchip Studio 7 and open object file for debugging.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/05a99/05a99364d93520cc5c4cc633bd1c069c2620a4c9" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose object file, fill project name and select where to save this project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9a64f/9a64fcf111b8ac9a5687db8fb984948bdb795d36" alt=""
|
|
|
|
|
|
|
|
|
|
* Select the right part number and complete object set up.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3b87b/3b87bc03bf04213b93680c5e747e81b11e42d797" alt=""
|
|
|
|
|
|
|
|
|
|
* Object file import complete and you can see related files are linked to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d5792/d579232af99b8487d61ff9614593e2dbd1f5c386" alt=""
|
|
|
|
|
|
|
|
|
|
* Right click the project and choose the debug tools in project propertities setting.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/34792/34792f043248f843a0b93754d23caebd16aae06a" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f1af8/f1af8fd859e42d9ea200c67e6036e06fad938fa1" alt=""
|
|
|
|
|
|
|
|
|
|
* Press debugging button and enjoy your debugging journey.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ad68b/ad68bc32f876f03552a417047621bbdaad04e0e2" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging start and you can add breakpoint.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9066c/9066ccbcbf0c0d5801b571db707247a5c47052cf" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/425ce/425ce1bbdaa55d356fbeb2208f1fa6231c01fe21" alt=""
|
|
|
|
|
|
2022-04-19 14:32:02 +08:00
|
|
|
|
* Debugging message output.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c1871/c18717f6ae3860b4d9acce5b44daa659892c49c2" 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/eb0bb/eb0bbb26352a0294cc5e546ee9e5a16fc003e3f8" alt=""
|
|
|
|
|
|
|
|
|
|
* Now you can reconfigure your project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/73d1f/73d1fbfae5feb7b60a79891a71a209fb4d1c97ca" 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/63e5d/63e5dd2dfd30da9b22583c701ff27a4e9d5f3d41" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/84b26/84b26a99531c8e94ef486748f9117c7756365d09" 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
|