; ; @Title: Example for flash declaration of Fujitsu MB9A310 series internal flash. ; ; @Description: ; Script arguments: ; ; DO mb9a310 [PREPAREONLY] [CPU=] ; ; PREPAREONLY only declares flash but does not execute flash programming ; ; CPU= selects CPU derivative ; ; Example: ; ; DO ~~/demo/arm/flash/mb9a310 CPU=MB9AF316N PREPAREONLY ; ; List of MB9A310 series derivatives and their configuration: ; ; CPU-Type FlashSize RamSize ; [kB] [kB] ; --------------------------------- ; MB9AF311L 64. 16. ; MB9AF311M 64. 16. ; MB9AF311N 64. 16. ; MB9AF312L 128. 16. ; MB9AF312M 128. 16. ; MB9AF312N 128. 16. ; MB9AF314L 256. 32. ; MB9AF314M 256. 32. ; MB9AF314N 256. 32. ; MB9AF315M 384. 32. ; MB9AF315N 384. 32. ; MB9AF316M 512. 32. ; MB9AF316N 512. 32. ; ; @Author: WRD ; @Copyright: (C) 1989-2022 Lauterbach GmbH, licensed for use with TRACE32(R) only ; @Chip: MB9AF31?L MB9AF31?M MB9AF31?N ; -------------------------------------------------------------------------------- ; $Rev: 10516 $ ; $Id: mb9a310.cmm 10516 2022-02-02 11:39:30Z bschroefel $ LOCAL ¶meters ¶m_prepareonly ENTRY %LINE ¶meters ¶m_prepareonly=(STRing.SCAN(STRing.UPpeR("¶meters"),"PREPAREONLY",0)!=-1) LOCAL ¶m_cpu ¶m_cpu=STRing.SCANAndExtract(STRing.UPpeR("¶meters"),"CPU=","") ; -------------------------------------------------------------------------------- ; Start debugging IF SYStem.MODE()<5 ( Break.RESet SYStem.RESet IF "¶m_cpu"!="" SYStem.CPU ¶m_cpu IF !CPUIS(MB9AF31*) SYStem.CPU MB9AF31* IF CABLE.TWOWIRE() SYStem.CONFIG.DEBUGPORTTYPE SWD ELSE SYStem.CONFIG.DEBUGPORTTYPE JTAG SYStem.Option.ResBreak OFF SYStem.Up ) ; -------------------------------------------------------------------------------- ; Flash declaration FLASH.RESet GOSUB FlashDeclaration ; -------------------------------------------------------------------------------- ; Flash programming example ; Flash script ends here if called with parameter PREPAREONLY IF ¶m_prepareonly ENDDO PREPAREDONE DIALOG.YESNO "Program flash memory?" LOCAL &progflash ENTRY &progflash IF &progflash ( FLASH.ReProgram.ALL /Erase Data.LOAD.auto * FLASH.ReProgram.off ; Reset device SYStem.Down SYStem.Up ) ENDDO ; -------------------------------------------------------------------------------- ; Flash declaration depending on selected CPU FlashDeclaration: LOCAL &FlashSize IF CPUIS("MB9AF311?") ( &FlashSize=0x10000 ) ELSE IF CPUIS("MB9AF312?") ( &FlashSize=0x20000 ) ELSE IF CPUIS("MB9AF314?") ( &FlashSize=0x40000 ) ELSE IF CPUIS("MB9AF315?") ( &FlashSize=0x60000 ) ELSE IF CPUIS("MB9AF316?") ( &FlashSize=0x80000 ) ELSE ( PRINT %ERROR "FLASH size of CPU type is unknown" ENDDO ) IF &FlashSize==0x10000 ( FLASH.Create 1. 0x000000--0x007FFF 0x4000 TARGET Long FLASH.Create 1. 0x008000--0x00FFFF 0x8000 TARGET Long ) ELSE IF &FlashSize>=0x20000 ( FLASH.Create 1. 0x000000--0x007FFF 0x4000 TARGET Long FLASH.Create 1. 0x008000--0x01FFFF 0x18000 TARGET Long ) IF &FlashSize>=0x40000 ( FLASH.Create 1. 0x020000--0x03FFFF 0x20000 TARGET Long ) IF &FlashSize>=0x60000 ( FLASH.Create 1. 0x040000--0x05FFFF 0x20000 TARGET Long ) IF &FlashSize>=0x80000 ( FLASH.Create 1. 0x060000--0x07FFFF 0x20000 TARGET Long ) FLASH.TARGET 0x1FFFF000 0x20000000 0x1000 ~~/demo/arm/flash/long/fm3t1.bin RETURN