diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2007-08-15 01:15:49 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2007-08-15 01:15:49 +0000 |
commit | 0bec494b12e1f27d1a02747f26629a37a3e26714 (patch) | |
tree | b92c1eae92b29742109bc1ac671f8fd8cb396240 | |
parent | 470404b3a4cc0cb6db75d87b050df687903ac7f1 (diff) |
fetch the user info off the board. the lladdr and firmware version are
stored on it.
display the fw and lladdr in attach.
-rw-r--r-- | sys/dev/pci/if_nxe.c | 64 |
1 files changed, 62 insertions, 2 deletions
diff --git a/sys/dev/pci/if_nxe.c b/sys/dev/pci/if_nxe.c index 09cb9d42397..fb98337c16b 100644 --- a/sys/dev/pci/if_nxe.c +++ b/sys/dev/pci/if_nxe.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_nxe.c,v 1.17 2007/08/15 00:54:41 dlg Exp $ */ +/* $OpenBSD: if_nxe.c,v 1.18 2007/08/15 01:15:48 dlg Exp $ */ /* * Copyright (c) 2007 David Gwynne <dlg@openbsd.org> @@ -58,6 +58,13 @@ int nxedebug = 0; #define DASSERT(_a) #endif +/* this driver likes firmwares around this version */ +#define NXE_VERSION_MAJOR 3 +#define NXE_VERSION_MINOR 4 +#define NXE_VERSION_BUILD 31 +#define NXE_VERSION \ + ((NXE_VERSION_MAJOR << 16)|(NXE_VERSION_MINOR << 8)|(NXE_VERSION_BUILD)) + /* * PCI configuration space registers @@ -399,6 +406,9 @@ struct nxe_softc { int sc_window; const struct nxe_board *sc_board; + u_int sc_fw_major; + u_int sc_fw_minor; + u_int sc_fw_build; struct arpcom sc_ac; struct ifmedia sc_media; @@ -426,6 +436,7 @@ int nxe_pci_map(struct nxe_softc *, void nxe_pci_unmap(struct nxe_softc *); int nxe_board_info(struct nxe_softc *sc); +int nxe_user_info(struct nxe_softc *sc); /* low level hardware access goo */ u_int32_t nxe_read(struct nxe_softc *, bus_size_t); @@ -506,7 +517,14 @@ nxe_attach(struct device *parent, struct device *self, void *aux) goto unmap; } - printf("\n"); + if (nxe_user_info(sc) != 0) { + /* error already printed by nxe_board_info() */ + goto unmap; + } + + printf(": firmware %d.%d.%d address %s\n", + sc->sc_fw_major, sc->sc_fw_minor, sc->sc_fw_build, + ether_sprintf(sc->sc_ac.ac_enaddr)); return; unmap: nxe_pci_unmap(sc); @@ -613,6 +631,48 @@ out: return (rv); } +int +nxe_user_info(struct nxe_softc *sc) +{ + struct nxe_userinfo *nu; + u_int64_t lladdr; + struct nxe_lladdr *la; + int rv = 1; + + nu = malloc(sizeof(struct nxe_userinfo), M_NOWAIT, M_TEMP); + if (nu == NULL) { + printf(": unable to allocate temp memory\n"); + return (1); + } + if (nxe_rom_read_region(sc, NXE_FLASH_USER, nu, + sizeof(struct nxe_userinfo)) != 0) { + printf(": unable to read user info\n"); + goto out; + } + + sc->sc_fw_major = nu->nu_imageinfo.nim_img_ver_major; + sc->sc_fw_minor = nu->nu_imageinfo.nim_img_ver_minor; + sc->sc_fw_build = letoh16(nu->nu_imageinfo.nim_img_ver_build); + + if (sc->sc_fw_major > NXE_VERSION_MAJOR || + sc->sc_fw_major < NXE_VERSION_MAJOR || + sc->sc_fw_minor > NXE_VERSION_MINOR || + sc->sc_fw_minor < NXE_VERSION_MINOR) { + printf(": firmware %d.%d.%d is unsupported by this driver\n", + sc->sc_fw_major, sc->sc_fw_minor, sc->sc_fw_build); + goto out; + } + + lladdr = swap64(nu->nu_lladdr[sc->sc_function][0]); + la = (struct nxe_lladdr *)&lladdr; + bcopy(la->lladdr, sc->sc_ac.ac_enaddr, ETHER_ADDR_LEN); + + rv = 0; +out: + free(nu, M_TEMP); + return (rv); +} + u_int32_t nxe_read(struct nxe_softc *sc, bus_size_t r) { |