asdf
Dependencies: mbed
Fork of 00_eeprom_emulation_f401 by
Diff: eeprom/eeprom.cpp
- Revision:
- 1:bc0ee9ad46aa
- Parent:
- 0:1756c3542c95
diff -r 1756c3542c95 -r bc0ee9ad46aa eeprom/eeprom.cpp --- a/eeprom/eeprom.cpp Thu Sep 22 03:54:18 2016 +0000 +++ b/eeprom/eeprom.cpp Tue Sep 27 20:36:44 2016 +0000 @@ -47,9 +47,10 @@ /* Private macro -------------------------------------------------------------*/ /* Private variables ---------------------------------------------------------*/ -/* Dummy variable to protect eeprom pages if code size is bigger than 32kb (F401) +/* Dummy variables to protect eeprom pages if code size is bigger than 32kb (F401) needed in Mbed online compiler to avoid conflict with linker (N.S.) */ -const uint8_t Eeprom_area[2 * PAGE_SIZE] __attribute__((at(EEPROM_START_ADDRESS),used))={ [0 ... (2 * PAGE_SIZE-1)] = 0xFF }; +const uint8_t Eeprom_area0[PAGE_SIZE] __attribute__((at(PAGE0_BASE_ADDRESS),used))={ [0 ... (PAGE_SIZE-1)] = 0xFF }; +const uint8_t Eeprom_area1[PAGE_SIZE] __attribute__((at(PAGE1_BASE_ADDRESS),used))={ [0 ... (PAGE_SIZE-1)] = 0xFF }; /* Global variable used to store variable value in read sequence */ @@ -328,21 +329,32 @@ */ uint16_t EE_VerifyPageFullyErased(uint32_t Address) { - uint32_t ReadStatus = 1; - uint16_t AddressValue = 0x5555; + uint32_t readstatus = 1; + uint16_t addressvalue = 0x5555; + uint32_t end_address; + + if (PAGE0_BASE_ADDRESS==Address) + { + end_address = PAGE0_END_ADDRESS; + } + else + { + end_address = PAGE1_END_ADDRESS; + }; + /* Check each active page address starting from end */ - while (Address <= PAGE0_END_ADDRESS) + while (Address <= end_address) { /* Get the current location content to be compared with virtual address */ - AddressValue = (*(__IO uint16_t*)Address); + addressvalue = (*(__IO uint16_t*)Address); /* Compare the read address with the virtual address */ - if (AddressValue != ERASED) + if (addressvalue != ERASED) { - /* In case variable value is read, reset ReadStatus flag */ - ReadStatus = 0; + /* In case variable value is read, reset readstatus flag */ + readstatus = 0; break; } @@ -350,8 +362,8 @@ Address = Address + 4; } - /* Return ReadStatus value: (0: Page not erased, 1: Sector erased) */ - return ReadStatus; + /* Return readstatus value: (0: Page not erased, 1: Page erased) */ + return readstatus; } /**