summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>2010-08-07 07:04:36 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>2010-08-07 07:04:36 +0000
commit633a7e5b6f893f4dbe64de0c6a62e06f85ef6ee3 (patch)
tree4c845ff061401a4a6fcadf65b699346276c7a480 /sys
parente5b528dadb9394ee08b04373a1b2845b9fc301ba (diff)
In fxp_pci_activate use the correct softc's; then use a workq since some
fxp's need load firmwares..... tested by sebastia
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pci/if_fxp_pci.c23
1 files changed, 18 insertions, 5 deletions
diff --git a/sys/dev/pci/if_fxp_pci.c b/sys/dev/pci/if_fxp_pci.c
index 6afc8ca4062..051eac8cfac 100644
--- a/sys/dev/pci/if_fxp_pci.c
+++ b/sys/dev/pci/if_fxp_pci.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_fxp_pci.c,v 1.53 2010/08/06 14:11:48 deraadt Exp $ */
+/* $OpenBSD: if_fxp_pci.c,v 1.54 2010/08/07 07:04:35 deraadt Exp $ */
/*
* Copyright (c) 1995, David Greenman
@@ -46,6 +46,7 @@
#include <sys/socket.h>
#include <sys/timeout.h>
#include <sys/syslog.h>
+#include <sys/workq.h>
#include <net/if.h>
#include <net/if_dl.h>
@@ -82,11 +83,13 @@ int fxp_pci_match(struct device *, void *, void *);
void fxp_pci_attach(struct device *, struct device *, void *);
int fxp_pci_detach(struct device *, int);
int fxp_pci_activate(struct device *, int);
+void fxp_pci_resume(void *, void *);
struct fxp_pci_softc {
struct fxp_softc psc_softc;
pci_chipset_tag_t psc_pc;
bus_size_t psc_mapsize;
+ struct workq_task psc_resume_wqt;
};
struct cfattach fxp_pci_ca = {
@@ -281,20 +284,30 @@ fxp_pci_detach(struct device *self, int flags)
int
fxp_pci_activate(struct device *self, int act)
{
- struct fxp_softc *sc = (struct fxp_softc *)self;
+ struct fxp_pci_softc *psc = (void *)self;
+ struct fxp_softc *sc = &psc->psc_softc;
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
switch (act) {
case DVACT_SUSPEND:
if (ifp->if_flags & IFF_RUNNING)
- fxp_stop(sc, 1, 1);
+ fxp_stop(sc, 1, 0);
config_activate_children(self, act);
break;
case DVACT_RESUME:
config_activate_children(self, act);
- if (ifp->if_flags & IFF_UP)
- fxp_init(ifp);
+ if (ifp->if_flags & IFF_RUNNING)
+ workq_queue_task(NULL, &psc->psc_resume_wqt, 0,
+ fxp_pci_resume, sc, NULL);
break;
}
return (0);
}
+
+void
+fxp_pci_resume(void *arg1, void *arg2)
+{
+ struct fxp_softc *sc = arg1;
+
+ fxp_init(sc);
+}