forked from Bananymous/banan-os
Kernel: PCI checks if ethernet device is E1000 before initialization
I used to treat all ethernet deivices as E1000 but now it is actually verified before initialization
This commit is contained in:
parent
73b9c28457
commit
1312a9dad2
|
@ -13,6 +13,7 @@ namespace Kernel
|
||||||
class E1000 final : public NetworkDriver
|
class E1000 final : public NetworkDriver
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
static bool probe(PCI::Device&);
|
||||||
static BAN::ErrorOr<BAN::UniqPtr<E1000>> create(PCI::Device&);
|
static BAN::ErrorOr<BAN::UniqPtr<E1000>> create(PCI::Device&);
|
||||||
~E1000();
|
~E1000();
|
||||||
|
|
||||||
|
|
|
@ -112,6 +112,45 @@ namespace Kernel
|
||||||
volatile uint16_t special;
|
volatile uint16_t special;
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
// https://www.intel.com/content/dam/doc/manual/pci-pci-x-family-gbe-controllers-software-dev-manual.pdf (section 5.2)
|
||||||
|
bool E1000::probe(PCI::Device& pci_device)
|
||||||
|
{
|
||||||
|
// Intel device
|
||||||
|
if (pci_device.vendor_id() != 0x8086)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
switch (pci_device.device_id())
|
||||||
|
{
|
||||||
|
case 0x1019:
|
||||||
|
case 0x101A:
|
||||||
|
case 0x1010:
|
||||||
|
case 0x1012:
|
||||||
|
case 0x101D:
|
||||||
|
case 0x1079:
|
||||||
|
case 0x107A:
|
||||||
|
case 0x107B:
|
||||||
|
case 0x100F:
|
||||||
|
case 0x1011:
|
||||||
|
case 0x1026:
|
||||||
|
case 0x1027:
|
||||||
|
case 0x1028:
|
||||||
|
case 0x1107:
|
||||||
|
case 0x1112:
|
||||||
|
case 0x1013:
|
||||||
|
case 0x1018:
|
||||||
|
case 0x1076:
|
||||||
|
case 0x1077:
|
||||||
|
case 0x1078:
|
||||||
|
case 0x1017:
|
||||||
|
case 0x1016:
|
||||||
|
case 0x100e:
|
||||||
|
case 0x1015:
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<BAN::UniqPtr<E1000>> E1000::create(PCI::Device& pci_device)
|
BAN::ErrorOr<BAN::UniqPtr<E1000>> E1000::create(PCI::Device& pci_device)
|
||||||
{
|
{
|
||||||
E1000* e1000 = new E1000();
|
E1000* e1000 = new E1000();
|
||||||
|
|
|
@ -173,8 +173,9 @@ namespace Kernel::PCI
|
||||||
switch (pci_device.subclass())
|
switch (pci_device.subclass())
|
||||||
{
|
{
|
||||||
case 0x00:
|
case 0x00:
|
||||||
if (auto res = E1000::create(pci_device); res.is_error())
|
if (E1000::probe(pci_device))
|
||||||
dprintln("E1000: {}", res.error());
|
if (auto res = E1000::create(pci_device); res.is_error())
|
||||||
|
dprintln("E1000: {}", res.error());
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
dprintln("unsupported ethernet device (pci {2H}.{2H}.{2H})", pci_device.class_code(), pci_device.subclass(), pci_device.prog_if());
|
dprintln("unsupported ethernet device (pci {2H}.{2H}.{2H})", pci_device.class_code(), pci_device.subclass(), pci_device.prog_if());
|
||||||
|
|
Loading…
Reference in New Issue