2017-08-30 04:49:20 +02:00
|
|
|
void pci_set_irq_routing(int pci_int, int irq);
|
2017-06-21 19:42:36 +02:00
|
|
|
|
2017-09-04 05:15:12 +02:00
|
|
|
void pci_enable_mirq(int mirq);
|
|
|
|
|
void pci_set_mirq_routing(int mirq, int irq);
|
|
|
|
|
|
|
|
|
|
uint8_t pci_use_mirq(uint8_t mirq);
|
|
|
|
|
|
2017-09-08 00:17:49 +02:00
|
|
|
int pci_irq_is_level(int irq);
|
|
|
|
|
|
2017-09-04 05:15:12 +02:00
|
|
|
void pci_set_mirq(uint8_t mirq, uint8_t channel);
|
2017-08-30 04:49:20 +02:00
|
|
|
void pci_set_irq(uint8_t card, uint8_t pci_int);
|
2017-09-04 05:15:12 +02:00
|
|
|
void pci_clear_mirq(uint8_t mirq, uint8_t channel);
|
2017-08-30 04:49:20 +02:00
|
|
|
void pci_clear_irq(uint8_t card, uint8_t pci_int);
|
|
|
|
|
|
2017-08-28 22:55:10 +02:00
|
|
|
void pci_reset(void);
|
2017-08-30 04:49:20 +02:00
|
|
|
void pci_init(int type);
|
|
|
|
|
void pci_register_slot(int card, int type, int inta, int intb, int intc, int intd);
|
|
|
|
|
uint8_t pci_add_card(uint8_t add_type, uint8_t (*read)(int func, int addr, void *priv), void (*write)(int func, int addr, uint8_t val, void *priv), void *priv);
|
2016-06-26 00:34:39 +02:00
|
|
|
|
|
|
|
|
#define PCI_REG_COMMAND 0x04
|
|
|
|
|
|
|
|
|
|
#define PCI_COMMAND_IO 0x01
|
|
|
|
|
#define PCI_COMMAND_MEM 0x02
|
|
|
|
|
|
|
|
|
|
#define PCI_CONFIG_TYPE_1 1
|
|
|
|
|
#define PCI_CONFIG_TYPE_2 2
|
|
|
|
|
|
2017-06-02 01:38:25 +02:00
|
|
|
#define PCI_INTA 1
|
|
|
|
|
#define PCI_INTB 2
|
|
|
|
|
#define PCI_INTC 3
|
|
|
|
|
#define PCI_INTD 4
|
|
|
|
|
|
2017-09-04 05:15:12 +02:00
|
|
|
#define PCI_MIRQ0 0
|
|
|
|
|
#define PCI_MIRQ1 1
|
|
|
|
|
|
2017-06-02 01:38:25 +02:00
|
|
|
#define PCI_IRQ_DISABLED -1
|
|
|
|
|
|
2017-08-30 04:49:20 +02:00
|
|
|
enum
|
|
|
|
|
{
|
|
|
|
|
PCI_CARD_NORMAL = 0,
|
|
|
|
|
PCI_CARD_ONBOARD,
|
|
|
|
|
PCI_CARD_SPECIAL
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define PCI_ADD_NORMAL 0x80
|
|
|
|
|
#define PCI_ADD_VIDEO 0x81
|
|
|
|
|
|
2016-06-26 00:34:39 +02:00
|
|
|
extern int pci_burst_time, pci_nonburst_time;
|
2017-08-30 04:49:20 +02:00
|
|
|
|
|
|
|
|
typedef union {
|
|
|
|
|
uint32_t addr;
|
|
|
|
|
uint8_t addr_regs[4];
|
|
|
|
|
} bar_t;
|