Commit 5501e738 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] sn: Change the definition and usage of iio_itte - make it an array

From: Pat Gefre <pfg@sgi.com>

Change the definition and usage of iio_itte - make it an array
parent aee5612f
...@@ -203,71 +203,18 @@ sn_dma_flush_init(unsigned long start, unsigned long end, int idx, int pin, int ...@@ -203,71 +203,18 @@ sn_dma_flush_init(unsigned long start, unsigned long end, int idx, int pin, int
memset(flush_nasid_list[nasid].widget_p, 0, (HUB_WIDGET_ID_MAX+1) * sizeof(struct sn_flush_device_list *)); memset(flush_nasid_list[nasid].widget_p, 0, (HUB_WIDGET_ID_MAX+1) * sizeof(struct sn_flush_device_list *));
} }
if (bwin > 0) { if (bwin > 0) {
bwin--; int itte_index = bwin - 1;
switch (bwin) { unsigned long itte;
case 0:
flush_nasid_list[nasid].iio_itte1 = HUB_L(IIO_ITTE_GET(nasid, 0)); itte = HUB_L(IIO_ITTE_GET(nasid, itte_index));
wid_num = ((flush_nasid_list[nasid].iio_itte1) >> 8) & 0xf; flush_nasid_list[nasid].iio_itte[bwin] = itte;
bus = flush_nasid_list[nasid].iio_itte1 & 0xf; wid_num = (itte >> IIO_ITTE_WIDGET_SHIFT) &
if (bus == 0x4 || bus == 0x8) IIO_ITTE_WIDGET_MASK;
bus = 0; bus = itte & IIO_ITTE_OFFSET_MASK;
else if (bus == 0x4 || bus == 0x8) {
bus = 1; bus = 0;
break; } else {
case 1: bus = 1;
flush_nasid_list[nasid].iio_itte2 = HUB_L(IIO_ITTE_GET(nasid, 1));
wid_num = ((flush_nasid_list[nasid].iio_itte2) >> 8) & 0xf;
bus = flush_nasid_list[nasid].iio_itte2 & 0xf;
if (bus == 0x4 || bus == 0x8)
bus = 0;
else
bus = 1;
break;
case 2:
flush_nasid_list[nasid].iio_itte3 = HUB_L(IIO_ITTE_GET(nasid, 2));
wid_num = ((flush_nasid_list[nasid].iio_itte3) >> 8) & 0xf;
bus = flush_nasid_list[nasid].iio_itte3 & 0xf;
if (bus == 0x4 || bus == 0x8)
bus = 0;
else
bus = 1;
break;
case 3:
flush_nasid_list[nasid].iio_itte4 = HUB_L(IIO_ITTE_GET(nasid, 3));
wid_num = ((flush_nasid_list[nasid].iio_itte4) >> 8) & 0xf;
bus = flush_nasid_list[nasid].iio_itte4 & 0xf;
if (bus == 0x4 || bus == 0x8)
bus = 0;
else
bus = 1;
break;
case 4:
flush_nasid_list[nasid].iio_itte5 = HUB_L(IIO_ITTE_GET(nasid, 4));
wid_num = ((flush_nasid_list[nasid].iio_itte5) >> 8) & 0xf;
bus = flush_nasid_list[nasid].iio_itte5 & 0xf;
if (bus == 0x4 || bus == 0x8)
bus = 0;
else
bus = 1;
break;
case 5:
flush_nasid_list[nasid].iio_itte6 = HUB_L(IIO_ITTE_GET(nasid, 5));
wid_num = ((flush_nasid_list[nasid].iio_itte6) >> 8) & 0xf;
bus = flush_nasid_list[nasid].iio_itte6 & 0xf;
if (bus == 0x4 || bus == 0x8)
bus = 0;
else
bus = 1;
break;
case 6:
flush_nasid_list[nasid].iio_itte7 = HUB_L(IIO_ITTE_GET(nasid, 6));
wid_num = ((flush_nasid_list[nasid].iio_itte7) >> 8) & 0xf;
bus = flush_nasid_list[nasid].iio_itte7 & 0xf;
if (bus == 0x4 || bus == 0x8)
bus = 0;
else
bus = 1;
break;
} }
} }
......
...@@ -156,30 +156,10 @@ sn_dma_flush(unsigned long addr) { ...@@ -156,30 +156,10 @@ sn_dma_flush(unsigned long addr) {
if (flush_nasid_list[nasid].widget_p == NULL) return; if (flush_nasid_list[nasid].widget_p == NULL) return;
if (bwin > 0) { if (bwin > 0) {
bwin--; unsigned long itte = flush_nasid_list[nasid].iio_itte[bwin];
switch (bwin) {
case 0: wid_num = (itte >> IIO_ITTE_WIDGET_SHIFT) &
wid_num = ((flush_nasid_list[nasid].iio_itte1) >> 8) & 0xf; IIO_ITTE_WIDGET_MASK;
break;
case 1:
wid_num = ((flush_nasid_list[nasid].iio_itte2) >> 8) & 0xf;
break;
case 2:
wid_num = ((flush_nasid_list[nasid].iio_itte3) >> 8) & 0xf;
break;
case 3:
wid_num = ((flush_nasid_list[nasid].iio_itte4) >> 8) & 0xf;
break;
case 4:
wid_num = ((flush_nasid_list[nasid].iio_itte5) >> 8) & 0xf;
break;
case 5:
wid_num = ((flush_nasid_list[nasid].iio_itte6) >> 8) & 0xf;
break;
case 6:
wid_num = ((flush_nasid_list[nasid].iio_itte7) >> 8) & 0xf;
break;
}
} }
if (flush_nasid_list[nasid].widget_p == NULL) return; if (flush_nasid_list[nasid].widget_p == NULL) return;
if (flush_nasid_list[nasid].widget_p[wid_num] == NULL) return; if (flush_nasid_list[nasid].widget_p[wid_num] == NULL) return;
......
...@@ -713,13 +713,7 @@ struct sn_flush_device_list { ...@@ -713,13 +713,7 @@ struct sn_flush_device_list {
struct sn_flush_nasid_entry { struct sn_flush_nasid_entry {
struct sn_flush_device_list **widget_p; struct sn_flush_device_list **widget_p;
unsigned long iio_itte1; unsigned long iio_itte[8];
unsigned long iio_itte2;
unsigned long iio_itte3;
unsigned long iio_itte4;
unsigned long iio_itte5;
unsigned long iio_itte6;
unsigned long iio_itte7;
}; };
#endif /* _ASM_SN_PCI_PCIBR_PRIVATE_H */ #endif /* _ASM_SN_PCI_PCIBR_PRIVATE_H */
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