-
Notifications
You must be signed in to change notification settings - Fork 37
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
419b4ea
commit 617741d
Showing
49 changed files
with
4,366 additions
and
65 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.
Oops, something went wrong.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
# Hands-on: CRC Checksum Generation | ||
|
||
### Introduction | ||
|
||
IAR EWARM provides a way to generate checksum as shown below: | ||
data:image/s3,"s3://crabby-images/b9f9d/b9f9d89b4006848ce5d39469da6fb312217a70fa" alt="" | ||
|
||
How can this be done by using STM32CubeIDE? This hands-on provides an option for you. | ||
|
||
### Steps | ||
|
||
1. Import the reference project. | ||
|
||
2. Build Project | ||
|
||
3. Start Debug session and check result from serial port console as shown below: | ||
data:image/s3,"s3://crabby-images/8136f/8136f905dbfd104d8ba5ad93941dc26371747744" alt="" | ||
|
||
* CRC generated by CRC unit in STM32F746 is 0x872D0D45. | ||
* CRC generated by CRC code running over STM32F746 is also 0x872D0D45. | ||
* Checksum stored in the last word of the first sector is 0xFFFFFFFF which is not aligned with that generated by CRC unit and therefore CRC check fails. This is expected since we have not put any checksum into the HEX/BIN file yet. | ||
|
||
|
||
|
||
4. [Srec_cat](http://srecord.sourceforge.net/download.html) could be used to generate CRC checksum and put it into HEX file. To simplify the process, please put srec_cat.exe into the root of project folder. | ||
|
||
|
||
|
||
5. Right click on project icon and then select "Properties": | ||
data:image/s3,"s3://crabby-images/a214d/a214de380287d52496fc8feefc9440f4b946e6b6" alt="" | ||
|
||
|
||
|
||
6. Type "..\checksum.bat" in Command of Post-build steps: | ||
data:image/s3,"s3://crabby-images/b0b40/b0b409ab5c86ce49e157cebe2c33d6e243262d77" alt="" | ||
|
||
|
||
|
||
7. "Clean Project" and then "Build Project" again and we can see checksum.bat executes correctly without error: | ||
data:image/s3,"s3://crabby-images/fbea3/fbea3dfcd2e24171e7b6b80c756b54223243e502" alt="" | ||
|
||
|
||
|
||
8. Check files under "Debug" folder and **06_F746-DISCO-CRC_SRECORD.hex** generated by checksum.bat is found: | ||
data:image/s3,"s3://crabby-images/08ba6/08ba62a7c780f1d37aa0de21d4d19070fa024c28" alt="" | ||
|
||
|
||
|
||
9. Check the last word of 06_F746-DISCO-CRC_SRECORD.hex by STM32CubeProgrammer. CRC checksum generated by srec_cat and put in the last word of **06_F746-DISCO-CRC_SRECORD.hex** (0x872D9D45) is exactly the same as that by CRC unit of STM32F746 (0x872D9D45). | ||
data:image/s3,"s3://crabby-images/1222c/1222c2b84255bcb5a3bfdb811184eccfe84850a5" alt="" | ||
|
||
|
||
|
||
10. After running the debug session and checking the result in serial port console, we still get CRC check failure. And memory address 0x08007FFC which is supposed to have CRC checksum 0x872D9D45 still contains 0xFFFFFFFF: | ||
data:image/s3,"s3://crabby-images/3b55e/3b55e169acfc2fe3b03e394b2ff75dfb5356562c" alt="" | ||
|
||
|
||
|
||
11. The reason of this failure is due to the fact that **06_F746-DISCO-CRC_SRECORD.hex** (containing CRC checksum) is not programmed when running debug session. We need to assign 06_F746-DISCO-CRC_SRECORD.hex** (containing CRC checksum) to be programmed instead of original **06_F746-DISCO-CRC.elf** (w/o CRC checksum). Please open "Debug Configuration" and make the following change: | ||
|
||
data:image/s3,"s3://crabby-images/ac170/ac170a423e1fb01af7b6dd2f3d5690d526432b3c" alt="" | ||
|
||
|
||
|
||
12. Run debug session again and finally get correct expected result: | ||
|
||
data:image/s3,"s3://crabby-images/03040/0304033a83ba1b381fb082fc9492d91a3e7915cc" alt="" | ||
|
||
|
||
|
||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
arm-none-eabi-objcopy -O ihex 08_F746-DISCO-CRC.elf "08_F746-DISCO-CRC.hex" | ||
srec_cat 08_F746-DISCO-CRC.hex -Intel -fill 0xFF 0x08000000 0x08007FFC -STM32 0x08007FFC -o 08_F746-DISCO-CRC_SRECORD.hex -Intel | ||
C:\ST\STM32CubeIDE_1.0.0\STM32CubeIDE\plugins\com.st.stm32cube.ide.mcu.externaltools.gnu-tools-for-stm32.7-2018-q2-update.win32_1.0.0.201904181610\tools\arm-none-eabi\bin\objcopy.exe -O ihex 06_F746-DISCO-CRC.elf "06_F746-DISCO-CRC.hex" | ||
..\srec_cat.exe 06_F746-DISCO-CRC.hex -Intel -fill 0xFF 0x08000000 0x08007FFC -STM32 0x08007FFC -o 06_F746-DISCO-CRC_SRECORD.hex -Intel |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Oops, something went wrong.