X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fdrv%2Feeprom.h;h=ef6c58c952100e42feb733ba3f758e21cbfcda8a;hb=ee668d15beb93a94fbb5d145284c9b39bdfa8c90;hp=5bd834af6441222c4db44c0968617ee645dd322c;hpb=911d2706a86d326786bfe721dcc3d63aeade7f28;p=bertos.git diff --git a/bertos/drv/eeprom.h b/bertos/drv/eeprom.h index 5bd834af..ef6c58c9 100644 --- a/bertos/drv/eeprom.h +++ b/bertos/drv/eeprom.h @@ -42,9 +42,26 @@ #ifndef DRV_EEPROM_H #define DRV_EEPROM_H +#include "cfg/cfg_eeprom.h" + #include +#include + +#include +#include #include +#include + +#include + +#if COMPILER_C99 + #define eeprom_init(...) PP_CAT(eeprom_init ## _, COUNT_PARMS(__VA_ARGS__)) (__VA_ARGS__) + #define eeprom_verify(...) PP_CAT(eeprom_verify ## _, COUNT_PARMS(__VA_ARGS__)) (__VA_ARGS__) +#else + #define eeprom_init(args...) PP_CAT(eeprom_init ## _, COUNT_PARMS(args)) (args) + #define eeprom_verify(args...) PP_CAT(eeprom_verify ## _, COUNT_PARMS(args)) (args) +#endif /** @@ -73,23 +90,35 @@ typedef uint8_t e2dev_addr_t; */ typedef struct Eeprom { - KFile fd; ///< File descriptor. + KBlock blk; + I2c *i2c; EepromType type; ///< EEPROM type e2dev_addr_t addr; ///< Device address. + bool verify; +#if !CONFIG_EEPROM_DISABLE_OLD_API + union { + KFile fd; + KFileBlock fdblk; + } DEPRECATED; +#endif /* !CONFIG_EEPROM_DISABLE_OLD_API */ } Eeprom; +#if !CONFIG_EEPROM_DISABLE_OLD_API + STATIC_ASSERT(offsetof(Eeprom, fd) == offsetof(Eeprom, fdblk.fd)); +#endif /* !CONFIG_EEPROM_DISABLE_OLD_API */ + /** * ID for eeproms. */ -#define KFT_EEPROM MAKE_ID('E', 'E', 'P', 'R') +#define KBT_EEPROM MAKE_ID('E', 'E', 'P', 'R') /** * Convert + ASSERT from generic KFile to Eeprom. */ -INLINE Eeprom * EEPROM_CAST(KFile *fd) +INLINE Eeprom * EEPROM_CAST_KBLOCK(KBlock *blk) { - ASSERT(fd->_type == KFT_EEPROM); - return (Eeprom *)fd; + ASSERT(blk->priv.type == KBT_EEPROM); + return (Eeprom *)blk; } /// Type for EEPROM addresses @@ -127,8 +156,21 @@ typedef struct EepromInfo e2_size_t e2_size; ///< eeprom size } EepromInfo; -bool eeprom_erase(Eeprom *fd, e2addr_t addr, e2_size_t count); -bool eeprom_verify(Eeprom *fd, const void *buf, size_t count); -void eeprom_init(Eeprom *fd, EepromType, e2dev_addr_t, bool verify); +bool eeprom_erase(Eeprom *eep, e2addr_t addr, e2_size_t count); +bool eeprom_verify_4(Eeprom *eep, e2addr_t addr, const void *buf, size_t count); +void eeprom_init_5(Eeprom *eep, I2c *i2c, EepromType type, e2dev_addr_t addr, bool verify); + +#if !CONFIG_EEPROM_DISABLE_OLD_API + +DEPRECATED INLINE bool eeprom_verify_3(Eeprom *eep, const void *buf, size_t count) +{ + return eeprom_verify_4(eep, (e2addr_t)eep->fdblk.fd.seek_pos, buf, count); +} +DEPRECATED INLINE void eeprom_init_4(Eeprom *eep, EepromType type, e2dev_addr_t addr, bool verify) +{ + eeprom_init_5(eep, &local_i2c_old_api, type, addr, verify); + kfileblock_init(&eep->fdblk, &eep->blk); +} +#endif /* !CONFIG_EEPROM_DISABLE_OLD_API */ #endif /* DRV_EEPROM_H */