From eaa1f269034e0d896237e1eb3e7374c385bd95d6 Mon Sep 17 00:00:00 2001 From: "K. Lange" Date: Fri, 28 May 2021 17:36:06 +0900 Subject: [PATCH] Don't waste time trying to find an EEPROM we know isn't there --- kernel/net/e1000.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/kernel/net/e1000.c b/kernel/net/e1000.c index 896c47f..413d77d 100644 --- a/kernel/net/e1000.c +++ b/kernel/net/e1000.c @@ -35,6 +35,7 @@ struct e1000_nic { fs_node_t * device_node; uint32_t pci_device; + uint16_t deviceid; uintptr_t mmio_addr; int irq_number; @@ -102,6 +103,9 @@ static struct ethernet_packet * dequeue_packet(struct e1000_nic * device) { static int eeprom_detect(struct e1000_nic * device) { + /* Definitely not */ + if (device->deviceid == 0x10d3) return 0; + write_command(device, E1000_REG_EEPROM, 1); for (int i = 0; i < 100000 && !device->has_eeprom; ++i) { @@ -429,6 +433,7 @@ static void find_e1000(uint32_t device, uint16_t vendorid, uint16_t deviceid, vo /* Allocate a device */ struct e1000_nic * nic = calloc(1,sizeof(struct e1000_nic)); nic->pci_device = device; + nic->deviceid = deviceid; devices[device_count++] = nic; snprintf(nic->if_name, 31,