1 /* Low-level parallel port routines for Archimedes onboard hardware
3 * Author: Phil Blundell <philb@gnu.org>
6 /* This driver is for the parallel port hardware found on Acorn's old
7 * range of Archimedes machines. The A5000 and newer systems have PC-style
8 * I/O hardware and should use the parport_pc driver instead.
10 * The Acorn printer port hardware is very simple. There is a single 8-bit
11 * write-only latch for the data port and control/status bits are handled
12 * with various auxilliary input and output lines. The port is not
13 * bidirectional, does not support any modes other than SPP, and has only
14 * a subset of the standard printer control lines connected.
17 #include <linux/threads.h>
18 #include <linux/delay.h>
19 #include <linux/errno.h>
20 #include <linux/interrupt.h>
21 #include <linux/ioport.h>
22 #include <linux/kernel.h>
23 #include <linux/slab.h>
24 #include <linux/parport.h>
26 #include <asm/ptrace.h>
28 #include <asm/arch/oldlatches.h>
29 #include <asm/arch/irqs.h>
31 #define DATA_ADDRESS 0x3350010
33 /* This is equivalent to the above and only used for request_region. */
34 #define PORT_BASE 0x80000000 | ((DATA_ADDRESS - IO_BASE) >> 2)
36 /* The hardware can't read from the data latch, so we must use a soft
38 static unsigned char data_copy
;
40 /* These are pretty simple. We know the irq is never shared and the
41 kernel does all the magic that's required. */
42 static void arc_enable_irq(struct parport
*p
)
47 static void arc_disable_irq(struct parport
*p
)
52 static void arc_interrupt(int irq
, void *dev_id
, struct pt_regs
*regs
)
54 parport_generic_irq(irq
, (struct parport
*) dev_id
, regs
);
57 static void arc_write_data(struct parport
*p
, unsigned char data
)
60 outb_t(data
, DATA_LATCH
);
63 static unsigned char arc_read_data(struct parport
*p
)
68 static struct parport_operations parport_arc_ops
=
70 .write_data
= arc_write_data
,
71 .read_data
= arc_read_data
,
73 .write_control
= arc_write_control
,
74 .read_control
= arc_read_control
,
75 .frob_control
= arc_frob_control
,
77 .read_status
= arc_read_status
,
79 .enable_irq
= arc_enable_irq
,
80 .disable_irq
= arc_disable_irq
,
82 .data_forward
= arc_data_forward
,
83 .data_reverse
= arc_data_reverse
,
85 .init_state
= arc_init_state
,
86 .save_state
= arc_save_state
,
87 .restore_state
= arc_restore_state
,
89 .epp_write_data
= parport_ieee1284_epp_write_data
,
90 .epp_read_data
= parport_ieee1284_epp_read_data
,
91 .epp_write_addr
= parport_ieee1284_epp_write_addr
,
92 .epp_read_addr
= parport_ieee1284_epp_read_addr
,
94 .ecp_write_data
= parport_ieee1284_ecp_write_data
,
95 .ecp_read_data
= parport_ieee1284_ecp_read_data
,
96 .ecp_write_addr
= parport_ieee1284_ecp_write_addr
,
98 .compat_write_data
= parport_ieee1284_write_compat
,
99 .nibble_read_data
= parport_ieee1284_read_nibble
,
100 .byte_read_data
= parport_ieee1284_read_byte
,
102 .owner
= THIS_MODULE
,
105 /* --- Initialisation code -------------------------------- */
107 static int parport_arc_init(void)
109 /* Archimedes hardware provides only one port, at a fixed address */
112 char *fake_name
= "parport probe");
114 res
= request_region(PORT_BASE
, 1, fake_name
);
118 p
= parport_register_port (PORT_BASE
, IRQ_PRINTERACK
,
119 PARPORT_DMA_NONE
, &parport_arc_ops
);
122 release_region(PORT_BASE
, 1);
126 p
->modes
= PARPORT_MODE_ARCSPP
;
128 rename_region(res
, p
->name
);
130 printk(KERN_INFO
"%s: Archimedes on-board port, using irq %d\n",
133 /* Tell the high-level drivers about the port. */
134 parport_announce_port (p
);
139 module_init(parport_arc_init
)