2023-02-26 02:56:53 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <BAN/Vector.h>
|
|
|
|
|
|
|
|
namespace Kernel
|
|
|
|
{
|
|
|
|
|
|
|
|
class PCIDevice
|
|
|
|
{
|
|
|
|
public:
|
2023-03-07 18:56:08 +02:00
|
|
|
PCIDevice(uint8_t, uint8_t, uint8_t);
|
2023-02-26 02:56:53 +02:00
|
|
|
|
|
|
|
uint32_t read_dword(uint8_t) const;
|
|
|
|
uint16_t read_word(uint8_t) const;
|
|
|
|
uint8_t read_byte(uint8_t) const;
|
2023-03-07 18:56:08 +02:00
|
|
|
|
2023-07-09 23:04:11 +03:00
|
|
|
void write_dword(uint8_t, uint32_t) const;
|
|
|
|
|
2023-03-07 18:56:08 +02:00
|
|
|
uint8_t bus() const { return m_bus; }
|
|
|
|
uint8_t dev() const { return m_dev; }
|
|
|
|
uint8_t func() const { return m_func; }
|
|
|
|
|
|
|
|
uint8_t class_code() const { return m_class_code; }
|
|
|
|
uint8_t subclass() const { return m_subclass; }
|
2023-04-19 16:28:51 +03:00
|
|
|
uint8_t prog_if() const { return m_prog_if; }
|
2023-03-07 18:56:08 +02:00
|
|
|
|
2023-07-09 23:04:11 +03:00
|
|
|
void enable_bus_mastering() const;
|
|
|
|
void disable_bus_mastering() const;
|
|
|
|
|
|
|
|
void enable_memory_space() const;
|
|
|
|
void disable_memory_space() const;
|
|
|
|
|
|
|
|
void enable_pin_interrupts() const;
|
|
|
|
void disable_pin_interrupts() const;
|
|
|
|
|
2023-03-07 18:56:08 +02:00
|
|
|
private:
|
|
|
|
uint8_t m_bus;
|
|
|
|
uint8_t m_dev;
|
|
|
|
uint8_t m_func;
|
|
|
|
|
|
|
|
uint8_t m_class_code;
|
|
|
|
uint8_t m_subclass;
|
2023-04-19 16:28:51 +03:00
|
|
|
uint8_t m_prog_if;
|
2023-02-26 02:56:53 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class PCI
|
|
|
|
{
|
2023-03-07 18:56:08 +02:00
|
|
|
BAN_NON_COPYABLE(PCI);
|
|
|
|
BAN_NON_MOVABLE(PCI);
|
|
|
|
|
2023-02-26 02:56:53 +02:00
|
|
|
public:
|
2023-03-07 18:56:08 +02:00
|
|
|
static void initialize();
|
2023-02-26 02:56:53 +02:00
|
|
|
static PCI& get();
|
|
|
|
|
|
|
|
const BAN::Vector<PCIDevice>& devices() const { return m_devices; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
PCI() = default;
|
|
|
|
void check_function(uint8_t bus, uint8_t dev, uint8_t func);
|
|
|
|
void check_device(uint8_t bus, uint8_t dev);
|
|
|
|
void check_bus(uint8_t bus);
|
|
|
|
void check_all_buses();
|
2023-07-10 23:17:14 +03:00
|
|
|
void initialize_devices();
|
2023-02-26 02:56:53 +02:00
|
|
|
|
|
|
|
private:
|
|
|
|
BAN::Vector<PCIDevice> m_devices;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|