diff options
Diffstat (limited to 'drivers/isdn/hardware/mISDN/hfcmulti.c')
-rw-r--r-- | drivers/isdn/hardware/mISDN/hfcmulti.c | 159 |
1 files changed, 81 insertions, 78 deletions
diff --git a/drivers/isdn/hardware/mISDN/hfcmulti.c b/drivers/isdn/hardware/mISDN/hfcmulti.c index 50e9f4d88f48..d60f5b7a41d0 100644 --- a/drivers/isdn/hardware/mISDN/hfcmulti.c +++ b/drivers/isdn/hardware/mISDN/hfcmulti.c | |||
@@ -275,7 +275,7 @@ HFC_outb_pcimem(struct hfc_multi *hc, u_char reg, u_char val, | |||
275 | HFC_outb_pcimem(struct hfc_multi *hc, u_char reg, u_char val) | 275 | HFC_outb_pcimem(struct hfc_multi *hc, u_char reg, u_char val) |
276 | #endif | 276 | #endif |
277 | { | 277 | { |
278 | writeb(val, (hc->pci_membase)+reg); | 278 | writeb(val, hc->pci_membase + reg); |
279 | } | 279 | } |
280 | static u_char | 280 | static u_char |
281 | #ifdef HFC_REGISTER_DEBUG | 281 | #ifdef HFC_REGISTER_DEBUG |
@@ -284,7 +284,7 @@ HFC_inb_pcimem(struct hfc_multi *hc, u_char reg, const char *function, int line) | |||
284 | HFC_inb_pcimem(struct hfc_multi *hc, u_char reg) | 284 | HFC_inb_pcimem(struct hfc_multi *hc, u_char reg) |
285 | #endif | 285 | #endif |
286 | { | 286 | { |
287 | return readb((hc->pci_membase)+reg); | 287 | return readb(hc->pci_membase + reg); |
288 | } | 288 | } |
289 | static u_short | 289 | static u_short |
290 | #ifdef HFC_REGISTER_DEBUG | 290 | #ifdef HFC_REGISTER_DEBUG |
@@ -293,7 +293,7 @@ HFC_inw_pcimem(struct hfc_multi *hc, u_char reg, const char *function, int line) | |||
293 | HFC_inw_pcimem(struct hfc_multi *hc, u_char reg) | 293 | HFC_inw_pcimem(struct hfc_multi *hc, u_char reg) |
294 | #endif | 294 | #endif |
295 | { | 295 | { |
296 | return readw((hc->pci_membase)+reg); | 296 | return readw(hc->pci_membase + reg); |
297 | } | 297 | } |
298 | static void | 298 | static void |
299 | #ifdef HFC_REGISTER_DEBUG | 299 | #ifdef HFC_REGISTER_DEBUG |
@@ -302,7 +302,8 @@ HFC_wait_pcimem(struct hfc_multi *hc, const char *function, int line) | |||
302 | HFC_wait_pcimem(struct hfc_multi *hc) | 302 | HFC_wait_pcimem(struct hfc_multi *hc) |
303 | #endif | 303 | #endif |
304 | { | 304 | { |
305 | while (readb((hc->pci_membase)+R_STATUS) & V_BUSY); | 305 | while (readb(hc->pci_membase + R_STATUS) & V_BUSY) |
306 | cpu_relax(); | ||
306 | } | 307 | } |
307 | 308 | ||
308 | /* HFC_IO_MODE_REGIO */ | 309 | /* HFC_IO_MODE_REGIO */ |
@@ -314,7 +315,7 @@ HFC_outb_regio(struct hfc_multi *hc, u_char reg, u_char val, | |||
314 | HFC_outb_regio(struct hfc_multi *hc, u_char reg, u_char val) | 315 | HFC_outb_regio(struct hfc_multi *hc, u_char reg, u_char val) |
315 | #endif | 316 | #endif |
316 | { | 317 | { |
317 | outb(reg, (hc->pci_iobase)+4); | 318 | outb(reg, hc->pci_iobase + 4); |
318 | outb(val, hc->pci_iobase); | 319 | outb(val, hc->pci_iobase); |
319 | } | 320 | } |
320 | static u_char | 321 | static u_char |
@@ -324,7 +325,7 @@ HFC_inb_regio(struct hfc_multi *hc, u_char reg, const char *function, int line) | |||
324 | HFC_inb_regio(struct hfc_multi *hc, u_char reg) | 325 | HFC_inb_regio(struct hfc_multi *hc, u_char reg) |
325 | #endif | 326 | #endif |
326 | { | 327 | { |
327 | outb(reg, (hc->pci_iobase)+4); | 328 | outb(reg, hc->pci_iobase + 4); |
328 | return inb(hc->pci_iobase); | 329 | return inb(hc->pci_iobase); |
329 | } | 330 | } |
330 | static u_short | 331 | static u_short |
@@ -334,7 +335,7 @@ HFC_inw_regio(struct hfc_multi *hc, u_char reg, const char *function, int line) | |||
334 | HFC_inw_regio(struct hfc_multi *hc, u_char reg) | 335 | HFC_inw_regio(struct hfc_multi *hc, u_char reg) |
335 | #endif | 336 | #endif |
336 | { | 337 | { |
337 | outb(reg, (hc->pci_iobase)+4); | 338 | outb(reg, hc->pci_iobase + 4); |
338 | return inw(hc->pci_iobase); | 339 | return inw(hc->pci_iobase); |
339 | } | 340 | } |
340 | static void | 341 | static void |
@@ -344,8 +345,9 @@ HFC_wait_regio(struct hfc_multi *hc, const char *function, int line) | |||
344 | HFC_wait_regio(struct hfc_multi *hc) | 345 | HFC_wait_regio(struct hfc_multi *hc) |
345 | #endif | 346 | #endif |
346 | { | 347 | { |
347 | outb(R_STATUS, (hc->pci_iobase)+4); | 348 | outb(R_STATUS, hc->pci_iobase + 4); |
348 | while (inb(hc->pci_iobase) & V_BUSY); | 349 | while (inb(hc->pci_iobase) & V_BUSY) |
350 | cpu_relax(); | ||
349 | } | 351 | } |
350 | 352 | ||
351 | #ifdef HFC_REGISTER_DEBUG | 353 | #ifdef HFC_REGISTER_DEBUG |
@@ -364,14 +366,14 @@ HFC_outb_debug(struct hfc_multi *hc, u_char reg, u_char val, | |||
364 | if (regname[0] == '\0') | 366 | if (regname[0] == '\0') |
365 | strcpy(regname, "register"); | 367 | strcpy(regname, "register"); |
366 | 368 | ||
367 | bits[7] = '0'+(!!(val&1)); | 369 | bits[7] = '0' + (!!(val & 1)); |
368 | bits[6] = '0'+(!!(val&2)); | 370 | bits[6] = '0' + (!!(val & 2)); |
369 | bits[5] = '0'+(!!(val&4)); | 371 | bits[5] = '0' + (!!(val & 4)); |
370 | bits[4] = '0'+(!!(val&8)); | 372 | bits[4] = '0' + (!!(val & 8)); |
371 | bits[3] = '0'+(!!(val&16)); | 373 | bits[3] = '0' + (!!(val & 16)); |
372 | bits[2] = '0'+(!!(val&32)); | 374 | bits[2] = '0' + (!!(val & 32)); |
373 | bits[1] = '0'+(!!(val&64)); | 375 | bits[1] = '0' + (!!(val & 64)); |
374 | bits[0] = '0'+(!!(val&128)); | 376 | bits[0] = '0' + (!!(val & 128)); |
375 | printk(KERN_DEBUG | 377 | printk(KERN_DEBUG |
376 | "HFC_outb(chip %d, %02x=%s, 0x%02x=%s); in %s() line %d\n", | 378 | "HFC_outb(chip %d, %02x=%s, 0x%02x=%s); in %s() line %d\n", |
377 | hc->id, reg, regname, val, bits, function, line); | 379 | hc->id, reg, regname, val, bits, function, line); |
@@ -394,14 +396,14 @@ HFC_inb_debug(struct hfc_multi *hc, u_char reg, const char *function, int line) | |||
394 | if (regname[0] == '\0') | 396 | if (regname[0] == '\0') |
395 | strcpy(regname, "register"); | 397 | strcpy(regname, "register"); |
396 | 398 | ||
397 | bits[7] = '0'+(!!(val&1)); | 399 | bits[7] = '0' + (!!(val & 1)); |
398 | bits[6] = '0'+(!!(val&2)); | 400 | bits[6] = '0' + (!!(val & 2)); |
399 | bits[5] = '0'+(!!(val&4)); | 401 | bits[5] = '0' + (!!(val & 4)); |
400 | bits[4] = '0'+(!!(val&8)); | 402 | bits[4] = '0' + (!!(val & 8)); |
401 | bits[3] = '0'+(!!(val&16)); | 403 | bits[3] = '0' + (!!(val & 16)); |
402 | bits[2] = '0'+(!!(val&32)); | 404 | bits[2] = '0' + (!!(val & 32)); |
403 | bits[1] = '0'+(!!(val&64)); | 405 | bits[1] = '0' + (!!(val & 64)); |
404 | bits[0] = '0'+(!!(val&128)); | 406 | bits[0] = '0' + (!!(val & 128)); |
405 | printk(KERN_DEBUG | 407 | printk(KERN_DEBUG |
406 | "HFC_inb(chip %d, %02x=%s) = 0x%02x=%s; in %s() line %d\n", | 408 | "HFC_inb(chip %d, %02x=%s) = 0x%02x=%s; in %s() line %d\n", |
407 | hc->id, reg, regname, val, bits, function, line); | 409 | hc->id, reg, regname, val, bits, function, line); |
@@ -481,6 +483,7 @@ write_fifo_pcimem(struct hfc_multi *hc, u_char *data, int len) | |||
481 | len--; | 483 | len--; |
482 | } | 484 | } |
483 | } | 485 | } |
486 | |||
484 | /* read fifo data (REGIO) */ | 487 | /* read fifo data (REGIO) */ |
485 | static void | 488 | static void |
486 | read_fifo_regio(struct hfc_multi *hc, u_char *data, int len) | 489 | read_fifo_regio(struct hfc_multi *hc, u_char *data, int len) |
@@ -526,7 +529,6 @@ read_fifo_pcimem(struct hfc_multi *hc, u_char *data, int len) | |||
526 | } | 529 | } |
527 | } | 530 | } |
528 | 531 | ||
529 | |||
530 | static void | 532 | static void |
531 | enable_hwirq(struct hfc_multi *hc) | 533 | enable_hwirq(struct hfc_multi *hc) |
532 | { | 534 | { |
@@ -1011,7 +1013,7 @@ plxsd_checksync(struct hfc_multi *hc, int rm) | |||
1011 | if (hc->syncronized) { | 1013 | if (hc->syncronized) { |
1012 | if (syncmaster == NULL) { | 1014 | if (syncmaster == NULL) { |
1013 | if (debug & DEBUG_HFCMULTI_PLXSD) | 1015 | if (debug & DEBUG_HFCMULTI_PLXSD) |
1014 | printk(KERN_WARNING "%s: GOT sync on card %d" | 1016 | printk(KERN_DEBUG "%s: GOT sync on card %d" |
1015 | " (id=%d)\n", __func__, hc->id + 1, | 1017 | " (id=%d)\n", __func__, hc->id + 1, |
1016 | hc->id); | 1018 | hc->id); |
1017 | hfcmulti_resync(hc, hc, rm); | 1019 | hfcmulti_resync(hc, hc, rm); |
@@ -1019,7 +1021,7 @@ plxsd_checksync(struct hfc_multi *hc, int rm) | |||
1019 | } else { | 1021 | } else { |
1020 | if (syncmaster == hc) { | 1022 | if (syncmaster == hc) { |
1021 | if (debug & DEBUG_HFCMULTI_PLXSD) | 1023 | if (debug & DEBUG_HFCMULTI_PLXSD) |
1022 | printk(KERN_WARNING "%s: LOST sync on card %d" | 1024 | printk(KERN_DEBUG "%s: LOST sync on card %d" |
1023 | " (id=%d)\n", __func__, hc->id + 1, | 1025 | " (id=%d)\n", __func__, hc->id + 1, |
1024 | hc->id); | 1026 | hc->id); |
1025 | hfcmulti_resync(hc, NULL, rm); | 1027 | hfcmulti_resync(hc, NULL, rm); |
@@ -1068,7 +1070,7 @@ release_io_hfcmulti(struct hfc_multi *hc) | |||
1068 | pv &= ~PLX_DSP_RES_N; | 1070 | pv &= ~PLX_DSP_RES_N; |
1069 | writel(pv, plx_acc_32); | 1071 | writel(pv, plx_acc_32); |
1070 | if (debug & DEBUG_HFCMULTI_INIT) | 1072 | if (debug & DEBUG_HFCMULTI_INIT) |
1071 | printk(KERN_WARNING "%s: PCM off: PLX_GPIO=%x\n", | 1073 | printk(KERN_DEBUG "%s: PCM off: PLX_GPIO=%x\n", |
1072 | __func__, pv); | 1074 | __func__, pv); |
1073 | spin_unlock_irqrestore(&plx_lock, plx_flags); | 1075 | spin_unlock_irqrestore(&plx_lock, plx_flags); |
1074 | } | 1076 | } |
@@ -1119,8 +1121,8 @@ init_chip(struct hfc_multi *hc) | |||
1119 | if (debug & DEBUG_HFCMULTI_INIT) | 1121 | if (debug & DEBUG_HFCMULTI_INIT) |
1120 | printk(KERN_DEBUG "%s: entered\n", __func__); | 1122 | printk(KERN_DEBUG "%s: entered\n", __func__); |
1121 | val = HFC_inb(hc, R_CHIP_ID); | 1123 | val = HFC_inb(hc, R_CHIP_ID); |
1122 | if ((val>>4) != 0x8 && (val>>4) != 0xc && (val>>4) != 0xe | 1124 | if ((val >> 4) != 0x8 && (val >> 4) != 0xc && (val >> 4) != 0xe && |
1123 | && (val>>1) != 0x31) { | 1125 | (val >> 1) != 0x31) { |
1124 | printk(KERN_INFO "HFC_multi: unknown CHIP_ID:%x\n", (u_int)val); | 1126 | printk(KERN_INFO "HFC_multi: unknown CHIP_ID:%x\n", (u_int)val); |
1125 | err = -EIO; | 1127 | err = -EIO; |
1126 | goto out; | 1128 | goto out; |
@@ -1202,7 +1204,7 @@ init_chip(struct hfc_multi *hc) | |||
1202 | writel(pv, plx_acc_32); | 1204 | writel(pv, plx_acc_32); |
1203 | spin_unlock_irqrestore(&plx_lock, plx_flags); | 1205 | spin_unlock_irqrestore(&plx_lock, plx_flags); |
1204 | if (debug & DEBUG_HFCMULTI_INIT) | 1206 | if (debug & DEBUG_HFCMULTI_INIT) |
1205 | printk(KERN_WARNING "%s: slave/term: PLX_GPIO=%x\n", | 1207 | printk(KERN_DEBUG "%s: slave/term: PLX_GPIO=%x\n", |
1206 | __func__, pv); | 1208 | __func__, pv); |
1207 | /* | 1209 | /* |
1208 | * If we are the 3rd PLXSD card or higher, we must turn | 1210 | * If we are the 3rd PLXSD card or higher, we must turn |
@@ -1230,8 +1232,9 @@ init_chip(struct hfc_multi *hc) | |||
1230 | writel(pv, plx_acc_32); | 1232 | writel(pv, plx_acc_32); |
1231 | spin_unlock_irqrestore(&plx_lock, plx_flags); | 1233 | spin_unlock_irqrestore(&plx_lock, plx_flags); |
1232 | if (debug & DEBUG_HFCMULTI_INIT) | 1234 | if (debug & DEBUG_HFCMULTI_INIT) |
1233 | printk(KERN_WARNING "%s: term off: PLX_GPIO=%x\n", | 1235 | printk(KERN_DEBUG |
1234 | __func__, pv); | 1236 | "%s: term off: PLX_GPIO=%x\n", |
1237 | __func__, pv); | ||
1235 | } | 1238 | } |
1236 | spin_unlock_irqrestore(&HFClock, hfc_flags); | 1239 | spin_unlock_irqrestore(&HFClock, hfc_flags); |
1237 | hc->hw.r_pcm_md0 = V_F0_LEN; /* shift clock for DSP */ | 1240 | hc->hw.r_pcm_md0 = V_F0_LEN; /* shift clock for DSP */ |
@@ -1292,13 +1295,13 @@ init_chip(struct hfc_multi *hc) | |||
1292 | pv |= PLX_MASTER_EN | PLX_SLAVE_EN_N; | 1295 | pv |= PLX_MASTER_EN | PLX_SLAVE_EN_N; |
1293 | pv |= PLX_SYNC_O_EN; | 1296 | pv |= PLX_SYNC_O_EN; |
1294 | if (debug & DEBUG_HFCMULTI_INIT) | 1297 | if (debug & DEBUG_HFCMULTI_INIT) |
1295 | printk(KERN_WARNING "%s: master: PLX_GPIO=%x\n", | 1298 | printk(KERN_DEBUG "%s: master: PLX_GPIO=%x\n", |
1296 | __func__, pv); | 1299 | __func__, pv); |
1297 | } else { | 1300 | } else { |
1298 | pv &= ~(PLX_MASTER_EN | PLX_SLAVE_EN_N); | 1301 | pv &= ~(PLX_MASTER_EN | PLX_SLAVE_EN_N); |
1299 | pv &= ~PLX_SYNC_O_EN; | 1302 | pv &= ~PLX_SYNC_O_EN; |
1300 | if (debug & DEBUG_HFCMULTI_INIT) | 1303 | if (debug & DEBUG_HFCMULTI_INIT) |
1301 | printk(KERN_WARNING "%s: slave: PLX_GPIO=%x\n", | 1304 | printk(KERN_DEBUG "%s: slave: PLX_GPIO=%x\n", |
1302 | __func__, pv); | 1305 | __func__, pv); |
1303 | } | 1306 | } |
1304 | writel(pv, plx_acc_32); | 1307 | writel(pv, plx_acc_32); |
@@ -1410,8 +1413,8 @@ controller_fail: | |||
1410 | writel(pv, plx_acc_32); | 1413 | writel(pv, plx_acc_32); |
1411 | spin_unlock_irqrestore(&plx_lock, plx_flags); | 1414 | spin_unlock_irqrestore(&plx_lock, plx_flags); |
1412 | if (debug & DEBUG_HFCMULTI_INIT) | 1415 | if (debug & DEBUG_HFCMULTI_INIT) |
1413 | printk(KERN_WARNING "%s: master: PLX_GPIO" | 1416 | printk(KERN_DEBUG "%s: master: " |
1414 | "=%x\n", __func__, pv); | 1417 | "PLX_GPIO=%x\n", __func__, pv); |
1415 | } | 1418 | } |
1416 | hc->hw.r_pcm_md0 |= V_PCM_MD; | 1419 | hc->hw.r_pcm_md0 |= V_PCM_MD; |
1417 | HFC_outb(hc, R_PCM_MD0, hc->hw.r_pcm_md0 | 0x00); | 1420 | HFC_outb(hc, R_PCM_MD0, hc->hw.r_pcm_md0 | 0x00); |
@@ -1445,7 +1448,7 @@ controller_fail: | |||
1445 | writel(pv, plx_acc_32); | 1448 | writel(pv, plx_acc_32); |
1446 | spin_unlock_irqrestore(&plx_lock, plx_flags); | 1449 | spin_unlock_irqrestore(&plx_lock, plx_flags); |
1447 | if (debug & DEBUG_HFCMULTI_INIT) | 1450 | if (debug & DEBUG_HFCMULTI_INIT) |
1448 | printk(KERN_WARNING "%s: reset off: PLX_GPIO=%x\n", | 1451 | printk(KERN_DEBUG "%s: reset off: PLX_GPIO=%x\n", |
1449 | __func__, pv); | 1452 | __func__, pv); |
1450 | } | 1453 | } |
1451 | 1454 | ||
@@ -1878,7 +1881,7 @@ hfcmulti_dtmf(struct hfc_multi *hc) | |||
1878 | hc->chan[ch].coeff_count = 0; | 1881 | hc->chan[ch].coeff_count = 0; |
1879 | skb = mI_alloc_skb(512, GFP_ATOMIC); | 1882 | skb = mI_alloc_skb(512, GFP_ATOMIC); |
1880 | if (!skb) { | 1883 | if (!skb) { |
1881 | printk(KERN_WARNING "%s: No memory for skb\n", | 1884 | printk(KERN_DEBUG "%s: No memory for skb\n", |
1882 | __func__); | 1885 | __func__); |
1883 | continue; | 1886 | continue; |
1884 | } | 1887 | } |
@@ -2104,7 +2107,7 @@ next_frame: | |||
2104 | printk(KERN_DEBUG "%s(card %d): fifo(%d) has %d bytes space " | 2107 | printk(KERN_DEBUG "%s(card %d): fifo(%d) has %d bytes space " |
2105 | "left (z1=%04x, z2=%04x) sending %d of %d bytes %s\n", | 2108 | "left (z1=%04x, z2=%04x) sending %d of %d bytes %s\n", |
2106 | __func__, hc->id + 1, ch, Zspace, z1, z2, ii-i, len-i, | 2109 | __func__, hc->id + 1, ch, Zspace, z1, z2, ii-i, len-i, |
2107 | temp ? "HDLC":"TRANS"); | 2110 | temp ? "HDLC" : "TRANS"); |
2108 | 2111 | ||
2109 | /* Have to prep the audio data */ | 2112 | /* Have to prep the audio data */ |
2110 | hc->write_fifo(hc, d, ii - i); | 2113 | hc->write_fifo(hc, d, ii - i); |
@@ -2780,13 +2783,13 @@ hfcmulti_interrupt(int intno, void *dev_id) | |||
2780 | handle_timer_irq(hc); | 2783 | handle_timer_irq(hc); |
2781 | } | 2784 | } |
2782 | 2785 | ||
2783 | if (r_irq_misc & V_DTMF_IRQ) { | 2786 | if (r_irq_misc & V_DTMF_IRQ) |
2784 | hfcmulti_dtmf(hc); | 2787 | hfcmulti_dtmf(hc); |
2785 | } | 2788 | |
2786 | if (r_irq_misc & V_IRQ_PROC) { | 2789 | if (r_irq_misc & V_IRQ_PROC) { |
2787 | static int irq_proc_cnt; | 2790 | static int irq_proc_cnt; |
2788 | if (!irq_proc_cnt++) | 2791 | if (!irq_proc_cnt++) |
2789 | printk(KERN_WARNING "%s: got V_IRQ_PROC -" | 2792 | printk(KERN_DEBUG "%s: got V_IRQ_PROC -" |
2790 | " this should not happen\n", __func__); | 2793 | " this should not happen\n", __func__); |
2791 | } | 2794 | } |
2792 | 2795 | ||
@@ -2936,7 +2939,7 @@ mode_hfcmulti(struct hfc_multi *hc, int ch, int protocol, int slot_tx, | |||
2936 | else | 2939 | else |
2937 | flow_rx = 0xc0; /* ST->(FIFO,PCM) */ | 2940 | flow_rx = 0xc0; /* ST->(FIFO,PCM) */ |
2938 | /* put on slot */ | 2941 | /* put on slot */ |
2939 | routing = bank_rx?0x80:0xc0; /* reversed */ | 2942 | routing = bank_rx ? 0x80 : 0xc0; /* reversed */ |
2940 | if (conf >= 0 || bank_rx > 1) | 2943 | if (conf >= 0 || bank_rx > 1) |
2941 | routing = 0x40; /* loop */ | 2944 | routing = 0x40; /* loop */ |
2942 | if (debug & DEBUG_HFCMULTI_MODE) | 2945 | if (debug & DEBUG_HFCMULTI_MODE) |
@@ -2971,7 +2974,7 @@ mode_hfcmulti(struct hfc_multi *hc, int ch, int protocol, int slot_tx, | |||
2971 | HFC_wait(hc); | 2974 | HFC_wait(hc); |
2972 | if (hc->chan[ch].bch && hc->ctype != HFC_TYPE_E1) { | 2975 | if (hc->chan[ch].bch && hc->ctype != HFC_TYPE_E1) { |
2973 | hc->hw.a_st_ctrl0[hc->chan[ch].port] &= | 2976 | hc->hw.a_st_ctrl0[hc->chan[ch].port] &= |
2974 | ((ch & 0x3) == 0)? ~V_B1_EN: ~V_B2_EN; | 2977 | ((ch & 0x3) == 0) ? ~V_B1_EN : ~V_B2_EN; |
2975 | HFC_outb(hc, R_ST_SEL, hc->chan[ch].port); | 2978 | HFC_outb(hc, R_ST_SEL, hc->chan[ch].port); |
2976 | /* undocumented: delay after R_ST_SEL */ | 2979 | /* undocumented: delay after R_ST_SEL */ |
2977 | udelay(1); | 2980 | udelay(1); |
@@ -3505,9 +3508,9 @@ handle_bmsg(struct mISDNchannel *ch, struct sk_buff *skb) | |||
3505 | switch (hh->id) { | 3508 | switch (hh->id) { |
3506 | case HFC_SPL_LOOP_ON: /* set sample loop */ | 3509 | case HFC_SPL_LOOP_ON: /* set sample loop */ |
3507 | if (debug & DEBUG_HFCMULTI_MSG) | 3510 | if (debug & DEBUG_HFCMULTI_MSG) |
3508 | printk(KERN_DEBUG | 3511 | printk(KERN_DEBUG |
3509 | "%s: HFC_SPL_LOOP_ON (len = %d)\n", | 3512 | "%s: HFC_SPL_LOOP_ON (len = %d)\n", |
3510 | __func__, skb->len); | 3513 | __func__, skb->len); |
3511 | ret = 0; | 3514 | ret = 0; |
3512 | break; | 3515 | break; |
3513 | case HFC_SPL_LOOP_OFF: /* set silence */ | 3516 | case HFC_SPL_LOOP_OFF: /* set silence */ |
@@ -3716,8 +3719,7 @@ ph_state_change(struct dchannel *dch) | |||
3716 | int ch, i; | 3719 | int ch, i; |
3717 | 3720 | ||
3718 | if (!dch) { | 3721 | if (!dch) { |
3719 | printk(KERN_WARNING "%s: ERROR given dch is NULL\n", | 3722 | printk(KERN_WARNING "%s: ERROR given dch is NULL\n", __func__); |
3720 | __func__); | ||
3721 | return; | 3723 | return; |
3722 | } | 3724 | } |
3723 | hc = dch->hw; | 3725 | hc = dch->hw; |
@@ -3738,14 +3740,15 @@ ph_state_change(struct dchannel *dch) | |||
3738 | switch (dch->state) { | 3740 | switch (dch->state) { |
3739 | case (1): | 3741 | case (1): |
3740 | if (hc->e1_state != 1) { | 3742 | if (hc->e1_state != 1) { |
3741 | for (i = 1; i <= 31; i++) { | 3743 | for (i = 1; i <= 31; i++) { |
3742 | /* reset fifos on e1 activation */ | 3744 | /* reset fifos on e1 activation */ |
3743 | HFC_outb_nodebug(hc, R_FIFO, (i << 1) | 1); | 3745 | HFC_outb_nodebug(hc, R_FIFO, |
3744 | HFC_wait_nodebug(hc); | 3746 | (i << 1) | 1); |
3745 | HFC_outb_nodebug(hc, | 3747 | HFC_wait_nodebug(hc); |
3746 | R_INC_RES_FIFO, V_RES_F); | 3748 | HFC_outb_nodebug(hc, R_INC_RES_FIFO, |
3747 | HFC_wait_nodebug(hc); | 3749 | V_RES_F); |
3748 | } | 3750 | HFC_wait_nodebug(hc); |
3751 | } | ||
3749 | } | 3752 | } |
3750 | test_and_set_bit(FLG_ACTIVE, &dch->Flags); | 3753 | test_and_set_bit(FLG_ACTIVE, &dch->Flags); |
3751 | _queue_data(&dch->dev.D, PH_ACTIVATE_IND, | 3754 | _queue_data(&dch->dev.D, PH_ACTIVATE_IND, |
@@ -4045,12 +4048,12 @@ open_dchannel(struct hfc_multi *hc, struct dchannel *dch, | |||
4045 | return -EINVAL; | 4048 | return -EINVAL; |
4046 | if ((dch->dev.D.protocol != ISDN_P_NONE) && | 4049 | if ((dch->dev.D.protocol != ISDN_P_NONE) && |
4047 | (dch->dev.D.protocol != rq->protocol)) { | 4050 | (dch->dev.D.protocol != rq->protocol)) { |
4048 | if (debug & DEBUG_HFCMULTI_MODE) | 4051 | if (debug & DEBUG_HFCMULTI_MODE) |
4049 | printk(KERN_WARNING "%s: change protocol %x to %x\n", | 4052 | printk(KERN_DEBUG "%s: change protocol %x to %x\n", |
4050 | __func__, dch->dev.D.protocol, rq->protocol); | 4053 | __func__, dch->dev.D.protocol, rq->protocol); |
4051 | } | 4054 | } |
4052 | if ((dch->dev.D.protocol == ISDN_P_TE_S0) | 4055 | if ((dch->dev.D.protocol == ISDN_P_TE_S0) && |
4053 | && (rq->protocol != ISDN_P_TE_S0)) | 4056 | (rq->protocol != ISDN_P_TE_S0)) |
4054 | l1_event(dch->l1, CLOSE_CHANNEL); | 4057 | l1_event(dch->l1, CLOSE_CHANNEL); |
4055 | if (dch->dev.D.protocol != rq->protocol) { | 4058 | if (dch->dev.D.protocol != rq->protocol) { |
4056 | if (rq->protocol == ISDN_P_TE_S0) { | 4059 | if (rq->protocol == ISDN_P_TE_S0) { |
@@ -4127,9 +4130,9 @@ channel_dctrl(struct dchannel *dch, struct mISDN_ctrl_req *cq) | |||
4127 | wd_cnt = cq->p1 & 0xf; | 4130 | wd_cnt = cq->p1 & 0xf; |
4128 | wd_mode = !!(cq->p1 >> 4); | 4131 | wd_mode = !!(cq->p1 >> 4); |
4129 | if (debug & DEBUG_HFCMULTI_MSG) | 4132 | if (debug & DEBUG_HFCMULTI_MSG) |
4130 | printk(KERN_DEBUG | 4133 | printk(KERN_DEBUG "%s: MISDN_CTRL_HFC_WD_INIT mode %s" |
4131 | "%s: MISDN_CTRL_HFC_WD_INIT mode %s counter 0x%x\n", | 4134 | ", counter 0x%x\n", __func__, |
4132 | __func__, wd_mode ? "AUTO" : "MANUAL", wd_cnt); | 4135 | wd_mode ? "AUTO" : "MANUAL", wd_cnt); |
4133 | /* set the watchdog timer */ | 4136 | /* set the watchdog timer */ |
4134 | HFC_outb(hc, R_TI_WD, poll_timer | (wd_cnt << 4)); | 4137 | HFC_outb(hc, R_TI_WD, poll_timer | (wd_cnt << 4)); |
4135 | hc->hw.r_bert_wd_md = (wd_mode ? V_AUTO_WD_RES : 0); | 4138 | hc->hw.r_bert_wd_md = (wd_mode ? V_AUTO_WD_RES : 0); |
@@ -4139,8 +4142,8 @@ channel_dctrl(struct dchannel *dch, struct mISDN_ctrl_req *cq) | |||
4139 | HFC_outb(hc, R_BERT_WD_MD, hc->hw.r_bert_wd_md | V_WD_RES); | 4142 | HFC_outb(hc, R_BERT_WD_MD, hc->hw.r_bert_wd_md | V_WD_RES); |
4140 | if (test_bit(HFC_CHIP_PLXSD, &hc->chip)) { | 4143 | if (test_bit(HFC_CHIP_PLXSD, &hc->chip)) { |
4141 | /* enable the watchdog output for Speech-Design */ | 4144 | /* enable the watchdog output for Speech-Design */ |
4142 | HFC_outb(hc, R_GPIO_SEL, V_GPIO_SEL7); | 4145 | HFC_outb(hc, R_GPIO_SEL, V_GPIO_SEL7); |
4143 | HFC_outb(hc, R_GPIO_EN1, V_GPIO_EN15); | 4146 | HFC_outb(hc, R_GPIO_EN1, V_GPIO_EN15); |
4144 | HFC_outb(hc, R_GPIO_OUT1, 0); | 4147 | HFC_outb(hc, R_GPIO_OUT1, 0); |
4145 | HFC_outb(hc, R_GPIO_OUT1, V_GPIO_OUT15); | 4148 | HFC_outb(hc, R_GPIO_OUT1, V_GPIO_OUT15); |
4146 | } | 4149 | } |
@@ -4319,7 +4322,7 @@ error: | |||
4319 | } | 4322 | } |
4320 | 4323 | ||
4321 | if (debug & DEBUG_HFCMULTI_INIT) | 4324 | if (debug & DEBUG_HFCMULTI_INIT) |
4322 | printk(KERN_WARNING "%s: free irq %d\n", __func__, hc->irq); | 4325 | printk(KERN_DEBUG "%s: free irq %d\n", __func__, hc->irq); |
4323 | if (hc->irq) { | 4326 | if (hc->irq) { |
4324 | free_irq(hc->irq, hc); | 4327 | free_irq(hc->irq, hc); |
4325 | hc->irq = 0; | 4328 | hc->irq = 0; |
@@ -4624,7 +4627,7 @@ release_card(struct hfc_multi *hc) | |||
4624 | int ch; | 4627 | int ch; |
4625 | 4628 | ||
4626 | if (debug & DEBUG_HFCMULTI_INIT) | 4629 | if (debug & DEBUG_HFCMULTI_INIT) |
4627 | printk(KERN_WARNING "%s: release card (%d) entered\n", | 4630 | printk(KERN_DEBUG "%s: release card (%d) entered\n", |
4628 | __func__, hc->id); | 4631 | __func__, hc->id); |
4629 | 4632 | ||
4630 | /* unregister clock source */ | 4633 | /* unregister clock source */ |
@@ -4653,7 +4656,7 @@ release_card(struct hfc_multi *hc) | |||
4653 | /* release hardware & irq */ | 4656 | /* release hardware & irq */ |
4654 | if (hc->irq) { | 4657 | if (hc->irq) { |
4655 | if (debug & DEBUG_HFCMULTI_INIT) | 4658 | if (debug & DEBUG_HFCMULTI_INIT) |
4656 | printk(KERN_WARNING "%s: free irq %d\n", | 4659 | printk(KERN_DEBUG "%s: free irq %d\n", |
4657 | __func__, hc->irq); | 4660 | __func__, hc->irq); |
4658 | free_irq(hc->irq, hc); | 4661 | free_irq(hc->irq, hc); |
4659 | hc->irq = 0; | 4662 | hc->irq = 0; |
@@ -4662,17 +4665,17 @@ release_card(struct hfc_multi *hc) | |||
4662 | release_io_hfcmulti(hc); | 4665 | release_io_hfcmulti(hc); |
4663 | 4666 | ||
4664 | if (debug & DEBUG_HFCMULTI_INIT) | 4667 | if (debug & DEBUG_HFCMULTI_INIT) |
4665 | printk(KERN_WARNING "%s: remove instance from list\n", | 4668 | printk(KERN_DEBUG "%s: remove instance from list\n", |
4666 | __func__); | 4669 | __func__); |
4667 | list_del(&hc->list); | 4670 | list_del(&hc->list); |
4668 | 4671 | ||
4669 | if (debug & DEBUG_HFCMULTI_INIT) | 4672 | if (debug & DEBUG_HFCMULTI_INIT) |
4670 | printk(KERN_WARNING "%s: delete instance\n", __func__); | 4673 | printk(KERN_DEBUG "%s: delete instance\n", __func__); |
4671 | if (hc == syncmaster) | 4674 | if (hc == syncmaster) |
4672 | syncmaster = NULL; | 4675 | syncmaster = NULL; |
4673 | kfree(hc); | 4676 | kfree(hc); |
4674 | if (debug & DEBUG_HFCMULTI_INIT) | 4677 | if (debug & DEBUG_HFCMULTI_INIT) |
4675 | printk(KERN_WARNING "%s: card successfully removed\n", | 4678 | printk(KERN_DEBUG "%s: card successfully removed\n", |
4676 | __func__); | 4679 | __func__); |
4677 | } | 4680 | } |
4678 | 4681 | ||
@@ -4695,7 +4698,7 @@ init_e1_port(struct hfc_multi *hc, struct hm_map *m) | |||
4695 | (1 << (ISDN_P_B_HDLC & ISDN_P_B_MASK)); | 4698 | (1 << (ISDN_P_B_HDLC & ISDN_P_B_MASK)); |
4696 | dch->dev.D.send = handle_dmsg; | 4699 | dch->dev.D.send = handle_dmsg; |
4697 | dch->dev.D.ctrl = hfcm_dctrl; | 4700 | dch->dev.D.ctrl = hfcm_dctrl; |
4698 | dch->dev.nrbchan = (hc->dslot)?30:31; | 4701 | dch->dev.nrbchan = (hc->dslot) ? 30 : 31; |
4699 | dch->slot = hc->dslot; | 4702 | dch->slot = hc->dslot; |
4700 | hc->chan[hc->dslot].dch = dch; | 4703 | hc->chan[hc->dslot].dch = dch; |
4701 | hc->chan[hc->dslot].port = 0; | 4704 | hc->chan[hc->dslot].port = 0; |
@@ -4937,7 +4940,7 @@ init_multi_port(struct hfc_multi *hc, int pt) | |||
4937 | } | 4940 | } |
4938 | /* disable E-channel */ | 4941 | /* disable E-channel */ |
4939 | if (port[Port_cnt] & 0x004) { | 4942 | if (port[Port_cnt] & 0x004) { |
4940 | if (debug & DEBUG_HFCMULTI_INIT) | 4943 | if (debug & DEBUG_HFCMULTI_INIT) |
4941 | printk(KERN_DEBUG | 4944 | printk(KERN_DEBUG |
4942 | "%s: PROTOCOL disable E-channel: " | 4945 | "%s: PROTOCOL disable E-channel: " |
4943 | "card(%d) port(%d)\n", | 4946 | "card(%d) port(%d)\n", |
@@ -5222,7 +5225,7 @@ static void __devexit hfc_remove_pci(struct pci_dev *pdev) | |||
5222 | spin_unlock_irqrestore(&HFClock, flags); | 5225 | spin_unlock_irqrestore(&HFClock, flags); |
5223 | } else { | 5226 | } else { |
5224 | if (debug) | 5227 | if (debug) |
5225 | printk(KERN_WARNING "%s: drvdata allready removed\n", | 5228 | printk(KERN_DEBUG "%s: drvdata allready removed\n", |
5226 | __func__); | 5229 | __func__); |
5227 | } | 5230 | } |
5228 | } | 5231 | } |