Tedd OKANO
/
__IAP_sector28write
IAP program sample to write sector28 (address 0x00070000)
Diff: main.cpp
- Revision:
- 0:34dda9d8ed01
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cpp Fri Jan 20 08:56:34 2012 +0000 @@ -0,0 +1,118 @@ +/** IAP demo : demo code for internal Flash memory access library + * + * The internal Flash memory access is described in the LPC1768 usermanual. + * http://www.nxp.com/documents/user_manual/UM10360.pdf + * + * Chapter 2: "LPC17xx Memory map" + * Chapter 32: "LPC17xx Flash memory interface and programming" + * refering Rev. 01 - 4 January 2010 + * + * This main.cpp demonstrates how the flash can be erased and wrote. + * + * This program tries to... + * 0. read device ID and serial# + * 1. check if the targat sector blank + * 2. erase the sector if it was not blank + * 3. write into the flash (prepare before write) + * 4. verify the data by IAP command + * 5. show the content of the flash + * + * The Flash must be erased as sectors. No overwrite can be done like SRAM. + * So erase should be done in size of 4K or 32K. + * + * Writing sector can be done with size of 256, 512, 1024 or 4096. + * If other size is used, the IAP returns an error. + * The SRAM memory should be allocated in + * + * + * Released under the MIT License: http://mbed.org/license/mit + * + * revision 1.0 09-Mar-2010 1st release + * revision 1.1 12-Mar-2010 chaged: to make possible to reserve flash area for user + * it can be set by USER_FLASH_AREA_START and USER_FLASH_AREA_SIZE in IAP.h + */ + +#include "mbed.h" +#include "IAP.h" + +#define MEM_SIZE 256 +#define TARGET_SECTOR 28 + +void memdump( char *p, int n ); +int isprint( int c ); + +IAP iap; + + +int main() { + char mem[ MEM_SIZE ]; // memory, it should be aligned to word boundary + int r; + + printf( "\r\n\r\n\r\nIAP: Flash memory writing test\r\n" ); + printf( " device-ID = 0x%08X, serial# = 0x%08X, CPU running %dkHz\r\n", iap.read_ID(), iap.read_serial(), SystemCoreClock / 1000 ); + printf( " user reserved flash area: start_address=0x%08X, size=%d bytes\r\n", iap.reserved_flash_area_start(), iap.reserved_flash_area_size() ); + + for ( int i = 0; i < MEM_SIZE; i++ ) + mem[ i ] = i & 0xFF; + + // blank check: The mbed will erase all flash contents after downloading new executable + + r = iap.blank_check( TARGET_SECTOR, TARGET_SECTOR ); + printf( "blank check result = 0x%08X\r\n", r ); + + // erase sector, if required + + if ( r == SECTOR_NOT_BLANK ) { + iap.prepare( TARGET_SECTOR, TARGET_SECTOR ); + r = iap.erase( TARGET_SECTOR, TARGET_SECTOR ); + printf( "erase result = 0x%08X\r\n", r ); + } + + // copy RAM to Flash + + iap.prepare( TARGET_SECTOR, TARGET_SECTOR ); + r = iap.write( mem, sector_start_adress[ TARGET_SECTOR ], MEM_SIZE ); + printf( "copied: SRAM(0x%08X)->Flash(0x%08X) for %d bytes. (result=0x%08X)\r\n", mem, sector_start_adress[ TARGET_SECTOR ], MEM_SIZE, r ); + + // compare + + r = iap.compare( mem, sector_start_adress[ TARGET_SECTOR ], MEM_SIZE ); + printf( "compare result = \"%s\"\r\n", r ? "FAILED" : "OK" ); + +//#define WRITE_NEXT_BLOCK +#ifdef WRITE_NEXT_BLOCK + + // copy RAM to Flash + + iap.prepare( TARGET_SECTOR, TARGET_SECTOR ); + r = iap.write( mem, sector_start_adress[ TARGET_SECTOR ] + 256, MEM_SIZE ); + printf( "copied: SRAM(0x%08X)->Flash(0x%08X) for %d bytes. (result=0x%08X)\n", mem, sector_start_adress[ TARGET_SECTOR ], MEM_SIZE, r ); + + // compare + + r = iap.compare( mem, sector_start_adress[ TARGET_SECTOR ] + 256, MEM_SIZE ); + printf( "compare result = \"%s\"\r\n", r ? "FAILED" : "OK" ); + +#endif + + printf( "showing the flash contents...\n" ); + memdump( sector_start_adress[ TARGET_SECTOR ], MEM_SIZE ); +} + + +void memdump( char *base, int n ) { + unsigned int *p; + + printf( " memdump from 0x%08X for %d bytes", (unsigned long)base, n ); + + p = (unsigned int *)((unsigned int)base & ~(unsigned int)0x3); + + for ( int i = 0; i < (n >> 2); i++, p++ ) { + if ( !(i % 4) ) + printf( "\r\n 0x%08X :", (unsigned int)p ); + + printf( " 0x%08X", *p ); + } + + printf( "\r\n" ); +}