summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/sparc/shared/uart/apbuart_pci.c
blob: fce1197e8c30cfedcce3c96b5280dec19b3d0f5d (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42

#undef DEBUG

/* Set registered device name */
#define APBUART_DEVNAME "/dev/apbupci0"
#define APBUART_DEVNAME_NO(devstr,no) ((devstr)[12]='0'+(no))

/* Any non-static function will begin with */
#define APBUART_PREFIX(name) apbuartpci##name

/* do nothing, assume that the interrupt handler is called
 * setup externally calling apbuartpci_interrupt_handler.
 */
#define APBUART_REG_INT(handler,irq,arg) \
 if ( apbuart_pci_int_reg ) \
   apbuart_pci_int_reg(handler,irq,arg);

void (*apbuart_pci_int_reg)(void *handler, int irq, void *arg) = 0;

void apbuartpci_interrupt_handler(int irq, void *arg);

/* AMBA Bus is clocked using the PCI clock (33.3MHz) */
#define SYS_FREQ_HZ 33333333

#include "apbuart.c"

int apbuart_pci_register(struct ambapp_bus *bus)
{
	/* Setup configuration */

	/* Register the driver */
	return APBUART_PREFIX(_register)(bus);
}


/* Call this from PCI interrupt handler
 * irq = the irq number of the HW device local to that IRQMP controller
 *
 */
void apbuartpci_interrupt_handler(int irq, void *arg){
	apbuart_interrupt(arg);
}