; -------------------------------------------------------------------------------- ; @Title: ST STM32F0xx Flash Dialog to program Option Bytes. ; ; @Description: ; Script arguments: ; ; do stm32f0xx-optionbyte [RDP=0|1|NODEBUG] [NRST_STDBY=0|1] [NRST_STOP=0|1] ; [BOOT_SEL=0|1] [RAM_PARITY_CHECK_DIS=0|1] [VDDA_MONITOR=0|1] ; [nBOOT1=0|1] [nBOOT0=0|1] ; [WDG_SW=0|1] [WRP=] [DATA0=] [DATA1=] [RESETDEVICE] ; ; RDP=0|1|NODEBUG is programming read protection option byte ; 0: disables flash read protection ; 1: enables flash read protection ; NODEBUG: no debug ; ; RAM_PARITY_CHECK_DIS=0|1 ; 0: RAM parity check enabled ; 1: RAM parity check disabled ; ; VDDA_MONITOR=0|1 is programming VDDA_MONITOR bit of user option byte ; 0: VDDA power supply supervisor disabled ; 1: VDDA power supply supervisor enabled ; ; BOOT_SEL=0|1 ; 0: BOOT0 signal is defined by nBOOT0 option bit ; 1: BOOT0 signal is defined by BOOT0 pin value (legacy mode) ; Available on STM32F04x devices only. Considered as �1� ; on other devices ; ; NBOOT1=0|1 ; Together with the BOOT0 signal, it selects the device boot mode ; ; NBOOT0=0|1 ; When BOOT_SEL is cleared, nBOOT0 bit defines BOOT0 signal value ; used to select the device boot mode ; ; NRST_STDBY=0|1 is programming nRST_STDBY bit of user option byte ; 0: Reset generated when entering Standby mode ; 1: No reset generated ; ; NRST_STOP=0|1 is programming nRST_STOP bit of user option byte ; 0: Reset generated when entering Stop mode ; 1: No reset generated. ; ; WDG_SW=0|1 is programming WDG_SW bit of user option byte ; 0: Hardware watchdog ; 1: Software watchdog ; ; WRP= is programming flash memory write protection option bytes ; WRP0..WRP3. Bit value 0 activates write protection for dedicated ; pages ; ; DATA0= byte value programmed for user data storage ; ; DATA1= byte value programmed for user data storage ; ; RESETDEVICE reset device and force a reload of the option bytes ; ; Calling the script without argument starts the Option Byte programming ; dialog window. ; ; @Author: WRD ; @Copyright: (C) 1989-2022 Lauterbach GmbH, licensed for use with TRACE32(R) only ; -------------------------------------------------------------------------------- ; $Rev: 10516 $ ; $Id: stm32f0xx-optionbyte.cmm 10516 2022-02-02 11:39:30Z bschroefel $ LOCAL ¶meters ENTRY %LINE ¶meters ; LOCAL macros used as script global macros LOCAL &FlashRegBase ; Flash controller base address LOCAL &FlashSize ; Flash size LOCAL &OptionByteBase ; Option byte base address LOCAL &WrpBits ; Number of Write Protect Bits LOCAL &PageSize ; Page size LOCAL &WrpGranularity ; Write protection granularity &FlashRegBase="tbd" &FlashSize=0x0 &PageSize=0x0 &OptionByteBase="tbd" &WrpBits=0. &WrpGranularity=0x1000 ; Macros for the Option Bytes LOCAL &OptByte_RDP LOCAL &OptByte_USER LOCAL &OptByte_Data0 LOCAL &OptByte_Data1 LOCAL &OptByte_WRP0 LOCAL &OptByte_WRP1 LOCAL &OptByte_WRP2 LOCAL &OptByte_WRP3 &OptByte_RDP=0xAA &OptByte_USER=0xFF &OptByte_Data0=0xFF &OptByte_Data1=0xFF &OptByte_WRP0=0xFF &OptByte_WRP1=0xFF &OptByte_WRP2=0xFF &OptByte_WRP3=0xFF ; Look for any opened STM32F0xx dialog windows and close them WHILE DIALOG.EXIST(CHK_WRP_0x0) DIALOG.END ; Checking CPU selection IF !CPUIS(STM32F0*) ( SYStem.RESet SYStem.CPU STM32F0* ) ; Check system mode IF SYStem.MODE()<5 SYStem.Up ; Setup configuration for CPU derivative IF CPUIS("STM32F0???4") ( &FlashSize=0x4000 &PageSize=0x400 ) ELSE IF CPUIS("STM32F0???6") ( &FlashSize=0x8000 &PageSize=0x400 ) ELSE IF CPUIS("STM32F0???8") ( &FlashSize=0x10000 IF CPUIS("STM32F07??8") &PageSize=0x800 ELSE &PageSize=0x400 ) ELSE IF CPUIS("STM32F0???B") ( &FlashSize=0x20000 &PageSize=0x800 ) ELSE IF CPUIS("STM32F0???C") ( &FlashSize=0x40000 &PageSize=0x800 ) ELSE ( PRINT %ERROR "FLASH size of CPU type is unknown" ENDDO ) ; Calculate number of write protect bits &WrpBits=&FlashSize/&WrpGranularity IF &WrpBits==64. ; 256 kByte device &WrpBits=32. IF &WrpBits>32. ( PRINT %ERROR "FLASH write protection granularity problem, please request an update" ENDDO ) IF &WrpBits==0.||&FlashSize==0. ( DIALOG.OK SYStem.CPU()+" is not supported by the script" ENDDO ) ELSE ( &FlashRegBase="D:0x40022000" &OptionByteBase="D:0x1FFFF800" ) ; Parse script arguments IF "¶meters"=="" ( GOSUB OptionByteDialog ) ELSE ( LOCAL ¶m_RDP ¶m_nRST_STDBY ¶m_nRST_STOP ¶m_WDG_SW LOCAL ¶m_WRP ¶m_DATA0 ¶m_DATA1 ¶m_resetDevice LOCAL ¶m_VDDA_MONITOR ¶m_RAM_PARITY_CHECK_DIS LOCAL ¶m_BOOT_SEL ¶m_nBOOT0 ¶m_nBOOT1 LOCAL &programFlash ¶m_RDP=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"RDP=","") ¶m_nRST_STDBY=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"NRST_STDBY=","") ¶m_nRST_STOP=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"NRST_STOP=","") ¶m_WDG_SW=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"WDG_SW=","") ¶m_WRP=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"WRP=","") ¶m_DATA0=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"DATA0=","") ¶m_DATA1=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"DATA1=","") ¶m_resetDevice=(STRing.SCAN(STRing.UPpeR("¶meters"),"RESETDEVICE",0)!=-1) ¶m_VDDA_MONITOR=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"VDDA_MONITOR=","") ¶m_RAM_PARITY_CHECK_DIS=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"RAM_PARITY_CHECK_DIS=","") ¶m_BOOT_SEL=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"BOOT_SEL=","") ¶m_nBOOT0=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"NBOOT0=","") ¶m_nBOOT1=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"NBOOT1=","") &programFlash=FALSE() GOSUB ReadOptionBytes IF "¶m_RDP"!="" ( IF "¶m_RDP"=="0" &OptByte_RDP=0xAA ELSE IF "¶m_RDP"=="1" &OptByte_RDP=0x00 ELSE IF "¶m_RDP"=="NODEBUG" &OptByte_RDP=0xCC ELSE ( PRINT %ERROR "Illegal parameter RDP="+"¶m_RDP" ENDDO ) &programFlash=TRUE() ) IF CPUIS("STM32F04*")||CPUIS("STM32F09*") ( IF "¶m_BOOT_SEL"!="" ( IF "¶m_BOOT_SEL"=="1" &OptByte_USER=&OptByte_USER|0x80 ELSE IF "¶m_BOOT_SEL"=="0" &OptByte_USER=&OptByte_USER&0x7F ELSE ( PRINT %ERROR "Illegal parameter BOOT_SEL="+"¶m_BOOT_SEL" ENDDO ) &programFlash=TRUE() ) ) IF "¶m_RAM_PARITY_CHECK_DIS"!="" ( IF "¶m_RAM_PARITY_CHECK_DIS"=="1" &OptByte_USER=&OptByte_USER|0x40 ELSE IF "¶m_RAM_PARITY_CHECK_DIS"=="0" &OptByte_USER=&OptByte_USER&0xBF ELSE ( PRINT %ERROR "Illegal parameter RAM_PARITY_CHECK_DIS="+"¶m_RAM_PARITY_CHECK_DIS" ENDDO ) &programFlash=TRUE() ) IF "¶m_VDDA_MONITOR"!="" ( IF "¶m_VDDA_MONITOR"=="1" &OptByte_USER=&OptByte_USER|0x20 ELSE IF "¶m_VDDA_MONITOR"=="0" &OptByte_USER=&OptByte_USER&0xDF ELSE ( PRINT %ERROR "Illegal parameter VDDA_MONITOR="+"¶m_VDDA_MONITOR" ENDDO ) &programFlash=TRUE() ) IF "¶m_nBOOT1"!="" ( IF "¶m_nBOOT1"=="1" &OptByte_USER=&OptByte_USER|0x10 ELSE IF "¶m_nBOOT1"=="0" &OptByte_USER=&OptByte_USER&0xEF ELSE ( PRINT %ERROR "Illegal parameter NBOOT1="+"¶m_nBOOT1" ENDDO ) &programFlash=TRUE() ) IF CPUIS("STM32F04*")||CPUIS("STM32F09*") ( IF "¶m_nBOOT0"!="" ( IF "¶m_nBOOT0"=="1" &OptByte_USER=&OptByte_USER|0x08 ELSE IF "¶m_nBOOT0"=="0" &OptByte_USER=&OptByte_USER&0xF7 ELSE ( PRINT %ERROR "Illegal parameter NBOOT0="+"¶m_nBOOT0" ENDDO ) &programFlash=TRUE() ) ) IF "¶m_nRST_STDBY"!="" ( IF "¶m_nRST_STDBY"=="1" &OptByte_USER=&OptByte_USER|0x04 ELSE IF "¶m_nRST_STDBY"=="0" &OptByte_USER=&OptByte_USER&0xFB ELSE ( PRINT %ERROR "Illegal parameter NRST_STDBY="+"¶m_nRST_STDBY" ENDDO ) &programFlash=TRUE() ) IF "¶m_nRST_STOP"!="" ( IF "¶m_nRST_STOP"=="1" &OptByte_USER=&OptByte_USER|0x02 ELSE IF "¶m_nRST_STOP"=="0" &OptByte_USER=&OptByte_USER&0xFD ELSE ( PRINT %ERROR "Illegal parameter NRST_STOP="+"¶m_nRST_STOP" ENDDO ) &programFlash=TRUE() ) IF "¶m_WDG_SW"!="" ( IF "¶m_WDG_SW"=="1" &OptByte_USER=&OptByte_USER|0x01 ELSE IF "¶m_WDG_SW"=="0" &OptByte_USER=&OptByte_USER&0xFE ELSE ( PRINT %ERROR "Illegal parameter WDG_SW="+"¶m_WDG_SW" ENDDO ) &programFlash=TRUE() ) IF "¶m_WRP"!="" ( &OptByte_WRP0=¶m_WRP&0xFF IF &WrpBits>8. &OptByte_WRP1=(¶m_WRP>>8.)&0xFF IF &WrpBits>16. &OptByte_WRP2=(¶m_WRP>>16.)&0xFF IF &WrpBits>24. &OptByte_WRP3=(¶m_WRP>>24.)&0xFF &programFlash=TRUE() ) IF "¶m_DATA0"!="" ( &OptByte_Data0=¶m_DATA0&0xFF &programFlash=TRUE() ) IF "¶m_DATA1"!="" ( &OptByte_Data1=¶m_DATA1&0xFF &programFlash=TRUE() ) ; Program option bytes into flash IF &programFlash GOSUB ProgramOptionBytes ; Reset device to activate programmed option bytes IF ¶m_resetDevice GOSUB ResetDevice ) ENDDO ; -------------------------------------------------------------------------------- ; NVM bit programming dialog window OptionByteDialog: LOCAL &WRP_0x0_pages &WRP_0x1_pages &WRP_0x2_pages &WRP_0x3_pages LOCAL &WRP_0x4_pages &WRP_0x5_pages &WRP_0x6_pages &WRP_0x7_pages LOCAL &WRP_0x8_pages &WRP_0x9_pages &WRP_0xA_pages &WRP_0xB_pages LOCAL &WRP_0xC_pages &WRP_0xD_pages &WRP_0xE_pages &WRP_0xF_pages LOCAL &WRP_0x10_pages &WRP_0x11_pages &WRP_0x12_pages &WRP_0x13_pages LOCAL &WRP_0x14_pages &WRP_0x15_pages &WRP_0x16_pages &WRP_0x17_pages LOCAL &WRP_0x18_pages &WRP_0x19_pages &WRP_0x1A_pages &WRP_0x1B_pages LOCAL &WRP_0x1C_pages &WRP_0x1D_pages &WRP_0x1E_pages &WRP_0x1F_pages IF (&WrpGranularity/&PageSize)==2. ( &WRP_0x0_pages="0--1" &WRP_0x1_pages="2--3" &WRP_0x2_pages="4--5" &WRP_0x3_pages="6--7" IF &FlashSize>0x4000 ( &WRP_0x4_pages="8--9" &WRP_0x5_pages="10--11" &WRP_0x6_pages="12--13" &WRP_0x7_pages="14--15" ) IF &FlashSize>0x8000 ( &WRP_0x8_pages="16--17" &WRP_0x9_pages="18--19" &WRP_0xA_pages="20--21" &WRP_0xB_pages="22--23" &WRP_0xC_pages="24--25" &WRP_0xD_pages="26--27" &WRP_0xE_pages="28--29" &WRP_0xF_pages="30--31" ) IF &FlashSize>0x10000 ( &WRP_0x10_pages="32--33" &WRP_0x11_pages="34--35" &WRP_0x12_pages="36--37" &WRP_0x13_pages="38--39" &WRP_0x14_pages="40--41" &WRP_0x15_pages="42--43" &WRP_0x16_pages="44--45" &WRP_0x17_pages="46--47" &WRP_0x18_pages="48--49" &WRP_0x19_pages="50--51" &WRP_0x1A_pages="52--53" &WRP_0x1B_pages="54--55" &WRP_0x1C_pages="56--57" &WRP_0x1D_pages="58--59" &WRP_0x1E_pages="60--61" ) IF &FlashSize==0x20000 &WRP_0x1F_pages="62--63" ELSE IF &FlashSize==0x40000 &WRP_0x1F_pages="62--127" ELSE ( PRINT %ERROR "FLASH write protection pages for WRP bit 31 not defined" ENDDO ) ) ELSE ( &WRP_0x0_pages="0--3" &WRP_0x1_pages="4--7" &WRP_0x2_pages="8--11" &WRP_0x3_pages="12--15" IF &FlashSize>0x4000 ( &WRP_0x4_pages="16--19" &WRP_0x5_pages="20--23" &WRP_0x6_pages="24--27" &WRP_0x7_pages="28--31" ) IF &FlashSize>0x8000 ( &WRP_0x8_pages="32--35" &WRP_0x9_pages="36--39" &WRP_0xA_pages="40--43" &WRP_0xB_pages="44--47" &WRP_0xC_pages="48--51" &WRP_0xD_pages="52--55" &WRP_0xE_pages="56--59" &WRP_0xF_pages="60--63" ) IF &FlashSize>0x10000 ( &WRP_0x10_pages="64--67" &WRP_0x11_pages="68--71" &WRP_0x12_pages="72--75" &WRP_0x13_pages="76--79" &WRP_0x14_pages="80--83" &WRP_0x15_pages="84--87" &WRP_0x16_pages="88--91" &WRP_0x17_pages="92--95" &WRP_0x18_pages="96--99" &WRP_0x19_pages="100--103" &WRP_0x1A_pages="104--107" &WRP_0x1B_pages="108--111" &WRP_0x1C_pages="112--115" &WRP_0x1D_pages="116--119" &WRP_0x1E_pages="120--123" &WRP_0x1F_pages="124--127" ) ) ; Creating the main dialog. (& after DIALOG command must be in first column! WinPOS 50. 5. 69. 25. DIALOG.view (& HEADER SYStem.CPU()+" option bytes" POS 1. 0. 67. 9. BOX "Write protected flash pages" POS 3. 2. 7. 1. CHK_WRP_0x0: CHECKBOX "&WRP_0x0_pages" "" POS 11. 2. 7. 1. CHK_WRP_0x1: CHECKBOX "&WRP_0x1_pages" "" POS 19. 2. 7. 1. CHK_WRP_0x2: CHECKBOX "&WRP_0x2_pages" "" POS 27. 2. 7. 1. CHK_WRP_0x3: CHECKBOX "&WRP_0x3_pages" "" POS 35. 2. 7. 1. CHK_WRP_0x4: CHECKBOX "&WRP_0x4_pages" "" POS 43. 2. 7. 1. CHK_WRP_0x5: CHECKBOX "&WRP_0x5_pages" "" POS 51. 2. 7. 1. CHK_WRP_0x6: CHECKBOX "&WRP_0x6_pages" "" POS 59. 2. 7. 1. CHK_WRP_0x7: CHECKBOX "&WRP_0x7_pages" "" POS 3. 3. 7. 1. CHK_WRP_0x8: CHECKBOX "&WRP_0x8_pages" "" POS 11. 3. 7. 1. CHK_WRP_0x9: CHECKBOX "&WRP_0x9_pages" "" POS 19. 3. 7. 1. CHK_WRP_0xA: CHECKBOX "&WRP_0xA_pages" "" POS 27. 3. 7. 1. CHK_WRP_0xB: CHECKBOX "&WRP_0xB_pages" "" POS 35. 3. 7. 1. CHK_WRP_0xC: CHECKBOX "&WRP_0xC_pages" "" POS 43. 3. 7. 1. CHK_WRP_0xD: CHECKBOX "&WRP_0xD_pages" "" POS 51. 3. 7. 1. CHK_WRP_0xE: CHECKBOX "&WRP_0xE_pages" "" POS 59. 3. 7. 1. CHK_WRP_0xF: CHECKBOX "&WRP_0xF_pages" "" POS 3. 4. 7. 1. CHK_WRP_0x10: CHECKBOX "&WRP_0x10_pages" "" POS 11. 4. 7. 1. CHK_WRP_0x11: CHECKBOX "&WRP_0x11_pages" "" POS 19. 4. 7. 1. CHK_WRP_0x12: CHECKBOX "&WRP_0x12_pages" "" POS 27. 4. 7. 1. CHK_WRP_0x13: CHECKBOX "&WRP_0x13_pages" "" POS 35. 4. 7. 1. CHK_WRP_0x14: CHECKBOX "&WRP_0x14_pages" "" POS 43. 4. 7. 1. CHK_WRP_0x15: CHECKBOX "&WRP_0x15_pages" "" POS 51. 4. 7. 1. CHK_WRP_0x16: CHECKBOX "&WRP_0x16_pages" "" POS 59. 4. 7. 1. CHK_WRP_0x17: CHECKBOX "&WRP_0x17_pages" "" POS 3. 5. 7. 1. CHK_WRP_0x18: CHECKBOX "&WRP_0x18_pages" "" POS 11. 5. 7. 1. CHK_WRP_0x19: CHECKBOX "&WRP_0x19_pages" "" POS 19. 5. 7. 1. CHK_WRP_0x1A: CHECKBOX "&WRP_0x1A_pages" "" POS 27. 5. 7. 1. CHK_WRP_0x1B: CHECKBOX "&WRP_0x1B_pages" "" POS 35. 5. 7. 1. CHK_WRP_0x1C: CHECKBOX "&WRP_0x1C_pages" "" POS 43. 5. 7. 1. CHK_WRP_0x1D: CHECKBOX "&WRP_0x1D_pages" "" POS 51. 5. 7. 1. CHK_WRP_0x1E: CHECKBOX "&WRP_0x1E_pages" "" POS 59. 5. 7. 1. CHK_WRP_0x1F: CHECKBOX "&WRP_0x1F_pages" "" POS 3. 7. 9. 1. BUTTON "Select All" "GOSUB WRPSelectAll" POS 13. 7. 9. 1. BUTTON "Deselect All" "GOSUB WRPDeselectAll" POS 1. 9. 67. 4. BOX "Read protection option byte" POS 3. 11. 20. 1. CHSB_RDP.OFF: CHOOSEBOX "no read protection" "" POS 24. 11. 20. 1. CHSB_RDP.ON: CHOOSEBOX "read protection" "" POS 45. 11. 20. 1. CHSB_RDP.NODEBUG: CHOOSEBOX "no debug" "GOSUB SelectNoDebug" POS 1. 13. 67. 7. BOX "User option byte" POS 3. 15. 24. 1. CHSB_BOOTSEL.OPT: CHOOSEBOX "BOOT0 is nBOOT option bit" "" CHSB_BOOTSEL.PIN: CHOOSEBOX "BOOT0 is BOOT0 pin" "" POS 29. 15. 15. 1. CHK_NBOOT0: CHECKBOX "nBOOT0 is main flash" "" POS 45. 15. 22. 1. CHSB_NBOOT1.SYSMEM: CHOOSEBOX "nBOOT1 is system memory" "" CHSB_NBOOT1.SRAM: CHOOSEBOX "nBOOT1 is embedded SRAM" "" POS 3. 17. 24. 1. CHK_RST_STDBY: CHECKBOX "Reset when entering Standby mode" "" POS 3. 18. 24. 1. CHK_RST_STOP: CHECKBOX "Reset when entering Stop mode" "" POS 29. 17. 15. 1. CHSB_WDG.HW: CHOOSEBOX "Hardware watchdog" "" CHSB_WDG.SW: CHOOSEBOX "Software watchdog" "" POS 45. 17. 22. 1. CHK_VDDA: CHECKBOX "VDDA power supply supervisor enabled" "" POS 45. 18. 22. 1. CHK_RAM_PARITY_CHECK_DIS: CHECKBOX "RAM Parity Check disabled" "" POS 1. 20. 67. 4. BOX "User data bytes" POS 3. 22. 7. 1. TEXT "Data0" POS 10. 22. 6. 1. EDIT_DATA0: EDIT "" "GOSUB CheckDatax 0" POS 27. 22. 7. 1. TEXT "Data1" POS 34. 22. 6. 1. EDIT_DATA1: EDIT "" "GOSUB CheckDatax 1" POS 1. 24. 10. 1. BUTTON "Program flash" "GOSUB ProgramFlashSettings" POS 20. 24. 10. 1. BUTTON "Reset device" "GOSUB ActivateFlashSettings" POS 39. 24. 10. 1. BUTTON "Refresh" "GOSUB UpdateWindowFromFlashContents" POS 58. 24. 10. 1. BUTTON "Exit" "CONTinue" CLOSE "CONTinue" ) ; Disable/Enable the check boxes GOSUB UpdateWindowFromFlashType GOSUB UpdateWindowFromFlashContents STOP DIALOG.END ENDDO SelectNoDebug: LOCAL &result IF &OptByte_RDP!=0xCC ( GOSUB QueryNoDebug ENTRY &result IF !&result ( IF &OptByte_RDP==0xAA DIALOG.Set CHSB_RDP.OFF ELSE IF &OptByte_RDP==0xCC DIALOG.Set CHSB_RDP.NODEBUG ELSE DIALOG.Set CHSB_RDP.ON ) ) RETURN ; -------------------------------------------------------------------------------- ; Lock not available write protection bit fields UpdateWindowFromFlashType: LOCAL &bitnum &bitnum=31., WHILE &bitnum>=&WrpBits ( LOCAL &fieldname &fieldname="CHK_WRP_0x"+FORMAT.HEX(1.,&bitnum) DIALOG.Disable &fieldname &bitnum=&bitnum-1. ) IF !CPUIS("STM32F04*")&&!CPUIS("STM32F09*") ( DIALOG.Disable CHSB_BOOTSEL.OPT DIALOG.Disable CHSB_BOOTSEL.PIN DIALOG.Disable CHK_NBOOT0 ) RETURN ; -------------------------------------------------------------------------------- ; Read out option bytes and set dialog entries UpdateWindowFromFlashContents: GOSUB ReadOptionBytes ; Get protection option bits LOCAL &bitnum &bytenum &bitindex &bitnum=0. &bytenum=0. &bitindex=0. WHILE &bitnum<&WrpBits ( LOCAL &fieldname LOCAL ®name ®val &fieldname="CHK_WRP_0x"+FORMAT.HEX(1.,&bitnum) ®name="&"+"OptByte_WRP"+FORMAT.Decimal(1.,&bytenum) &®val=®name IF ((®val)&(1.<<&bitindex))!=0 DIALOG.Set &fieldname " " ELSE DIALOG.Set &fieldname "" &bitnum=&bitnum+1. &bitindex=&bitindex+1. IF &bitindex>=8. ( &bytenum=&bytenum+1. &bitindex=0. ) ) ; Get read protection IF &OptByte_RDP==0xAA DIALOG.Set CHSB_RDP.OFF ELSE IF &OptByte_RDP==0xCC DIALOG.Set CHSB_RDP.NODEBUG ELSE DIALOG.Set CHSB_RDP.ON ; Get user option byte IF (&OptByte_USER&0x01)!=0 DIALOG.Set CHSB_WDG.SW ELSE DIALOG.Set CHSB_WDG.HW IF (&OptByte_USER&0x02)!=0 DIALOG.Set CHK_RST_STOP "OFF" ELSE DIALOG.Set CHK_RST_STOP "ON" IF (&OptByte_USER&0x04)!=0 DIALOG.Set CHK_RST_STDBY "OFF" ELSE DIALOG.Set CHK_RST_STDBY "ON" IF (&OptByte_USER&0x08)!=0 DIALOG.Set CHK_NBOOT0 "ON" ELSE DIALOG.Set CHK_NBOOT0 "OFF" IF (&OptByte_USER&0x10)!=0 DIALOG.Set CHSB_NBOOT1.SYSMEM ELSE DIALOG.Set CHSB_NBOOT1.SRAM IF (&OptByte_USER&0x20)!=0 DIALOG.Set CHK_VDDA "ON" ELSE DIALOG.Set CHK_VDDA "OFF" IF (&OptByte_USER&0x40)!=0 DIALOG.Set CHK_RAM_PARITY_CHECK_DIS "ON" ELSE DIALOG.Set CHK_RAM_PARITY_CHECK_DIS "OFF" IF (&OptByte_USER&0x80)!=0 DIALOG.Set CHSB_BOOTSEL.PIN ELSE DIALOG.Set CHSB_BOOTSEL.OPT ; Get user data bytes DIALOG.Set EDIT_DATA0 "0x"+FORMAT.HEX(2.,&OptByte_Data0) DIALOG.Set EDIT_DATA1 "0x"+FORMAT.HEX(2.,&OptByte_Data1) RETURN ; -------------------------------------------------------------------------------- ; Select all EEFC sector lock bits WRPSelectAll: LOCAL &bitnum &bitnum=0. WHILE &bitnum<&WrpBits ( LOCAL &fieldname &fieldname="CHK_WRP_0x"+FORMAT.HEX(1.,&bitnum) DIALOG.Set &fieldname "" &bitnum=&bitnum+1. ) RETURN ; -------------------------------------------------------------------------------- ; Deselect all EEFC sector lock bits WRPDeselectAll: LOCAL &bitnum &bitnum=0. WHILE &bitnum<&WrpBits ( LOCAL &fieldname &fieldname="CHK_WRP_0x"+FORMAT.HEX(1.,&bitnum) DIALOG.Set &fieldname " " &bitnum=&bitnum+1. ) RETURN ; -------------------------------------------------------------------------------- ; Check user data value CheckDatax: LOCAL &dataNr ENTRY &dataNr LOCAL &data ®name &data=DIALOG.STRing(EDIT_DATA&dataNr) ®name="&"+"OptByte_WRP"+FORMAT.Decimal(1.,&dataNr) &&origdata=®name LOCAL &error &error=0 ON.ERROR GOSUB ( &error=1 RETURN ) &data="0x"+FORMAT.HEX(1.,&data) ON.ERROR IF &error!=0 ( DIALOG.OK "Data must be a 8-bit unsigned numeric value!" DIALOG.Set EDIT_DATA&dataNr "&origdata" ) ELSE ( Eval &data IF EVAL()>0xFF||EVAL()<0x00 ( DIALOG.OK "Data is out of range!" "Data must be a 8-bit unsigned numeric value" DIALOG.Set EDIT_DATA&dataNr "&origdata" ) ELSE ( &data="0x"+FORMAT.HEX(2.,&data) DIALOG.Set EDIT_DATA&dataNr "&data" ) ) RETURN QueryNoDebug: LOCAL &result DIALOG.YESNO "Are you really sure you want to disable DEBUG mode?" "Read protection level 2 cannot be removed at all:" "I T I S A N I R R E V E R S I B L E O P E R A T I O N !" ENTRY &result RETURN &result ; -------------------------------------------------------------------------------- ; Programming Option Bytes ProgramFlashSettings: LOCAL &result LOCAL &error LOCAL §orlockbit ; Set write protection option bytes LOCAL &bitnum &wrpval &bitnum=0. &wrpval=0xFFFFFFFF WHILE &bitnum<&WrpBits ( LOCAL &fieldname &fieldname="CHK_WRP_0x"+FORMAT.HEX(1.,&bitnum) IF DIALOG.BOOLEAN(&fieldname) &wrpval=(&wrpval)&(~(0x1<<&bitnum)) &bitnum=&bitnum+1. ) &OptByte_WRP0=&wrpval&0xFF &OptByte_WRP1=(&wrpval>>8.)&0xFF &OptByte_WRP2=(&wrpval>>16.)&0xFF &OptByte_WRP3=(&wrpval>>24.)&0xFF ; Set read protection option byte IF DIALOG.BOOLEAN("CHSB_RDP.OFF") &OptByte_RDP=0xAA ELSE IF DIALOG.BOOLEAN("CHSB_RDP.NODEBUG") ( LOCAL &result GOSUB QueryNoDebug ENTRY &result IF &result &OptByte_RDP=0xCC ELSE ( PRINT %ERROR "Option byte programming aborted" RETURN ) ) ELSE &OptByte_RDP=0x00 ; Set user option byte IF DIALOG.BOOLEAN(CHSB_WDG.SW) &OptByte_USER=&OptByte_USER|0x01 ELSE &OptByte_USER=&OptByte_USER&0xFE IF !DIALOG.BOOLEAN("CHK_RST_STOP") &OptByte_USER=&OptByte_USER|0x02 ELSE &OptByte_USER=&OptByte_USER&0xFD IF !DIALOG.BOOLEAN("CHK_RST_STDBY") &OptByte_USER=&OptByte_USER|0x04 ELSE &OptByte_USER=&OptByte_USER&0xFB IF DIALOG.BOOLEAN("CHK_NBOOT0")||(!CPUIS("STM32F04*")&&!CPUIS("STM32F09*")) &OptByte_USER=&OptByte_USER|0x08 ELSE &OptByte_USER=&OptByte_USER&0xF7 IF DIALOG.BOOLEAN(CHSB_NBOOT1.SYSMEM) &OptByte_USER=&OptByte_USER|0x10 ELSE &OptByte_USER=&OptByte_USER&0xEF IF DIALOG.BOOLEAN("CHK_VDDA") &OptByte_USER=&OptByte_USER|0x20 ELSE &OptByte_USER=&OptByte_USER&0xDF IF DIALOG.BOOLEAN("CHK_RAM_PARITY_CHECK_DIS") &OptByte_USER=&OptByte_USER|0x40 ELSE &OptByte_USER=&OptByte_USER&0xBF IF DIALOG.BOOLEAN(CHSB_BOOTSEL.PIN)||(!CPUIS("STM32F04*")&&!CPUIS("STM32F09*")) &OptByte_USER=&OptByte_USER|0x80 ELSE &OptByte_USER=&OptByte_USER&0x7F ; Set user data bytes &OptByte_Data0=DIALOG.STRing(EDIT_DATA0) &OptByte_Data1=DIALOG.STRing(EDIT_DATA1) ; Program into option byte flash section GOSUB ProgramOptionBytes RETURN ; -------------------------------------------------------------------------------- ; Activate programmed flash settings by resetting device ActivateFlashSettings: GOSUB ResetDevice GOSUB UpdateWindowFromFlashContents RETURN ; -------------------------------------------------------------------------------- ; Reset device and force a reload of the option bytes ResetDevice: IF !SYStem.Up() SYStem.Up ; Unlock the Flash Program Erase controller Data.Set &FlashRegBase+0x04 %Long 0x45670123 // FLASH->KEYR = FLASH_KEY1; Data.Set &FlashRegBase+0x04 %Long 0xCDEF89AB // FLASH->KEYR = FLASH_KEY2; ; Authorize the small information block programming Data.Set &FlashRegBase+0x08 %Long 0x45670123 // FLASH->OPTKEYR = FLASH_KEY1; Data.Set &FlashRegBase+0x08 %Long 0xCDEF89AB // FLASH->OPTKEYR = FLASH_KEY2; ON ERROR CONTinue Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)|0x00002000 //Execute OBL_LAUNCH; ON ERROR inherit SYStem.Up RETURN ; -------------------------------------------------------------------------------- ; Read option byte values out of flash ReadOptionBytes: LOCAL &tmp &OptByte_WRP0=Data.Long(&FlashRegBase+0x20)&0xFF &OptByte_WRP1=(Data.Long(&FlashRegBase+0x20)>>8.)&0xFF &OptByte_WRP2=(Data.Long(&FlashRegBase+0x20)>>16.)&0xFF &OptByte_WRP3=(Data.Long(&FlashRegBase+0x20)>>24.)&0xFF &tmp=Data.Long(&FlashRegBase+0x1C) IF (&tmp&0x6)==0x6 &OptByte_RDP=0xCC ELSE IF (&tmp&0x6)==0x2 &OptByte_RDP=0x0 ELSE &OptByte_RDP=0xAA &OptByte_Data0=(&tmp>>16.)&0xFF &OptByte_Data1=(&tmp>>24.)&0xFF &OptByte_USER=(&tmp>>8.)&0xFF RETURN ; -------------------------------------------------------------------------------- ; Program option bytes ProgramOptionBytes: LOCAL &locked &locked=Data.Long(&FlashRegBase+0x10)&0x80 // locked = FLASH->CR & CR_LOCK_Set; ; Unlock the Flash Program Erase controller Data.Set &FlashRegBase+0x04 %Long 0x45670123 // FLASH->KEYR = FLASH_KEY1; Data.Set &FlashRegBase+0x04 %Long 0xCDEF89AB // FLASH->KEYR = FLASH_KEY2; ; Clear All pending flags Data.Set &FlashRegBase+0x0C %Long 0x00000035 // FLASH->SR = (FLASH_FLAG_BSY | FLASH_FLAG_EOP | FLASH_FLAG_PGERR | FLASH_FLAG_WRPRTERR); ; Wait for last operation to be completed IF (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // if ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( PRINT %ERROR "Flash memory interface busy, operation aborted" RETURN ) ; Authorize the small information block programming Data.Set &FlashRegBase+0x08 %Long 0x45670123 // FLASH->OPTKEYR = FLASH_KEY1; Data.Set &FlashRegBase+0x08 %Long 0xCDEF89AB // FLASH->OPTKEYR = FLASH_KEY2; ; erase the option bytes Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)|0x00000020 // FLASH->CR |= CR_OPTER_Set; Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)|0x00000040 // FLASH->CR |= CR_STRT_Set; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; if the erase operation is completed, disable the OPTER Bit Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)&0x00001FDF // FLASH->CR &= CR_OPTER_Reset; ; Enable the Option Bytes Programming operation Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)|0x00000010 // FLASH->CR |= CR_OPTPG_Set; ; Program read protection Option Byte */ Data.Set &OptionByteBase+0x00 %Word &OptByte_RDP // OB->RDP = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program User Option Byte */ Data.Set &OptionByteBase+0x02 %Word &OptByte_USER // OB->USER = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program User Data Byte 0 */ Data.Set &OptionByteBase+0x04 %Word &OptByte_Data0 // OB->Data0 = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program User Data Byte 1 */ Data.Set &OptionByteBase+0x06 %Word &OptByte_Data1 // OB->Data1 = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program WRP0 */ Data.Set &OptionByteBase+0x08 %Word &OptByte_WRP0 // OB->WRP0 = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program WRP1 */ Data.Set &OptionByteBase+0x0A %Word &OptByte_WRP1 // OB->WRP1 = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program WRP2 */ Data.Set &OptionByteBase+0x0C %Word &OptByte_WRP2 // OB->WRP2 = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; Program WRP3 */ Data.Set &OptionByteBase+0x0E %Word &OptByte_WRP3 // OB->WRP3 = (uint16_t)val; ; Wait for last operation to be completed */ WHILE (Data.Long(&FlashRegBase+0x0C)&0x00000001)==0x00000001 // while ((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY) ( ) ; if the program operation is completed, disable the OPTWRE Bit */ Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)&0x00001DFF // FLASH->CR &= CR_OPTWRE_Reset; ; if the program operation is completed, disable the OPTPG Bit */ Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)&0x00001FEF // FLASH->CR &= CR_OPTPG_Reset; IF &locked!=0x00 // if ( locked ) ( Data.Set &FlashRegBase+0x10 %Long Data.Long(&FlashRegBase+0x10)|0x00000080 // FLASH->CR |= CR_LOCK_Set; ) RETURN