| /* SPDX-License-Identifier: GPL-2.0+ */ |
| /* |
| * Copyright (c) 2014 Google, Inc |
| */ |
| |
| #ifndef __I2C_EEPROM |
| #define __I2C_EEPROM |
| |
| struct udevice; |
| |
| struct i2c_eeprom_ops { |
| int (*read)(struct udevice *dev, int offset, uint8_t *buf, int size); |
| int (*write)(struct udevice *dev, int offset, const uint8_t *buf, |
| int size); |
| int (*size)(struct udevice *dev); |
| }; |
| |
| struct i2c_eeprom { |
| /* The EEPROM's page size in byte */ |
| unsigned long pagesize; |
| /* The EEPROM's capacity in bytes */ |
| unsigned long size; |
| }; |
| |
| #if CONFIG_IS_ENABLED(I2C_EEPROM) |
| /* |
| * i2c_eeprom_read() - read bytes from an I2C EEPROM chip |
| * |
| * @dev: Chip to read from |
| * @offset: Offset within chip to start reading |
| * @buf: Place to put data |
| * @size: Number of bytes to read |
| * |
| * Return: 0 on success, -ve on failure |
| */ |
| int i2c_eeprom_read(struct udevice *dev, int offset, uint8_t *buf, int size); |
| |
| /* |
| * i2c_eeprom_write() - write bytes to an I2C EEPROM chip |
| * |
| * @dev: Chip to write to |
| * @offset: Offset within chip to start writing |
| * @buf: Buffer containing data to write |
| * @size: Number of bytes to write |
| * |
| * Return: 0 on success, -ve on failure |
| */ |
| int i2c_eeprom_write(struct udevice *dev, int offset, const uint8_t *buf, |
| int size); |
| |
| /* |
| * i2c_eeprom_size() - get size of I2C EEPROM chip |
| * |
| * @dev: Chip to query |
| * |
| * Return: +ve size in bytes on success, -ve on failure |
| */ |
| int i2c_eeprom_size(struct udevice *dev); |
| |
| #else /* !I2C_EEPROM */ |
| |
| static inline int i2c_eeprom_read(struct udevice *dev, int offset, uint8_t *buf, |
| int size) |
| { |
| return -ENOSYS; |
| } |
| |
| static inline int i2c_eeprom_write(struct udevice *dev, int offset, |
| const uint8_t *buf, int size) |
| { |
| return -ENOSYS; |
| } |
| |
| static inline int i2c_eeprom_size(struct udevice *dev) |
| { |
| return -ENOSYS; |
| } |
| |
| #endif /* I2C_EEPROM */ |
| |
| #endif |