/* * Copyright 2005-2008, Axel Dörfler, axeld@pinc-software.de. All rights reserved. * Copyright 2003-2006, Marcus Overhagen. All rights reserved. * * Distributed under the terms of the MIT License. */ #ifndef __PCI_PRIV_H__ #define __PCI_PRIV_H__ #include #include #include // name of PCI legacy driver endpoint module #define PCI_LEGACY_DRIVER_MODULE_NAME "bus_managers/pci/legacy_v1" // name of PCI device modules #define PCI_DEVICE_MODULE_NAME "bus_managers/pci/driver_v1" extern device_manager_info *gDeviceManager; // PCI root. // apart from being the common parent of all PCI devices, it // manages access to PCI config space typedef struct pci_root_module_info { driver_module_info info; // read PCI config space uint32 (*read_pci_config)(uint8 bus, uint8 device, uint8 function, uint16 offset, uint8 size); // write PCI config space void (*write_pci_config)(uint8 bus, uint8 device, uint8 function, uint16 offset, uint8 size, uint32 value); } pci_root_module_info; extern pci_root_module_info gPCIRootModule; extern pci_device_module_info gPCIDeviceModule; extern device_node* gPCIRootNode; #ifdef __cplusplus extern "C" { #endif phys_addr_t pci_ram_address(phys_addr_t physical_address_in_system_memory); status_t pci_find_capability(uint8 bus, uint8 device, uint8 function, uint8 cap_id, uint8 *offset); status_t pci_find_extended_capability(uint8 bus, uint8 device, uint8 function, uint16 cap_id, uint16 *offset); status_t pci_reserve_device(uchar virtualBus, uchar device, uchar function, const char *driverName, void *nodeCookie); status_t pci_unreserve_device(uchar virtualBus, uchar device, uchar function, const char *driverName, void *nodeCookie); status_t pci_update_interrupt_line(uchar virtualBus, uchar device, uchar function, uchar newInterruptLineValue); status_t pci_get_powerstate(uchar virtualBus, uint8 device, uint8 function, uint8* state); status_t pci_set_powerstate(uchar virtualBus, uint8 device, uint8 function, uint8 newState); status_t pci_io_init(void); uint8 pci_read_io_8(int mapped_io_addr); void pci_write_io_8(int mapped_io_addr, uint8 value); uint16 pci_read_io_16(int mapped_io_addr); void pci_write_io_16(int mapped_io_addr, uint16 value); uint32 pci_read_io_32(int mapped_io_addr); void pci_write_io_32(int mapped_io_addr, uint32 value); #ifdef __cplusplus } #endif #endif /* __PCI_PRIV_H__ */