Tweaks to HAL codestyle
This commit is contained in:
@@ -72,10 +72,10 @@
|
||||
// Public functions
|
||||
// --------------------------------------------------------------------------
|
||||
|
||||
static bool eeprom_initialised = false;
|
||||
static uint8_t eeprom_device_address = 0x50;
|
||||
|
||||
static void eeprom_init(void) {
|
||||
static bool eeprom_initialised = false;
|
||||
if (!eeprom_initialised) {
|
||||
Wire.begin();
|
||||
eeprom_initialised = true;
|
||||
@@ -100,27 +100,25 @@ void eeprom_write_byte(unsigned char *pos, unsigned char value) {
|
||||
|
||||
// WARNING: address is a page address, 6-bit end will wrap around
|
||||
// also, data can be maximum of about 30 bytes, because the Wire library has a buffer of 32 bytes
|
||||
void eeprom_update_block(const void* pos, void* eeprom_address, size_t n) {
|
||||
uint8_t eeprom_temp[32] = {0};
|
||||
uint8_t flag = 0;
|
||||
|
||||
void eeprom_update_block(const void *pos, void* eeprom_address, size_t n) {
|
||||
eeprom_init();
|
||||
|
||||
Wire.beginTransmission(eeprom_device_address);
|
||||
Wire.write((int)((unsigned)eeprom_address >> 8)); // MSB
|
||||
Wire.write((int)((unsigned)eeprom_address & 0xFF)); // LSB
|
||||
Wire.endTransmission();
|
||||
|
||||
uint8_t *ptr = (uint8_t*)pos;
|
||||
uint8_t flag = 0;
|
||||
Wire.requestFrom(eeprom_device_address, (byte)n);
|
||||
for (byte c = 0; c < n; c++) {
|
||||
if (Wire.available()) eeprom_temp[c] = Wire.read();
|
||||
flag |= (eeprom_temp[c] ^ *((uint8_t*)pos + c));
|
||||
}
|
||||
for (byte c = 0; c < n && Wire.available(); c++)
|
||||
flag |= Wire.read() ^ ptr[c];
|
||||
|
||||
if (flag) {
|
||||
Wire.beginTransmission(eeprom_device_address);
|
||||
Wire.write((int)((unsigned)eeprom_address >> 8)); // MSB
|
||||
Wire.write((int)((unsigned)eeprom_address & 0xFF)); // LSB
|
||||
Wire.write((uint8_t*)(pos), n);
|
||||
Wire.write((uint8_t*)pos, n);
|
||||
Wire.endTransmission();
|
||||
|
||||
// wait for write cycle to complete
|
||||
@@ -132,18 +130,16 @@ void eeprom_update_block(const void* pos, void* eeprom_address, size_t n) {
|
||||
|
||||
unsigned char eeprom_read_byte(unsigned char *pos) {
|
||||
byte data = 0xFF;
|
||||
unsigned eeprom_address = (unsigned) pos;
|
||||
unsigned eeprom_address = (unsigned)pos;
|
||||
|
||||
eeprom_init ();
|
||||
eeprom_init();
|
||||
|
||||
Wire.beginTransmission(eeprom_device_address);
|
||||
Wire.write((int)(eeprom_address >> 8)); // MSB
|
||||
Wire.write((int)(eeprom_address & 0xFF)); // LSB
|
||||
Wire.endTransmission();
|
||||
Wire.requestFrom(eeprom_device_address, (byte)1);
|
||||
if (Wire.available())
|
||||
data = Wire.read();
|
||||
return data;
|
||||
return Wire.available() ? Wire.read() : 0xFF;
|
||||
}
|
||||
|
||||
// maybe let's not read more than 30 or 32 bytes at a time!
|
||||
|
||||
Reference in New Issue
Block a user