mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-28 04:27:07 +08:00
231 lines
6.2 KiB
Markdown
231 lines
6.2 KiB
Markdown
# Microchip BSP
|
||
|
||
## 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/0b2c0/0b2c03d82a0b05e4022a7c63db8f13bbd02a979c" alt=""
|
||
|
||
Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/f8274/f8274b2a701cbfa79f91a12790331c0e205891bd" alt=""
|
||
|
||
Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/6c723/6c7231696ff12efe68a063c8c51a8e838f188ec5" alt=""
|
||
|
||
Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/c8cfa/c8cfae7d0ecf3bb51f69fb6081062e33dfe32ec7" alt=""
|
||
|
||
Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/5b5df/5b5dfa0db0c12402bdd9a98f37b2a891e12ea8cf" alt=""
|
||
|
||
Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/4bb90/4bb901258fba3505102c6054cf64e4a4254c2214" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/073ee/073ee34f7c40a868438fb331511b67553776806e" alt=""
|
||
|
||
Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/36dea/36dea2c9dde4ccc05ae5cad9b69fab1bcbbf7463" alt=""
|
||
|
||
Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/94711/9471134c1861324b247096e212b470eb4a20cc11" alt=""
|
||
|
||
Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/91ac7/91ac78d7d83df697c2ca90bc463e700110074f87" alt=""
|
||
|
||
Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/9cf5b/9cf5b58ac66b7f74647b76de115745bfc8e295a5" 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/66cf3/66cf372c480be2a228afeb0612e55f89bb36f333" alt=""
|
||
|
||
Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/76f0a/76f0aa15f67ab4d6211b5295ca450f769ba85dc1" alt=""
|
||
|
||
Enter *rt-thread-xxx/bsp/microchip* directory and copy **same70** folder and rename it to **same70q20**.
|
||
|
||
data:image/s3,"s3://crabby-images/37c06/37c06599d85095d5fc26360e100257ba581bb9bd" alt=""
|
||
|
||
Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/cc694/cc694681da0ca67af3ed1ca355b631fb9baee65e" alt=""
|
||
|
||
Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/8dcd6/8dcd6718f6aef748ec44e2565cf45463251928a9" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/5b824/5b824da3185c89644c128c6296bd8ddfa58d48dc" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/0e2c6/0e2c6d004027c6f0e3bb3350f8e53f59aa0b7e6a" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/6cbd3/6cbd3babaaf4cd10751e3625ed96705871c962aa" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/656d3/656d3e998edc1a9f6ce7079ed276c38f274e6ede" 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/61fd0/61fd036d53e0c9ffd41adf9b6e8569ee37128217" alt=""
|
||
|
||
Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/c2638/c26382c78c4fe44438c7f209350108dbb6abb41a" alt=""
|
||
|
||
Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/18665/18665e403950e8c5c0c4850f9b0b7bcec4410cad" alt=""
|
||
|
||
Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/58b97/58b9763c2c4d2865f214b33156b1a42ee0482fe7" alt=""
|
||
|
||
Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/9debc/9debc611f651699c39e02b86a07e049748217649" alt=""
|
||
|
||
Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/d13ce/d13cecf0d7ca3b803bf3333fd23a8b3a5e28b3fd" 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/ae7b7/ae7b70b66435b123e4f4bf66ba28669827836e54" alt=""
|
||
|
||
Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/fe3c0/fe3c034eb5a65ce6aab2751f900e370b33da9c3e" alt=""
|
||
|
||
Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/f506d/f506d0cae964344e1cf3c76257eb22ceb1a7ea1a" alt=""
|
||
|
||
Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/91d7d/91d7df57ab694a7b876f51334f42eab0f5a4c4e9" alt=""
|
||
|
||
Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/299b3/299b3b8c738b08c99f893eb26f65c11027cd7542" alt=""
|
||
|
||
Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/22b88/22b888616617ae06ad4402a049754070c6982a10" alt=""
|
||
|
||
Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/9ccd9/9ccd986c2f7b7204e59a8f8c82f93488ab1e35fe" alt=""
|
||
|
||
Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/e70d3/e70d3fed7672a70f9dce8691b4c2244c27515937" alt=""
|
||
|
||
Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/d0d81/d0d817a9cdc548cee230a56681ca239cf7ce1412" alt=""
|
||
|
||
Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/387c4/387c484fd389a671ded5419797701ca47ac532da" alt=""
|
||
|
||
Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/57551/575511c8e44f075643f7be58deb9da4c85a8b6fd" alt=""
|
||
|
||
## 4. Reconfigure MCU BSP
|
||
|
||
Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/8c9cd/8c9cdb104982ea0d7100ee851290a811da9c7f65" alt=""
|
||
|
||
Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/6ef79/6ef7968356a4a30759209ad9962f56af9e439bb1" alt=""
|
||
|
||
|
||
## 5. Microchip SAM MCU BSP configuration and user guide
|
||
|
||
Please refer to [ASF4 API Reference Manual](https://ww1.microchip.com/downloads/en/DeviceDoc/50002633B.pdf) for more details
|
||
|
||
### 5.1 SAMC2x/E5x/E70 CAN Driver
|
||
|
||
CAN driver configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/4d967/4d967ded27ef5512295f4bb5618f0f9663f6c245" alt=""
|
||
data:image/s3,"s3://crabby-images/69390/69390b59ef1a8fdb8d1e28f226084b21c7dd4e7c" alt=""
|
||
|
||
CAN driver user guide - see [ASF4 API Reference Manual](https://ww1.microchip.com/downloads/en/DeviceDoc/50002633B.pdf) P121 for more details.
|
||
|
||
To be continued.
|
||
|
||
## 6. Contact Info
|
||
|
||
- [Kevin Liu](https://github.com/klmchp), email: <kevin.liu.mchp@gmail.com>
|
||
- [luhuadong](https://github.com/luhuadong), email: <luhuadong@163.com>
|