1 /* 2 * Copyright 2022, Haiku, Inc. 3 * Distributed under the terms of the MIT License. 4 */ 5 6 7 #include "DWPCIController.h" 8 9 10 device_manager_info* gDeviceManager; 11 12 13 pci_controller_module_info gPciControllerDriver = { 14 .info = { 15 .info = { 16 .name = DESIGNWARE_PCI_DRIVER_MODULE_NAME, 17 }, 18 .supports_device = DWPCIController::SupportsDevice, 19 .register_device = DWPCIController::RegisterDevice, 20 .init_driver = [](device_node* node, void** driverCookie) { 21 return DWPCIController::InitDriver(node, *(DWPCIController**)driverCookie); 22 }, 23 .uninit_driver = [](void* driverCookie) { 24 return static_cast<DWPCIController*>(driverCookie)->UninitDriver(); 25 }, 26 }, 27 .read_pci_config = [](void* cookie, 28 uint8 bus, uint8 device, uint8 function, 29 uint16 offset, uint8 size, uint32* value) { 30 return static_cast<DWPCIController*>(cookie) 31 ->ReadConfig(bus, device, function, offset, size, *value); 32 }, 33 .write_pci_config = [](void* cookie, 34 uint8 bus, uint8 device, uint8 function, 35 uint16 offset, uint8 size, uint32 value) { 36 return static_cast<DWPCIController*>(cookie) 37 ->WriteConfig(bus, device, function, offset, size, value); 38 }, 39 .get_max_bus_devices = [](void* cookie, int32* count) { 40 return static_cast<DWPCIController*>(cookie)->GetMaxBusDevices(*count); 41 }, 42 .read_pci_irq = [](void* cookie, 43 uint8 bus, uint8 device, uint8 function, 44 uint8 pin, uint8 *irq) { 45 return static_cast<DWPCIController*>(cookie)->ReadIrq(bus, device, function, pin, *irq); 46 }, 47 .write_pci_irq = [](void* cookie, 48 uint8 bus, uint8 device, uint8 function, 49 uint8 pin, uint8 irq) { 50 return static_cast<DWPCIController*>(cookie)->WriteIrq(bus, device, function, pin, irq); 51 }, 52 .get_range = [](void *cookie, uint32 index, pci_resource_range* range) { 53 return static_cast<DWPCIController*>(cookie)->GetRange(index, range); 54 } 55 }; 56 57 58 _EXPORT module_dependency module_dependencies[] = { 59 { B_DEVICE_MANAGER_MODULE_NAME, (module_info**)&gDeviceManager }, 60 {} 61 }; 62 63 _EXPORT module_info *modules[] = { 64 (module_info *)&gPciControllerDriver, 65 NULL 66 }; 67