Commit bac08cee authored by Sergei Shtylyov's avatar Sergei Shtylyov Committed by Bartlomiej Zolnierkiewicz

ide: call {in|out}put_data() methods from tf_{read|load}() methods (take 2)

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: default avatarSergei Shtylyov <sshtylyov@ru.mvista.com>
Signed-off-by: default avatarBartlomiej Zolnierkiewicz <bzolnier@gmail.com>
parent deae17fd
...@@ -196,9 +196,9 @@ static void at91_ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -196,9 +196,9 @@ static void at91_ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
HIHI = 0xFF; HIHI = 0xFF;
if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) { 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) 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) ...@@ -234,11 +234,12 @@ static void at91_ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
struct ide_taskfile *tf = &cmd->tf; struct ide_taskfile *tf = &cmd->tf;
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
u16 data; u8 data[2];
at91_ide_input_data(drive, NULL, &data, 2); at91_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 */ /* be sure we're looking at the low order bits */
......
...@@ -54,8 +54,11 @@ static void h8300_tf_load(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -54,8 +54,11 @@ static void h8300_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
if (cmd->ftf_flags & IDE_FTFLAG_FLAGGED) if (cmd->ftf_flags & IDE_FTFLAG_FLAGGED)
HIHI = 0xFF; HIHI = 0xFF;
if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
mm_outw((tf->hob_data << 8) | tf->data, io_ports->data_addr); u8 data[2] = { tf->data, tf->hob_data };
h8300_output_data(drive, cmd, data, 2);
}
if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE) if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
outb(tf->hob_feature, io_ports->feature_addr); 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) ...@@ -91,10 +94,12 @@ static void h8300_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
struct ide_taskfile *tf = &cmd->tf; struct ide_taskfile *tf = &cmd->tf;
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { 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->data = data[0];
tf->hob_data = (data >> 8) & 0xff; tf->hob_data = data[1];
} }
/* be sure we're looking at the low order bits */ /* be sure we're looking at the low order bits */
......
...@@ -91,12 +91,9 @@ void ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -91,12 +91,9 @@ void ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
HIHI = 0xFF; HIHI = 0xFF;
if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) { 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) ide_output_data(drive, cmd, data, 2);
writew(data, (void __iomem *)io_ports->data_addr);
else
outw(data, io_ports->data_addr);
} }
if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE) 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) ...@@ -145,15 +142,12 @@ void ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
} }
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
u16 data; u8 data[2];
if (mmio) ide_input_data(drive, cmd, data, 2);
data = readw((void __iomem *)io_ports->data_addr);
else
data = inw(io_ports->data_addr);
tf->data = data & 0xff; tf->data = data[0];
tf->hob_data = (data >> 8) & 0xff; tf->hob_data = data[1];
} }
/* be sure we're looking at the low order bits */ /* be sure we're looking at the low order bits */
......
...@@ -67,10 +67,12 @@ static void superio_tf_read(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -67,10 +67,12 @@ static void superio_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
struct ide_taskfile *tf = &cmd->tf; struct ide_taskfile *tf = &cmd->tf;
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
u16 data = inw(io_ports->data_addr); u8 data[2];
tf->data = data & 0xff; ide_input_data(drive, cmd, data, 2);
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 */ /* be sure we're looking at the low order bits */
......
...@@ -656,9 +656,11 @@ static void scc_tf_load(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -656,9 +656,11 @@ static void scc_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
if (cmd->ftf_flags & IDE_FTFLAG_FLAGGED) if (cmd->ftf_flags & IDE_FTFLAG_FLAGGED)
HIHI = 0xFF; HIHI = 0xFF;
if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) {
out_be32((void *)io_ports->data_addr, u8 data[2] = { tf->data, tf->hob_data };
(tf->hob_data << 8) | tf->data);
scc_output_data(drive, NULL, data, 2);
}
if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE) if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE)
scc_ide_outb(tf->hob_feature, io_ports->feature_addr); 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) ...@@ -693,10 +695,12 @@ static void scc_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
struct ide_taskfile *tf = &cmd->tf; struct ide_taskfile *tf = &cmd->tf;
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { 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->data = data[0];
tf->hob_data = (data >> 8) & 0xff; tf->hob_data = data[1];
} }
/* be sure we're looking at the low order bits */ /* be sure we're looking at the low order bits */
......
...@@ -93,10 +93,9 @@ static void tx4938ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -93,10 +93,9 @@ static void tx4938ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
HIHI = 0xFF; HIHI = 0xFF;
if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) { 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 */ hwif->tp_ops->output_data(drive, cmd, data, 2);
__raw_writew(data, (void __iomem *)io_ports->data_addr);
} }
if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE) 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) ...@@ -133,12 +132,12 @@ static void tx4938ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
struct ide_taskfile *tf = &cmd->tf; struct ide_taskfile *tf = &cmd->tf;
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
u16 data; u8 data[2];
/* no endian swap */ hwif->tp_ops->input_data(drive, cmd, data, 2);
data = __raw_readw((void __iomem *)io_ports->data_addr);
tf->data = data & 0xff; tf->data = data[0];
tf->hob_data = (data >> 8) & 0xff; tf->hob_data = data[1];
} }
/* be sure we're looking at the low order bits */ /* be sure we're looking at the low order bits */
......
...@@ -458,10 +458,9 @@ static void tx4939ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd) ...@@ -458,10 +458,9 @@ static void tx4939ide_tf_load(ide_drive_t *drive, struct ide_cmd *cmd)
HIHI = 0xFF; HIHI = 0xFF;
if (cmd->ftf_flags & IDE_FTFLAG_OUT_DATA) { 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 */ hwif->tp_ops->output_data(drive, cmd, data, 2);
__raw_writew(data, (void __iomem *)io_ports->data_addr);
} }
if (cmd->tf_flags & IDE_TFLAG_OUT_HOB_FEATURE) 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) ...@@ -500,12 +499,12 @@ static void tx4939ide_tf_read(ide_drive_t *drive, struct ide_cmd *cmd)
struct ide_taskfile *tf = &cmd->tf; struct ide_taskfile *tf = &cmd->tf;
if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) { if (cmd->ftf_flags & IDE_FTFLAG_IN_DATA) {
u16 data; u8 data[2];
/* no endian swap */ hwif->tp_ops->input_data(drive, cmd, data, 2);
data = __raw_readw((void __iomem *)io_ports->data_addr);
tf->data = data & 0xff; tf->data = data[0];
tf->hob_data = (data >> 8) & 0xff; tf->hob_data = data[1];
} }
/* be sure we're looking at the low order bits */ /* be sure we're looking at the low order bits */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment