2012-02-24 14:41:06 +08:00
|
|
|
/*
|
|
|
|
* at24.h - platform_data for the at24 (generic eeprom) driver
|
|
|
|
* (C) Copyright 2008 by Pengutronix
|
|
|
|
* (C) Copyright 2012 by Wolfram Sang
|
|
|
|
* same license as the driver
|
|
|
|
*/
|
|
|
|
|
2008-07-15 04:38:35 +08:00
|
|
|
#ifndef _LINUX_AT24_H
|
|
|
|
#define _LINUX_AT24_H
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
2016-02-27 03:59:24 +08:00
|
|
|
#include <linux/nvmem-consumer.h>
|
2016-06-06 16:48:50 +08:00
|
|
|
#include <linux/bitops.h>
|
2008-07-15 04:38:35 +08:00
|
|
|
|
2012-02-24 14:41:06 +08:00
|
|
|
/**
|
|
|
|
* struct at24_platform_data - data to set up at24 (generic eeprom) driver
|
|
|
|
* @byte_len: size of eeprom in byte
|
|
|
|
* @page_size: number of byte which can be written in one go
|
|
|
|
* @flags: tunable options, check AT24_FLAG_* defines
|
|
|
|
* @setup: an optional callback invoked after eeprom is probed; enables kernel
|
2016-02-27 03:59:24 +08:00
|
|
|
code to access eeprom via nvmem, see example
|
2012-02-24 14:41:06 +08:00
|
|
|
* @context: optional parameter passed to setup()
|
2008-07-15 04:38:35 +08:00
|
|
|
*
|
|
|
|
* If you set up a custom eeprom type, please double-check the parameters.
|
|
|
|
* Especially page_size needs extra care, as you risk data loss if your value
|
|
|
|
* is bigger than what the chip actually supports!
|
2012-02-24 14:41:06 +08:00
|
|
|
*
|
|
|
|
* An example in pseudo code for a setup() callback:
|
|
|
|
*
|
2016-05-24 02:44:39 +08:00
|
|
|
* void get_mac_addr(struct nvmem_device *nvmem, void *context)
|
2012-02-24 14:41:06 +08:00
|
|
|
* {
|
2013-09-28 03:06:28 +08:00
|
|
|
* u8 *mac_addr = ethernet_pdata->mac_addr;
|
2012-02-24 14:41:06 +08:00
|
|
|
* off_t offset = context;
|
|
|
|
*
|
|
|
|
* // Read MAC addr from EEPROM
|
2016-02-27 03:59:24 +08:00
|
|
|
* if (nvmem_device_read(nvmem, offset, ETH_ALEN, mac_addr) == ETH_ALEN)
|
2012-02-24 14:41:06 +08:00
|
|
|
* pr_info("Read MAC addr from EEPROM: %pM\n", mac_addr);
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* This function pointer and context can now be set up in at24_platform_data.
|
2008-07-15 04:38:35 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
struct at24_platform_data {
|
|
|
|
u32 byte_len; /* size (sum of all addr) */
|
|
|
|
u16 page_size; /* for writes */
|
|
|
|
u8 flags;
|
2016-06-06 16:48:50 +08:00
|
|
|
#define AT24_FLAG_ADDR16 BIT(7) /* address pointer is 16 bit */
|
|
|
|
#define AT24_FLAG_READONLY BIT(6) /* sysfs-entry will be read-only */
|
|
|
|
#define AT24_FLAG_IRUGO BIT(5) /* sysfs-entry will be world-readable */
|
|
|
|
#define AT24_FLAG_TAKE8ADDR BIT(4) /* take always 8 addresses (24c00) */
|
2016-06-06 16:48:51 +08:00
|
|
|
#define AT24_FLAG_SERIAL BIT(3) /* factory-programmed serial number */
|
2016-06-06 16:48:54 +08:00
|
|
|
#define AT24_FLAG_MAC BIT(2) /* factory-programmed mac address */
|
2017-12-22 00:53:09 +08:00
|
|
|
#define AT24_FLAG_NO_RDROL BIT(1) /* does not auto-rollover reads to */
|
2017-12-09 00:28:30 +08:00
|
|
|
/* the next slave address */
|
2009-04-03 07:56:57 +08:00
|
|
|
|
2016-02-27 03:59:24 +08:00
|
|
|
void (*setup)(struct nvmem_device *nvmem, void *context);
|
2009-04-03 07:56:57 +08:00
|
|
|
void *context;
|
2008-07-15 04:38:35 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _LINUX_AT24_H */
|