lib eeprom

Fork of eeprom by FRA221_2015

Committer:
soulx
Date:
Mon Oct 26 16:43:07 2015 +0000
Revision:
2:c648c5e93d5e
Parent:
1:e91aa7bef1f9
edit ack chacking with wait_ms(5) *Application Note:AN1028

Who changed what in which revision?

UserRevisionLine numberNew contents of line
bborredon 0:80245aff63ce 1 #ifndef __EEPROM__H_
bborredon 0:80245aff63ce 2 #define __EEPROM__H_
bborredon 0:80245aff63ce 3
bborredon 0:80245aff63ce 4 // Includes
bborredon 0:80245aff63ce 5 #include <string>
bborredon 0:80245aff63ce 6
bborredon 0:80245aff63ce 7 #include "mbed.h"
bborredon 0:80245aff63ce 8
bborredon 0:80245aff63ce 9 // Example
bborredon 0:80245aff63ce 10 /*
bborredon 0:80245aff63ce 11 */
bborredon 0:80245aff63ce 12
bborredon 0:80245aff63ce 13 // Defines
bborredon 0:80245aff63ce 14 #define EEPROM_Address 0xa0
bborredon 0:80245aff63ce 15
bborredon 0:80245aff63ce 16 #define EEPROM_NoError 0x00
bborredon 0:80245aff63ce 17 #define EEPROM_BadAddress 0x01
bborredon 0:80245aff63ce 18 #define EEPROM_I2cError 0x02
bborredon 0:80245aff63ce 19 #define EEPROM_ParamError 0x03
bborredon 0:80245aff63ce 20 #define EEPROM_OutOfRange 0x04
bborredon 0:80245aff63ce 21 #define EEPROM_MallocError 0x05
bborredon 0:80245aff63ce 22
bborredon 0:80245aff63ce 23 #define EEPROM_MaxError 6
bborredon 0:80245aff63ce 24
bborredon 0:80245aff63ce 25 static std::string _ErrorMessageEEPROM[EEPROM_MaxError] = {
bborredon 0:80245aff63ce 26 "",
bborredon 0:80245aff63ce 27 "Bad chip address",
bborredon 0:80245aff63ce 28 "I2C error (nack)",
bborredon 0:80245aff63ce 29 "Invalid parameter",
bborredon 0:80245aff63ce 30 "Data address out of range",
bborredon 0:80245aff63ce 31 "Memory allocation error"
bborredon 0:80245aff63ce 32 };
bborredon 0:80245aff63ce 33
bborredon 0:80245aff63ce 34 // Class
bborredon 0:80245aff63ce 35 class EEPROM {
bborredon 0:80245aff63ce 36 public:
bborredon 0:80245aff63ce 37 enum TypeEeprom {T24C01=128,T24C02=256,T24C04=512,T24C08=1024,T24C16=2048,
bborredon 0:80245aff63ce 38 T24C32=4096,T24C64=8192,T24C128=16384,T24C256=32768,
bborredon 0:80245aff63ce 39 T24C512=65536,T24C1024=131072,T24C1025=131073} Type;
bborredon 0:80245aff63ce 40
bborredon 0:80245aff63ce 41 /*
bborredon 0:80245aff63ce 42 * Constructor, initialize the eeprom on i2c interface.
bborredon 0:80245aff63ce 43 * @param sda : sda i2c pin (PinName)
bborredon 0:80245aff63ce 44 * @param scl : scl i2c pin (PinName)
bborredon 0:80245aff63ce 45 * @param address : eeprom address, according to eeprom type (uint8_t)
bborredon 0:80245aff63ce 46 * @param type : eeprom type (TypeEeprom)
bborredon 0:80245aff63ce 47 * @return none
bborredon 0:80245aff63ce 48 */
soulx 2:c648c5e93d5e 49 EEPROM(PinName sda, PinName scl, uint8_t address, TypeEeprom type=T24C64);
bborredon 0:80245aff63ce 50
bborredon 0:80245aff63ce 51 /*
bborredon 0:80245aff63ce 52 * Random read byte
bborredon 0:80245aff63ce 53 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 54 * @param data : byte to read (int8_t&)
bborredon 0:80245aff63ce 55 * @return none
bborredon 0:80245aff63ce 56 */
bborredon 0:80245aff63ce 57 void read(uint16_t address, int8_t& data);
bborredon 0:80245aff63ce 58
bborredon 0:80245aff63ce 59 /*
bborredon 0:80245aff63ce 60 * Random read short
bborredon 0:80245aff63ce 61 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 62 * @param data : short to read (int16_t&)
bborredon 0:80245aff63ce 63 * @return none
bborredon 0:80245aff63ce 64 */
bborredon 0:80245aff63ce 65 void read(uint16_t address, int16_t& data);
bborredon 0:80245aff63ce 66
bborredon 0:80245aff63ce 67 /*
bborredon 0:80245aff63ce 68 * Random read long
bborredon 0:80245aff63ce 69 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 70 * @param data : long to read (int32_t&)
bborredon 0:80245aff63ce 71 * @return none
bborredon 0:80245aff63ce 72 */
bborredon 0:80245aff63ce 73 void read(uint16_t address, int32_t& data);
bborredon 0:80245aff63ce 74
bborredon 0:80245aff63ce 75 /*
bborredon 0:80245aff63ce 76 * Random read float
bborredon 0:80245aff63ce 77 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 78 * @param data : float to read (float&)
bborredon 0:80245aff63ce 79 * @return none
bborredon 0:80245aff63ce 80 */
bborredon 0:80245aff63ce 81 void read(uint16_t address, float& data);
bborredon 0:80245aff63ce 82
bborredon 0:80245aff63ce 83 /*
bborredon 0:80245aff63ce 84 * Random read anything
bborredon 0:80245aff63ce 85 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 86 * @param data : data to read (void *)
bborredon 0:80245aff63ce 87 * @param size : number of bytes to read (uint16_t)
bborredon 0:80245aff63ce 88 * @return none
bborredon 0:80245aff63ce 89 */
bborredon 0:80245aff63ce 90 void read(uint16_t address, void *data, uint16_t size);
bborredon 0:80245aff63ce 91
bborredon 0:80245aff63ce 92 /*
bborredon 0:80245aff63ce 93 * Current address read byte
bborredon 0:80245aff63ce 94 * @param data : byte to read (int8_t&)
bborredon 0:80245aff63ce 95 * @return none
bborredon 0:80245aff63ce 96 */
bborredon 0:80245aff63ce 97 void read(int8_t& data);
bborredon 0:80245aff63ce 98
bborredon 0:80245aff63ce 99 /*
bborredon 0:80245aff63ce 100 * Sequential read byte
bborredon 0:80245aff63ce 101 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 102 * @param data : bytes array to read (int8_t[]&)
bborredon 0:80245aff63ce 103 * @param size : number of bytes to read (uint16_t)
bborredon 0:80245aff63ce 104 * @return none
bborredon 0:80245aff63ce 105 */
bborredon 0:80245aff63ce 106 void read(uint16_t address, int8_t *data, uint16_t size);
bborredon 0:80245aff63ce 107
bborredon 0:80245aff63ce 108 /*
bborredon 0:80245aff63ce 109 * Write byte
bborredon 0:80245aff63ce 110 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 111 * @param data : byte to write (int8_t)
bborredon 0:80245aff63ce 112 * @return none
bborredon 0:80245aff63ce 113 */
bborredon 0:80245aff63ce 114 void write(uint16_t address, int8_t data);
bborredon 0:80245aff63ce 115
bborredon 0:80245aff63ce 116 /*
bborredon 0:80245aff63ce 117 * Write short
bborredon 0:80245aff63ce 118 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 119 * @param data : short to write (int16_t)
bborredon 0:80245aff63ce 120 * @return none
bborredon 0:80245aff63ce 121 */
bborredon 0:80245aff63ce 122 void write(uint16_t address, int16_t data);
bborredon 0:80245aff63ce 123
bborredon 0:80245aff63ce 124 /*
bborredon 0:80245aff63ce 125 * Write long
bborredon 0:80245aff63ce 126 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 127 * @param data : long to write (int32_t)
bborredon 0:80245aff63ce 128 * @return none
bborredon 0:80245aff63ce 129 */
bborredon 0:80245aff63ce 130 void write(uint16_t address, int32_t data);
bborredon 0:80245aff63ce 131
bborredon 0:80245aff63ce 132 /*
bborredon 0:80245aff63ce 133 * Write float
bborredon 0:80245aff63ce 134 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 135 * @param data : float to write (float)
bborredon 0:80245aff63ce 136 * @return error number if > 0 (uint8_t)
bborredon 0:80245aff63ce 137 */
bborredon 0:80245aff63ce 138 void write(uint16_t address, float data);
bborredon 0:80245aff63ce 139
bborredon 0:80245aff63ce 140 /*
bborredon 0:80245aff63ce 141 * Write anything
bborredon 0:80245aff63ce 142 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 143 * @param data : data to write (void *)
bborredon 0:80245aff63ce 144 * @param size : number of bytes to read (uint16_t)
bborredon 0:80245aff63ce 145 * @return none
bborredon 0:80245aff63ce 146 */
bborredon 0:80245aff63ce 147 void write(uint16_t address, void *data, uint16_t size);
bborredon 0:80245aff63ce 148
bborredon 0:80245aff63ce 149 /*
bborredon 0:80245aff63ce 150 * Write page
bborredon 0:80245aff63ce 151 * @param address : start address (uint16_t)
bborredon 0:80245aff63ce 152 * @param data : bytes array to write (int8_t[])
bborredon 0:80245aff63ce 153 * @param size : number of bytes to write (uint16_t)
bborredon 0:80245aff63ce 154 * @return none
bborredon 0:80245aff63ce 155 */
bborredon 0:80245aff63ce 156 void write(uint16_t address, int8_t data[], uint16_t size);
bborredon 0:80245aff63ce 157
bborredon 0:80245aff63ce 158 /*
bborredon 0:80245aff63ce 159 * Wait eeprom ready
bborredon 0:80245aff63ce 160 * @param : none
bborredon 0:80245aff63ce 161 * @return none
bborredon 0:80245aff63ce 162 */
bborredon 0:80245aff63ce 163 void ready(void);
bborredon 0:80245aff63ce 164
bborredon 0:80245aff63ce 165 /*
bborredon 0:80245aff63ce 166 * Get eeprom size in bytes
bborredon 0:80245aff63ce 167 * @param : none
bborredon 0:80245aff63ce 168 * @return size in bytes (uint16_t)
bborredon 0:80245aff63ce 169 */
bborredon 0:80245aff63ce 170 uint32_t getSize(void);
bborredon 0:80245aff63ce 171
bborredon 0:80245aff63ce 172 /*
bborredon 0:80245aff63ce 173 * Get the current error number (EEPROM_NoError if no error)
bborredon 0:80245aff63ce 174 * @param : none
bborredon 0:80245aff63ce 175 * @return current error number (uint8_t)
bborredon 0:80245aff63ce 176 */
bborredon 0:80245aff63ce 177 uint8_t getError(void);
bborredon 0:80245aff63ce 178
bborredon 0:80245aff63ce 179 /*
bborredon 0:80245aff63ce 180 * Get current error message
bborredon 0:80245aff63ce 181 * @param : none
bborredon 0:80245aff63ce 182 * @return current error message(std::string)
bborredon 0:80245aff63ce 183 */
bborredon 0:80245aff63ce 184 std::string getErrorMessage(void)
bborredon 0:80245aff63ce 185 {
bborredon 0:80245aff63ce 186 return(_ErrorMessageEEPROM[_errnum]);
bborredon 0:80245aff63ce 187 }
bborredon 0:80245aff63ce 188
bborredon 0:80245aff63ce 189 //---------- local variables ----------
bborredon 0:80245aff63ce 190 private:
bborredon 0:80245aff63ce 191 I2C _i2c; // Local i2c communication interface instance
bborredon 0:80245aff63ce 192 int _address; // Local ds1621 i2c address
bborredon 0:80245aff63ce 193 uint8_t _errnum; // Error number
bborredon 0:80245aff63ce 194 TypeEeprom _type; // EEPROM type
bborredon 0:80245aff63ce 195 uint8_t _page_write; // Page write size
bborredon 0:80245aff63ce 196 uint8_t _page_number; // Number of page
bborredon 0:80245aff63ce 197 uint32_t _size; // Size in bytes
bborredon 0:80245aff63ce 198 bool checkAddress(uint16_t address); // Check address range
bborredon 0:80245aff63ce 199 //-------------------------------------
bborredon 0:80245aff63ce 200 };
bborredon 0:80245aff63ce 201 #endif