aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/char/cyclades.c315
-rw-r--r--include/linux/cyclades.h10
2 files changed, 153 insertions, 172 deletions
diff --git a/drivers/char/cyclades.c b/drivers/char/cyclades.c
index 3b62962b3512..9bf0fb2fa0d4 100644
--- a/drivers/char/cyclades.c
+++ b/drivers/char/cyclades.c
@@ -675,13 +675,13 @@ static void cy_send_xchar(struct tty_struct *tty, char ch);
675#define IS_CYC_Z(card) ((card).num_chips == -1) 675#define IS_CYC_Z(card) ((card).num_chips == -1)
676 676
677#define Z_FPGA_CHECK(card) \ 677#define Z_FPGA_CHECK(card) \
678 ((cy_readl(&((struct RUNTIME_9060 __iomem *) \ 678 ((readl(&((struct RUNTIME_9060 __iomem *) \
679 ((card).ctl_addr))->init_ctrl) & (1<<17)) != 0) 679 ((card).ctl_addr))->init_ctrl) & (1<<17)) != 0)
680 680
681#define ISZLOADED(card) (((ZO_V1==cy_readl(&((struct RUNTIME_9060 __iomem *) \ 681#define ISZLOADED(card) (((ZO_V1==readl(&((struct RUNTIME_9060 __iomem *) \
682 ((card).ctl_addr))->mail_box_0)) || \ 682 ((card).ctl_addr))->mail_box_0)) || \
683 Z_FPGA_CHECK(card)) && \ 683 Z_FPGA_CHECK(card)) && \
684 (ZFIRM_ID==cy_readl(&((struct FIRM_ID __iomem *) \ 684 (ZFIRM_ID==readl(&((struct FIRM_ID __iomem *) \
685 ((card).base_addr+ID_ADDRESS))->signature))) 685 ((card).base_addr+ID_ADDRESS))->signature)))
686 686
687#ifndef SERIAL_XMIT_SIZE 687#ifndef SERIAL_XMIT_SIZE
@@ -972,7 +972,7 @@ static int cyy_issue_cmd(void __iomem * base_addr, u_char cmd, int index)
972 972
973 /* Check to see that the previous command has completed */ 973 /* Check to see that the previous command has completed */
974 for (i = 0; i < 100; i++) { 974 for (i = 0; i < 100; i++) {
975 if (cy_readb(base_addr + (CyCCR << index)) == 0) { 975 if (readb(base_addr + (CyCCR << index)) == 0) {
976 break; 976 break;
977 } 977 }
978 udelay(10L); 978 udelay(10L);
@@ -1015,7 +1015,7 @@ static unsigned detect_isa_irq(void __iomem * address)
1015 1015
1016 cy_writeb(address + (CyCAR << index), 0); 1016 cy_writeb(address + (CyCAR << index), 0);
1017 cy_writeb(address + (CySRER << index), 1017 cy_writeb(address + (CySRER << index),
1018 cy_readb(address + (CySRER << index)) | CyTxRdy); 1018 readb(address + (CySRER << index)) | CyTxRdy);
1019 local_irq_restore(flags); 1019 local_irq_restore(flags);
1020 1020
1021 /* Wait ... */ 1021 /* Wait ... */
@@ -1025,11 +1025,11 @@ static unsigned detect_isa_irq(void __iomem * address)
1025 irq = probe_irq_off(irqs); 1025 irq = probe_irq_off(irqs);
1026 1026
1027 /* Clean up */ 1027 /* Clean up */
1028 save_xir = (u_char) cy_readb(address + (CyTIR << index)); 1028 save_xir = (u_char) readb(address + (CyTIR << index));
1029 save_car = cy_readb(address + (CyCAR << index)); 1029 save_car = readb(address + (CyCAR << index));
1030 cy_writeb(address + (CyCAR << index), (save_xir & 0x3)); 1030 cy_writeb(address + (CyCAR << index), (save_xir & 0x3));
1031 cy_writeb(address + (CySRER << index), 1031 cy_writeb(address + (CySRER << index),
1032 cy_readb(address + (CySRER << index)) & ~CyTxRdy); 1032 readb(address + (CySRER << index)) & ~CyTxRdy);
1033 cy_writeb(address + (CyTIR << index), (save_xir & 0x3f)); 1033 cy_writeb(address + (CyTIR << index), (save_xir & 0x3f));
1034 cy_writeb(address + (CyCAR << index), (save_car)); 1034 cy_writeb(address + (CyCAR << index), (save_car));
1035 cy_writeb(address + (Cy_ClrIntr << index), 0); 1035 cy_writeb(address + (Cy_ClrIntr << index), 0);
@@ -1055,34 +1055,34 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1055#endif 1055#endif
1056 /* determine the channel & change to that context */ 1056 /* determine the channel & change to that context */
1057 spin_lock(&cinfo->card_lock); 1057 spin_lock(&cinfo->card_lock);
1058 save_xir = (u_char) cy_readb(base_addr + (CyRIR << index)); 1058 save_xir = (u_char) readb(base_addr + (CyRIR << index));
1059 channel = (u_short) (save_xir & CyIRChannel); 1059 channel = (u_short) (save_xir & CyIRChannel);
1060 i = channel + chip * 4 + cinfo->first_line; 1060 i = channel + chip * 4 + cinfo->first_line;
1061 info = &cy_port[i]; 1061 info = &cy_port[i];
1062 info->last_active = jiffies; 1062 info->last_active = jiffies;
1063 save_car = cy_readb(base_addr + (CyCAR << index)); 1063 save_car = readb(base_addr + (CyCAR << index));
1064 cy_writeb(base_addr + (CyCAR << index), save_xir); 1064 cy_writeb(base_addr + (CyCAR << index), save_xir);
1065 1065
1066 /* if there is nowhere to put the data, discard it */ 1066 /* if there is nowhere to put the data, discard it */
1067 if (info->tty == 0) { 1067 if (info->tty == 0) {
1068 j = (cy_readb(base_addr + (CyRIVR << index)) & 1068 j = (readb(base_addr + (CyRIVR << index)) &
1069 CyIVRMask); 1069 CyIVRMask);
1070 if (j == CyIVRRxEx) { /* exception */ 1070 if (j == CyIVRRxEx) { /* exception */
1071 data = cy_readb(base_addr + (CyRDSR << index)); 1071 data = readb(base_addr + (CyRDSR << index));
1072 } else { /* normal character reception */ 1072 } else { /* normal character reception */
1073 char_count = cy_readb(base_addr + 1073 char_count = readb(base_addr +
1074 (CyRDCR << index)); 1074 (CyRDCR << index));
1075 while (char_count--) { 1075 while (char_count--) {
1076 data = cy_readb(base_addr + 1076 data = readb(base_addr +
1077 (CyRDSR << index)); 1077 (CyRDSR << index));
1078 } 1078 }
1079 } 1079 }
1080 } else { /* there is an open port for this data */ 1080 } else { /* there is an open port for this data */
1081 tty = info->tty; 1081 tty = info->tty;
1082 j = (cy_readb(base_addr + (CyRIVR << index)) & 1082 j = (readb(base_addr + (CyRIVR << index)) &
1083 CyIVRMask); 1083 CyIVRMask);
1084 if (j == CyIVRRxEx) { /* exception */ 1084 if (j == CyIVRRxEx) { /* exception */
1085 data = cy_readb(base_addr + (CyRDSR << index)); 1085 data = readb(base_addr + (CyRDSR << index));
1086 1086
1087 /* For statistics only */ 1087 /* For statistics only */
1088 if (data & CyBREAK) 1088 if (data & CyBREAK)
@@ -1103,7 +1103,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1103 if (data & CyBREAK) { 1103 if (data & CyBREAK) {
1104 tty_insert_flip_char( 1104 tty_insert_flip_char(
1105 tty, 1105 tty,
1106 cy_readb( 1106 readb(
1107 base_addr + 1107 base_addr +
1108 (CyRDSR << 1108 (CyRDSR <<
1109 index)), 1109 index)),
@@ -1116,7 +1116,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1116 } else if (data & CyFRAME) { 1116 } else if (data & CyFRAME) {
1117 tty_insert_flip_char( 1117 tty_insert_flip_char(
1118 tty, 1118 tty,
1119 cy_readb( 1119 readb(
1120 base_addr + 1120 base_addr +
1121 (CyRDSR << 1121 (CyRDSR <<
1122 index)), 1122 index)),
@@ -1128,7 +1128,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1128 /* Pieces of seven... */ 1128 /* Pieces of seven... */
1129 tty_insert_flip_char( 1129 tty_insert_flip_char(
1130 tty, 1130 tty,
1131 cy_readb( 1131 readb(
1132 base_addr + 1132 base_addr +
1133 (CyRDSR << 1133 (CyRDSR <<
1134 index)), 1134 index)),
@@ -1147,7 +1147,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1147 */ 1147 */
1148 tty_insert_flip_char( 1148 tty_insert_flip_char(
1149 tty, 1149 tty,
1150 cy_readb( 1150 readb(
1151 base_addr + 1151 base_addr +
1152 (CyRDSR << 1152 (CyRDSR <<
1153 index)), 1153 index)),
@@ -1179,7 +1179,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1179 } 1179 }
1180 } else { /* normal character reception */ 1180 } else { /* normal character reception */
1181 /* load # chars available from the chip */ 1181 /* load # chars available from the chip */
1182 char_count = cy_readb(base_addr + 1182 char_count = readb(base_addr +
1183 (CyRDCR << index)); 1183 (CyRDCR << index));
1184 1184
1185#ifdef CY_ENABLE_MONITORING 1185#ifdef CY_ENABLE_MONITORING
@@ -1191,7 +1191,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1191#endif 1191#endif
1192 len = tty_buffer_request_room(tty, char_count); 1192 len = tty_buffer_request_room(tty, char_count);
1193 while (len--) { 1193 while (len--) {
1194 data = cy_readb(base_addr + 1194 data = readb(base_addr +
1195 (CyRDSR << index)); 1195 (CyRDSR << index));
1196 tty_insert_flip_char(tty, data, 1196 tty_insert_flip_char(tty, data,
1197 TTY_NORMAL); 1197 TTY_NORMAL);
@@ -1221,16 +1221,16 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1221 1221
1222 /* determine the channel & change to that context */ 1222 /* determine the channel & change to that context */
1223 spin_lock(&cinfo->card_lock); 1223 spin_lock(&cinfo->card_lock);
1224 save_xir = (u_char) cy_readb(base_addr + (CyTIR << index)); 1224 save_xir = (u_char) readb(base_addr + (CyTIR << index));
1225 channel = (u_short) (save_xir & CyIRChannel); 1225 channel = (u_short) (save_xir & CyIRChannel);
1226 i = channel + chip * 4 + cinfo->first_line; 1226 i = channel + chip * 4 + cinfo->first_line;
1227 save_car = cy_readb(base_addr + (CyCAR << index)); 1227 save_car = readb(base_addr + (CyCAR << index));
1228 cy_writeb(base_addr + (CyCAR << index), save_xir); 1228 cy_writeb(base_addr + (CyCAR << index), save_xir);
1229 1229
1230 /* validate the port# (as configured and open) */ 1230 /* validate the port# (as configured and open) */
1231 if ((i < 0) || (NR_PORTS <= i)) { 1231 if ((i < 0) || (NR_PORTS <= i)) {
1232 cy_writeb(base_addr + (CySRER << index), 1232 cy_writeb(base_addr + (CySRER << index),
1233 cy_readb(base_addr + (CySRER << index)) & 1233 readb(base_addr + (CySRER << index)) &
1234 ~CyTxRdy); 1234 ~CyTxRdy);
1235 goto txend; 1235 goto txend;
1236 } 1236 }
@@ -1238,7 +1238,7 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1238 info->last_active = jiffies; 1238 info->last_active = jiffies;
1239 if (info->tty == 0) { 1239 if (info->tty == 0) {
1240 cy_writeb(base_addr + (CySRER << index), 1240 cy_writeb(base_addr + (CySRER << index),
1241 cy_readb(base_addr + (CySRER << index)) & 1241 readb(base_addr + (CySRER << index)) &
1242 ~CyTxRdy); 1242 ~CyTxRdy);
1243 goto txdone; 1243 goto txdone;
1244 } 1244 }
@@ -1271,15 +1271,15 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1271 1271
1272 while (char_count-- > 0) { 1272 while (char_count-- > 0) {
1273 if (!info->xmit_cnt) { 1273 if (!info->xmit_cnt) {
1274 if (cy_readb(base_addr + (CySRER << index)) & 1274 if (readb(base_addr + (CySRER << index)) &
1275 CyTxMpty) { 1275 CyTxMpty) {
1276 cy_writeb(base_addr + (CySRER << index), 1276 cy_writeb(base_addr + (CySRER << index),
1277 cy_readb(base_addr + 1277 readb(base_addr +
1278 (CySRER << index)) & 1278 (CySRER << index)) &
1279 ~CyTxMpty); 1279 ~CyTxMpty);
1280 } else { 1280 } else {
1281 cy_writeb(base_addr + (CySRER << index), 1281 cy_writeb(base_addr + (CySRER << index),
1282 (cy_readb(base_addr + 1282 (readb(base_addr +
1283 (CySRER << index)) & 1283 (CySRER << index)) &
1284 ~CyTxRdy) | CyTxMpty); 1284 ~CyTxRdy) | CyTxMpty);
1285 } 1285 }
@@ -1287,13 +1287,13 @@ static void cyy_intr_chip(struct cyclades_card *cinfo, int chip,
1287 } 1287 }
1288 if (info->xmit_buf == 0) { 1288 if (info->xmit_buf == 0) {
1289 cy_writeb(base_addr + (CySRER << index), 1289 cy_writeb(base_addr + (CySRER << index),
1290 cy_readb(base_addr + (CySRER << index))& 1290 readb(base_addr + (CySRER << index)) &
1291 ~CyTxRdy); 1291 ~CyTxRdy);
1292 goto txdone; 1292 goto txdone;
1293 } 1293 }
1294 if (info->tty->stopped || info->tty->hw_stopped) { 1294 if (info->tty->stopped || info->tty->hw_stopped) {
1295 cy_writeb(base_addr + (CySRER << index), 1295 cy_writeb(base_addr + (CySRER << index),
1296 cy_readb(base_addr + (CySRER << index))& 1296 readb(base_addr + (CySRER << index)) &
1297 ~CyTxRdy); 1297 ~CyTxRdy);
1298 goto txdone; 1298 goto txdone;
1299 } 1299 }
@@ -1346,15 +1346,15 @@ txend:
1346 1346
1347 /* determine the channel & change to that context */ 1347 /* determine the channel & change to that context */
1348 spin_lock(&cinfo->card_lock); 1348 spin_lock(&cinfo->card_lock);
1349 save_xir = (u_char) cy_readb(base_addr + (CyMIR << index)); 1349 save_xir = (u_char) readb(base_addr + (CyMIR << index));
1350 channel = (u_short) (save_xir & CyIRChannel); 1350 channel = (u_short) (save_xir & CyIRChannel);
1351 info = &cy_port[channel + chip * 4 + cinfo->first_line]; 1351 info = &cy_port[channel + chip * 4 + cinfo->first_line];
1352 info->last_active = jiffies; 1352 info->last_active = jiffies;
1353 save_car = cy_readb(base_addr + (CyCAR << index)); 1353 save_car = readb(base_addr + (CyCAR << index));
1354 cy_writeb(base_addr + (CyCAR << index), save_xir); 1354 cy_writeb(base_addr + (CyCAR << index), save_xir);
1355 1355
1356 mdm_change = cy_readb(base_addr + (CyMISR << index)); 1356 mdm_change = readb(base_addr + (CyMISR << index));
1357 mdm_status = cy_readb(base_addr + (CyMSVR1 << index)); 1357 mdm_status = readb(base_addr + (CyMSVR1 << index));
1358 1358
1359 if (info->tty == 0) { /* no place for data, ignore it */ 1359 if (info->tty == 0) { /* no place for data, ignore it */
1360 ; 1360 ;
@@ -1391,7 +1391,7 @@ txend:
1391 info->tty->hw_stopped = 0; 1391 info->tty->hw_stopped = 0;
1392 cy_writeb(base_addr + 1392 cy_writeb(base_addr +
1393 (CySRER << index), 1393 (CySRER << index),
1394 cy_readb(base_addr + 1394 readb(base_addr +
1395 (CySRER << 1395 (CySRER <<
1396 index))| 1396 index))|
1397 CyTxRdy); 1397 CyTxRdy);
@@ -1405,7 +1405,7 @@ txend:
1405 info->tty->hw_stopped = 1; 1405 info->tty->hw_stopped = 1;
1406 cy_writeb(base_addr + 1406 cy_writeb(base_addr +
1407 (CySRER << index), 1407 (CySRER << index),
1408 cy_readb(base_addr + 1408 readb(base_addr +
1409 (CySRER << 1409 (CySRER <<
1410 index)) & 1410 index)) &
1411 ~CyTxRdy); 1411 ~CyTxRdy);
@@ -1459,7 +1459,7 @@ static irqreturn_t cyy_interrupt(int irq, void *dev_id)
1459 base_addr = cinfo->base_addr + 1459 base_addr = cinfo->base_addr +
1460 (cy_chip_offset[chip] << index); 1460 (cy_chip_offset[chip] << index);
1461 too_many = 0; 1461 too_many = 0;
1462 while ((status = cy_readb(base_addr + 1462 while ((status = readb(base_addr +
1463 (CySVRR << index))) != 0x00) { 1463 (CySVRR << index))) != 0x00) {
1464 had_work++; 1464 had_work++;
1465 /* The purpose of the following test is to ensure that 1465 /* The purpose of the following test is to ensure that
@@ -1502,16 +1502,15 @@ cyz_fetch_msg(struct cyclades_card *cinfo,
1502 if (!ISZLOADED(*cinfo)) { 1502 if (!ISZLOADED(*cinfo)) {
1503 return -1; 1503 return -1;
1504 } 1504 }
1505 zfw_ctrl = cinfo->base_addr + (cy_readl(&firm_id->zfwctrl_addr) & 1505 zfw_ctrl = cinfo->base_addr + (readl(&firm_id->zfwctrl_addr) & 0xfffff);
1506 0xfffff);
1507 board_ctrl = &zfw_ctrl->board_ctrl; 1506 board_ctrl = &zfw_ctrl->board_ctrl;
1508 1507
1509 loc_doorbell = cy_readl(&((struct RUNTIME_9060 __iomem *) 1508 loc_doorbell = readl(&((struct RUNTIME_9060 __iomem *)
1510 (cinfo->ctl_addr))->loc_doorbell); 1509 (cinfo->ctl_addr))->loc_doorbell);
1511 if (loc_doorbell) { 1510 if (loc_doorbell) {
1512 *cmd = (char)(0xff & loc_doorbell); 1511 *cmd = (char)(0xff & loc_doorbell);
1513 *channel = cy_readl(&board_ctrl->fwcmd_channel); 1512 *channel = readl(&board_ctrl->fwcmd_channel);
1514 *param = (__u32) cy_readl(&board_ctrl->fwcmd_param); 1513 *param = (__u32) readl(&board_ctrl->fwcmd_param);
1515 cy_writel(&((struct RUNTIME_9060 __iomem *)(cinfo->ctl_addr))-> 1514 cy_writel(&((struct RUNTIME_9060 __iomem *)(cinfo->ctl_addr))->
1516 loc_doorbell, 0xffffffff); 1515 loc_doorbell, 0xffffffff);
1517 return 1; 1516 return 1;
@@ -1533,16 +1532,15 @@ cyz_issue_cmd(struct cyclades_card *cinfo,
1533 if (!ISZLOADED(*cinfo)) { 1532 if (!ISZLOADED(*cinfo)) {
1534 return -1; 1533 return -1;
1535 } 1534 }
1536 zfw_ctrl = cinfo->base_addr + (cy_readl(&firm_id->zfwctrl_addr) & 1535 zfw_ctrl = cinfo->base_addr + (readl(&firm_id->zfwctrl_addr) & 0xfffff);
1537 0xfffff);
1538 board_ctrl = &zfw_ctrl->board_ctrl; 1536 board_ctrl = &zfw_ctrl->board_ctrl;
1539 1537
1540 index = 0; 1538 index = 0;
1541 pci_doorbell = 1539 pci_doorbell =
1542 &((struct RUNTIME_9060 __iomem *)(cinfo->ctl_addr))->pci_doorbell; 1540 &((struct RUNTIME_9060 __iomem *)(cinfo->ctl_addr))->pci_doorbell;
1543 while ((cy_readl(pci_doorbell) & 0xff) != 0) { 1541 while ((readl(pci_doorbell) & 0xff) != 0) {
1544 if (index++ == 1000) { 1542 if (index++ == 1000) {
1545 return (int)(cy_readl(pci_doorbell) & 0xff); 1543 return (int)(readl(pci_doorbell) & 0xff);
1546 } 1544 }
1547 udelay(50L); 1545 udelay(50L);
1548 } 1546 }
@@ -1569,10 +1567,10 @@ cyz_handle_rx(struct cyclades_port *info,
1569#endif 1567#endif
1570 volatile __u32 rx_put, rx_get, new_rx_get, rx_bufsize, rx_bufaddr; 1568 volatile __u32 rx_put, rx_get, new_rx_get, rx_bufsize, rx_bufaddr;
1571 1569
1572 rx_get = new_rx_get = cy_readl(&buf_ctrl->rx_get); 1570 rx_get = new_rx_get = readl(&buf_ctrl->rx_get);
1573 rx_put = cy_readl(&buf_ctrl->rx_put); 1571 rx_put = readl(&buf_ctrl->rx_put);
1574 rx_bufsize = cy_readl(&buf_ctrl->rx_bufsize); 1572 rx_bufsize = readl(&buf_ctrl->rx_bufsize);
1575 rx_bufaddr = cy_readl(&buf_ctrl->rx_bufaddr); 1573 rx_bufaddr = readl(&buf_ctrl->rx_bufaddr);
1576 if (rx_put >= rx_get) 1574 if (rx_put >= rx_get)
1577 char_count = rx_put - rx_get; 1575 char_count = rx_put - rx_get;
1578 else 1576 else
@@ -1622,7 +1620,7 @@ cyz_handle_rx(struct cyclades_port *info,
1622#else 1620#else
1623 len = tty_buffer_request_room(tty, char_count); 1621 len = tty_buffer_request_room(tty, char_count);
1624 while (len--) { 1622 while (len--) {
1625 data = cy_readb(cinfo->base_addr + rx_bufaddr + 1623 data = readb(cinfo->base_addr + rx_bufaddr +
1626 new_rx_get); 1624 new_rx_get);
1627 new_rx_get = (new_rx_get + 1)& (rx_bufsize - 1); 1625 new_rx_get = (new_rx_get + 1)& (rx_bufsize - 1);
1628 tty_insert_flip_char(tty, data, TTY_NORMAL); 1626 tty_insert_flip_char(tty, data, TTY_NORMAL);
@@ -1633,13 +1631,12 @@ cyz_handle_rx(struct cyclades_port *info,
1633#ifdef CONFIG_CYZ_INTR 1631#ifdef CONFIG_CYZ_INTR
1634 /* Recalculate the number of chars in the RX buffer and issue 1632 /* Recalculate the number of chars in the RX buffer and issue
1635 a cmd in case it's higher than the RX high water mark */ 1633 a cmd in case it's higher than the RX high water mark */
1636 rx_put = cy_readl(&buf_ctrl->rx_put); 1634 rx_put = readl(&buf_ctrl->rx_put);
1637 if (rx_put >= rx_get) 1635 if (rx_put >= rx_get)
1638 char_count = rx_put - rx_get; 1636 char_count = rx_put - rx_get;
1639 else 1637 else
1640 char_count = rx_put - rx_get + rx_bufsize; 1638 char_count = rx_put - rx_get + rx_bufsize;
1641 if (char_count >= (int)cy_readl(&buf_ctrl-> 1639 if (char_count >= (int)readl(&buf_ctrl->rx_threshold)) {
1642 rx_threshold)) {
1643 cy_sched_event(info, Cy_EVENT_Z_RX_FULL); 1640 cy_sched_event(info, Cy_EVENT_Z_RX_FULL);
1644 } 1641 }
1645#endif 1642#endif
@@ -1668,10 +1665,10 @@ cyz_handle_tx(struct cyclades_port *info,
1668 if (info->xmit_cnt <= 0) /* Nothing to transmit */ 1665 if (info->xmit_cnt <= 0) /* Nothing to transmit */
1669 return; 1666 return;
1670 1667
1671 tx_get = cy_readl(&buf_ctrl->tx_get); 1668 tx_get = readl(&buf_ctrl->tx_get);
1672 tx_put = cy_readl(&buf_ctrl->tx_put); 1669 tx_put = readl(&buf_ctrl->tx_put);
1673 tx_bufsize = cy_readl(&buf_ctrl->tx_bufsize); 1670 tx_bufsize = readl(&buf_ctrl->tx_bufsize);
1674 tx_bufaddr = cy_readl(&buf_ctrl->tx_bufaddr); 1671 tx_bufaddr = readl(&buf_ctrl->tx_bufaddr);
1675 if (tx_put >= tx_get) 1672 if (tx_put >= tx_get)
1676 char_count = tx_get - tx_put - 1 + tx_bufsize; 1673 char_count = tx_get - tx_put - 1 + tx_bufsize;
1677 else 1674 else
@@ -1756,11 +1753,10 @@ static void cyz_handle_cmd(struct cyclades_card *cinfo)
1756 int delta_count; 1753 int delta_count;
1757 1754
1758 firm_id = cinfo->base_addr + ID_ADDRESS; 1755 firm_id = cinfo->base_addr + ID_ADDRESS;
1759 zfw_ctrl = cinfo->base_addr + (cy_readl(&firm_id->zfwctrl_addr) & 1756 zfw_ctrl = cinfo->base_addr + (readl(&firm_id->zfwctrl_addr) & 0xfffff);
1760 0xfffff);
1761 board_ctrl = &zfw_ctrl->board_ctrl; 1757 board_ctrl = &zfw_ctrl->board_ctrl;
1762 fw_ver = cy_readl(&board_ctrl->fw_version); 1758 fw_ver = readl(&board_ctrl->fw_version);
1763 hw_ver = cy_readl(&((struct RUNTIME_9060 __iomem *)(cinfo->ctl_addr))-> 1759 hw_ver = readl(&((struct RUNTIME_9060 __iomem *)(cinfo->ctl_addr))->
1764 mail_box_0); 1760 mail_box_0);
1765 1761
1766 while (cyz_fetch_msg(cinfo, &channel, &cmd, &param) == 1) { 1762 while (cyz_fetch_msg(cinfo, &channel, &cmd, &param) == 1) {
@@ -1794,7 +1790,7 @@ static void cyz_handle_cmd(struct cyclades_card *cinfo)
1794 delta_count++; 1790 delta_count++;
1795 if (info->flags & ASYNC_CHECK_CD) { 1791 if (info->flags & ASYNC_CHECK_CD) {
1796 if ((fw_ver > 241 ? ((u_long) param) : 1792 if ((fw_ver > 241 ? ((u_long) param) :
1797 cy_readl(&ch_ctrl->rs_status)) & 1793 readl(&ch_ctrl->rs_status)) &
1798 C_RS_DCD) { 1794 C_RS_DCD) {
1799 cy_sched_event(info, 1795 cy_sched_event(info,
1800 Cy_EVENT_OPEN_WAKEUP); 1796 Cy_EVENT_OPEN_WAKEUP);
@@ -1923,12 +1919,12 @@ static void cyz_poll(unsigned long arg)
1923 1919
1924 firm_id = cinfo->base_addr + ID_ADDRESS; 1920 firm_id = cinfo->base_addr + ID_ADDRESS;
1925 zfw_ctrl = cinfo->base_addr + 1921 zfw_ctrl = cinfo->base_addr +
1926 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 1922 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
1927 board_ctrl = &(zfw_ctrl->board_ctrl); 1923 board_ctrl = &(zfw_ctrl->board_ctrl);
1928 1924
1929 /* Skip first polling cycle to avoid racing conditions with the FW */ 1925 /* Skip first polling cycle to avoid racing conditions with the FW */
1930 if (!cinfo->intr_enabled) { 1926 if (!cinfo->intr_enabled) {
1931 cinfo->nports = (int)cy_readl(&board_ctrl->n_channel); 1927 cinfo->nports = (int)readl(&board_ctrl->n_channel);
1932 cinfo->intr_enabled = 1; 1928 cinfo->intr_enabled = 1;
1933 continue; 1929 continue;
1934 } 1930 }
@@ -2029,12 +2025,12 @@ static int startup(struct cyclades_port *info)
2029#ifdef CY_DEBUG_DTR 2025#ifdef CY_DEBUG_DTR
2030 printk("cyc:startup raising DTR\n"); 2026 printk("cyc:startup raising DTR\n");
2031 printk(" status: 0x%x, 0x%x\n", 2027 printk(" status: 0x%x, 0x%x\n",
2032 cy_readb(base_addr + (CyMSVR1 << index)), 2028 readb(base_addr + (CyMSVR1 << index)),
2033 cy_readb(base_addr + (CyMSVR2 << index))); 2029 readb(base_addr + (CyMSVR2 << index)));
2034#endif 2030#endif
2035 2031
2036 cy_writeb(base_addr + (CySRER << index), 2032 cy_writeb(base_addr + (CySRER << index),
2037 cy_readb(base_addr + (CySRER << index)) | CyRxData); 2033 readb(base_addr + (CySRER << index)) | CyRxData);
2038 info->flags |= ASYNC_INITIALIZED; 2034 info->flags |= ASYNC_INITIALIZED;
2039 2035
2040 if (info->tty) { 2036 if (info->tty) {
@@ -2064,7 +2060,7 @@ static int startup(struct cyclades_port *info)
2064 } 2060 }
2065 2061
2066 zfw_ctrl = cy_card[card].base_addr + 2062 zfw_ctrl = cy_card[card].base_addr +
2067 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 2063 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
2068 board_ctrl = &zfw_ctrl->board_ctrl; 2064 board_ctrl = &zfw_ctrl->board_ctrl;
2069 ch_ctrl = zfw_ctrl->ch_ctrl; 2065 ch_ctrl = zfw_ctrl->ch_ctrl;
2070 2066
@@ -2112,7 +2108,7 @@ static int startup(struct cyclades_port *info)
2112 /* set timeout !!! */ 2108 /* set timeout !!! */
2113 /* set RTS and DTR !!! */ 2109 /* set RTS and DTR !!! */
2114 cy_writel(&ch_ctrl[channel].rs_control, 2110 cy_writel(&ch_ctrl[channel].rs_control,
2115 cy_readl(&ch_ctrl[channel].rs_control) | C_RS_RTS | 2111 readl(&ch_ctrl[channel].rs_control) | C_RS_RTS |
2116 C_RS_DTR); 2112 C_RS_DTR);
2117 retval = cyz_issue_cmd(&cy_card[info->card], channel, 2113 retval = cyz_issue_cmd(&cy_card[info->card], channel,
2118 C_CM_IOCTLM, 0L); 2114 C_CM_IOCTLM, 0L);
@@ -2168,7 +2164,7 @@ static void start_xmit(struct cyclades_port *info)
2168 CY_LOCK(info, flags); 2164 CY_LOCK(info, flags);
2169 cy_writeb(base_addr + (CyCAR << index), channel); 2165 cy_writeb(base_addr + (CyCAR << index), channel);
2170 cy_writeb(base_addr + (CySRER << index), 2166 cy_writeb(base_addr + (CySRER << index),
2171 cy_readb(base_addr + (CySRER << index)) | CyTxRdy); 2167 readb(base_addr + (CySRER << index)) | CyTxRdy);
2172 CY_UNLOCK(info, flags); 2168 CY_UNLOCK(info, flags);
2173 } else { 2169 } else {
2174#ifdef CONFIG_CYZ_INTR 2170#ifdef CONFIG_CYZ_INTR
@@ -2235,8 +2231,8 @@ static void shutdown(struct cyclades_port *info)
2235#ifdef CY_DEBUG_DTR 2231#ifdef CY_DEBUG_DTR
2236 printk("cyc shutdown dropping DTR\n"); 2232 printk("cyc shutdown dropping DTR\n");
2237 printk(" status: 0x%x, 0x%x\n", 2233 printk(" status: 0x%x, 0x%x\n",
2238 cy_readb(base_addr + (CyMSVR1 << index)), 2234 readb(base_addr + (CyMSVR1 << index)),
2239 cy_readb(base_addr + (CyMSVR2 << index))); 2235 readb(base_addr + (CyMSVR2 << index)));
2240#endif 2236#endif
2241 } 2237 }
2242 cyy_issue_cmd(base_addr, CyCHAN_CTL | CyDIS_RCVR, index); 2238 cyy_issue_cmd(base_addr, CyCHAN_CTL | CyDIS_RCVR, index);
@@ -2267,7 +2263,7 @@ static void shutdown(struct cyclades_port *info)
2267 } 2263 }
2268 2264
2269 zfw_ctrl = cy_card[card].base_addr + 2265 zfw_ctrl = cy_card[card].base_addr +
2270 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 2266 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
2271 board_ctrl = &zfw_ctrl->board_ctrl; 2267 board_ctrl = &zfw_ctrl->board_ctrl;
2272 ch_ctrl = zfw_ctrl->ch_ctrl; 2268 ch_ctrl = zfw_ctrl->ch_ctrl;
2273 2269
@@ -2282,7 +2278,7 @@ static void shutdown(struct cyclades_port *info)
2282 2278
2283 if (!info->tty || (info->tty->termios->c_cflag & HUPCL)) { 2279 if (!info->tty || (info->tty->termios->c_cflag & HUPCL)) {
2284 cy_writel(&ch_ctrl[channel].rs_control, 2280 cy_writel(&ch_ctrl[channel].rs_control,
2285 (__u32)(cy_readl(&ch_ctrl[channel].rs_control)& 2281 (__u32)(readl(&ch_ctrl[channel].rs_control) &
2286 ~(C_RS_RTS | C_RS_DTR))); 2282 ~(C_RS_RTS | C_RS_DTR)));
2287 retval = cyz_issue_cmd(&cy_card[info->card], channel, 2283 retval = cyz_issue_cmd(&cy_card[info->card], channel,
2288 C_CM_IOCTLM, 0L); 2284 C_CM_IOCTLM, 0L);
@@ -2390,10 +2386,8 @@ block_til_ready(struct tty_struct *tty, struct file *filp,
2390#ifdef CY_DEBUG_DTR 2386#ifdef CY_DEBUG_DTR
2391 printk("cyc:block_til_ready raising DTR\n"); 2387 printk("cyc:block_til_ready raising DTR\n");
2392 printk(" status: 0x%x, 0x%x\n", 2388 printk(" status: 0x%x, 0x%x\n",
2393 cy_readb(base_addr + 2389 readb(base_addr + (CyMSVR1 << index)),
2394 (CyMSVR1 << index)), 2390 readb(base_addr + (CyMSVR2 << index)));
2395 cy_readb(base_addr +
2396 (CyMSVR2 << index)));
2397#endif 2391#endif
2398 } 2392 }
2399 CY_UNLOCK(info, flags); 2393 CY_UNLOCK(info, flags);
@@ -2410,7 +2404,7 @@ block_til_ready(struct tty_struct *tty, struct file *filp,
2410 cy_writeb(base_addr + (CyCAR << index), 2404 cy_writeb(base_addr + (CyCAR << index),
2411 (u_char) channel); 2405 (u_char) channel);
2412 if (!(info->flags & ASYNC_CLOSING) && (C_CLOCAL(tty) || 2406 if (!(info->flags & ASYNC_CLOSING) && (C_CLOCAL(tty) ||
2413 (cy_readb(base_addr + 2407 (readb(base_addr +
2414 (CyMSVR1 << index)) & CyDCD))) { 2408 (CyMSVR1 << index)) & CyDCD))) {
2415 CY_UNLOCK(info, flags); 2409 CY_UNLOCK(info, flags);
2416 break; 2410 break;
@@ -2444,19 +2438,17 @@ block_til_ready(struct tty_struct *tty, struct file *filp,
2444 return -EINVAL; 2438 return -EINVAL;
2445 } 2439 }
2446 2440
2447 zfw_ctrl = base_addr + (cy_readl(&firm_id->zfwctrl_addr) & 2441 zfw_ctrl = base_addr + (readl(&firm_id->zfwctrl_addr)& 0xfffff);
2448 0xfffff);
2449 board_ctrl = &zfw_ctrl->board_ctrl; 2442 board_ctrl = &zfw_ctrl->board_ctrl;
2450 ch_ctrl = zfw_ctrl->ch_ctrl; 2443 ch_ctrl = zfw_ctrl->ch_ctrl;
2451 2444
2452 while (1) { 2445 while (1) {
2453 if ((tty->termios->c_cflag & CBAUD)) { 2446 if ((tty->termios->c_cflag & CBAUD)) {
2454 cy_writel(&ch_ctrl[channel].rs_control, 2447 cy_writel(&ch_ctrl[channel].rs_control,
2455 cy_readl(&ch_ctrl[channel]. 2448 readl(&ch_ctrl[channel].rs_control) |
2456 rs_control) | (C_RS_RTS | 2449 C_RS_RTS | C_RS_DTR);
2457 C_RS_DTR));
2458 retval = cyz_issue_cmd(&cy_card[info->card], 2450 retval = cyz_issue_cmd(&cy_card[info->card],
2459 channel, C_CM_IOCTLM, 0L); 2451 channel, C_CM_IOCTLM, 0L);
2460 if (retval != 0) { 2452 if (retval != 0) {
2461 printk("cyc:block_til_ready retval on " 2453 printk("cyc:block_til_ready retval on "
2462 "ttyC%d was %x\n", 2454 "ttyC%d was %x\n",
@@ -2475,7 +2467,7 @@ block_til_ready(struct tty_struct *tty, struct file *filp,
2475 break; 2467 break;
2476 } 2468 }
2477 if (!(info->flags & ASYNC_CLOSING) && (C_CLOCAL(tty) || 2469 if (!(info->flags & ASYNC_CLOSING) && (C_CLOCAL(tty) ||
2478 (cy_readl(&ch_ctrl[channel].rs_status) & 2470 (readl(&ch_ctrl[channel].rs_status) &
2479 C_RS_DCD))) { 2471 C_RS_DCD))) {
2480 break; 2472 break;
2481 } 2473 }
@@ -2540,11 +2532,10 @@ static int cy_open(struct tty_struct *tty, struct file *filp)
2540 struct FIRM_ID __iomem *firm_id = cinfo->base_addr + ID_ADDRESS; 2532 struct FIRM_ID __iomem *firm_id = cinfo->base_addr + ID_ADDRESS;
2541 2533
2542 if (!ISZLOADED(*cinfo)) { 2534 if (!ISZLOADED(*cinfo)) {
2543 if (((ZE_V1 == cy_readl( 2535 if (((ZE_V1 == readl(&((struct RUNTIME_9060 __iomem *)
2544 &((struct RUNTIME_9060 __iomem *)
2545 (cinfo->ctl_addr))->mail_box_0)) && 2536 (cinfo->ctl_addr))->mail_box_0)) &&
2546 Z_FPGA_CHECK(*cinfo)) && 2537 Z_FPGA_CHECK(*cinfo)) &&
2547 (ZFIRM_HLT == cy_readl( 2538 (ZFIRM_HLT == readl(
2548 &firm_id->signature))) { 2539 &firm_id->signature))) {
2549 printk("cyc:Cyclades-Z Error: you need an " 2540 printk("cyc:Cyclades-Z Error: you need an "
2550 "external power supply for this number " 2541 "external power supply for this number "
@@ -2565,15 +2556,14 @@ static int cy_open(struct tty_struct *tty, struct file *filp)
2565 struct BOARD_CTRL __iomem *board_ctrl; 2556 struct BOARD_CTRL __iomem *board_ctrl;
2566 2557
2567 zfw_ctrl = cinfo->base_addr + 2558 zfw_ctrl = cinfo->base_addr +
2568 (cy_readl(&firm_id->zfwctrl_addr) & 2559 (readl(&firm_id->zfwctrl_addr) &
2569 0xfffff); 2560 0xfffff);
2570 2561
2571 board_ctrl = &zfw_ctrl->board_ctrl; 2562 board_ctrl = &zfw_ctrl->board_ctrl;
2572 2563
2573 /* Enable interrupts on the PLX chip */ 2564 /* Enable interrupts on the PLX chip */
2574 cy_writew(cinfo->ctl_addr + 0x68, 2565 cy_writew(cinfo->ctl_addr + 0x68,
2575 cy_readw(cinfo->ctl_addr + 2566 readw(cinfo->ctl_addr + 0x68) | 0x0900);
2576 0x68) | 0x0900);
2577 /* Enable interrupts on the FW */ 2567 /* Enable interrupts on the FW */
2578 retval = cyz_issue_cmd(cinfo, 0, 2568 retval = cyz_issue_cmd(cinfo, 0,
2579 C_CM_IRQ_ENBL, 0L); 2569 C_CM_IRQ_ENBL, 0L);
@@ -2582,7 +2572,7 @@ static int cy_open(struct tty_struct *tty, struct file *filp)
2582 retval); 2572 retval);
2583 } 2573 }
2584 cinfo->nports = 2574 cinfo->nports =
2585 (int)cy_readl(&board_ctrl->n_channel); 2575 (int)readl(&board_ctrl->n_channel);
2586 cinfo->intr_enabled = 1; 2576 cinfo->intr_enabled = 1;
2587 } 2577 }
2588 } 2578 }
@@ -2701,7 +2691,7 @@ static void cy_wait_until_sent(struct tty_struct *tty, int timeout)
2701 index = cy_card[card].bus_index; 2691 index = cy_card[card].bus_index;
2702 base_addr = 2692 base_addr =
2703 cy_card[card].base_addr + (cy_chip_offset[chip] << index); 2693 cy_card[card].base_addr + (cy_chip_offset[chip] << index);
2704 while (cy_readb(base_addr + (CySRER << index)) & CyTxRdy) { 2694 while (readb(base_addr + (CySRER << index)) & CyTxRdy) {
2705#ifdef CY_DEBUG_WAIT_UNTIL_SENT 2695#ifdef CY_DEBUG_WAIT_UNTIL_SENT
2706 printk("Not clean (jiff=%lu)...", jiffies); 2696 printk("Not clean (jiff=%lu)...", jiffies);
2707#endif 2697#endif
@@ -2794,7 +2784,7 @@ static void cy_close(struct tty_struct *tty, struct file *filp)
2794 channel &= 0x03; 2784 channel &= 0x03;
2795 cy_writeb(base_addr + (CyCAR << index), (u_char) channel); 2785 cy_writeb(base_addr + (CyCAR << index), (u_char) channel);
2796 cy_writeb(base_addr + (CySRER << index), 2786 cy_writeb(base_addr + (CySRER << index),
2797 cy_readb(base_addr + (CySRER << index)) & ~CyRxData); 2787 readb(base_addr + (CySRER << index)) & ~CyRxData);
2798 if (info->flags & ASYNC_INITIALIZED) { 2788 if (info->flags & ASYNC_INITIALIZED) {
2799 /* Waiting for on-board buffers to be empty before closing 2789 /* Waiting for on-board buffers to be empty before closing
2800 the port */ 2790 the port */
@@ -2808,12 +2798,12 @@ static void cy_close(struct tty_struct *tty, struct file *filp)
2808 void __iomem *base_addr = cy_card[info->card].base_addr; 2798 void __iomem *base_addr = cy_card[info->card].base_addr;
2809 struct FIRM_ID __iomem *firm_id = base_addr + ID_ADDRESS; 2799 struct FIRM_ID __iomem *firm_id = base_addr + ID_ADDRESS;
2810 struct ZFW_CTRL __iomem *zfw_ctrl = 2800 struct ZFW_CTRL __iomem *zfw_ctrl =
2811 base_addr + (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 2801 base_addr + (readl(&firm_id->zfwctrl_addr) & 0xfffff);
2812 struct CH_CTRL __iomem *ch_ctrl = zfw_ctrl->ch_ctrl; 2802 struct CH_CTRL __iomem *ch_ctrl = zfw_ctrl->ch_ctrl;
2813 int channel = info->line - cy_card[info->card].first_line; 2803 int channel = info->line - cy_card[info->card].first_line;
2814 int retval; 2804 int retval;
2815 2805
2816 if (cy_readl(&ch_ctrl[channel].flow_status) != C_FS_TXIDLE) { 2806 if (readl(&ch_ctrl[channel].flow_status) != C_FS_TXIDLE) {
2817 retval = cyz_issue_cmd(&cy_card[info->card], channel, 2807 retval = cyz_issue_cmd(&cy_card[info->card], channel,
2818 C_CM_IOCTLW, 0L); 2808 C_CM_IOCTLW, 0L);
2819 if (retval != 0) { 2809 if (retval != 0) {
@@ -3023,13 +3013,13 @@ static int cy_chars_in_buffer(struct tty_struct *tty)
3023 3013
3024 firm_id = cy_card[card].base_addr + ID_ADDRESS; 3014 firm_id = cy_card[card].base_addr + ID_ADDRESS;
3025 zfw_ctrl = cy_card[card].base_addr + 3015 zfw_ctrl = cy_card[card].base_addr +
3026 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 3016 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
3027 ch_ctrl = &(zfw_ctrl->ch_ctrl[channel]); 3017 ch_ctrl = &(zfw_ctrl->ch_ctrl[channel]);
3028 buf_ctrl = &(zfw_ctrl->buf_ctrl[channel]); 3018 buf_ctrl = &(zfw_ctrl->buf_ctrl[channel]);
3029 3019
3030 tx_get = cy_readl(&buf_ctrl->tx_get); 3020 tx_get = readl(&buf_ctrl->tx_get);
3031 tx_put = cy_readl(&buf_ctrl->tx_put); 3021 tx_put = readl(&buf_ctrl->tx_put);
3032 tx_bufsize = cy_readl(&buf_ctrl->tx_bufsize); 3022 tx_bufsize = readl(&buf_ctrl->tx_bufsize);
3033 if (tx_put >= tx_get) 3023 if (tx_put >= tx_get)
3034 char_count = tx_put - tx_get; 3024 char_count = tx_put - tx_get;
3035 else 3025 else
@@ -3269,8 +3259,7 @@ static void set_line_char(struct cyclades_port *info)
3269 if (C_CLOCAL(info->tty)) { 3259 if (C_CLOCAL(info->tty)) {
3270 /* without modem intr */ 3260 /* without modem intr */
3271 cy_writeb(base_addr + (CySRER << index), 3261 cy_writeb(base_addr + (CySRER << index),
3272 cy_readb(base_addr + 3262 readb(base_addr + (CySRER << index)) | CyMdmCh);
3273 (CySRER << index)) | CyMdmCh);
3274 /* act on 1->0 modem transitions */ 3263 /* act on 1->0 modem transitions */
3275 if ((cflag & CRTSCTS) && info->rflow) { 3264 if ((cflag & CRTSCTS) && info->rflow) {
3276 cy_writeb(base_addr + (CyMCOR1 << index), 3265 cy_writeb(base_addr + (CyMCOR1 << index),
@@ -3284,7 +3273,7 @@ static void set_line_char(struct cyclades_port *info)
3284 } else { 3273 } else {
3285 /* without modem intr */ 3274 /* without modem intr */
3286 cy_writeb(base_addr + (CySRER << index), 3275 cy_writeb(base_addr + (CySRER << index),
3287 cy_readb(base_addr + 3276 readb(base_addr +
3288 (CySRER << index)) | CyMdmCh); 3277 (CySRER << index)) | CyMdmCh);
3289 /* act on 1->0 modem transitions */ 3278 /* act on 1->0 modem transitions */
3290 if ((cflag & CRTSCTS) && info->rflow) { 3279 if ((cflag & CRTSCTS) && info->rflow) {
@@ -3311,8 +3300,8 @@ static void set_line_char(struct cyclades_port *info)
3311#ifdef CY_DEBUG_DTR 3300#ifdef CY_DEBUG_DTR
3312 printk("cyc:set_line_char dropping DTR\n"); 3301 printk("cyc:set_line_char dropping DTR\n");
3313 printk(" status: 0x%x, 0x%x\n", 3302 printk(" status: 0x%x, 0x%x\n",
3314 cy_readb(base_addr + (CyMSVR1 << index)), 3303 readb(base_addr + (CyMSVR1 << index)),
3315 cy_readb(base_addr + (CyMSVR2 << index))); 3304 readb(base_addr + (CyMSVR2 << index)));
3316#endif 3305#endif
3317 } else { 3306 } else {
3318 if (info->rtsdtr_inv) { 3307 if (info->rtsdtr_inv) {
@@ -3325,8 +3314,8 @@ static void set_line_char(struct cyclades_port *info)
3325#ifdef CY_DEBUG_DTR 3314#ifdef CY_DEBUG_DTR
3326 printk("cyc:set_line_char raising DTR\n"); 3315 printk("cyc:set_line_char raising DTR\n");
3327 printk(" status: 0x%x, 0x%x\n", 3316 printk(" status: 0x%x, 0x%x\n",
3328 cy_readb(base_addr + (CyMSVR1 << index)), 3317 readb(base_addr + (CyMSVR1 << index)),
3329 cy_readb(base_addr + (CyMSVR2 << index))); 3318 readb(base_addr + (CyMSVR2 << index)));
3330#endif 3319#endif
3331 } 3320 }
3332 3321
@@ -3350,7 +3339,7 @@ static void set_line_char(struct cyclades_port *info)
3350 } 3339 }
3351 3340
3352 zfw_ctrl = cy_card[card].base_addr + 3341 zfw_ctrl = cy_card[card].base_addr +
3353 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 3342 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
3354 board_ctrl = &zfw_ctrl->board_ctrl; 3343 board_ctrl = &zfw_ctrl->board_ctrl;
3355 ch_ctrl = &(zfw_ctrl->ch_ctrl[channel]); 3344 ch_ctrl = &(zfw_ctrl->ch_ctrl[channel]);
3356 buf_ctrl = &zfw_ctrl->buf_ctrl[channel]; 3345 buf_ctrl = &zfw_ctrl->buf_ctrl[channel];
@@ -3401,10 +3390,10 @@ static void set_line_char(struct cyclades_port *info)
3401 } 3390 }
3402 if (cflag & CSTOPB) { 3391 if (cflag & CSTOPB) {
3403 cy_writel(&ch_ctrl->comm_data_l, 3392 cy_writel(&ch_ctrl->comm_data_l,
3404 cy_readl(&ch_ctrl->comm_data_l) | C_DL_2STOP); 3393 readl(&ch_ctrl->comm_data_l) | C_DL_2STOP);
3405 } else { 3394 } else {
3406 cy_writel(&ch_ctrl->comm_data_l, 3395 cy_writel(&ch_ctrl->comm_data_l,
3407 cy_readl(&ch_ctrl->comm_data_l) | C_DL_1STOP); 3396 readl(&ch_ctrl->comm_data_l) | C_DL_1STOP);
3408 } 3397 }
3409 if (cflag & PARENB) { 3398 if (cflag & PARENB) {
3410 if (cflag & PARODD) { 3399 if (cflag & PARODD) {
@@ -3419,12 +3408,10 @@ static void set_line_char(struct cyclades_port *info)
3419 /* CTS flow control flag */ 3408 /* CTS flow control flag */
3420 if (cflag & CRTSCTS) { 3409 if (cflag & CRTSCTS) {
3421 cy_writel(&ch_ctrl->hw_flow, 3410 cy_writel(&ch_ctrl->hw_flow,
3422 cy_readl(&ch_ctrl-> 3411 readl(&ch_ctrl->hw_flow) | C_RS_CTS | C_RS_RTS);
3423 hw_flow) | C_RS_CTS | C_RS_RTS);
3424 } else { 3412 } else {
3425 cy_writel(&ch_ctrl->hw_flow, 3413 cy_writel(&ch_ctrl->hw_flow, readl(&ch_ctrl->hw_flow) &
3426 cy_readl(&ch_ctrl-> 3414 ~(C_RS_CTS | C_RS_RTS));
3427 hw_flow) & ~(C_RS_CTS | C_RS_RTS));
3428 } 3415 }
3429 /* As the HW flow control is done in firmware, the driver 3416 /* As the HW flow control is done in firmware, the driver
3430 doesn't need to care about it */ 3417 doesn't need to care about it */
@@ -3454,13 +3441,13 @@ static void set_line_char(struct cyclades_port *info)
3454 3441
3455 if (baud == 0) { /* baud rate is zero, turn off line */ 3442 if (baud == 0) { /* baud rate is zero, turn off line */
3456 cy_writel(&ch_ctrl->rs_control, 3443 cy_writel(&ch_ctrl->rs_control,
3457 cy_readl(&ch_ctrl->rs_control) & ~C_RS_DTR); 3444 readl(&ch_ctrl->rs_control) & ~C_RS_DTR);
3458#ifdef CY_DEBUG_DTR 3445#ifdef CY_DEBUG_DTR
3459 printk("cyc:set_line_char dropping Z DTR\n"); 3446 printk("cyc:set_line_char dropping Z DTR\n");
3460#endif 3447#endif
3461 } else { 3448 } else {
3462 cy_writel(&ch_ctrl->rs_control, 3449 cy_writel(&ch_ctrl->rs_control,
3463 cy_readl(&ch_ctrl->rs_control) | C_RS_DTR); 3450 readl(&ch_ctrl->rs_control) | C_RS_DTR);
3464#ifdef CY_DEBUG_DTR 3451#ifdef CY_DEBUG_DTR
3465 printk("cyc:set_line_char raising Z DTR\n"); 3452 printk("cyc:set_line_char raising Z DTR\n");
3466#endif 3453#endif
@@ -3575,7 +3562,7 @@ static int get_lsr_info(struct cyclades_port *info, unsigned int __user * value)
3575 cy_card[card].base_addr + (cy_chip_offset[chip] << index); 3562 cy_card[card].base_addr + (cy_chip_offset[chip] << index);
3576 3563
3577 CY_LOCK(info, flags); 3564 CY_LOCK(info, flags);
3578 status = cy_readb(base_addr + (CySRER << index)) & 3565 status = readb(base_addr + (CySRER << index)) &
3579 (CyTxRdy | CyTxMpty); 3566 (CyTxRdy | CyTxMpty);
3580 CY_UNLOCK(info, flags); 3567 CY_UNLOCK(info, flags);
3581 result = (status ? 0 : TIOCSER_TEMT); 3568 result = (status ? 0 : TIOCSER_TEMT);
@@ -3614,8 +3601,8 @@ static int cy_tiocmget(struct tty_struct *tty, struct file *file)
3614 3601
3615 CY_LOCK(info, flags); 3602 CY_LOCK(info, flags);
3616 cy_writeb(base_addr + (CyCAR << index), (u_char) channel); 3603 cy_writeb(base_addr + (CyCAR << index), (u_char) channel);
3617 status = cy_readb(base_addr + (CyMSVR1 << index)); 3604 status = readb(base_addr + (CyMSVR1 << index));
3618 status |= cy_readb(base_addr + (CyMSVR2 << index)); 3605 status |= readb(base_addr + (CyMSVR2 << index));
3619 CY_UNLOCK(info, flags); 3606 CY_UNLOCK(info, flags);
3620 3607
3621 if (info->rtsdtr_inv) { 3608 if (info->rtsdtr_inv) {
@@ -3639,10 +3626,10 @@ static int cy_tiocmget(struct tty_struct *tty, struct file *file)
3639 firm_id = cy_card[card].base_addr + ID_ADDRESS; 3626 firm_id = cy_card[card].base_addr + ID_ADDRESS;
3640 if (ISZLOADED(cy_card[card])) { 3627 if (ISZLOADED(cy_card[card])) {
3641 zfw_ctrl = cy_card[card].base_addr + 3628 zfw_ctrl = cy_card[card].base_addr +
3642 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 3629 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
3643 board_ctrl = &zfw_ctrl->board_ctrl; 3630 board_ctrl = &zfw_ctrl->board_ctrl;
3644 ch_ctrl = zfw_ctrl->ch_ctrl; 3631 ch_ctrl = zfw_ctrl->ch_ctrl;
3645 lstatus = cy_readl(&ch_ctrl[channel].rs_status); 3632 lstatus = readl(&ch_ctrl[channel].rs_status);
3646 result = ((lstatus & C_RS_RTS) ? TIOCM_RTS : 0) | 3633 result = ((lstatus & C_RS_RTS) ? TIOCM_RTS : 0) |
3647 ((lstatus & C_RS_DTR) ? TIOCM_DTR : 0) | 3634 ((lstatus & C_RS_DTR) ? TIOCM_DTR : 0) |
3648 ((lstatus & C_RS_DCD) ? TIOCM_CAR : 0) | 3635 ((lstatus & C_RS_DCD) ? TIOCM_CAR : 0) |
@@ -3724,8 +3711,8 @@ cy_tiocmset(struct tty_struct *tty, struct file *file,
3724#ifdef CY_DEBUG_DTR 3711#ifdef CY_DEBUG_DTR
3725 printk("cyc:set_modem_info raising DTR\n"); 3712 printk("cyc:set_modem_info raising DTR\n");
3726 printk(" status: 0x%x, 0x%x\n", 3713 printk(" status: 0x%x, 0x%x\n",
3727 cy_readb(base_addr + (CyMSVR1 << index)), 3714 readb(base_addr + (CyMSVR1 << index)),
3728 cy_readb(base_addr + (CyMSVR2 << index))); 3715 readb(base_addr + (CyMSVR2 << index)));
3729#endif 3716#endif
3730 CY_UNLOCK(info, flags); 3717 CY_UNLOCK(info, flags);
3731 } 3718 }
@@ -3744,8 +3731,8 @@ cy_tiocmset(struct tty_struct *tty, struct file *file,
3744#ifdef CY_DEBUG_DTR 3731#ifdef CY_DEBUG_DTR
3745 printk("cyc:set_modem_info dropping DTR\n"); 3732 printk("cyc:set_modem_info dropping DTR\n");
3746 printk(" status: 0x%x, 0x%x\n", 3733 printk(" status: 0x%x, 0x%x\n",
3747 cy_readb(base_addr + (CyMSVR1 << index)), 3734 readb(base_addr + (CyMSVR1 << index)),
3748 cy_readb(base_addr + (CyMSVR2 << index))); 3735 readb(base_addr + (CyMSVR2 << index)));
3749#endif 3736#endif
3750 CY_UNLOCK(info, flags); 3737 CY_UNLOCK(info, flags);
3751 } 3738 }
@@ -3755,29 +3742,29 @@ cy_tiocmset(struct tty_struct *tty, struct file *file,
3755 firm_id = cy_card[card].base_addr + ID_ADDRESS; 3742 firm_id = cy_card[card].base_addr + ID_ADDRESS;
3756 if (ISZLOADED(cy_card[card])) { 3743 if (ISZLOADED(cy_card[card])) {
3757 zfw_ctrl = cy_card[card].base_addr + 3744 zfw_ctrl = cy_card[card].base_addr +
3758 (cy_readl(&firm_id->zfwctrl_addr) & 0xfffff); 3745 (readl(&firm_id->zfwctrl_addr) & 0xfffff);
3759 board_ctrl = &zfw_ctrl->board_ctrl; 3746 board_ctrl = &zfw_ctrl->board_ctrl;
3760 ch_ctrl = zfw_ctrl->ch_ctrl; 3747 ch_ctrl = zfw_ctrl->ch_ctrl;
3761 3748
3762 if (set & TIOCM_RTS) { 3749 if (set & TIOCM_RTS) {
3763 CY_LOCK(info, flags); 3750 CY_LOCK(info, flags);
3764 cy_writel(&ch_ctrl[channel].rs_control, 3751 cy_writel(&ch_ctrl[channel].rs_control,
3765 cy_readl(&ch_ctrl[channel]. 3752 readl(&ch_ctrl[channel].rs_control) |
3766 rs_control) | C_RS_RTS); 3753 C_RS_RTS);
3767 CY_UNLOCK(info, flags); 3754 CY_UNLOCK(info, flags);
3768 } 3755 }
3769 if (clear & TIOCM_RTS) { 3756 if (clear & TIOCM_RTS) {
3770 CY_LOCK(info, flags); 3757 CY_LOCK(info, flags);
3771 cy_writel(&ch_ctrl[channel].rs_control, 3758 cy_writel(&ch_ctrl[channel].rs_control,
3772 cy_readl(&ch_ctrl[channel]. 3759 readl(&ch_ctrl[channel].rs_control) &
3773 rs_control) & ~C_RS_RTS); 3760 ~C_RS_RTS);
3774 CY_UNLOCK(info, flags); 3761 CY_UNLOCK(info, flags);
3775 } 3762 }
3776 if (set & TIOCM_DTR) { 3763 if (set & TIOCM_DTR) {
3777 CY_LOCK(info, flags); 3764 CY_LOCK(info, flags);
3778 cy_writel(&ch_ctrl[channel].rs_control, 3765 cy_writel(&ch_ctrl[channel].rs_control,
3779 cy_readl(&ch_ctrl[channel]. 3766 readl(&ch_ctrl[channel].rs_control) |
3780 rs_control) | C_RS_DTR); 3767 C_RS_DTR);
3781#ifdef CY_DEBUG_DTR 3768#ifdef CY_DEBUG_DTR
3782 printk("cyc:set_modem_info raising Z DTR\n"); 3769 printk("cyc:set_modem_info raising Z DTR\n");
3783#endif 3770#endif
@@ -3786,8 +3773,8 @@ cy_tiocmset(struct tty_struct *tty, struct file *file,
3786 if (clear & TIOCM_DTR) { 3773 if (clear & TIOCM_DTR) {
3787 CY_LOCK(info, flags); 3774 CY_LOCK(info, flags);
3788 cy_writel(&ch_ctrl[channel].rs_control, 3775 cy_writel(&ch_ctrl[channel].rs_control,
3789 cy_readl(&ch_ctrl[channel]. 3776 readl(&ch_ctrl[channel].rs_control) &
3790 rs_control) & ~C_RS_DTR); 3777 ~C_RS_DTR);
3791#ifdef CY_DEBUG_DTR 3778#ifdef CY_DEBUG_DTR
3792 printk("cyc:set_modem_info clearing Z DTR\n"); 3779 printk("cyc:set_modem_info clearing Z DTR\n");
3793#endif 3780#endif
@@ -3924,7 +3911,7 @@ get_threshold(struct cyclades_port *info, unsigned long __user * value)
3924 base_addr = 3911 base_addr =
3925 cy_card[card].base_addr + (cy_chip_offset[chip] << index); 3912 cy_card[card].base_addr + (cy_chip_offset[chip] << index);
3926 3913
3927 tmp = cy_readb(base_addr + (CyCOR3 << index)) & CyREC_FIFO; 3914 tmp = readb(base_addr + (CyCOR3 << index)) & CyREC_FIFO;
3928 return put_user(tmp, value); 3915 return put_user(tmp, value);
3929 } else { 3916 } else {
3930 /* Nothing to do! */ 3917 /* Nothing to do! */
@@ -3984,7 +3971,7 @@ static int get_timeout(struct cyclades_port *info, unsigned long __user * value)
3984 base_addr = 3971 base_addr =
3985 cy_card[card].base_addr + (cy_chip_offset[chip] << index); 3972 cy_card[card].base_addr + (cy_chip_offset[chip] << index);
3986 3973
3987 tmp = cy_readb(base_addr + (CyRTPR << index)); 3974 tmp = readb(base_addr + (CyRTPR << index));
3988 return put_user(tmp, value); 3975 return put_user(tmp, value);
3989 } else { 3976 } else {
3990 /* Nothing to do! */ 3977 /* Nothing to do! */
@@ -4410,7 +4397,7 @@ static void cy_stop(struct tty_struct *tty)
4410 cy_writeb(base_addr + (CyCAR << index), 4397 cy_writeb(base_addr + (CyCAR << index),
4411 (u_char)(channel & 0x0003)); /* index channel */ 4398 (u_char)(channel & 0x0003)); /* index channel */
4412 cy_writeb(base_addr + (CySRER << index), 4399 cy_writeb(base_addr + (CySRER << index),
4413 cy_readb(base_addr + (CySRER << index)) & ~CyTxRdy); 4400 readb(base_addr + (CySRER << index)) & ~CyTxRdy);
4414 CY_UNLOCK(info, flags); 4401 CY_UNLOCK(info, flags);
4415 } else { 4402 } else {
4416 /* Nothing to do! */ 4403 /* Nothing to do! */
@@ -4444,7 +4431,7 @@ static void cy_start(struct tty_struct *tty)
4444 CY_LOCK(info, flags); 4431 CY_LOCK(info, flags);
4445 cy_writeb(base_addr + (CyCAR << index), (u_char) (channel & 0x0003)); /* index channel */ 4432 cy_writeb(base_addr + (CyCAR << index), (u_char) (channel & 0x0003)); /* index channel */
4446 cy_writeb(base_addr + (CySRER << index), 4433 cy_writeb(base_addr + (CySRER << index),
4447 cy_readb(base_addr + (CySRER << index)) | CyTxRdy); 4434 readb(base_addr + (CySRER << index)) | CyTxRdy);
4448 CY_UNLOCK(info, flags); 4435 CY_UNLOCK(info, flags);
4449 } else { 4436 } else {
4450 /* Nothing to do! */ 4437 /* Nothing to do! */
@@ -4537,7 +4524,7 @@ cyy_init_card(void __iomem * true_base_addr, int index)
4537 base_addr = 4524 base_addr =
4538 true_base_addr + (cy_chip_offset[chip_number] << index); 4525 true_base_addr + (cy_chip_offset[chip_number] << index);
4539 mdelay(1); 4526 mdelay(1);
4540 if (cy_readb(base_addr + (CyCCR << index)) != 0x00) { 4527 if (readb(base_addr + (CyCCR << index)) != 0x00) {
4541 /************* 4528 /*************
4542 printk(" chip #%d at %#6lx is never idle (CCR != 0)\n", 4529 printk(" chip #%d at %#6lx is never idle (CCR != 0)\n",
4543 chip_number, (unsigned long)base_addr); 4530 chip_number, (unsigned long)base_addr);
@@ -4554,7 +4541,7 @@ cyy_init_card(void __iomem * true_base_addr, int index)
4554 chip 4 GFRCR register appears at chip 0, there is no chip 4 4541 chip 4 GFRCR register appears at chip 0, there is no chip 4
4555 and this must be a Cyclom-16Y, not a Cyclom-32Ye. 4542 and this must be a Cyclom-16Y, not a Cyclom-32Ye.
4556 */ 4543 */
4557 if (chip_number == 4 && cy_readb(true_base_addr + 4544 if (chip_number == 4 && readb(true_base_addr +
4558 (cy_chip_offset[0] << index) + 4545 (cy_chip_offset[0] << index) +
4559 (CyGFRCR << index)) == 0) { 4546 (CyGFRCR << index)) == 0) {
4560 return chip_number; 4547 return chip_number;
@@ -4563,7 +4550,7 @@ cyy_init_card(void __iomem * true_base_addr, int index)
4563 cy_writeb(base_addr + (CyCCR << index), CyCHIP_RESET); 4550 cy_writeb(base_addr + (CyCCR << index), CyCHIP_RESET);
4564 mdelay(1); 4551 mdelay(1);
4565 4552
4566 if (cy_readb(base_addr + (CyGFRCR << index)) == 0x00) { 4553 if (readb(base_addr + (CyGFRCR << index)) == 0x00) {
4567 /* 4554 /*
4568 printk(" chip #%d at %#6lx is not responding ", 4555 printk(" chip #%d at %#6lx is not responding ",
4569 chip_number, (unsigned long)base_addr); 4556 chip_number, (unsigned long)base_addr);
@@ -4571,7 +4558,7 @@ cyy_init_card(void __iomem * true_base_addr, int index)
4571 */ 4558 */
4572 return chip_number; 4559 return chip_number;
4573 } 4560 }
4574 if ((0xf0 & (cy_readb(base_addr + (CyGFRCR << index)))) != 4561 if ((0xf0 & (readb(base_addr + (CyGFRCR << index)))) !=
4575 0x40) { 4562 0x40) {
4576 /* 4563 /*
4577 printk(" chip #%d at %#6lx is not valid (GFRCR == " 4564 printk(" chip #%d at %#6lx is not valid (GFRCR == "
@@ -4582,7 +4569,7 @@ cyy_init_card(void __iomem * true_base_addr, int index)
4582 return chip_number; 4569 return chip_number;
4583 } 4570 }
4584 cy_writeb(base_addr + (CyGCR << index), CyCH0_SERIAL); 4571 cy_writeb(base_addr + (CyGCR << index), CyCH0_SERIAL);
4585 if (cy_readb(base_addr + (CyGFRCR << index)) >= CD1400_REV_J) { 4572 if (readb(base_addr + (CyGFRCR << index)) >= CD1400_REV_J) {
4586 /* It is a CD1400 rev. J or later */ 4573 /* It is a CD1400 rev. J or later */
4587 /* Impossible to reach 5ms with this chip. 4574 /* Impossible to reach 5ms with this chip.
4588 Changed to 2ms instead (f = 500 Hz). */ 4575 Changed to 2ms instead (f = 500 Hz). */
@@ -4595,7 +4582,7 @@ cyy_init_card(void __iomem * true_base_addr, int index)
4595 /* 4582 /*
4596 printk(" chip #%d at %#6lx is rev 0x%2x\n", 4583 printk(" chip #%d at %#6lx is rev 0x%2x\n",
4597 chip_number, (unsigned long)base_addr, 4584 chip_number, (unsigned long)base_addr,
4598 cy_readb(base_addr+(CyGFRCR<<index))); 4585 readb(base_addr+(CyGFRCR<<index)));
4599 */ 4586 */
4600 } 4587 }
4601 return chip_number; 4588 return chip_number;
@@ -4717,14 +4704,14 @@ static int __init cy_detect_isa(void)
4717static void plx_init(void __iomem * addr, __u32 initctl) 4704static void plx_init(void __iomem * addr, __u32 initctl)
4718{ 4705{
4719 /* Reset PLX */ 4706 /* Reset PLX */
4720 cy_writel(addr + initctl, cy_readl(addr + initctl) | 0x40000000); 4707 cy_writel(addr + initctl, readl(addr + initctl) | 0x40000000);
4721 udelay(100L); 4708 udelay(100L);
4722 cy_writel(addr + initctl, cy_readl(addr + initctl) & ~0x40000000); 4709 cy_writel(addr + initctl, readl(addr + initctl) & ~0x40000000);
4723 4710
4724 /* Reload Config. Registers from EEPROM */ 4711 /* Reload Config. Registers from EEPROM */
4725 cy_writel(addr + initctl, cy_readl(addr + initctl) | 0x20000000); 4712 cy_writel(addr + initctl, readl(addr + initctl) | 0x20000000);
4726 udelay(100L); 4713 udelay(100L);
4727 cy_writel(addr + initctl, cy_readl(addr + initctl) & ~0x20000000); 4714 cy_writel(addr + initctl, readl(addr + initctl) & ~0x20000000);
4728} 4715}
4729 4716
4730/* 4717/*
@@ -4879,7 +4866,7 @@ static int __init cy_detect_pci(void)
4879 cy_card[j].pdev = pdev; 4866 cy_card[j].pdev = pdev;
4880 4867
4881 /* enable interrupts in the PCI interface */ 4868 /* enable interrupts in the PCI interface */
4882 plx_ver = cy_readb(cy_pci_addr2 + CyPLX_VER) & 0x0f; 4869 plx_ver = readb(cy_pci_addr2 + CyPLX_VER) & 0x0f;
4883 switch (plx_ver) { 4870 switch (plx_ver) {
4884 case PLX_9050: 4871 case PLX_9050:
4885 4872
@@ -4900,8 +4887,7 @@ static int __init cy_detect_pci(void)
4900 cy_pci_irq); 4887 cy_pci_irq);
4901 4888
4902 cy_writew(cy_pci_addr0 + 0x68, 4889 cy_writew(cy_pci_addr0 + 0x68,
4903 cy_readw(cy_pci_addr0 + 4890 readw(cy_pci_addr0 + 0x68) | 0x0900);
4904 0x68) | 0x0900);
4905 break; 4891 break;
4906 } 4892 }
4907 4893
@@ -4940,7 +4926,7 @@ static int __init cy_detect_pci(void)
4940 4926
4941 /* Disable interrupts on the PLX before resetting it */ 4927 /* Disable interrupts on the PLX before resetting it */
4942 cy_writew(cy_pci_addr0 + 0x68, 4928 cy_writew(cy_pci_addr0 + 0x68,
4943 cy_readw(cy_pci_addr0 + 0x68) & ~0x0900); 4929 readw(cy_pci_addr0 + 0x68) & ~0x0900);
4944 4930
4945 plx_init(cy_pci_addr0, 0x6c); 4931 plx_init(cy_pci_addr0, 0x6c);
4946 /* For some yet unknown reason, once the PLX9060 reloads 4932 /* For some yet unknown reason, once the PLX9060 reloads
@@ -4951,9 +4937,8 @@ static int __init cy_detect_pci(void)
4951 pci_write_config_byte(pdev, PCI_INTERRUPT_LINE, 4937 pci_write_config_byte(pdev, PCI_INTERRUPT_LINE,
4952 cy_pci_irq); 4938 cy_pci_irq);
4953 4939
4954 mailbox = 4940 mailbox = (__u32)readl(&((struct RUNTIME_9060 __iomem *)
4955 (__u32)cy_readl(&((struct RUNTIME_9060 __iomem *) 4941 cy_pci_addr0)->mail_box_0);
4956 cy_pci_addr0)->mail_box_0);
4957 4942
4958 if (pci_resource_flags(pdev, 2) & IORESOURCE_IO) { 4943 if (pci_resource_flags(pdev, 2) & IORESOURCE_IO) {
4959 printk(" Warning: PCI I/O bit incorrectly " 4944 printk(" Warning: PCI I/O bit incorrectly "
@@ -5005,10 +4990,10 @@ static int __init cy_detect_pci(void)
5005 WIN_CREG); 4990 WIN_CREG);
5006 printk("Cyclades-8Zo/PCI: FPGA id %lx, ver " 4991 printk("Cyclades-8Zo/PCI: FPGA id %lx, ver "
5007 "%lx\n", (ulong) (0xff & 4992 "%lx\n", (ulong) (0xff &
5008 cy_readl(&((struct CUSTOM_REG *) 4993 readl(&((struct CUSTOM_REG *)
5009 (cy_pci_addr2))->fpga_id)), 4994 (cy_pci_addr2))->fpga_id)),
5010 (ulong)(0xff & 4995 (ulong)(0xff &
5011 cy_readl(&((struct CUSTOM_REG *) 4996 readl(&((struct CUSTOM_REG *)
5012 (cy_pci_addr2))-> 4997 (cy_pci_addr2))->
5013 fpga_version))); 4998 fpga_version)));
5014 cy_writel(&((struct RUNTIME_9060 *) 4999 cy_writel(&((struct RUNTIME_9060 *)
@@ -5113,7 +5098,7 @@ static int __init cy_detect_pci(void)
5113 Ze_pdev[j] = Ze_pdev[j + 1]; 5098 Ze_pdev[j] = Ze_pdev[j + 1];
5114 } 5099 }
5115 ZeIndex--; 5100 ZeIndex--;
5116 mailbox = (__u32)cy_readl(&((struct RUNTIME_9060 __iomem *) 5101 mailbox = (__u32)readl(&((struct RUNTIME_9060 __iomem *)
5117 cy_pci_addr0)->mail_box_0); 5102 cy_pci_addr0)->mail_box_0);
5118#ifdef CY_PCI_DEBUG 5103#ifdef CY_PCI_DEBUG
5119 printk("Cyclades-Z/PCI: relocate winaddr=0x%lx ctladdr=0x%lx\n", 5104 printk("Cyclades-Z/PCI: relocate winaddr=0x%lx ctladdr=0x%lx\n",
@@ -5382,7 +5367,7 @@ static int __init cy_init(void)
5382 cinfo = &cy_card[board]; 5367 cinfo = &cy_card[board];
5383 if (cinfo->num_chips == -1) { /* Cyclades-Z */ 5368 if (cinfo->num_chips == -1) { /* Cyclades-Z */
5384 number_z_boards++; 5369 number_z_boards++;
5385 mailbox = cy_readl(&((struct RUNTIME_9060 __iomem *) 5370 mailbox = readl(&((struct RUNTIME_9060 __iomem *)
5386 cy_card[board].ctl_addr)-> 5371 cy_card[board].ctl_addr)->
5387 mail_box_0); 5372 mail_box_0);
5388 nports = (mailbox == ZE_V1) ? ZE_V1_NPORTS : 8; 5373 nports = (mailbox == ZE_V1) ? ZE_V1_NPORTS : 8;
@@ -5478,7 +5463,7 @@ static int __init cy_init(void)
5478 info->icount.overrun = info->icount.brk = 0; 5463 info->icount.overrun = info->icount.brk = 0;
5479 chip_number = (port - cinfo->first_line) / 4; 5464 chip_number = (port - cinfo->first_line) / 4;
5480 if ((info->chip_rev = 5465 if ((info->chip_rev =
5481 cy_readb(cinfo->base_addr + 5466 readb(cinfo->base_addr +
5482 (cy_chip_offset[chip_number] << 5467 (cy_chip_offset[chip_number] <<
5483 index) + (CyGFRCR << index))) >= 5468 index) + (CyGFRCR << index))) >=
5484 CD1400_REV_J) { 5469 CD1400_REV_J) {
diff --git a/include/linux/cyclades.h b/include/linux/cyclades.h
index 4c5b4763f5b8..f0ad61f69792 100644
--- a/include/linux/cyclades.h
+++ b/include/linux/cyclades.h
@@ -539,13 +539,9 @@ struct cyclades_chip {
539 * (required to support Alpha systems) * 539 * (required to support Alpha systems) *
540 ***************************************/ 540 ***************************************/
541 541
542#define cy_writeb(port,val) {writeb((val),(port)); mb();} 542#define cy_writeb(port,val) do { writeb((val), (port)); mb(); } while (0)
543#define cy_writew(port,val) {writew((val),(port)); mb();} 543#define cy_writew(port,val) do { writew((val), (port)); mb(); } while (0)
544#define cy_writel(port,val) {writel((val),(port)); mb();} 544#define cy_writel(port,val) do { writel((val), (port)); mb(); } while (0)
545
546#define cy_readb(port) readb(port)
547#define cy_readw(port) readw(port)
548#define cy_readl(port) readl(port)
549 545
550/* 546/*
551 * Statistics counters 547 * Statistics counters