at24.h 1.8 KB
Newer Older
1 2 3 4 5 6 7
/*
 * 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
 */

8 9 10 11
#ifndef _LINUX_AT24_H
#define _LINUX_AT24_H

#include <linux/types.h>
12
#include <linux/nvmem-consumer.h>
13

14 15 16 17 18 19
/**
 * 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
20
	code to access eeprom via nvmem, see example
21
 * @context: optional parameter passed to setup()
22 23 24 25
 *
 * 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!
26 27 28
 *
 * An example in pseudo code for a setup() callback:
 *
29
 * void get_mac_addr(struct nvmem_device *nvmem, void *context)
30
 * {
31
 *	u8 *mac_addr = ethernet_pdata->mac_addr;
32 33 34
 *	off_t offset = context;
 *
 *	// Read MAC addr from EEPROM
35
 *	if (nvmem_device_read(nvmem, offset, ETH_ALEN, mac_addr) == ETH_ALEN)
36 37 38 39
 *		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.
40 41 42 43 44 45 46 47 48 49
 */

struct at24_platform_data {
	u32		byte_len;		/* size (sum of all addr) */
	u16		page_size;		/* for writes */
	u8		flags;
#define AT24_FLAG_ADDR16	0x80	/* address pointer is 16 bit */
#define AT24_FLAG_READONLY	0x40	/* sysfs-entry will be read-only */
#define AT24_FLAG_IRUGO		0x20	/* sysfs-entry will be world-readable */
#define AT24_FLAG_TAKE8ADDR	0x10	/* take always 8 addresses (24c00) */
50

51
	void		(*setup)(struct nvmem_device *nvmem, void *context);
52
	void		*context;
53 54 55
};

#endif /* _LINUX_AT24_H */