//***************************************************************************** // // eeprom.h - Prototypes for the EEPROM driver. // // Copyright (c) 2010-2011 Texas Instruments Incorporated. All rights reserved. // Software License Agreement // // Texas Instruments (TI) is supplying this software for use solely and // exclusively on TI's microcontroller products. The software is owned by // TI and/or its suppliers, and is protected under applicable copyright // laws. You may not combine this software with "viral" open-source // software in order to form a larger program. // // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS. // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL // DAMAGES, FOR ANY REASON WHATSOEVER. // // This is part of revision 8049 of the Stellaris Peripheral Driver Library. // //***************************************************************************** #ifndef __EEPROM_H__ #define __EEPROM_H__ //***************************************************************************** // // If building with a C++ compiler, make all of the definitions in this header // have a C binding. // //***************************************************************************** #ifdef __cplusplus extern "C" { #endif //***************************************************************************** // //! \addtogroup eeprom_api //! @{ // //***************************************************************************** //***************************************************************************** // // Values returned by EEPROMInit. // //***************************************************************************** // //! This value may be returned from a call to EEPROMInit(). It indicates that //! no previous write operations were interrupted by a reset event and that the //! EEPROM peripheral is ready for use. // #define EEPROM_INIT_OK 0 // //! This value may be returned from a call to EEPROMInit(). It indicates that //! a previous data or protection write operation was interrupted by a reset //! event. The EEPROM peripheral has recovered its state but the last write //! operation may have been lost. The application must check the validity of //! data it has written and retry any writes as required. // #define EEPROM_INIT_RETRY 1 // //! This value may be returned from a call to EEPROMInit(). It indicates that a //! previous data or protection write operation was interrupted by a reset //! event and that the EEPROM peripheral was unable to clean up after the //! problem. This situation may be resolved with another reset or may be fatal //! depending upon the cause of the problem. For example, if the voltage to //! the part is unstable, retrying once the voltage has stabilized may clear //! the error. // #define EEPROM_INIT_ERROR 2 //***************************************************************************** // // Error indicators returned by various EEPROM API calls. These will be ORed // together into the final return code. // //***************************************************************************** // //! This return code bit indicates that the EEPROM programming state machine //! failed to write a value due to the voltage level dropping below that //! required for EEPROM programming. The operation may be retried once the //! voltage stabilizes. // #define EEPROM_RC_INVPL 0x00000100 // //! This return code bit indicates that an attempt was made to read from //! the EEPROM while a write operation was in progress. // #define EEPROM_RC_WRBUSY 0x00000020 // //! This return code bit indicates that an attempt was made to write a //! value but the destination permissions disallow write operations. This //! may be due to the destination block being locked, access protection set //! to prohibit writes or an attempt to write a password when one is already //! written. // #define EEPROM_RC_NOPERM 0x00000010 // //! This return code bit indicates that the EEPROM programming state machine //! is currently copying to or from the internal copy buffer to make room for //! a newly written value. It is provided as a status indicator and does not //! indicate an error. // #define EEPROM_RC_WKCOPY 0x00000008 // //! This return code bit indicates that the EEPROM programming state machine //! is currently erasing the internal copy buffer. It is provided as a //! status indicator and does not indicate an error. // #define EEPROM_RC_WKERASE 0x00000004 // //! This return code bit indicates that the EEPROM programming state machine //! is currently working. No new write operations should be attempted until //! this bit is clear. // #define EEPROM_RC_WORKING 0x00000001 //***************************************************************************** // // Values that can be passed to EEPROMBlockProtectSet() in the ulProtect // parameter, and returned by EEPROMBlockProtectGet(). // //***************************************************************************** // //! This bit may be ORed with the protection option passed to //! EEPROMBlockProtectSet() or returned from EEPROMBlockProtectGet(). It //! restricts EEPROM access to threads running in supervisor mode and prevents //! access to an EEPROM block when the CPU is in user mode. // #define EEPROM_PROT_SUPERVISOR_ONLY 0x00000008 // //! This value may be passed to EEPROMBlockProtectSet() or returned from //! EEPROMBlockProtectGet(). It indicates that the block should offer //! read/write access when no password is set or when a password is set and //! the block is unlocked, and read-only access when a password is set but //! the block is locked. // #define EEPROM_PROT_RW_LRO_URW 0x00000000 // //! This value may be passed to EEPROMBlockProtectSet() or returned from //! EEPROMBlockProtectGet(). It indicates that the block should offer neither //! read nor write access unless it is protected by a password and unlocked. // #define EEPROM_PROT_NA_LNA_URW 0x00000001 // //! This value may be passed to EEPROMBlockProtectSet() or returned from //! EEPROMBlockProtectGet(). It indicates that the block should offer //! read-only access when no password is set or when a password is set and the //! block is unlocked. When a password is set and the block is locked, neither //! read nor write access is permitted. // #define EEPROM_PROT_RO_LNA_URO 0x00000002 //***************************************************************************** // //! This value may be passed to EEPROMIntEnable() and EEPROMIntDisable() and is //! returned by EEPROMIntStatus() if an EEPROM interrupt is currently being //! signaled. // //***************************************************************************** #define EEPROM_INT_PROGRAM 0x00000004 //***************************************************************************** // //! Returns the EEPROM block number containing a given offset address. //! //! \param ulAddr is the linear, byte address of the EEPROM location whose //! block number is to be returned. This is a zero-based offset from the start //! of the EEPROM storage. //! //! This macro may be used to translate an EEPROM address offset into a //! block number suitable for use in any of the driver's block protection //! functions. The address provided is expressed as a byte offset from the //! base of the EEPROM. //! //! \return Returns the zero-based block number which contains the passed //! address. // //***************************************************************************** #define EEPROMBlockFromAddr(ulAddr) ((ulAddr) >> 6) //***************************************************************************** // //! Returns the offset address of the first word in an EEPROM block. //! //! \param ulBlock is the index of the EEPROM block whose first word address //! is to be returned. //! //! This macro may be used to determine the address of the first word in a //! given EEPROM block. The address returned is expressed as a byte offset //! from the base of EEPROM storage. //! //! \return Returns the address of the first word in the given EEPROM block. // //***************************************************************************** #define EEPROMAddrFromBlock(ulBlock) ((ulBlock) << 6) //***************************************************************************** // // Prototypes for the APIs. // //***************************************************************************** extern unsigned long EEPROMInit(void); extern unsigned long EEPROMSizeGet(void); extern unsigned long EEPROMBlockCountGet(void); extern void EEPROMRead(unsigned long *pulData, unsigned long ulAddress, unsigned long ulCount); extern unsigned long EEPROMProgram(unsigned long *pulData, unsigned long ulAddress, unsigned long ulCount); extern unsigned long EEPROMProgramNonBlocking(unsigned long ulData, unsigned long ulAddress); extern unsigned long EEPROMStatusGet(void); extern unsigned long EEPROMMassErase(void); extern unsigned long EEPROMBlockProtectGet(unsigned long ulBlock); extern unsigned long EEPROMBlockProtectSet(unsigned long ulBlock, unsigned long ulProtect); extern unsigned long EEPROMBlockPasswordSet(unsigned long ulBlock, unsigned long *pulPassword, unsigned long ulCount); extern unsigned long EEPROMBlockLock(unsigned long ulBlock); extern unsigned long EEPROMBlockUnlock(unsigned long ulBlock, unsigned long *pulPassword, unsigned long ulCount); extern void EEPROMBlockHide(unsigned long ulBlock); extern void EEPROMIntEnable(unsigned long ulIntFlags); extern void EEPROMIntDisable(unsigned long ulIntFlags); extern unsigned long EEPROMIntStatus(tBoolean bMasked); extern void EEPROMIntClear(unsigned long ulIntFlags); //***************************************************************************** // // Close the Doxygen group. //! @} // //***************************************************************************** //***************************************************************************** // // Mark the end of the C bindings section for C++ compilers. // //***************************************************************************** #ifdef __cplusplus } #endif #endif // __EEPROM_H__