]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
ide: call {in|out}put_data() methods from tf_{read|load}() methods (take 2)
authorSergei Shtylyov <sshtylyov@ru.mvista.com>
Tue, 31 Mar 2009 18:15:31 +0000 (20:15 +0200)
committerBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Tue, 31 Mar 2009 18:15:31 +0000 (20:15 +0200)
Handle IDE_FTFLAG_{IN|OUT}_DATA flags in tf_{read|load}() methods by calling
{in|out}put_data() methods to transfer 2 bytes -- this will allow us to move
that handling out of those methods altogether...

Signed-off-by: Sergei Shtylyov <sshtylyov@ru.mvista.com>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
drivers/ide/at91_ide.c
drivers/ide/ide-h8300.c
drivers/ide/ide-io-std.c
drivers/ide/ns87415.c
drivers/ide/scc_pata.c
drivers/ide/tx4938ide.c
drivers/ide/tx4939ide.c

index 9dce793d93b45fe4021cbe9e973d1d64ddddcb52..b7be66d600f82adc50e774b88fc1d4d308eed296 100644 (file)
@@ -196,9 +196,9 @@ static void at91_ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
                HIHI = 0xFF;
 
        if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
-               u16 data = (tf->hob_data << 8) | tf->data;
+               u8 data[2] = { tf->data, tf->hob_data };
 
-               at91_ide_output_data(drive, NULL, &data, 2);
+               at91_ide_output_data(drive, cmd, data, 2);
        }
 
        if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
@@ -234,11 +234,12 @@ static void at91_ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        struct ide_taskfile *tf = &cmd->tf;
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data;
+               u8 data[2];
 
-               at91_ide_input_data(drive, NULL, &data, 2);
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               at91_ide_input_data(drive, cmd, data, 2);
+
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */
index 1d45cd5b6a1c4fe6cc2d3f13db5c25bb4b6c91b4..6cb1785d32e6ab419dd8c438ec6776996068f591 100644 (file)
@@ -54,8 +54,11 @@ static void h8300_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
        if (cmd->ftf_flags & IDE_FTFLAG_FLAGGED)
                HIHI = 0xFF;
 
-       if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA)
-               mm_outw((tf->hob_data << 8) | tf->data, io_ports->data_addr);
+       if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
+               u8 data[2] = { tf->data, tf->hob_data };
+
+               h8300_output_data(drive, cmd, data, 2);
+       }
 
        if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
                outb(tf->hob_feature, io_ports->feature_addr);
@@ -91,10 +94,12 @@ static void h8300_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        struct ide_taskfile *tf = &cmd->tf;
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data = mm_inw(io_ports->data_addr);
+               u8 data[2];
+
+               h8300_input_data(drive, cmd, data, 2);
 
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */
index 96a537da892543c17a53c3166906000e7b9f1318..f06940df255e9ce9cbb1b0cdef1388f63b9eae87 100644 (file)
@@ -91,12 +91,9 @@ void ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
                HIHI = 0xFF;
 
        if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
-               u16 data = (tf->hob_data << 8) | tf->data;
+               u8 data[2] = { tf->data, tf->hob_data };
 
-               if (mmio)
-                       writew(data, (void __iomem *)io_ports->data_addr);
-               else
-                       outw(data, io_ports->data_addr);
+               ide_output_data(drive, cmd, data, 2);
        }
 
        if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
@@ -145,15 +142,12 @@ void ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        }
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data;
+               u8 data[2];
 
-               if (mmio)
-                       data = readw((void __iomem *)io_ports->data_addr);
-               else
-                       data = inw(io_ports->data_addr);
+               ide_input_data(drive, cmd, data, 2);
 
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */
index 0a6cf74c326515a00c282ff508030a2b3dc42dd5..7d64bc079fa83bebb5a406ae0e39c3b4e4d5f1d0 100644 (file)
@@ -67,10 +67,12 @@ static void superio_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        struct ide_taskfile *tf = &cmd->tf;
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data = inw(io_ports->data_addr);
+               u8 data[2];
 
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               ide_input_data(drive, cmd, data, 2);
+
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */
index ea0a9752c6f96d677bf946e5c7c65a36387f22aa..9c47cbf8c506df4c7979c57ab15879dbf5ac862f 100644 (file)
@@ -656,9 +656,11 @@ static void scc_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
        if (cmd->ftf_flags & IDE_FTFLAG_FLAGGED)
                HIHI = 0xFF;
 
-       if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA)
-               out_be32((void *)io_ports->data_addr,
-                        (tf->hob_data << 8) | tf->data);
+       if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
+               u8 data[2] = { tf->data, tf->hob_data };
+
+               scc_output_data(drive, NULL, data, 2);
+       }
 
        if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
                scc_ide_outb(tf->hob_feature, io_ports->feature_addr);
@@ -693,10 +695,12 @@ static void scc_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        struct ide_taskfile *tf = &cmd->tf;
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data = (u16)in_be32((void *)io_ports->data_addr);
+               u8 data[2];
+
+               scc_input_data(drive, cmd, data, 2);
 
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */
index 606c37f5267de3baf4bcbfc97631cf82df37448d..c075464308a0f6e53ccdf00dbbf8938f860c0cf3 100644 (file)
@@ -93,10 +93,9 @@ static void tx4938ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
                HIHI = 0xFF;
 
        if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
-               u16 data = (tf->hob_data << 8) | tf->data;
+               u8 data[2] = { tf->data, tf->hob_data };
 
-               /* no endian swap */
-               __raw_writew(data, (void __iomem *)io_ports->data_addr);
+               hwif->tp_ops->output_data(drive, cmd, data, 2);
        }
 
        if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
@@ -133,12 +132,12 @@ static void tx4938ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        struct ide_taskfile *tf = &cmd->tf;
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data;
+               u8 data[2];
 
-               /* no endian swap */
-               data = __raw_readw((void __iomem *)io_ports->data_addr);
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               hwif->tp_ops->input_data(drive, cmd, data, 2);
+
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */
index f1e9da71110c8f7d153210be95ac14f8e1cd7449..c350d0c7ba4a384e543fbaa99399ef84e4fac1ac 100644 (file)
@@ -458,10 +458,9 @@ static void tx4939ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
                HIHI = 0xFF;
 
        if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
-               u16 data = (tf->hob_data << 8) | tf->data;
+               u8 data[2] = { tf->data, tf->hob_data };
 
-               /* no endian swap */
-               __raw_writew(data, (void __iomem *)io_ports->data_addr);
+               hwif->tp_ops->output_data(drive, cmd, data, 2);
        }
 
        if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
@@ -500,12 +499,12 @@ static void tx4939ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
        struct ide_taskfile *tf = &cmd->tf;
 
        if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
-               u16 data;
+               u8 data[2];
 
-               /* no endian swap */
-               data = __raw_readw((void __iomem *)io_ports->data_addr);
-               tf->data = data & 0xff;
-               tf->hob_data = (data >> 8) & 0xff;
+               hwif->tp_ops->input_data(drive, cmd, data, 2);
+
+               tf->data = data[0];
+               tf->hob_data = data[1];
        }
 
        /* be sure we're looking at the low order bits */