| Wolfram Sang | 64eac23 | 2012-02-24 07:41:06 +0100 | [diff] [blame] | 1 | /* | 
|  | 2 | * at24.h - platform_data for the at24 (generic eeprom) driver | 
|  | 3 | * (C) Copyright 2008 by Pengutronix | 
|  | 4 | * (C) Copyright 2012 by Wolfram Sang | 
|  | 5 | * same license as the driver | 
|  | 6 | */ | 
|  | 7 |  | 
| Wolfram Sang | 2b7a505 | 2008-07-14 22:38:35 +0200 | [diff] [blame] | 8 | #ifndef _LINUX_AT24_H | 
|  | 9 | #define _LINUX_AT24_H | 
|  | 10 |  | 
|  | 11 | #include <linux/types.h> | 
| Kevin Hilman | 7274ec8 | 2009-04-02 16:56:57 -0700 | [diff] [blame] | 12 | #include <linux/memory.h> | 
| Wolfram Sang | 2b7a505 | 2008-07-14 22:38:35 +0200 | [diff] [blame] | 13 |  | 
| Wolfram Sang | 64eac23 | 2012-02-24 07:41:06 +0100 | [diff] [blame] | 14 | /** | 
|  | 15 | * struct at24_platform_data - data to set up at24 (generic eeprom) driver | 
|  | 16 | * @byte_len: size of eeprom in byte | 
|  | 17 | * @page_size: number of byte which can be written in one go | 
|  | 18 | * @flags: tunable options, check AT24_FLAG_* defines | 
|  | 19 | * @setup: an optional callback invoked after eeprom is probed; enables kernel | 
|  | 20 | code to access eeprom via memory_accessor, see example | 
|  | 21 | * @context: optional parameter passed to setup() | 
| Wolfram Sang | 2b7a505 | 2008-07-14 22:38:35 +0200 | [diff] [blame] | 22 | * | 
|  | 23 | * If you set up a custom eeprom type, please double-check the parameters. | 
|  | 24 | * Especially page_size needs extra care, as you risk data loss if your value | 
|  | 25 | * is bigger than what the chip actually supports! | 
| Wolfram Sang | 64eac23 | 2012-02-24 07:41:06 +0100 | [diff] [blame] | 26 | * | 
|  | 27 | * An example in pseudo code for a setup() callback: | 
|  | 28 | * | 
|  | 29 | * void get_mac_addr(struct memory_accessor *mem_acc, void *context) | 
|  | 30 | * { | 
|  | 31 | * 	u8 *mac_addr = ethernet_pdata->mac_addr; | 
|  | 32 | *	off_t offset = context; | 
|  | 33 | * | 
|  | 34 | *	// Read MAC addr from EEPROM | 
|  | 35 | *	if (mem_acc->read(mem_acc, mac_addr, offset, ETH_ALEN) == ETH_ALEN) | 
|  | 36 | *		pr_info("Read MAC addr from EEPROM: %pM\n", mac_addr); | 
|  | 37 | * } | 
|  | 38 | * | 
|  | 39 | * This function pointer and context can now be set up in at24_platform_data. | 
| Wolfram Sang | 2b7a505 | 2008-07-14 22:38:35 +0200 | [diff] [blame] | 40 | */ | 
|  | 41 |  | 
|  | 42 | struct at24_platform_data { | 
|  | 43 | u32		byte_len;		/* size (sum of all addr) */ | 
|  | 44 | u16		page_size;		/* for writes */ | 
|  | 45 | u8		flags; | 
|  | 46 | #define AT24_FLAG_ADDR16	0x80	/* address pointer is 16 bit */ | 
|  | 47 | #define AT24_FLAG_READONLY	0x40	/* sysfs-entry will be read-only */ | 
|  | 48 | #define AT24_FLAG_IRUGO		0x20	/* sysfs-entry will be world-readable */ | 
|  | 49 | #define AT24_FLAG_TAKE8ADDR	0x10	/* take always 8 addresses (24c00) */ | 
| Kevin Hilman | 7274ec8 | 2009-04-02 16:56:57 -0700 | [diff] [blame] | 50 |  | 
|  | 51 | void		(*setup)(struct memory_accessor *, void *context); | 
|  | 52 | void		*context; | 
| Wolfram Sang | 2b7a505 | 2008-07-14 22:38:35 +0200 | [diff] [blame] | 53 | }; | 
|  | 54 |  | 
|  | 55 | #endif /* _LINUX_AT24_H */ |