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/49731/49731ef40f1daa8334d24480bd357f2df490d25a" alt=""
|
|
|
|
|
|
|
|
|
|
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cb701/cb7018f9312c7e80b10cc7f98d662fccbc4abbef" alt=""
|
|
|
|
|
|
|
|
|
|
* Add STDIO and other driver/middleware to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/80fa1/80fa140ee4a262d8c7aa9a897cb13c11b73d5bb7" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure STDIO driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b9294/b9294a4dc1989261f329d6b6cd74e6fe88c73528" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module clock.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e4c66/e4c66e2059165ab02b684779bf6611de32c07036" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c5ded/c5ded0598302a8426e50a38bdaf65bd47ae4847d" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/111a7/111a7df227f323bc5c82902420a3bc86823bcb1e" alt=""
|
|
|
|
|
|
|
|
|
|
* Add LED pin description.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/49f48/49f4818e67afdc8aad8d70a671fca9d3317dc00e" alt=""
|
|
|
|
|
|
|
|
|
|
* Rename project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5ba51/5ba51b166dd748815fa62d42351bce2a489be87d" alt=""
|
|
|
|
|
|
|
|
|
|
* Save project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/74119/74119c33cfe8839953a9681c1e5f9216dadf86dd" alt=""
|
|
|
|
|
|
|
|
|
|
* Export project source code.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c1034/c1034f9bfb256ead9fdb63e3b9ad5894527c0d75" 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/63bc3/63bc3865395f216ee358571d1b35d23cc4811a75" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/781e1/781e16c72654b7a0fd0ec65c9f1187093022340d" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dece8/dece87d3a04f15c0657b0da69bb6797afb2cecf8" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter same70q20 directory and remove all files except SConscript file.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/987ad/987addd5eecf9c434f2b2531f15a46c50ae4cea3" alt=""
|
|
|
|
|
|
|
|
|
|
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/22c9e/22c9e9cf1328e08565c394234165920808488188" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6ab11/6ab118bd75399d3165f22fc8ac7920ccdee6800f" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1108c/1108c691af2165c047ce53bb580db98d207cd28a" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ddbd1/ddbd139ed98b57d03f2cc0822eeb94c821cacdab" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/d938e/d938e6b6596d7786a1b2e03dcd0d4c469619a272" 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).
|
|
|
|
|
|
2023-04-18 21:18:56 +08:00
|
|
|
|
* Download RT-Thread env tools <https://www.rt-thread.org/download.html#download-rt-thread-env-tool>
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/07638/0763855cc0bd7fc4df53e7447abd047a3bce3f4a" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded file and run env.exe.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/03feb/03feb2ffb613edd24da21947e0d6c60f5b7f7d9a" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter your project directory and run scons command to compile it.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/48a58/48a584fdefd91ebf2ada2f5105e41cc46912f7b4" alt=""
|
|
|
|
|
|
|
|
|
|
* Compile error you may have and proposed solution.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/952aa/952aa63d4d62d83304df71b5719530b498266984" alt=""
|
|
|
|
|
|
|
|
|
|
* Fix compiling error
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/583f1/583f164203777715027eda675233c709ffb6535b" alt=""
|
|
|
|
|
|
|
|
|
|
* Compiling success
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/9a606/9a606942474d6d4a392f282627d47ef77e1ef77f" 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/58642/58642e91f11becf433c90eae97b08474cf8a2fa5" alt=""
|
|
|
|
|
|
|
|
|
|
* Open installed Microchip Studio 7 and open object file for debugging.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bfc26/bfc268cdae6f86e5cd9b7182393f0ca575d07b9c" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose object file, fill project name and select where to save this project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/40b50/40b50789b46228e880360b7b68630a9f8791dc6a" alt=""
|
|
|
|
|
|
|
|
|
|
* Select the right part number and complete object set up.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dfbe3/dfbe3fbf688f4fdecd0f48f69b46d9312391b768" alt=""
|
|
|
|
|
|
|
|
|
|
* Object file import complete and you can see related files are linked to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/73e70/73e70a2f2fe5833dcda5488bc16d6b81232ce4fe" alt=""
|
|
|
|
|
|
|
|
|
|
* Right click the project and choose the debug tools in project propertities setting.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/488a4/488a432beefaa37c45fb95f646999f99a43e2919" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/77414/77414bee12348b3e601d81d0e94c62b9951d12a5" alt=""
|
|
|
|
|
|
|
|
|
|
* Press debugging button and enjoy your debugging journey.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f2e7c/f2e7c208070f5e477108075d283a07f9b5320661" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging start and you can add breakpoint.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0d88b/0d88b5869fbb68d96706dd294dac8fa1cd7a2c68" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b3f6e/b3f6e2f8b4a44dcb5df316dd5432579ebb0f66e1" alt=""
|
|
|
|
|
|
2022-04-19 14:32:02 +08:00
|
|
|
|
* Debugging message output.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bca27/bca2711aec5c9ba2c6bbccb3afe5daa4e49c1ed8" 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/89f2b/89f2bc211b6e95874dc4a0df4ed95707d1f09009" alt=""
|
|
|
|
|
|
|
|
|
|
* Now you can reconfigure your project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/70b90/70b90ac89e2c67aa181995ad112503e76b6dd04c" 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/d3b0b/d3b0b9942bfc7181769b90ee88cfb6bf98338f08" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/7b45f/7b45fa505c808ddd75493e2ff3f761db7dc9c1fe" 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
|