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/79ed7/79ed7e4da67980ce128d4c012e6fae2c38d56bb2" alt=""
|
|
|
|
|
|
|
|
|
|
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/21356/21356fcd28024351d4e94b8e53bec5fc2cfbf892" alt=""
|
|
|
|
|
|
|
|
|
|
* Add STDIO and other driver/middleware to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/79723/797230a7bbd093906e6db4f849108e36ba31e4ec" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure STDIO driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/42e6b/42e6b58d6b886e2ecf918986fd2d8fbd6431907e" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module clock.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2acca/2acca5dd9e5f4bf5fc8394d2e2ace7c56305a416" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/57155/571550d44081b846f181f812ce603749751726b1" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6f163/6f1637915c16b288e5310fe1421af02673d5549b" alt=""
|
|
|
|
|
|
|
|
|
|
* Add LED pin description.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0936e/0936e509e18ad35baa1cfc6de28251b0520b5e0f" alt=""
|
|
|
|
|
|
|
|
|
|
* Rename project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/554b4/554b450eee5bb14545c1cd792f7d2a014d099c3e" alt=""
|
|
|
|
|
|
|
|
|
|
* Save project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b467c/b467ccdfdeff5a2c8962ec9b29ef233b5cd18676" alt=""
|
|
|
|
|
|
|
|
|
|
* Export project source code.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1b697/1b6973a885e352d3e675ac56b0fbf3f1cb7bfb46" 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/59e6f/59e6fe474994d0565afb06babb24dccc275bac77" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/214ff/214ff2b9b1c3cb9bc4293ea7d8fbcc812f23bd35" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/83370/83370938ed7f345bf8054ac27266ad39d7a6531b" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter same70q20 directory and remove all files except SConscript file.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/45ae5/45ae530e6eac36464521ecf1037ad541bd71f883" alt=""
|
|
|
|
|
|
|
|
|
|
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3f718/3f7181a97826bf74ae904700bb5d1435d57de60c" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5149c/5149c94d4a3931f5e0af2d394cc82c0d27d998eb" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bbcd2/bbcd22305e9ab5ff1e44d046615abbb92b655fa1" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/dfa47/dfa47078d943c50b53ef419ef7cb62b5b145c25f" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ee9c4/ee9c4841f27bc2668499bd1f85b5d8556b1c4264" 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/808cc/808cc908e755479b2247dc3fe1d9d631e9a1bd94" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded file and run env.exe.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0327b/0327b8553ceae591c459abe392789c5262427b39" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter your project directory and run scons command to compile it.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/67cf7/67cf7fdf329da7b1a79fc51ce00d3fe069fa373d" alt=""
|
|
|
|
|
|
|
|
|
|
* Compile error you may have and proposed solution.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8e0aa/8e0aa86fc11e03193bb94b32b090d4a247267d82" alt=""
|
|
|
|
|
|
|
|
|
|
* Fix compiling error
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/262f6/262f641f5f77fc843b1cf24ea959741090f8a58a" alt=""
|
|
|
|
|
|
|
|
|
|
* Compiling success
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8fc39/8fc390e35ec23c4290704ac9aec4ab6598c6763a" 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/b1006/b100644cf0ce3bacdf4a70e63f06629d8a294360" alt=""
|
|
|
|
|
|
|
|
|
|
* Open installed Microchip Studio 7 and open object file for debugging.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1c964/1c9647a7f96df86652ab6e1bbfbc578538a084d2" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose object file, fill project name and select where to save this project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ee9e9/ee9e9f3e873aa82c6020dcc33b5320ea7e0b3a83" alt=""
|
|
|
|
|
|
|
|
|
|
* Select the right part number and complete object set up.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a143b/a143b77ef5e52e581aba0d7004a096ae35ac7fad" alt=""
|
|
|
|
|
|
|
|
|
|
* Object file import complete and you can see related files are linked to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/6c063/6c063489892dfd6b142698344099e35a3c42b658" alt=""
|
|
|
|
|
|
|
|
|
|
* Right click the project and choose the debug tools in project propertities setting.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/259f3/259f3225c80b01789c29a55a0cc24ae030d1e5ed" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/195a9/195a921e3834a4034459fe908b683b615d963e6b" alt=""
|
|
|
|
|
|
|
|
|
|
* Press debugging button and enjoy your debugging journey.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/827f1/827f128b3ca5f4e7287f066732fd2aaaaa0d2920" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging start and you can add breakpoint.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/77f82/77f82510bea793e558abd8ea5143ee1038d3b994" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e6eea/e6eeac4702ffc6c803e3ee85d90aecfdd2ad5c1e" alt=""
|
|
|
|
|
|
2022-04-19 14:32:02 +08:00
|
|
|
|
* Debugging message output.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2e386/2e38678e3ae29c95652f0b2874c81180ae09d973" 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/dc973/dc9737c7eb2e970a78c34585373e8e01729d43a2" alt=""
|
|
|
|
|
|
|
|
|
|
* Now you can reconfigure your project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c431a/c431a8a0ce261e231fabc95b2b1f27f52d4aeb25" 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/87008/8700806b3bf142e49e11ea521608c1d00722abfe" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/fcadc/fcadc4ba7f20f640668ea1490193a1ff1812257f" 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
|