2022-04-14 10:54:53 +08:00
|
|
|
|
# 1. Microchip BSP Introduction
|
|
|
|
|
|
|
|
|
|
Supported Microchip SAM (ARM Cortex-Mx Core) MCU is as following:
|
|
|
|
|
|
2022-04-27 09:24:56 +08:00
|
|
|
|
## 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
|
|
|
|
|
|
2022-04-14 10:54:53 +08:00
|
|
|
|
## 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/fc011/fc0119db8926afaae30564bf2b53c21d31eef221" alt=""
|
|
|
|
|
|
|
|
|
|
* Input MCU part number and then select device, click CREATE NEW PROJECT.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/da1fd/da1fdbb7d2e20dc77f234be7e4c0d5f1d23c16ec" alt=""
|
|
|
|
|
|
|
|
|
|
* Add STDIO and other driver/middleware to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b8750/b8750628c79d6d41996353788b4d4b214f07eb76" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure STDIO driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8b218/8b21856b82f82ccb414644bc31dd399f275b6ce8" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module clock.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1b677/1b677b4e5a9817e4955460293285591671fc1248" alt=""
|
|
|
|
|
|
|
|
|
|
* Configure CAN module driver.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/46d9b/46d9b2bdabaedc4b61edf774b94f59850c1963fc" alt=""
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/caa67/caa677e35c026354c4c93fab93bc9d3b35ce1941" alt=""
|
|
|
|
|
|
|
|
|
|
* Add LED pin description.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f7c1a/f7c1a4241346a6e8f7ed77a58c683d1ff444b1a7" alt=""
|
|
|
|
|
|
|
|
|
|
* Rename project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a95e3/a95e37b97e65e4d7d62d9c6ae469373201eb84b3" alt=""
|
|
|
|
|
|
|
|
|
|
* Save project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/80c7f/80c7fb69ef5e7772b7925a9a094252ac15304220" alt=""
|
|
|
|
|
|
|
|
|
|
* Export project source code.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c2905/c29056a36462f147806b6ef13d50531efade20cf" 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/1c1d1/1c1d1f9a93e571ca6dac752fd222265355decf7b" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded RT-Thread and SAME70 CAN Example
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/01432/0143213afdf8c9cb60cda9ded13e00a2b13beffb" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter rt-thread-xxx/bsp/microchip directory and copy same70 folder and rename it to same70q20.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/3b8bd/3b8bd48d505cf4cffb8491fcb29e5504f7e9a395" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter same70q20 directory and remove all files except SConscript file.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bdd3c/bdd3cd0907a4fe37ef4e7c52241d8bd3a41bf8c6" alt=""
|
|
|
|
|
|
|
|
|
|
* Copy all files from SAME70 CAN Example to rt-thread-xxx/bsp/microchip/same70q20/bsp.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/bed59/bed59c97ce1ff88ac5c52baa608c049cc2592181" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\rtconfig.py.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/95970/95970270477c0917bc682dae46e8ebdc39a27ade" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\SConscript.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/66d98/66d983ed4c20b62bfb97d172abc96be3b2e65bb6" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\same70q20b_flash.ld.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4b5b9/4b5b969728a826546023aa101151d21c8e321e4b" alt=""
|
|
|
|
|
|
|
|
|
|
* Modify rt-thread-xxx\bsp\microchip\same70q20\bsp\same70b\gcc\gcc\startup_same70q20b.c.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e04d9/e04d9dafdebbfdf8c54f74d85920be10bc7a0ce0" 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/page/download.html>
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b3b79/b3b79efaf6b34f835c00e6d431d95b1f2d186a28" alt=""
|
|
|
|
|
|
|
|
|
|
* Unzip downloaded file and run env.exe.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/95cea/95ceaf38a36283eb69023d327ed76a2f12e130cd" alt=""
|
|
|
|
|
|
|
|
|
|
* Enter your project directory and run scons command to compile it.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5aa09/5aa0926ffba5c91620cb2b3afe8e925b4264bd0d" alt=""
|
|
|
|
|
|
|
|
|
|
* Compile error you may have and proposed solution.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c8836/c883694c660f13b753ee2434fa5b9e992a6fc4e1" alt=""
|
|
|
|
|
|
|
|
|
|
* Fix compiling error
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/5f99d/5f99df07f3b70c1fb8b2d353fb85929332757d63" alt=""
|
|
|
|
|
|
|
|
|
|
* Compiling success
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1fe15/1fe15de7dfc1f1ec8c93e329f560ac6a7f921ae3" 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/dd10a/dd10a866152ddf9d2dd0ca2deb7a5751609473cd" alt=""
|
|
|
|
|
|
|
|
|
|
* Open installed Microchip Studio 7 and open object file for debugging.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/0589f/0589f0da3d4ebf8cf79ab8c16baa54aac0f2eaeb" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose object file, fill project name and select where to save this project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4434d/4434dbc77836fbf872dfd16161508efaae205f48" alt=""
|
|
|
|
|
|
|
|
|
|
* Select the right part number and complete object set up.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/91523/91523d847e7cd18880fc6ee2e0afde2613f16048" alt=""
|
|
|
|
|
|
|
|
|
|
* Object file import complete and you can see related files are linked to project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f389e/f389eae15bcac270c3cb2a1b34bfd5b82ce66cc9" alt=""
|
|
|
|
|
|
|
|
|
|
* Right click the project and choose the debug tools in project propertities setting.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a3bfe/a3bfe3c5416bb1e968a6b9a8e5725ee1cc85940e" alt=""
|
|
|
|
|
|
|
|
|
|
* Choose debugger/programmer and debugger interface - SWD or JTGA.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/4d7d7/4d7d787714c840138f362459e0611e7bb4d39f43" alt=""
|
|
|
|
|
|
|
|
|
|
* Press debugging button and enjoy your debugging journey.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/b8d16/b8d1619d11a9f1a3f4005b09899b4802e92824f8" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging start and you can add breakpoint.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/aea5a/aea5a9a127aa1d43cabab6eb139ed3b54afe27ff" alt=""
|
|
|
|
|
|
|
|
|
|
* Debugging paused at breakpoint and you can monitor local variables at Watch window.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/ade74/ade74d897a93a1e3c363d42734437d49ae58d0e1" alt=""
|
|
|
|
|
|
2022-04-19 14:32:02 +08:00
|
|
|
|
* Debugging message output.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e164a/e164aad53b00f1ee4d84b73e5b162733fcaf2928" alt=""
|
2022-04-14 10:54:53 +08:00
|
|
|
|
|
|
|
|
|
# 4. Reconfigure MCU BSP
|
|
|
|
|
|
|
|
|
|
* Visit <https://start.atmel.com/#> and upload project configuration.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/98a20/98a20fe2dc054c22b0ad6dd2caef7a3e393feeff" alt=""
|
|
|
|
|
|
|
|
|
|
* Now you can reconfigure your project.
|
|
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/56587/56587fbfd2b45cb1f302057dd0fc53525528eab9" 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/9a0b4/9a0b4b122acc95ba35d8cea93aa677d8ffeac5b8" alt=""
|
|
|
|
|
data:image/s3,"s3://crabby-images/f27fb/f27fbb700369ea46ee4d1d18fc0ace29bb19ae2a" 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
|