mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-26 01:57:06 +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/8dec5/8dec5331933230e645719328ea780abab79db4de" alt=""
|
||
|
||
Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/3f6f6/3f6f6234e62a91802815055227bddd7ab9c80481" alt=""
|
||
|
||
Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/c2346/c2346b1fe1bcb07b122e30118f691ddf5bceef5e" alt=""
|
||
|
||
Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/722e0/722e09099410574e1e2422e51fabe6aa8c0abe6c" alt=""
|
||
|
||
Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/88bd4/88bd451b773228c605afe2ed6ec8a595a3cf5f94" alt=""
|
||
|
||
Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/06f47/06f47f67b17f24d75c275a8cac327e5459283182" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/59abc/59abc70d527ee628eb1864212d87a99a84ba5743" alt=""
|
||
|
||
Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/8d6db/8d6dba40aef2e95a6dcc634259c49df27bdb7c1c" alt=""
|
||
|
||
Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/18216/182162bc338bad04f8267b985af6e58528b80865" alt=""
|
||
|
||
Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/18e2c/18e2c3f6e70e5a43a44cb879c8691c750da8f41e" alt=""
|
||
|
||
Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/e21ca/e21caa0181d330a90b324d8fcabcda2d4de6ec9c" 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/ffc4a/ffc4a1ebebe1f3a9217ea2f7b52edbf480504f32" alt=""
|
||
|
||
Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/61e29/61e2914d2b182d65f8e3095311e0426636e587ad" alt=""
|
||
|
||
Enter *rt-thread-xxx/bsp/microchip* directory and copy **same70** folder and rename it to **same70q20**.
|
||
|
||
data:image/s3,"s3://crabby-images/716ee/716eef196ebf2c4c1005f3ade12783cebb1b28f1" alt=""
|
||
|
||
Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/db2e1/db2e1ef21c76aa61e8d30f73f255cce2064f2fef" alt=""
|
||
|
||
Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/1a231/1a23188f90c44e861315197fe4f66c9a8391f286" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/3dc2b/3dc2bcba6dfeb2f4e24c31636fa610877348a2a7" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/3ab50/3ab50e5ba44b7eb02a1547456425f859f291500d" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/d17ed/d17edbebbcecb7e1bbdd0f75115350e79100efcd" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/569c6/569c670f1e5d058fa2ce1552cebacb852f2d8a99" 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/a68ca/a68ca7fc1e2d174be5ad9a06b4c799d61682c87e" alt=""
|
||
|
||
Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/71ebb/71ebb340169b3a8a7c04808b867db4cd013ae46c" alt=""
|
||
|
||
Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/905f5/905f5e154e4c867f70db1bed771bf5fa2f1b03fe" alt=""
|
||
|
||
Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/f2ce8/f2ce879c7bf81f3329b3e7272fa84377189aa5be" alt=""
|
||
|
||
Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/2bc13/2bc134836fd55e2416e8503e66c34b4f9fc0d7d9" alt=""
|
||
|
||
Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/2ee89/2ee89c3d200da0486b1234f0a98785431ea861fc" 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/d13ab/d13ab6fa1daffe3359a2efeed7d09d07689cb9e7" alt=""
|
||
|
||
Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/42586/42586bbf45ea34fcd9da95da3db6548542fcacad" alt=""
|
||
|
||
Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/e43e7/e43e778eaa9d0f302a481bb04f7c2054eddc2077" alt=""
|
||
|
||
Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/a5799/a5799c369662b6a4a28e3502631c05e57d2e8c2b" alt=""
|
||
|
||
Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/98fa7/98fa7c23bb831bfc8de051eb0bf0026ceea7be81" alt=""
|
||
|
||
Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/b9cc7/b9cc777c77ae0ddf57e32bde9b95e180deac7b67" alt=""
|
||
|
||
Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/24e7b/24e7ba545a9b3491e2baa6e98a1d18ab12006b43" alt=""
|
||
|
||
Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/55086/5508696411213dcd98d26c906e7531810cc3b908" alt=""
|
||
|
||
Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/87f4d/87f4d9abd2bc99544e2714bdc1b277fcc4fbd3dd" alt=""
|
||
|
||
Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/70549/705496247f2a0a9219f4285e9e56a0cc94101763" alt=""
|
||
|
||
Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/670d5/670d5fba42213e8f84eeccbdda62b81c9add6568" alt=""
|
||
|
||
## 4. Reconfigure MCU BSP
|
||
|
||
Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/d4fc1/d4fc1410d2bdc777b74f2e5ba1d0abcb964e79a9" alt=""
|
||
|
||
Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/c0e20/c0e20bbf1fb2db0806be5eb6302c072421a820fe" 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/39cda/39cda54f6a9d13d30c195e7d2b3fc8eaacba0d4f" alt=""
|
||
data:image/s3,"s3://crabby-images/cdf9d/cdf9daac6539b1c02a4eef7fccee0300a6c2367f" 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>
|