Lines Matching +full:1 +full:p

41  * IEEE 1284 parallel port driven by a Texas Instrument TL16PIR552PH chip[1].
45 * [1] http://focus.ti.com/docs/prod/folders/print/tl16pir552.html
58 * 1 standard level: pr_debug1 is enabled
71 #if DEBUG_PARPORT_IP32 == 1
72 # warning DEBUG_PARPORT_IP32 == 1
104 #if DEBUG_PARPORT_IP32 >= 1
105 # define DEFAULT_VERBOSE_PROBING 1
119 #define PARPORT_IP32_ENABLE_IRQ (1U << 0)
120 #define PARPORT_IP32_ENABLE_DMA (1U << 1)
121 #define PARPORT_IP32_ENABLE_SPP (1U << 2)
122 #define PARPORT_IP32_ENABLE_EPP (1U << 3)
123 #define PARPORT_IP32_ENABLE_ECP (1U << 4)
143 * @eppData1: EPP Data Register 1
172 #define DSR_nBUSY (1U << 7) /* PARPORT_STATUS_BUSY */
173 #define DSR_nACK (1U << 6) /* PARPORT_STATUS_ACK */
174 #define DSR_PERROR (1U << 5) /* PARPORT_STATUS_PAPEROUT */
175 #define DSR_SELECT (1U << 4) /* PARPORT_STATUS_SELECT */
176 #define DSR_nFAULT (1U << 3) /* PARPORT_STATUS_ERROR */
177 #define DSR_nPRINT (1U << 2) /* specific to TL16PIR552 */
178 /* #define DSR_reserved (1U << 1) */
179 #define DSR_TIMEOUT (1U << 0) /* EPP timeout */
182 /* #define DCR_reserved (1U << 7) | (1U << 6) */
183 #define DCR_DIR (1U << 5) /* direction */
184 #define DCR_IRQ (1U << 4) /* interrupt on nAck */
185 #define DCR_SELECT (1U << 3) /* PARPORT_CONTROL_SELECT */
186 #define DCR_nINIT (1U << 2) /* PARPORT_CONTROL_INIT */
187 #define DCR_AUTOFD (1U << 1) /* PARPORT_CONTROL_AUTOFD */
188 #define DCR_STROBE (1U << 0) /* PARPORT_CONTROL_STROBE */
191 #define CNFGA_IRQ (1U << 7)
192 #define CNFGA_ID_MASK ((1U << 6) | (1U << 5) | (1U << 4))
197 /* #define CNFGA_reserved (1U << 3) */
198 #define CNFGA_nBYTEINTRANS (1U << 2)
199 #define CNFGA_PWORDLEFT ((1U << 1) | (1U << 0))
202 #define CNFGB_COMPRESS (1U << 7)
203 #define CNFGB_INTRVAL (1U << 6)
204 #define CNFGB_IRQ_MASK ((1U << 5) | (1U << 4) | (1U << 3))
206 #define CNFGB_DMA_MASK ((1U << 2) | (1U << 1) | (1U << 0))
210 #define ECR_MODE_MASK ((1U << 7) | (1U << 6) | (1U << 5))
220 #define ECR_nERRINTR (1U << 4)
221 #define ECR_DMAEN (1U << 3)
222 #define ECR_SERVINTR (1U << 2)
223 #define ECR_F_FULL (1U << 1)
224 #define ECR_F_EMPTY (1U << 0)
266 * This is like pr_debug(), but is defined for %DEBUG_PARPORT_IP32 >= 1
268 #if DEBUG_PARPORT_IP32 >= 1
270 #else /* DEBUG_PARPORT_IP32 < 1 */
276 * @p: pointer to &struct parport
285 #define __pr_trace(pr, p, fmt, ...) \ argument
287 ({ const struct parport *__p = (p); \
290 #define pr_trace(p, fmt, ...) __pr_trace(pr_debug, p, fmt , ##__VA_ARGS__) argument
291 #define pr_trace1(p, fmt, ...) __pr_trace(pr_debug1, p, fmt , ##__VA_ARGS__) argument
295 * @p: pointer to &struct parport
303 #define pr_probe(p, fmt, ...) \ argument
304 __pr_probe(KERN_INFO PPIP32 "0x%lx: " fmt, (p)->base , ##__VA_ARGS__)
308 * @p: pointer to &struct parport
318 static void parport_ip32_dump_state(struct parport *p, char *str, in parport_ip32_dump_state() argument
321 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_dump_state()
324 printk(KERN_DEBUG PPIP32 "%s: state (%s):\n", p->name, str); in parport_ip32_dump_state()
375 ((cnfgA & CNFGA_PWORDLEFT) > 1) ? "s" : ""); in parport_ip32_dump_state()
432 * @p: pointer to &struct parport
438 * defined if %DEBUG_PARPORT_IP32 >= 1.
440 #if DEBUG_PARPORT_IP32 >= 1
441 #define CHECK_EXTRA_BITS(p, b, m) \ argument
447 (p)->name, __func__, #b, __b, __m); \
449 #else /* DEBUG_PARPORT_IP32 < 1 */
462 * @ctx: next context to write (0: context_a; 1: context_b)
517 ctxval |= ((count - 1) << MACEPAR_CONTEXT_DATALEN_SHIFT) & in parport_ip32_dma_setup_context()
522 parport_ip32_dma.ctx ^= 1U; in parport_ip32_dma_setup_context()
559 * @p: partport to work on
567 static int parport_ip32_dma_start(struct parport *p, in parport_ip32_dma_start() argument
585 WARN_ON(1); in parport_ip32_dma_start()
588 parport_ip32_dma.irq_on = 1; in parport_ip32_dma_start()
593 parport_ip32_dma.buf = dma_map_single(&p->bus_dev, addr, count, dir); in parport_ip32_dma_start()
604 (parport_ip32_dma.next & (MACEPAR_CONTEXT_DATA_BOUND - 1)); in parport_ip32_dma_start()
617 * @p: partport to work on
622 static void parport_ip32_dma_stop(struct parport *p) in parport_ip32_dma_stop() argument
628 size_t res[2]; /* {[0] = res_a, [1] = res_b} */ in parport_ip32_dma_stop()
657 1 + ((ctx_a & MACEPAR_CONTEXT_DATALEN_MASK) >> in parport_ip32_dma_stop()
660 res[1] = (ctrl & MACEPAR_CTLSTAT_CTXB_VALID) ? in parport_ip32_dma_stop()
661 1 + ((ctx_b & MACEPAR_CONTEXT_DATALEN_MASK) >> in parport_ip32_dma_stop()
666 1 + ((diag & MACEPAR_DIAG_CTRMASK) >> in parport_ip32_dma_stop()
668 parport_ip32_dma.left += res[0] + res[1]; in parport_ip32_dma_stop()
676 parport_ip32_dma.irq_on = 1; in parport_ip32_dma_stop()
678 dma_unmap_single(&p->bus_dev, parport_ip32_dma.buf, in parport_ip32_dma_stop()
702 parport_ip32_dma.irq_on = 1; in parport_ip32_dma_register()
751 * @p: pointer to &struct parport
753 static inline void parport_ip32_wakeup(struct parport *p) in parport_ip32_wakeup() argument
755 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_wakeup()
769 struct parport * const p = dev_id; in parport_ip32_interrupt() local
770 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_interrupt()
778 parport_ip32_wakeup(p); in parport_ip32_interrupt()
789 * @p: pointer to &struct parport
791 static inline unsigned int parport_ip32_read_econtrol(struct parport *p) in parport_ip32_read_econtrol() argument
793 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_read_econtrol()
799 * @p: pointer to &struct parport
802 static inline void parport_ip32_write_econtrol(struct parport *p, in parport_ip32_write_econtrol() argument
805 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_write_econtrol()
811 * @p: pointer to &struct parport
818 static inline void parport_ip32_frob_econtrol(struct parport *p, in parport_ip32_frob_econtrol() argument
823 c = (parport_ip32_read_econtrol(p) & ~mask) ^ val; in parport_ip32_frob_econtrol()
824 parport_ip32_write_econtrol(p, c); in parport_ip32_frob_econtrol()
829 * @p: pointer to &struct parport
835 static void parport_ip32_set_mode(struct parport *p, unsigned int mode) in parport_ip32_set_mode() argument
840 omode = parport_ip32_read_econtrol(p) & ECR_MODE_MASK; in parport_ip32_set_mode()
846 parport_ip32_write_econtrol(p, ecr); in parport_ip32_set_mode()
848 parport_ip32_write_econtrol(p, mode | ECR_nERRINTR | ECR_SERVINTR); in parport_ip32_set_mode()
855 * @p: pointer to &struct parport
857 static inline unsigned char parport_ip32_read_data(struct parport *p) in parport_ip32_read_data() argument
859 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_read_data()
865 * @p: pointer to &struct parport
868 static inline void parport_ip32_write_data(struct parport *p, unsigned char d) in parport_ip32_write_data() argument
870 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_write_data()
876 * @p: pointer to &struct parport
878 static inline unsigned char parport_ip32_read_status(struct parport *p) in parport_ip32_read_status() argument
880 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_read_status()
886 * @p: pointer to &struct parport
888 static inline unsigned int __parport_ip32_read_control(struct parport *p) in __parport_ip32_read_control() argument
890 struct parport_ip32_private * const priv = p->physport->private_data; in __parport_ip32_read_control()
896 * @p: pointer to &struct parport
899 static inline void __parport_ip32_write_control(struct parport *p, in __parport_ip32_write_control() argument
902 struct parport_ip32_private * const priv = p->physport->private_data; in __parport_ip32_write_control()
903 CHECK_EXTRA_BITS(p, c, priv->dcr_writable); in __parport_ip32_write_control()
911 * @p: pointer to &struct parport
919 static inline void __parport_ip32_frob_control(struct parport *p, in __parport_ip32_frob_control() argument
924 c = (__parport_ip32_read_control(p) & ~mask) ^ val; in __parport_ip32_frob_control()
925 __parport_ip32_write_control(p, c); in __parport_ip32_frob_control()
930 * @p: pointer to &struct parport
935 static inline unsigned char parport_ip32_read_control(struct parport *p) in parport_ip32_read_control() argument
939 return __parport_ip32_read_control(p) & rm; in parport_ip32_read_control()
944 * @p: pointer to &struct parport
950 static inline void parport_ip32_write_control(struct parport *p, in parport_ip32_write_control() argument
955 CHECK_EXTRA_BITS(p, c, wm); in parport_ip32_write_control()
956 __parport_ip32_frob_control(p, wm, c & wm); in parport_ip32_write_control()
961 * @p: pointer to &struct parport
968 static inline unsigned char parport_ip32_frob_control(struct parport *p, in parport_ip32_frob_control() argument
974 CHECK_EXTRA_BITS(p, mask, wm); in parport_ip32_frob_control()
975 CHECK_EXTRA_BITS(p, val, wm); in parport_ip32_frob_control()
976 __parport_ip32_frob_control(p, mask & wm, val & wm); in parport_ip32_frob_control()
977 return parport_ip32_read_control(p); in parport_ip32_frob_control()
982 * @p: pointer to &struct parport
984 static inline void parport_ip32_disable_irq(struct parport *p) in parport_ip32_disable_irq() argument
986 __parport_ip32_frob_control(p, DCR_IRQ, 0); in parport_ip32_disable_irq()
991 * @p: pointer to &struct parport
993 static inline void parport_ip32_enable_irq(struct parport *p) in parport_ip32_enable_irq() argument
995 __parport_ip32_frob_control(p, DCR_IRQ, DCR_IRQ); in parport_ip32_enable_irq()
1000 * @p: pointer to &struct parport
1004 static inline void parport_ip32_data_forward(struct parport *p) in parport_ip32_data_forward() argument
1006 __parport_ip32_frob_control(p, DCR_DIR, 0); in parport_ip32_data_forward()
1011 * @p: pointer to &struct parport
1013 * Place the data bus in a high impedance state, if @p->modes has the
1016 static inline void parport_ip32_data_reverse(struct parport *p) in parport_ip32_data_reverse() argument
1018 __parport_ip32_frob_control(p, DCR_DIR, DCR_DIR); in parport_ip32_data_reverse()
1035 * @p: pointer to &struct parport
1038 static void parport_ip32_save_state(struct parport *p, in parport_ip32_save_state() argument
1041 s->u.ip32.dcr = __parport_ip32_read_control(p); in parport_ip32_save_state()
1042 s->u.ip32.ecr = parport_ip32_read_econtrol(p); in parport_ip32_save_state()
1047 * @p: pointer to &struct parport
1050 static void parport_ip32_restore_state(struct parport *p, in parport_ip32_restore_state() argument
1053 parport_ip32_set_mode(p, s->u.ip32.ecr & ECR_MODE_MASK); in parport_ip32_restore_state()
1054 parport_ip32_write_econtrol(p, s->u.ip32.ecr); in parport_ip32_restore_state()
1055 __parport_ip32_write_control(p, s->u.ip32.dcr); in parport_ip32_restore_state()
1062 * @p: pointer to &struct parport
1064 * Returns 1 if the Timeout bit is clear, and 0 otherwise.
1066 static unsigned int parport_ip32_clear_epp_timeout(struct parport *p) in parport_ip32_clear_epp_timeout() argument
1068 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_clear_epp_timeout()
1071 if (!(parport_ip32_read_status(p) & DSR_TIMEOUT)) in parport_ip32_clear_epp_timeout()
1072 cleared = 1; in parport_ip32_clear_epp_timeout()
1076 parport_ip32_read_status(p); in parport_ip32_clear_epp_timeout()
1077 r = parport_ip32_read_status(p); in parport_ip32_clear_epp_timeout()
1078 /* Some reset by writing 1 */ in parport_ip32_clear_epp_timeout()
1083 r = parport_ip32_read_status(p); in parport_ip32_clear_epp_timeout()
1087 pr_trace(p, "(): %s", cleared ? "cleared" : "failed"); in parport_ip32_clear_epp_timeout()
1094 * @p: pointer to &struct parport
1100 struct parport *p, void *buf, in parport_ip32_epp_read() argument
1103 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_epp_read()
1105 parport_ip32_set_mode(p, ECR_MODE_EPP); in parport_ip32_epp_read()
1106 parport_ip32_data_reverse(p); in parport_ip32_epp_read()
1107 parport_ip32_write_control(p, DCR_nINIT); in parport_ip32_epp_read()
1108 if ((flags & PARPORT_EPP_FAST) && (len > 1)) { in parport_ip32_epp_read()
1111 parport_ip32_clear_epp_timeout(p); in parport_ip32_epp_read()
1120 parport_ip32_clear_epp_timeout(p); in parport_ip32_epp_read()
1125 parport_ip32_data_forward(p); in parport_ip32_epp_read()
1126 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_epp_read()
1133 * @p: pointer to &struct parport
1139 struct parport *p, const void *buf, in parport_ip32_epp_write() argument
1142 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_epp_write()
1144 parport_ip32_set_mode(p, ECR_MODE_EPP); in parport_ip32_epp_write()
1145 parport_ip32_data_forward(p); in parport_ip32_epp_write()
1146 parport_ip32_write_control(p, DCR_nINIT); in parport_ip32_epp_write()
1147 if ((flags & PARPORT_EPP_FAST) && (len > 1)) { in parport_ip32_epp_write()
1150 parport_ip32_clear_epp_timeout(p); in parport_ip32_epp_write()
1159 parport_ip32_clear_epp_timeout(p); in parport_ip32_epp_write()
1164 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_epp_write()
1170 * @p: pointer to &struct parport
1175 static size_t parport_ip32_epp_read_data(struct parport *p, void *buf, in parport_ip32_epp_read_data() argument
1178 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_epp_read_data()
1179 return parport_ip32_epp_read(priv->regs.eppData0, p, buf, len, flags); in parport_ip32_epp_read_data()
1184 * @p: pointer to &struct parport
1189 static size_t parport_ip32_epp_write_data(struct parport *p, const void *buf, in parport_ip32_epp_write_data() argument
1192 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_epp_write_data()
1193 return parport_ip32_epp_write(priv->regs.eppData0, p, buf, len, flags); in parport_ip32_epp_write_data()
1198 * @p: pointer to &struct parport
1203 static size_t parport_ip32_epp_read_addr(struct parport *p, void *buf, in parport_ip32_epp_read_addr() argument
1206 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_epp_read_addr()
1207 return parport_ip32_epp_read(priv->regs.eppAddr, p, buf, len, flags); in parport_ip32_epp_read_addr()
1212 * @p: pointer to &struct parport
1217 static size_t parport_ip32_epp_write_addr(struct parport *p, const void *buf, in parport_ip32_epp_write_addr() argument
1220 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_epp_write_addr()
1221 return parport_ip32_epp_write(priv->regs.eppAddr, p, buf, len, flags); in parport_ip32_epp_write_addr()
1228 * @p: pointer to &struct parport
1238 static unsigned int parport_ip32_fifo_wait_break(struct parport *p, in parport_ip32_fifo_wait_break() argument
1243 pr_debug1(PPIP32 "%s: FIFO write timed out\n", p->name); in parport_ip32_fifo_wait_break()
1244 return 1; in parport_ip32_fifo_wait_break()
1247 pr_debug1(PPIP32 "%s: Signal pending\n", p->name); in parport_ip32_fifo_wait_break()
1248 return 1; in parport_ip32_fifo_wait_break()
1250 if (!(parport_ip32_read_status(p) & DSR_nFAULT)) { in parport_ip32_fifo_wait_break()
1251 pr_debug1(PPIP32 "%s: nFault asserted low\n", p->name); in parport_ip32_fifo_wait_break()
1252 return 1; in parport_ip32_fifo_wait_break()
1259 * @p: pointer to &struct parport
1265 static unsigned int parport_ip32_fwp_wait_polling(struct parport *p) in parport_ip32_fwp_wait_polling() argument
1267 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_fwp_wait_polling()
1268 struct parport * const physport = p->physport; in parport_ip32_fwp_wait_polling()
1275 while (1) { in parport_ip32_fwp_wait_polling()
1276 if (parport_ip32_fifo_wait_break(p, expire)) in parport_ip32_fwp_wait_polling()
1283 ecr = parport_ip32_read_econtrol(p); in parport_ip32_fwp_wait_polling()
1292 } /* while (1) */ in parport_ip32_fwp_wait_polling()
1299 * @p: pointer to &struct parport
1305 static unsigned int parport_ip32_fwp_wait_interrupt(struct parport *p) in parport_ip32_fwp_wait_interrupt() argument
1308 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_fwp_wait_interrupt()
1309 struct parport * const physport = p->physport; in parport_ip32_fwp_wait_interrupt()
1319 while (1) { in parport_ip32_fwp_wait_interrupt()
1320 if (parport_ip32_fifo_wait_break(p, expire)) in parport_ip32_fwp_wait_interrupt()
1327 parport_ip32_frob_econtrol(p, ECR_SERVINTR, 0); in parport_ip32_fwp_wait_interrupt()
1332 ecr = parport_ip32_read_econtrol(p); in parport_ip32_fwp_wait_interrupt()
1338 ecr = parport_ip32_read_econtrol(p); in parport_ip32_fwp_wait_interrupt()
1342 p->name, __func__); in parport_ip32_fwp_wait_interrupt()
1343 lost_interrupt = 1; in parport_ip32_fwp_wait_interrupt()
1348 parport_ip32_frob_econtrol(p, ECR_SERVINTR, ECR_SERVINTR); in parport_ip32_fwp_wait_interrupt()
1365 } /* while (1) */ in parport_ip32_fwp_wait_interrupt()
1372 * @p: pointer to &struct parport
1381 static size_t parport_ip32_fifo_write_block_pio(struct parport *p, in parport_ip32_fifo_write_block_pio() argument
1384 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_fifo_write_block_pio()
1393 count = (p->irq == PARPORT_IRQ_NONE) ? in parport_ip32_fifo_write_block_pio()
1394 parport_ip32_fwp_wait_polling(p) : in parport_ip32_fifo_write_block_pio()
1395 parport_ip32_fwp_wait_interrupt(p); in parport_ip32_fifo_write_block_pio()
1400 if (count == 1) { in parport_ip32_fifo_write_block_pio()
1416 * @p: pointer to &struct parport
1425 static size_t parport_ip32_fifo_write_block_dma(struct parport *p, in parport_ip32_fifo_write_block_dma() argument
1428 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_fifo_write_block_dma()
1429 struct parport * const physport = p->physport; in parport_ip32_fifo_write_block_dma()
1437 parport_ip32_dma_start(p, DMA_TO_DEVICE, (void *)buf, len); in parport_ip32_fifo_write_block_dma()
1439 parport_ip32_frob_econtrol(p, ECR_DMAEN | ECR_SERVINTR, ECR_DMAEN); in parport_ip32_fifo_write_block_dma()
1444 while (1) { in parport_ip32_fifo_write_block_dma()
1445 if (parport_ip32_fifo_wait_break(p, expire)) in parport_ip32_fifo_write_block_dma()
1449 ecr = parport_ip32_read_econtrol(p); in parport_ip32_fifo_write_block_dma()
1453 parport_ip32_dma_stop(p); in parport_ip32_fifo_write_block_dma()
1463 * @p: pointer to &struct parport
1468 * p FIFO. Returns the number of bytes that were actually written.
1470 static size_t parport_ip32_fifo_write_block(struct parport *p, in parport_ip32_fifo_write_block() argument
1477 written = (p->modes & PARPORT_MODE_DMA) ? in parport_ip32_fifo_write_block()
1478 parport_ip32_fifo_write_block_dma(p, buf, len) : in parport_ip32_fifo_write_block()
1479 parport_ip32_fifo_write_block_pio(p, buf, len); in parport_ip32_fifo_write_block()
1485 * @p: pointer to &struct parport
1488 * This function waits for FIFO to empty. It returns 1 when FIFO is empty, or
1491 static unsigned int parport_ip32_drain_fifo(struct parport *p, in parport_ip32_drain_fifo() argument
1500 if (parport_ip32_read_econtrol(p) & ECR_F_EMPTY) in parport_ip32_drain_fifo()
1508 /* Poll slowly. Polling interval starts with 1 millisecond, and is in parport_ip32_drain_fifo()
1510 polling_interval = 1; /* msecs */ in parport_ip32_drain_fifo()
1511 while (!(parport_ip32_read_econtrol(p) & ECR_F_EMPTY)) { in parport_ip32_drain_fifo()
1521 return !!(parport_ip32_read_econtrol(p) & ECR_F_EMPTY); in parport_ip32_drain_fifo()
1526 * @p: pointer to &struct parport
1531 static unsigned int parport_ip32_get_fifo_residue(struct parport *p, in parport_ip32_get_fifo_residue() argument
1534 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_get_fifo_residue()
1543 if (parport_ip32_read_econtrol(p) & ECR_F_EMPTY) in parport_ip32_get_fifo_residue()
1546 pr_debug1(PPIP32 "%s: FIFO is stuck\n", p->name); in parport_ip32_get_fifo_residue()
1560 parport_ip32_frob_control(p, DCR_STROBE, 0); in parport_ip32_get_fifo_residue()
1564 if (parport_ip32_read_econtrol(p) & ECR_F_FULL) in parport_ip32_get_fifo_residue()
1571 p->name, residue, in parport_ip32_get_fifo_residue()
1572 (residue == 1) ? " was" : "s were"); in parport_ip32_get_fifo_residue()
1575 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_get_fifo_residue()
1579 parport_ip32_data_reverse(p); in parport_ip32_get_fifo_residue()
1580 parport_ip32_frob_control(p, DCR_nINIT, 0); in parport_ip32_get_fifo_residue()
1581 if (parport_wait_peripheral(p, DSR_PERROR, 0)) in parport_ip32_get_fifo_residue()
1582 pr_debug1(PPIP32 "%s: PEerror timeout 1 in %s\n", in parport_ip32_get_fifo_residue()
1583 p->name, __func__); in parport_ip32_get_fifo_residue()
1584 parport_ip32_frob_control(p, DCR_STROBE, DCR_STROBE); in parport_ip32_get_fifo_residue()
1585 parport_ip32_frob_control(p, DCR_nINIT, DCR_nINIT); in parport_ip32_get_fifo_residue()
1586 if (parport_wait_peripheral(p, DSR_PERROR, DSR_PERROR)) in parport_ip32_get_fifo_residue()
1588 p->name, __func__); in parport_ip32_get_fifo_residue()
1592 parport_ip32_set_mode(p, ECR_MODE_CFG); in parport_ip32_get_fifo_residue()
1596 p->name, cnfga); in parport_ip32_get_fifo_residue()
1598 p->name); in parport_ip32_get_fifo_residue()
1603 * PWord != 1 byte. */ in parport_ip32_get_fifo_residue()
1606 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_get_fifo_residue()
1607 parport_ip32_data_forward(p); in parport_ip32_get_fifo_residue()
1614 * @p: pointer to &struct parport
1619 static size_t parport_ip32_compat_write_data(struct parport *p, in parport_ip32_compat_write_data() argument
1623 static unsigned int ready_before = 1; in parport_ip32_compat_write_data()
1624 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_compat_write_data()
1625 struct parport * const physport = p->physport; in parport_ip32_compat_write_data()
1631 return parport_ieee1284_write_compat(p, buf, len, flags); in parport_ip32_compat_write_data()
1634 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_compat_write_data()
1635 parport_ip32_write_control(p, DCR_SELECT | DCR_nINIT); in parport_ip32_compat_write_data()
1636 parport_ip32_data_forward(p); in parport_ip32_compat_write_data()
1637 parport_ip32_disable_irq(p); in parport_ip32_compat_write_data()
1638 parport_ip32_set_mode(p, ECR_MODE_PPF); in parport_ip32_compat_write_data()
1642 if (parport_wait_peripheral(p, DSR_nBUSY | DSR_nFAULT, in parport_ip32_compat_write_data()
1647 p->name, __func__); in parport_ip32_compat_write_data()
1651 ready_before = 1; in parport_ip32_compat_write_data()
1653 written = parport_ip32_fifo_write_block(p, buf, len); in parport_ip32_compat_write_data()
1656 parport_ip32_drain_fifo(p, physport->cad->timeout * priv->fifo_depth); in parport_ip32_compat_write_data()
1659 written -= parport_ip32_get_fifo_residue(p, ECR_MODE_PPF); in parport_ip32_compat_write_data()
1662 if (parport_wait_peripheral(p, DSR_nBUSY, DSR_nBUSY)) in parport_ip32_compat_write_data()
1664 p->name, __func__); in parport_ip32_compat_write_data()
1668 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_compat_write_data()
1680 * @p: pointer to &struct parport
1685 static size_t parport_ip32_ecp_write_data(struct parport *p, in parport_ip32_ecp_write_data() argument
1689 static unsigned int ready_before = 1; in parport_ip32_ecp_write_data()
1690 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_ecp_write_data()
1691 struct parport * const physport = p->physport; in parport_ip32_ecp_write_data()
1697 return parport_ieee1284_ecp_write_data(p, buf, len, flags); in parport_ip32_ecp_write_data()
1702 parport_ip32_frob_control(p, DCR_nINIT | DCR_AUTOFD, in parport_ip32_ecp_write_data()
1706 if (parport_wait_peripheral(p, DSR_PERROR, DSR_PERROR)) { in parport_ip32_ecp_write_data()
1708 p->name, __func__); in parport_ip32_ecp_write_data()
1715 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_ecp_write_data()
1716 parport_ip32_write_control(p, DCR_SELECT | DCR_nINIT); in parport_ip32_ecp_write_data()
1717 parport_ip32_data_forward(p); in parport_ip32_ecp_write_data()
1718 parport_ip32_disable_irq(p); in parport_ip32_ecp_write_data()
1719 parport_ip32_set_mode(p, ECR_MODE_ECP); in parport_ip32_ecp_write_data()
1723 if (parport_wait_peripheral(p, DSR_nBUSY | DSR_nFAULT, in parport_ip32_ecp_write_data()
1728 p->name, __func__); in parport_ip32_ecp_write_data()
1732 ready_before = 1; in parport_ip32_ecp_write_data()
1734 written = parport_ip32_fifo_write_block(p, buf, len); in parport_ip32_ecp_write_data()
1737 parport_ip32_drain_fifo(p, physport->cad->timeout * priv->fifo_depth); in parport_ip32_ecp_write_data()
1740 written -= parport_ip32_get_fifo_residue(p, ECR_MODE_ECP); in parport_ip32_ecp_write_data()
1743 if (parport_wait_peripheral(p, DSR_nBUSY, DSR_nBUSY)) in parport_ip32_ecp_write_data()
1745 p->name, __func__); in parport_ip32_ecp_write_data()
1749 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_ecp_write_data()
1801 * @p: pointer to the &parport structure
1803 * Returns 1 if an ECP port is found, and 0 otherwise. This function actually
1807 static __init unsigned int parport_ip32_ecp_supported(struct parport *p) in parport_ip32_ecp_supported() argument
1809 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_ecp_supported()
1817 pr_probe(p, "Found working ECR register\n"); in parport_ip32_ecp_supported()
1818 parport_ip32_set_mode(p, ECR_MODE_SPP); in parport_ip32_ecp_supported()
1819 parport_ip32_write_control(p, DCR_SELECT | DCR_nINIT); in parport_ip32_ecp_supported()
1820 return 1; in parport_ip32_ecp_supported()
1823 pr_probe(p, "ECR register not found\n"); in parport_ip32_ecp_supported()
1829 * @p: pointer to the &parport structure
1831 * Check for FIFO parameters of an Extended Capabilities Port. Returns 1 on
1835 static __init unsigned int parport_ip32_fifo_supported(struct parport *p) in parport_ip32_fifo_supported() argument
1837 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_fifo_supported()
1843 parport_ip32_set_mode(p, ECR_MODE_CFG); in parport_ip32_fifo_supported()
1850 pword = 1; in parport_ip32_fifo_supported()
1859 pr_probe(p, "Unknown implementation ID: 0x%0x\n", in parport_ip32_fifo_supported()
1864 if (pword != 1) { in parport_ip32_fifo_supported()
1865 pr_probe(p, "Unsupported PWord size: %u\n", pword); in parport_ip32_fifo_supported()
1869 pr_probe(p, "PWord is %u bits\n", 8 * priv->pword); in parport_ip32_fifo_supported()
1874 pr_probe(p, "Hardware compression detected (unsupported)\n"); in parport_ip32_fifo_supported()
1878 parport_ip32_set_mode(p, ECR_MODE_TST); in parport_ip32_fifo_supported()
1882 pr_probe(p, "FIFO not reset\n"); in parport_ip32_fifo_supported()
1897 pr_probe(p, "Can't fill FIFO\n"); in parport_ip32_fifo_supported()
1901 pr_probe(p, "Can't get FIFO depth\n"); in parport_ip32_fifo_supported()
1904 pr_probe(p, "FIFO is %u PWords deep\n", priv->fifo_depth); in parport_ip32_fifo_supported()
1907 parport_ip32_frob_econtrol(p, ECR_SERVINTR, 0); in parport_ip32_fifo_supported()
1914 pr_probe(p, "Invalid data in FIFO\n"); in parport_ip32_fifo_supported()
1920 priv->writeIntrThreshold = i + 1; in parport_ip32_fifo_supported()
1921 if (i + 1 < priv->fifo_depth in parport_ip32_fifo_supported()
1924 pr_probe(p, "Data lost in FIFO\n"); in parport_ip32_fifo_supported()
1929 pr_probe(p, "Can't get writeIntrThreshold\n"); in parport_ip32_fifo_supported()
1932 pr_probe(p, "writeIntrThreshold is %u\n", priv->writeIntrThreshold); in parport_ip32_fifo_supported()
1936 pr_probe(p, "Can't empty FIFO\n"); in parport_ip32_fifo_supported()
1941 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_fifo_supported()
1943 parport_ip32_data_reverse(p); in parport_ip32_fifo_supported()
1945 parport_ip32_set_mode(p, ECR_MODE_TST); in parport_ip32_fifo_supported()
1947 parport_ip32_frob_econtrol(p, ECR_SERVINTR, 0); in parport_ip32_fifo_supported()
1956 priv->readIntrThreshold = i + 1; in parport_ip32_fifo_supported()
1961 pr_probe(p, "Can't get readIntrThreshold\n"); in parport_ip32_fifo_supported()
1964 pr_probe(p, "readIntrThreshold is %u\n", priv->readIntrThreshold); in parport_ip32_fifo_supported()
1967 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_fifo_supported()
1968 parport_ip32_data_forward(p); in parport_ip32_fifo_supported()
1969 parport_ip32_set_mode(p, ECR_MODE_SPP); in parport_ip32_fifo_supported()
1970 return 1; in parport_ip32_fifo_supported()
1974 parport_ip32_set_mode(p, ECR_MODE_SPP); in parport_ip32_fifo_supported()
2000 .dsr = r_base(1), in parport_ip32_make_isa_registers()
2010 .cnfgB = r_base_hi(1), in parport_ip32_make_isa_registers()
2028 struct parport *p = NULL; in parport_ip32_probe_port() local
2036 p = parport_register_port(0, PARPORT_IRQ_NONE, PARPORT_DMA_NONE, ops); in parport_ip32_probe_port()
2037 if (ops == NULL || priv == NULL || p == NULL) { in parport_ip32_probe_port()
2041 p->base = MACE_BASE + offsetof(struct sgi_mace, isa.parallel); in parport_ip32_probe_port()
2042 p->base_hi = MACE_BASE + offsetof(struct sgi_mace, isa.ecp1284); in parport_ip32_probe_port()
2043 p->private_data = priv; in parport_ip32_probe_port()
2055 if (!parport_ip32_ecp_supported(p)) { in parport_ip32_probe_port()
2059 parport_ip32_dump_state(p, "begin init", 0); in parport_ip32_probe_port()
2063 p->modes = PARPORT_MODE_PCSPP | PARPORT_MODE_SAFEININT; in parport_ip32_probe_port()
2064 p->modes |= PARPORT_MODE_TRISTATE; in parport_ip32_probe_port()
2066 if (!parport_ip32_fifo_supported(p)) { in parport_ip32_probe_port()
2067 pr_warn(PPIP32 "%s: error: FIFO disabled\n", p->name); in parport_ip32_probe_port()
2078 if (request_irq(irq, parport_ip32_interrupt, 0, p->name, p)) { in parport_ip32_probe_port()
2079 pr_warn(PPIP32 "%s: error: IRQ disabled\n", p->name); in parport_ip32_probe_port()
2083 pr_probe(p, "Interrupt support enabled\n"); in parport_ip32_probe_port()
2084 p->irq = irq; in parport_ip32_probe_port()
2092 pr_warn(PPIP32 "%s: error: DMA disabled\n", p->name); in parport_ip32_probe_port()
2094 pr_probe(p, "DMA support enabled\n"); in parport_ip32_probe_port()
2095 p->dma = 0; /* arbitrary value != PARPORT_DMA_NONE */ in parport_ip32_probe_port()
2096 p->modes |= PARPORT_MODE_DMA; in parport_ip32_probe_port()
2102 p->ops->compat_write_data = parport_ip32_compat_write_data; in parport_ip32_probe_port()
2103 p->modes |= PARPORT_MODE_COMPAT; in parport_ip32_probe_port()
2104 pr_probe(p, "Hardware support for SPP mode enabled\n"); in parport_ip32_probe_port()
2108 p->ops->epp_read_data = parport_ip32_epp_read_data; in parport_ip32_probe_port()
2109 p->ops->epp_write_data = parport_ip32_epp_write_data; in parport_ip32_probe_port()
2110 p->ops->epp_read_addr = parport_ip32_epp_read_addr; in parport_ip32_probe_port()
2111 p->ops->epp_write_addr = parport_ip32_epp_write_addr; in parport_ip32_probe_port()
2112 p->modes |= PARPORT_MODE_EPP; in parport_ip32_probe_port()
2113 pr_probe(p, "Hardware support for EPP mode enabled\n"); in parport_ip32_probe_port()
2117 p->ops->ecp_write_data = parport_ip32_ecp_write_data; in parport_ip32_probe_port()
2119 /* p->ops->ecp_read_data = parport_ip32_ecp_read_data; */ in parport_ip32_probe_port()
2120 /* p->ops->ecp_write_addr = parport_ip32_ecp_write_addr; */ in parport_ip32_probe_port()
2121 p->modes |= PARPORT_MODE_ECP; in parport_ip32_probe_port()
2122 pr_probe(p, "Hardware support for ECP mode enabled\n"); in parport_ip32_probe_port()
2126 parport_ip32_set_mode(p, ECR_MODE_PS2); in parport_ip32_probe_port()
2127 parport_ip32_write_control(p, DCR_SELECT | DCR_nINIT); in parport_ip32_probe_port()
2128 parport_ip32_data_forward(p); in parport_ip32_probe_port()
2129 parport_ip32_disable_irq(p); in parport_ip32_probe_port()
2130 parport_ip32_write_data(p, 0x00); in parport_ip32_probe_port()
2131 parport_ip32_dump_state(p, "end init", 0); in parport_ip32_probe_port()
2134 pr_info("%s: SGI IP32 at 0x%lx (0x%lx)", p->name, p->base, p->base_hi); in parport_ip32_probe_port()
2135 if (p->irq != PARPORT_IRQ_NONE) in parport_ip32_probe_port()
2136 pr_cont(", irq %d", p->irq); in parport_ip32_probe_port()
2140 if (p->modes & PARPORT_MODE_##x) \ in parport_ip32_probe_port()
2155 parport_announce_port(p); in parport_ip32_probe_port()
2156 return p; in parport_ip32_probe_port()
2159 if (p) in parport_ip32_probe_port()
2160 parport_put_port(p); in parport_ip32_probe_port()
2168 * @p: pointer to the &struct parport
2173 static __exit void parport_ip32_unregister_port(struct parport *p) in parport_ip32_unregister_port() argument
2175 struct parport_ip32_private * const priv = p->physport->private_data; in parport_ip32_unregister_port()
2176 struct parport_operations *ops = p->ops; in parport_ip32_unregister_port()
2178 parport_remove_port(p); in parport_ip32_unregister_port()
2179 if (p->modes & PARPORT_MODE_DMA) in parport_ip32_unregister_port()
2181 if (p->irq != PARPORT_IRQ_NONE) in parport_ip32_unregister_port()
2182 free_irq(p->irq, p); in parport_ip32_unregister_port()
2183 parport_put_port(p); in parport_ip32_unregister_port()
2223 ", bit 1: DMA support"