eeprom.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. #ifndef __LINUX_SPI_EEPROM_H
  2. #define __LINUX_SPI_EEPROM_H
  3. #include <linux/memory.h>
  4. /*
  5. * Put one of these structures in platform_data for SPI EEPROMS handled
  6. * by the "at25" driver. On SPI, most EEPROMS understand the same core
  7. * command set. If you need to support EEPROMs that don't yet fit, add
  8. * flags to support those protocol options. These values all come from
  9. * the chip datasheets.
  10. */
  11. struct spi_eeprom {
  12. u32 byte_len;
  13. char name[10];
  14. u16 page_size; /* for writes */
  15. u16 flags;
  16. #define EE_ADDR1 0x0001 /* 8 bit addrs */
  17. #define EE_ADDR2 0x0002 /* 16 bit addrs */
  18. #define EE_ADDR3 0x0004 /* 24 bit addrs */
  19. #define EE_READONLY 0x0008 /* disallow writes */
  20. /*
  21. * Certain EEPROMS have a size that is larger than the number of address
  22. * bytes would allow (e.g. like M95040 from ST that has 512 Byte size
  23. * but uses only one address byte (A0 to A7) for addressing.) For
  24. * the extra address bit (A8, A16 or A24) bit 3 of the instruction byte
  25. * is used. This instruction bit is normally defined as don't care for
  26. * other AT25 like chips.
  27. */
  28. #define EE_INSTR_BIT3_IS_ADDR 0x0010
  29. /* for exporting this chip's data to other kernel code */
  30. void (*setup)(struct memory_accessor *mem, void *context);
  31. void *context;
  32. };
  33. #endif /* __LINUX_SPI_EEPROM_H */