firewire: ohci: add a function for reading PHY registers
authorClemens Ladisch <clemens@ladisch.de>
Sun, 4 Apr 2010 13:19:52 +0000 (15:19 +0200)
committerStefan Richter <stefanr@s5r6.in-berlin.de>
Sat, 10 Apr 2010 14:51:14 +0000 (16:51 +0200)
Move the register reading code from ohci_update_phy_reg() into
a function which can be used separately.

Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
drivers/firewire/ohci.c

index e33917bf97d28eb803699e46f4dfb46860ec1b45..8ebccda94df9889e401514f406dbb6d54d43c955 100644 (file)
@@ -460,22 +460,36 @@ static inline void flush_writes(const struct fw_ohci *ohci)
        reg_read(ohci, OHCI1394_Version);
 }
 
-static int ohci_update_phy_reg(struct fw_card *card, int addr,
-                              int clear_bits, int set_bits)
+static int read_phy_reg(struct fw_card *card, int addr, u32 *value)
 {
        struct fw_ohci *ohci = fw_ohci(card);
-       u32 val, old;
+       u32 val;
 
        reg_write(ohci, OHCI1394_PhyControl, OHCI1394_PhyControl_Read(addr));
        flush_writes(ohci);
        msleep(2);
        val = reg_read(ohci, OHCI1394_PhyControl);
        if ((val & OHCI1394_PhyControl_ReadDone) == 0) {
-               fw_error("failed to set phy reg bits.\n");
+               fw_error("failed to read phy reg bits\n");
                return -EBUSY;
        }
 
-       old = OHCI1394_PhyControl_ReadData(val);
+       *value = OHCI1394_PhyControl_ReadData(val);
+
+       return 0;
+}
+
+static int ohci_update_phy_reg(struct fw_card *card, int addr,
+                              int clear_bits, int set_bits)
+{
+       struct fw_ohci *ohci = fw_ohci(card);
+       u32 old;
+       int err;
+
+       err = read_phy_reg(card, addr, &old);
+       if (err < 0)
+               return err;
+
        old = (old & ~clear_bits) | set_bits;
        reg_write(ohci, OHCI1394_PhyControl,
                  OHCI1394_PhyControl_Write(addr, old));