summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/pci/if_che.c106
1 files changed, 59 insertions, 47 deletions
diff --git a/sys/dev/pci/if_che.c b/sys/dev/pci/if_che.c
index a989af60fbd..5432de0b7cd 100644
--- a/sys/dev/pci/if_che.c
+++ b/sys/dev/pci/if_che.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_che.c,v 1.2 2007/05/27 03:52:00 claudio Exp $ */
+/* $OpenBSD: if_che.c,v 1.3 2007/05/27 05:18:52 dlg Exp $ */
/*
* Copyright (c) 2007 Claudio Jeker <claudio@openbsd.org>
@@ -45,50 +45,6 @@
#include <netinet/in.h>
#include <netinet/if_ether.h>
-#define DEVNAME(_sc) ((_sc)->sc_dev.dv_xname)
-
-
-struct cheg_softc {
- struct device sc_dev;
-
- bus_dma_tag_t sc_dmat;
-
- bus_space_tag_t sc_memt;
- bus_space_handle_t sc_memh;
- bus_size_t sc_mems;
-
- u_int32_t sc_rev; /* card revision */
-};
-
-struct che_softc {
- struct device sc_dev;
- struct arpcom sc_ac;
- struct ifmedia sc_media;
-
- void *sc_if;
-};
-
-/* function protos */
-int cheg_match(struct device *, void *, void *);
-void cheg_attach(struct device *, struct device *, void *);
-int cheg_print(void *, const char *);
-int che_match(struct device *, void *, void *);
-void che_attach(struct device *, struct device *, void *);
-u_int32_t che_read(struct cheg_softc *, bus_size_t);
-void che_write(struct cheg_softc *, bus_size_t, u_int32_t);
-int che_waitfor(struct cheg_softc *, bus_size_t, u_int32_t, int);
-int che_write_flash_reg(struct cheg_softc *, size_t, int,
- u_int32_t);
-int che_read_flash_reg(struct cheg_softc *, size_t, int,
- u_int32_t *);
-int che_read_flash_multi4(struct cheg_softc *, u_int, u_int32_t *,
- size_t);
-int che_read_eeprom(struct cheg_softc *, struct pci_attach_args *,
- pcireg_t, pcireg_t *);
-int che_get_vpd(struct cheg_softc *, struct pci_attach_args *,
- void *, size_t);
-void che_reset(struct cheg_softc *);
-
/* registers & defines */
#define CHE_PCI_BAR 0x10
#define CHE_PCI_CAP_ID_VPD 0x03
@@ -186,8 +142,30 @@ struct che_vpd {
} __packed;
+#define DEVNAME(_sc) ((_sc)->sc_dev.dv_xname)
+
+/* the pci controller */
+
+struct cheg_softc {
+ struct device sc_dev;
+
+ bus_dma_tag_t sc_dmat;
+
+ bus_space_tag_t sc_memt;
+ bus_space_handle_t sc_memh;
+ bus_size_t sc_mems;
+
+ u_int32_t sc_rev; /* card revision */
+};
+
+int cheg_match(struct device *, void *, void *);
+void cheg_attach(struct device *, struct device *, void *);
+int cheg_print(void *, const char *);
+
struct cfattach cheg_ca = {
- sizeof(struct cheg_softc), cheg_match, cheg_attach
+ sizeof(struct cheg_softc),
+ cheg_match,
+ cheg_attach
};
struct cfdriver cheg_cd = {
@@ -195,20 +173,54 @@ struct cfdriver cheg_cd = {
};
/* glue between the controller and the port */
+
struct che_attach_args {
struct pci_attach_args *caa_pa;
pci_intr_handle_t caa_ih;
int caa_port;
};
+/* che itself */
+
+struct che_softc {
+ struct device sc_dev;
+ struct arpcom sc_ac;
+ struct ifmedia sc_media;
+
+ void *sc_ih;
+};
+
+int che_match(struct device *, void *, void *);
+void che_attach(struct device *, struct device *, void *);
+
struct cfattach che_ca = {
- sizeof(struct che_softc), che_match, che_attach
+ sizeof(struct che_softc),
+ che_match,
+ che_attach
};
struct cfdriver che_cd = {
NULL, "che", DV_IFNET
};
+int che_write_flash_reg(struct cheg_softc *, size_t, int,
+ u_int32_t);
+int che_read_flash_reg(struct cheg_softc *, size_t, int,
+ u_int32_t *);
+int che_read_flash_multi4(struct cheg_softc *, u_int, u_int32_t *,
+ size_t);
+int che_read_eeprom(struct cheg_softc *, struct pci_attach_args *,
+ pcireg_t, pcireg_t *);
+int che_get_vpd(struct cheg_softc *, struct pci_attach_args *,
+ void *, size_t);
+void che_reset(struct cheg_softc *);
+
+/* bus_space wrappers */
+u_int32_t che_read(struct cheg_softc *, bus_size_t);
+void che_write(struct cheg_softc *, bus_size_t, u_int32_t);
+int che_waitfor(struct cheg_softc *, bus_size_t, u_int32_t, int);
+
+/* cheg */
struct cheg_device {
pci_vendor_id_t cd_vendor;
pci_vendor_id_t cd_product;