mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-25 19:07:04 +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/7cc31/7cc310fe9ccc10e25b34ac8fc410836ea7acd60e" alt=""
|
||
|
||
Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/1dd3d/1dd3d14e513f85be04419079456433149b49b694" alt=""
|
||
|
||
Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/560e6/560e641a0c4d20837e1b96759a8c878a9bd4105b" alt=""
|
||
|
||
Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/82f7f/82f7f5cef11c098ac6e16e743a8071d62d5bf42d" alt=""
|
||
|
||
Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/c7969/c79690a365bcec024fbaff2dc2efee5d4c73fae8" alt=""
|
||
|
||
Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/f975d/f975d7e8b38fd9052b513b0d6b9ce965629d1b79" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/cf4b1/cf4b13b9dfff3ae218b72f9f91f2480347978adf" alt=""
|
||
|
||
Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/5d47c/5d47cba764b501190a00485aa5e5d5cb5678228a" alt=""
|
||
|
||
Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/fa6fa/fa6fa600018c24294dbd27f30de6051bfb5a9bd2" alt=""
|
||
|
||
Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/2355d/2355df7722a707ffb16abd8802982ed5e438e0b4" alt=""
|
||
|
||
Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/3e60a/3e60ae01dcf49e581a7f5a15c60af5da8b29d5a0" 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/ac5da/ac5da3b4738b78400932b10ad57d7c214c6119e4" alt=""
|
||
|
||
Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/4cd3b/4cd3b9093ea71bf96b422c84bc9b63d6ce14b989" alt=""
|
||
|
||
Enter *rt-thread-xxx/bsp/microchip* directory and copy **same70** folder and rename it to **same70q20**.
|
||
|
||
data:image/s3,"s3://crabby-images/63606/636066a1d10f38e2aa100aff4b89a129710aecd6" alt=""
|
||
|
||
Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/9a09e/9a09e0a90f08534a6e4f928132b602351e757297" alt=""
|
||
|
||
Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/41fcf/41fcf27c3613f5681e2d1d2536ef1b1737392625" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/8da1a/8da1a1906210652c2f9bf88ceb87f85c94cd97fa" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/661bc/661bce1b7239dc841ef4ffca0bf09f6e97e1e428" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/32eb5/32eb5daf298de2f0169fa9277f8bf590c9c51e57" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/0c79a/0c79aa2722dbe2ea955483fea0c3cba577e946a6" 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/14513/14513362e21aefe5ed406ba63d8931f40da2c059" alt=""
|
||
|
||
Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/9c897/9c897e8a0aecc174a729cabb8df0e2be380fd1a3" alt=""
|
||
|
||
Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/748fb/748fbe40fe9ccec4839a492c55bbd643f8b6f8b2" alt=""
|
||
|
||
Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/e6fcb/e6fcb4dd40f05aa8cc0d648f778b410410653061" alt=""
|
||
|
||
Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/08b96/08b96a15f349f9f07e443caf98372d9c67198726" alt=""
|
||
|
||
Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/b9cb3/b9cb32cff617f510ad946d4c5b81da30fb7bb2f8" 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/fcde8/fcde8a7b86ba20d24f6439456992d6d988bc843c" alt=""
|
||
|
||
Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/c76bb/c76bbfc7cef55ffaa9ee5bed5a5e76c7c4231099" alt=""
|
||
|
||
Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/acdcb/acdcbdd5b5675bf7c73e14e144c5aada281595a5" alt=""
|
||
|
||
Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/c99bb/c99bb05ce89c94faba853002992975fa3231986c" alt=""
|
||
|
||
Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/52c7c/52c7ccf5b449ad3947bd330ae291510393bc685e" alt=""
|
||
|
||
Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/fb8af/fb8afb012b54587f9698028ff9aed25ad1dff9ef" alt=""
|
||
|
||
Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/d2b0e/d2b0e16176c3de69ff25094374efb5a0ac776593" alt=""
|
||
|
||
Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/5463e/5463e74e8e6e5ed88d595d029cb5903b1983f1b0" alt=""
|
||
|
||
Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/54df9/54df9d1211ff01a0f28c195655b712fb20ea130c" alt=""
|
||
|
||
Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/5078e/5078e680d12471c4047b1e5fef2badc171b122ea" alt=""
|
||
|
||
Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/45aa4/45aa4c0aaea4570ad6f3a7dd6ebf505675abe9c4" alt=""
|
||
|
||
## 4. Reconfigure MCU BSP
|
||
|
||
Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/11a17/11a1728f03ebc05e3ee34acaf64641351938e159" alt=""
|
||
|
||
Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/cf5c4/cf5c43130ee193a28304a327d0e956a0ad3044ff" 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/a93df/a93dfc9a88c6176511af63d740b8954ea51af8ee" alt=""
|
||
data:image/s3,"s3://crabby-images/8c74f/8c74fb8222a31ef10fed8ba02fb940fc15d89750" 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>
|