eeprom_93cx6: Add data direction control.
authorBen Dooks <ben@simtec.co.uk>
Mon, 21 Nov 2011 08:57:56 +0000 (08:57 +0000)
committerDavid S. Miller <davem@davemloft.net>
Sat, 26 Nov 2011 19:59:38 +0000 (14:59 -0500)
Some devices need to know if the data is to be output or read, so add a
data direction into the eeprom structure to tell the driver whether the
data line should be driven.

The user in this case is the Micrel KS8851 which has a direction
control for the EEPROM data line and thus needs to know whether
to drive it (writing) or to tristate it for receiving.

Signed-off-by: Ben Dooks <ben@simtec.co.uk>
Cc: Wolfram Sang <w.sang@pengutronix.de>
Cc: Jean Delvare <khali@linux-fr.org>
Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/misc/eeprom/eeprom_93cx6.c
include/linux/eeprom_93cx6.h

index 7b33de95c4bf5ff762e8f7bd9d56d671248f509b..a6037af6f0760d51e59044f15dbaf3dfd60a8ce7 100644 (file)
@@ -63,6 +63,7 @@ static void eeprom_93cx6_startup(struct eeprom_93cx6 *eeprom)
        eeprom->reg_data_out = 0;
        eeprom->reg_data_clock = 0;
        eeprom->reg_chip_select = 1;
+       eeprom->drive_data = 1;
        eeprom->register_write(eeprom);
 
        /*
@@ -101,6 +102,7 @@ static void eeprom_93cx6_write_bits(struct eeprom_93cx6 *eeprom,
         */
        eeprom->reg_data_in = 0;
        eeprom->reg_data_out = 0;
+       eeprom->drive_data = 1;
 
        /*
         * Start writing all bits.
@@ -140,6 +142,7 @@ static void eeprom_93cx6_read_bits(struct eeprom_93cx6 *eeprom,
         */
        eeprom->reg_data_in = 0;
        eeprom->reg_data_out = 0;
+       eeprom->drive_data = 0;
 
        /*
         * Start reading all bits.
index c4627cbdb8e038e4f61187db301c13a6acc12742..e04546e9c59278f896d6487d1965c212f8568f18 100644 (file)
@@ -46,6 +46,7 @@
  * @register_write(struct eeprom_93cx6 *eeprom): handler to
  * write to the eeprom register by using all reg_* fields.
  * @width: eeprom width, should be one of the PCI_EEPROM_WIDTH_* defines
+ * @drive_data: Set if we're driving the data line.
  * @reg_data_in: register field to indicate data input
  * @reg_data_out: register field to indicate data output
  * @reg_data_clock: register field to set the data clock
@@ -62,6 +63,7 @@ struct eeprom_93cx6 {
 
        int width;
 
+       char drive_data;
        char reg_data_in;
        char reg_data_out;
        char reg_data_clock;