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/84c32/84c3262f94cea11b6f765987a2be4ee9fe02862a" alt=""
|
||
|
||
Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/96718/967185f0ce30cc8901514cc3f6b99d360b50e09b" alt=""
|
||
|
||
Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/3e5e4/3e5e4e92c11dad2aa52e401b90380924b063ec6d" alt=""
|
||
|
||
Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/6e349/6e34908ad9af6df13740f2ec44626352b9673af4" alt=""
|
||
|
||
Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/be52d/be52d3115690db437bc5d21545adfe9d7dc0ce2c" alt=""
|
||
|
||
Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/e272e/e272eb2356b245e307af19a56fb3def161aab046" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/e4003/e4003b6d32c218b5fa6ad332efe57f61cca9a6ca" alt=""
|
||
|
||
Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/5f24b/5f24bcce458ad6a9e7f143689edab0c19ccb56f4" alt=""
|
||
|
||
Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/a1577/a1577acdad1652f470f375168593e03310b7470b" alt=""
|
||
|
||
Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/ba939/ba9396dce9419bf606e4f7e86a3c8f2e82b875d2" alt=""
|
||
|
||
Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/f2659/f26590fe237be32d2a8bb897e2d1ca090490df93" 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/9705f/9705fae30368869c89d92a4ba1baf8cf035508fb" alt=""
|
||
|
||
Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/31c4a/31c4a57e16e26bbda709377e0e8ec892f10cd625" alt=""
|
||
|
||
Enter *rt-thread-xxx/bsp/microchip* directory and copy **same70** folder and rename it to **same70q20**.
|
||
|
||
data:image/s3,"s3://crabby-images/ee7f3/ee7f37a6461a581e935d3f712caf05a91222d987" alt=""
|
||
|
||
Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/8dddd/8ddddee0725ae986476dfeea339337003183c0f8" alt=""
|
||
|
||
Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/13f5e/13f5edcef9a03057e6ac00cd834aeef2353f90e7" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/90bdf/90bdff1f2db8bf935866dd11e9e97dc8aae567b0" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/85025/85025e076aee90a05b71712e96b141a532809e3c" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/bd3c5/bd3c52035d5316f81b02cd5653cddc5e96a27ccb" alt=""
|
||
|
||
Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/e3158/e315880c7d3e57cd07ee737f9b5ce4ae95d9cd3f" 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/4e272/4e2724ef433318634dec5a41b0ea379e08664ea2" alt=""
|
||
|
||
Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/9552f/9552f299247263ebbe7f559618fe76f72d3321c8" alt=""
|
||
|
||
Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/e374b/e374be270a80bab42185fa1f0b53a054e51af0ca" alt=""
|
||
|
||
Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/d8e3b/d8e3bbf45608415018befa344a53b723574bb0fe" alt=""
|
||
|
||
Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/199c7/199c71a82df140da1b06ef0e6c224b1a661ade03" alt=""
|
||
|
||
Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/aee93/aee93f4c5f9939a1ad01dd41167c80092f537c9f" 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/98bd3/98bd32de566863522c5c24334cee1f20400665b7" alt=""
|
||
|
||
Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/30df9/30df9949c28cdee1f423e926d99eb965e029ec35" alt=""
|
||
|
||
Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/8ab6e/8ab6e603bd7b249b0aecb8c86ce90f8a0061373c" alt=""
|
||
|
||
Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/5c91f/5c91f22a1f7ad227343e081c9d1093e11d3ff283" alt=""
|
||
|
||
Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/26e80/26e8047e509cea897e2d019363a7298f17ca091a" alt=""
|
||
|
||
Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/f8348/f83483f6c2f35bac21615f6bbbcede317dc52102" alt=""
|
||
|
||
Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/31bb3/31bb39c468ed99e9b7cda37d7040b679104a884e" alt=""
|
||
|
||
Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/3d30b/3d30b2ffb043aadc68f4c0ee8b63b9940bbe91a3" alt=""
|
||
|
||
Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/f972b/f972b3ffc8af3ba7f3c2acede12c4fc92b27cd8d" alt=""
|
||
|
||
Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/e8b3e/e8b3e7b70b095c774544e54216973762b000f910" alt=""
|
||
|
||
Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/1e0b8/1e0b8f26d851da9c62abbc17bfc67b8d6643625a" alt=""
|
||
|
||
## 4. Reconfigure MCU BSP
|
||
|
||
Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/72496/724963911e6785b3a1743ecc93b4404d433579cc" alt=""
|
||
|
||
Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/d5621/d5621878165fb30e361b2dacc3bf508f25142700" 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/3ebe6/3ebe64c0aad21f5f96edd1bb5498966fabc895fa" alt=""
|
||
data:image/s3,"s3://crabby-images/00113/00113ba09bd46277ef0e4ca6edf2dda44069f8e5" 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>
|