mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-03-03 15:55:28 +08:00
225 lines
6.2 KiB
Markdown
225 lines
6.2 KiB
Markdown
# 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/588e5/588e55c4bf215143d0cacddd05303a19158413ea" alt=""
|
||
|
||
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
||
|
||
data:image/s3,"s3://crabby-images/d5c49/d5c497a48f7b2a08b26e32aff8fd2024c37725e6" alt=""
|
||
|
||
* Add STDIO and other driver/middleware to project.
|
||
|
||
data:image/s3,"s3://crabby-images/8ec63/8ec6318934c08453010260b815f9b4d66911886b" alt=""
|
||
|
||
* Configure STDIO driver.
|
||
|
||
data:image/s3,"s3://crabby-images/fa203/fa203731b212b5e26b579eec0ee05d349d087f63" alt=""
|
||
|
||
* Configure CAN module clock.
|
||
|
||
data:image/s3,"s3://crabby-images/f27f8/f27f8f163745758b1a7eb6acc572b7adc9a82806" alt=""
|
||
|
||
* Configure CAN module driver.
|
||
|
||
data:image/s3,"s3://crabby-images/92440/92440714147ccf8e251ccdc2b901a4a3ceab9b76" alt=""
|
||
|
||
data:image/s3,"s3://crabby-images/38394/38394e15cbe176212ad5e2dee4ccbd13cc7d1e4f" alt=""
|
||
|
||
* Add LED pin description.
|
||
|
||
data:image/s3,"s3://crabby-images/7de1e/7de1e51848b950778d7dee6d0c1c7cc572ef8405" alt=""
|
||
|
||
* Rename project.
|
||
|
||
data:image/s3,"s3://crabby-images/e4506/e45067bdaef4988861b81a8e2e958b99bc4243ff" alt=""
|
||
|
||
* Save project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/d6f25/d6f2580e31b75d583b8ea6397aac00c97e34db0c" alt=""
|
||
|
||
* Export project source code.
|
||
|
||
data:image/s3,"s3://crabby-images/ae268/ae268ff1e9222af229cf105bd3aa6ef002d770b5" 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/023fd/023fd635cf27843f6920dce691652da824116539" alt=""
|
||
|
||
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
||
|
||
data:image/s3,"s3://crabby-images/baec9/baec9de9dab4503841fc41ed254655b69d2c2a14" alt=""
|
||
|
||
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
||
|
||
data:image/s3,"s3://crabby-images/6f710/6f710c6895ab4d336a2c5c768e67cf5f6b7428df" alt=""
|
||
|
||
* Enter same70q20 directory and remove all files except SConscript file.
|
||
|
||
data:image/s3,"s3://crabby-images/07bd9/07bd9ba68b3820ae3054fc9542a09ad0108c6227" alt=""
|
||
|
||
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
||
|
||
data:image/s3,"s3://crabby-images/07209/0720977be9db91981945bbd87ddb33d74b0573ca" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
||
|
||
data:image/s3,"s3://crabby-images/10e76/10e76580aaaf5bf64126b39755f7e940e4618738" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
||
|
||
data:image/s3,"s3://crabby-images/d3d1c/d3d1c47216bd486c877e906de843281f5844c4df" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
||
|
||
data:image/s3,"s3://crabby-images/77b20/77b20428af8066fb1d42cffdad4669443db51d8d" alt=""
|
||
|
||
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
||
|
||
data:image/s3,"s3://crabby-images/8508f/8508fcc645711edcc2fa579f8d5a9939bdb2b5a5" 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/928af/928af6d2f3fd6544981e80ee6f5197e6af2d5a8e" alt=""
|
||
|
||
* Unzip downloaded file and run env.exe.
|
||
|
||
data:image/s3,"s3://crabby-images/6e0c1/6e0c15c7fd74d9282a3cd740967a30ccb90abd84" alt=""
|
||
|
||
* Enter your project directory and run scons command to compile it.
|
||
|
||
data:image/s3,"s3://crabby-images/52754/52754ff04b2a8354b1945673f5c877e1e5fbcd8d" alt=""
|
||
|
||
* Compile error you may have and proposed solution.
|
||
|
||
data:image/s3,"s3://crabby-images/082e4/082e4335b74314a983c370c8acd8df5a73de00e1" alt=""
|
||
|
||
* Fix compiling error
|
||
|
||
data:image/s3,"s3://crabby-images/c8c2d/c8c2d927ca6e9e3bfb1cced9f40e80f347044396" alt=""
|
||
|
||
* Compiling success
|
||
|
||
data:image/s3,"s3://crabby-images/0eb3e/0eb3ecc2277a1207a84ad71ea0d15bee5db52b0e" 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/3bb86/3bb862d3ebb7f3f2661ed8fc19791f75300fc537" alt=""
|
||
|
||
* Open installed Microchip Studio 7 and open object file for debugging.
|
||
|
||
data:image/s3,"s3://crabby-images/02aec/02aec99e7eee3cdddeddca172d4be213dd6277e6" alt=""
|
||
|
||
* Choose object file, fill project name and select where to save this project.
|
||
|
||
data:image/s3,"s3://crabby-images/2206b/2206bc7329f34599c21ec0f095fcbbd68b9e283a" alt=""
|
||
|
||
* Select the right part number and complete object set up.
|
||
|
||
data:image/s3,"s3://crabby-images/e11a6/e11a618305c90de069d93e440f53c97bb4b55895" alt=""
|
||
|
||
* Object file import complete and you can see related files are linked to project.
|
||
|
||
data:image/s3,"s3://crabby-images/54787/547872fa19fe06d5c5f33715f0646b1f732e2fec" alt=""
|
||
|
||
* Right click the project and choose the debug tools in project propertities setting.
|
||
|
||
data:image/s3,"s3://crabby-images/262d2/262d2994795a237cda8341df26255fb6a72db128" alt=""
|
||
|
||
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
||
|
||
data:image/s3,"s3://crabby-images/b1e2b/b1e2b59b362e6b443256754813fa2b498132de49" alt=""
|
||
|
||
* Press debugging button and enjoy your debugging journey.
|
||
|
||
data:image/s3,"s3://crabby-images/323d3/323d39463723bd7f52915ddda6ca7e3fa17e3168" alt=""
|
||
|
||
* Debugging start and you can add breakpoint.
|
||
|
||
data:image/s3,"s3://crabby-images/2e8eb/2e8ebc8bb9f9e3301ceafcb2132966be21002928" alt=""
|
||
|
||
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
||
|
||
data:image/s3,"s3://crabby-images/0f22c/0f22c4e8a7a20c8179f0442f265ed631828de91a" alt=""
|
||
|
||
* Debugging message output.
|
||
|
||
data:image/s3,"s3://crabby-images/fddc8/fddc8a9b0380b636b478321b27d6baff225659f3" alt=""
|
||
|
||
# 4. Reconfigure MCU BSP
|
||
|
||
* Visit <https://start.atmel.com/#> and upload project configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/bb863/bb8634771ab733022d38808c3679d35d7fd6df06" alt=""
|
||
|
||
* Now you can reconfigure your project.
|
||
|
||
data:image/s3,"s3://crabby-images/61cae/61caee55f4963ae97ac2597cdfe0364176c127d4" alt=""
|
||
|
||
|
||
# 5. Microchip SAM MCU BSP configuration and user guide
|
||
|
||
* Please refer to <ASF4 API Reference Manual> for more details
|
||
[ASF4 API Reference Manual](https://ww1.microchip.com/downloads/en/DeviceDoc/50002633B.pdf)
|
||
|
||
## 5.1 SAMC2x/E5x/E70 CAN Driver
|
||
|
||
* CAN driver configuration.
|
||
|
||
data:image/s3,"s3://crabby-images/cf947/cf9473dacc5c439177f8a83918ce665849ae5c13" alt=""
|
||
data:image/s3,"s3://crabby-images/7ad57/7ad57f6b1d7b71357b462ad04bc68ada8dc09185" alt=""
|
||
|
||
* CAN driver user guide - see <ASF4 API Reference Manual.pdf> P121 for more details.
|
||
|
||
* To be continued.
|
||
|
||
# 6. Contact Info
|
||
|
||
- [Kevin Liu](https://github.com/klmchp)
|
||
|
||
* https://github.com/klmchp && kevin.liu.mchp@gmail.com |