2010-04-14 01:55:52 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2010, Haiku Inc. All Rights Reserved.
|
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*/
|
2010-04-13 19:18:46 +04:00
|
|
|
#ifndef PCI_X86_H
|
|
|
|
#define PCI_X86_H
|
|
|
|
|
|
|
|
#include <SupportDefs.h>
|
|
|
|
#include <module.h>
|
|
|
|
|
|
|
|
typedef struct pci_x86_module_info {
|
|
|
|
module_info info;
|
|
|
|
|
|
|
|
uint8 (*get_msi_count)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
|
|
|
|
status_t (*configure_msi)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function, /* function # in device */
|
|
|
|
uint8 count, /* count of vectors desired */
|
|
|
|
uint8 *startVector); /* first configured vector */
|
|
|
|
status_t (*unconfigure_msi)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
|
|
|
|
status_t (*enable_msi)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
status_t (*disable_msi)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
2013-07-10 01:33:27 +04:00
|
|
|
|
|
|
|
uint8 (*get_msix_count)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
|
|
|
|
status_t (*configure_msix)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function, /* function # in device */
|
|
|
|
uint8 count, /* count of vectors desired */
|
|
|
|
uint8 *startVector); /* first configured vector */
|
|
|
|
status_t (*unconfigure_msix)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
|
|
|
|
status_t (*enable_msix)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
status_t (*disable_msix)(
|
|
|
|
uint8 bus, /* bus number */
|
|
|
|
uint8 device, /* device # on bus */
|
|
|
|
uint8 function); /* function # in device */
|
|
|
|
|
|
|
|
|
2010-04-13 19:18:46 +04:00
|
|
|
} pci_x86_module_info;
|
|
|
|
|
|
|
|
#define B_PCI_X86_MODULE_NAME "bus_managers/pci/x86/v1"
|
|
|
|
|
|
|
|
#endif // PCI_X86_H
|