2
0
mirror of https://github.com/xcat2/xNBA.git synced 2025-01-05 11:05:07 +00:00
xNBA/src/drivers/net/prism2_pci.c

48 lines
1.5 KiB
C
Raw Normal View History

2005-03-08 18:53:11 +00:00
/**************************************************************************
Etherboot - BOOTP/TFTP Bootstrap Program
Prism2 NIC driver for Etherboot
Wrapper for prism2_pci
Written by Michael Brown of Fen Systems Ltd
$Id$
***************************************************************************/
/*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2, or (at
* your option) any later version.
*/
#define WLAN_HOSTIF WLAN_PCI
#include "prism2.c"
static struct pci_id prism2_pci_nics[] = {
PCI_ROM(0x1260, 0x3873, "prism2_pci", "Harris Semiconductor Prism2.5 clone"),
PCI_ROM(0x1260, 0x3873, "hwp01170", "ActionTec HWP01170"),
PCI_ROM(0x1260, 0x3873, "dwl520", "DLink DWL-520"),
2005-03-08 18:53:11 +00:00
};
static struct pci_driver prism2_pci_driver =
PCI_DRIVER ( "Prism2_PCI", prism2_pci_nics, PCI_NO_CLASS );
static int prism2_pci_probe ( struct dev *dev, struct pci_device *pci ) {
2005-04-13 02:02:08 +00:00
struct nic *nic = nic_device ( dev );
hfa384x_t *hw = &hw_global;
uint32_t membase = 0; /* Prism2.5 Memory Base */
if ( ! find_pci_device ( pci, &prism2_pci_driver ) )
return 0;
pci_read_config_dword( pci, PRISM2_PCI_MEM_BASE, &membase);
membase &= PCI_BASE_ADDRESS_MEM_MASK;
hw->membase = (uint32_t) phys_to_virt(membase);
printf ( "Prism2.5 has registers at %#x\n", hw->membase );
nic->ioaddr = hw->membase;
return prism2_probe ( nic, hw );
}
BOOT_DRIVER ( "Prism2_PCI", prism2_pci_probe );
2005-03-08 18:53:11 +00:00