mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-26 19:17: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/e2692/e2692ae8c075aef56e157924aa370963f5fe5997" alt=""
|
||
|
||
Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/ed2fe/ed2fe2dc49d30a7aeb4f2a1e576439f2645fb623" alt=""
|
||
|
||
Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/7f7f7/7f7f7a726a8655239229cb773408e3059c0fb10d" alt=""
|
||
|
||
Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/a2246/a2246d271c6233d9222701034e5da866580edf7c" alt=""
|
||
|
||
Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/fdd85/fdd859b0b6e48fe2fd2e152b1f8c3a4717d59cae" alt=""
|
||
|
||
Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/c2f2a/c2f2ac2f14a28a3d829e04196aeb3f0847ba4f4d" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/d7dc2/d7dc273859e71834a6658550ad3308a4d5e5e028" alt=""
|
||
|
||
Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/91768/91768b319f2840a172b5ddb4d963a484050e7105" alt=""
|
||
|
||
Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/4f2af/4f2afe49de8709500c24a3b248e0f3a474f06fae" alt=""
|
||
|
||
Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/f0423/f04236d43cc0a26b361b505b6b212a71bb9c3955" alt=""
|
||
|
||
Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/d37f0/d37f0d8132e8da51596abd1db82f2713f4c80330" 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/ed92d/ed92d4da36cb9ec5223ab628c1340d36a80b5941" alt=""
|
||
|
||
Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/b66f6/b66f6383f09b11c2b4d12311209594d7297aae9f" alt=""
|
||
|
||
Enter *rt-thread-xxx/bsp/microchip* directory and copy **same70** folder and rename it to **same70q20**.
|
||
|
||
data:image/s3,"s3://crabby-images/f0cbb/f0cbb210941206642573fa2da60a3e2343bbe81f" alt=""
|
||
|
||
Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/fe8a2/fe8a218a90a8e7eedf2fb271645e94c832f737e5" alt=""
|
||
|
||
Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/eaf2c/eaf2cc24154f53e75903262c52e2c9830ab7c9b0" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/9a543/9a543eb7fa2d9581a6cffe6e208adb7aca96b36e" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/1eb98/1eb98fa388fc79e99ae8fe7c54c9f7cec4042a0a" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/6c5e7/6c5e79b0873980aca79d7882b9c52d47752ab45d" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/ee5b7/ee5b71bfba4aa05189d2ba76daa3a920cf836990" 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/43eed/43eed600aea25c3a5550b87deb51cc790c4b68ce" alt=""
|
||
|
||
Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/feb1b/feb1be6527dfd14205087bbb30affb6b6e38858f" alt=""
|
||
|
||
Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/31547/31547eda838ed2eed1d44564b3f0a2cabffbaee7" alt=""
|
||
|
||
Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/d5981/d5981e4d5923e1b560d6f5a412ca15fb1f6d13a1" alt=""
|
||
|
||
Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/fc86c/fc86c34d30dd426a1bd464ba8aa1e14b37c56984" alt=""
|
||
|
||
Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/f569b/f569ba70e30675358205c7f1dcb2a870d4d272d1" 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/9a06f/9a06fe5146a6637518139f017b40252b455a1e4e" alt=""
|
||
|
||
Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/17ed3/17ed36f427ee98f987f2f9d21526d27dfc68d24a" alt=""
|
||
|
||
Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/f8208/f82083c2986e0d44922b398d30b9d77530bb3bb6" alt=""
|
||
|
||
Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/ea8da/ea8daa8e725a77539f488e07772dcf754912b4d5" alt=""
|
||
|
||
Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/7342f/7342f647f06118d2a5b0ae5f6961efd65ce4d09c" alt=""
|
||
|
||
Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/5cb5d/5cb5d6d6a0a13d4732f52726aaed7e02d125c2b7" alt=""
|
||
|
||
Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/49a83/49a83e587f3366f5c0db30bf2661f7e33f1336c3" alt=""
|
||
|
||
Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/a5f42/a5f4229285759e6a13bbab11a572c6534b732f3c" alt=""
|
||
|
||
Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/bbce3/bbce350d9b63d21971986c8f310e51cb9bd26840" alt=""
|
||
|
||
Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/cdd6d/cdd6dd7266bb1cf32c37ab7994010c72326b47bd" alt=""
|
||
|
||
Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/0e4b4/0e4b48030cf71011e131fe451a3cb42d8649105e" alt=""
|
||
|
||
## 4. Reconfigure MCU BSP
|
||
|
||
Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/e79c2/e79c24a910e82ed09ca83622e8c05fb7c8f3d576" alt=""
|
||
|
||
Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/d2b2c/d2b2c9cc0474572429b200ea3de8eedd6f391a94" 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/09532/095324f2a2f7ad31a3a3fb2f8e1632b0efec977f" alt=""
|
||
data:image/s3,"s3://crabby-images/027a0/027a0ba6317210f13635cf538811589e60942f5f" 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>
|