79 lines
6.8 KiB
Markdown
79 lines
6.8 KiB
Markdown
# pci.h
|
|
|
|
PCI bus stuff.
|
|
|
|
# Class and subclasses enums
|
|
All these enums are not documented in here, because they are basically just the definitions matching the PCI device main and sub classes.
|
|
A [list of these (sub)classes](https://wiki.osdev.org/PCI#Class_Codes) can be found in the osdev wiki.
|
|
|
|
# `pci_device_header_T` - struct
|
|
| Name | Type | Description |
|
|
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------|
|
|
| vendor_id | uint16_t | The Device manufacturers ID number |
|
|
| device_id | uint16_t | The devices ID number |
|
|
| command_reg | uint16_t | Provides control over a device's ability to generate and respond to PCI cycles. |
|
|
| status | uint16_t | The status register PCI bus related events |
|
|
| revision_id | uint8_t | The devices revision ID number |
|
|
| progif | uint8_t | Programming Interface Byte. This can specify special programming interfaces. |
|
|
| subclass | uint8_t | The special function that the device performs. |
|
|
| main_class | uint8_t | The general function class, which the device operates in. |
|
|
| cache_line_size | uint8_t | Specifies the system cache line size in 32-bit units. |
|
|
| latency_timer | uint8_t | Specifies the latency timer in units of PCI bus clocks. |
|
|
| header_type | uint8_t | Specifies whether the device is a general device or a bridge. This affects the data representation that follows this header. |
|
|
| bist | uint8_t | Built-In-Self-Test status and control. |
|
|
|
|
# `pci_header_0_T` - struct
|
|
| Name | Type | Description |
|
|
|----------------------------|---------------------|-------------------------------------------------------------------------------------------------|
|
|
| header | pci_device_header_T | The devices base header |
|
|
| bar0 | uint32_t | Base address 0 |
|
|
| bar1 | uint32_t | Base address 1 |
|
|
| bar2 | uint32_t | Base address 2 |
|
|
| bar3 | uint32_t | Base address 3 |
|
|
| bar4 | uint32_t | Base address 4 |
|
|
| bar5 | uint32_t | Base address 5 |
|
|
| cardbus_cis_pointer | uint32_t | Used by devices that share silicon between CardBus and PCI. |
|
|
| subsystem_vendor_id | uint16_t | idk, but probably not that important |
|
|
| subsystem_id | uint16_t | idk, but probably not that important |
|
|
| expansion_rom_base_address | uint32_t | An optional max 16MB ROM BAR. |
|
|
| capabilities | uint8_t | An offset in the devices config space that points to a linked list of implemented capabilities. |
|
|
| reserved | uint8_t[7] | Reserved. |
|
|
| interrupt_line | uint8_t | The devices interrupt IRQ. |
|
|
| interrupt_pin | uint8_t | The devices interrupt pin. |
|
|
| min_grant | uint8_t | Specifies the burst period length, in 1/4 microsecond units, that the device needs. |
|
|
| max_latency | uint8_t | Specifies how often the device needs access to the PCI bus (in 1/4 microsecond units). |
|
|
|
|
# `pci_device_T` - struct
|
|
| Name | Type | Description |
|
|
|--------|----------------------|-------------------------|
|
|
| header | pci_device_header_T* | The devices base header |
|
|
| prev | pci_device_T* | The previous device. |
|
|
| next | pci_device_T* | The next device. |
|
|
|
|
# `pci_manager_T` - struct
|
|
| Name | Type | Description |
|
|
|---------|---------------|-----------------------------------------------|
|
|
| devices | pci_device_T* | The linked list of devices connected via PCI. |
|
|
|
|
# `pci_init()` - function (void)
|
|
Initializes the global PCI manager and enumerates the PCI bus.
|
|
This needs to be called after `acpi_init`, because it uses the _MCFG_ table.
|
|
|
|
# `pci_manager_add_device(header*)` - function (void)
|
|
Adds a device to the global PCI manager.
|
|
This should only be called by the PCI enumerator.
|
|
|
|
# `pci_manager_remove_device(device*)` - function (void)
|
|
Removes a device from the global PCI manager, and frees it resources in the manager.
|
|
|
|
# `pci_manager_find_device(class, subclass, progif)` - function (pci_device_T*)
|
|
Returns the first device with **_class_**, **_subclass_** and **_progif_** that is defined in the global PCI manager.
|
|
|
|
# `pci_manager_dump_devices()` - function (void)
|
|
Logs a list of all registered PCI devices.
|
|
|
|
# `pci_get_subclass_string(class, subclass)` - function (string_t)
|
|
Returns the Name of **_class_** + **_subclass_**.
|
|
|
|
# `pci_get_vendor_string(vendor_id)` - function (string_t)
|
|
Returns the name of the vendor. |