summaryrefslogtreecommitdiffstats
path: root/sys/pc98
diff options
context:
space:
mode:
authorkato <kato@FreeBSD.org>1998-12-31 03:23:39 +0000
committerkato <kato@FreeBSD.org>1998-12-31 03:23:39 +0000
commit406890324eb0589423ff233a2caba68825f69eba (patch)
tree1aed16fc389ed5330fff1da5d80fec6600bcb69f /sys/pc98
parent0539734ce17868e5b7cee9ba4f3d5142fe258466 (diff)
downloadFreeBSD-src-406890324eb0589423ff233a2caba68825f69eba.zip
FreeBSD-src-406890324eb0589423ff233a2caba68825f69eba.tar.gz
Add SMC EtherEZ98 support(PC-98).
Slim up of if_ed98.h. Submitted by: Chiharu Shibata <chi@bd.mbn.or.jp>
Diffstat (limited to 'sys/pc98')
-rw-r--r--sys/pc98/pc98/if_ed.c14
-rw-r--r--sys/pc98/pc98/if_ed98.h114
2 files changed, 65 insertions, 63 deletions
diff --git a/sys/pc98/pc98/if_ed.c b/sys/pc98/pc98/if_ed.c
index 022db4c..e5f7e4d 100644
--- a/sys/pc98/pc98/if_ed.c
+++ b/sys/pc98/pc98/if_ed.c
@@ -24,7 +24,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
- * $Id: if_ed.c,v 1.55 1998/10/22 05:58:44 bde Exp $
+ * $Id: if_ed.c,v 1.56 1998/12/14 08:58:12 kato Exp $
*/
/*
@@ -49,6 +49,7 @@
* MELCO LPC-TJ, LPC-TS, LGY-98, LGH-98, IND-SP, IND-SS, EGY-98
* PLANET SMART COM CREDITCARD/2000 PCMCIA, EN-2298
* Contec C-NET(98), C-NET(98)E, C-NET(98)L, C-NET(98)E-A, C-NET(98)L-A
+ * SMC EtherEZ98
*
* Modified for FreeBSD(98) 2.2 by KATO T. of Nagoya University.
*
@@ -357,6 +358,16 @@ static unsigned short ed_intr_mask[] = {
* Interrupt conversion table for 83C790
*/
static unsigned short ed_790_intr_mask[] = {
+#ifdef PC98
+ 0,
+ IRQ3,
+ IRQ5,
+ IRQ6,
+ 0,
+ IRQ9,
+ IRQ12,
+ IRQ13
+#else
0,
IRQ9,
IRQ3,
@@ -365,6 +376,7 @@ static unsigned short ed_790_intr_mask[] = {
IRQ10,
IRQ11,
IRQ15
+#endif
};
/*
diff --git a/sys/pc98/pc98/if_ed98.h b/sys/pc98/pc98/if_ed98.h
index 6320064..19d07d0 100644
--- a/sys/pc98/pc98/if_ed98.h
+++ b/sys/pc98/pc98/if_ed98.h
@@ -26,7 +26,7 @@
*/
/*
- * PC-9801 specific definitions for National Semiconductor DP8390 NIC.
+ * PC-9801 specific definitions for DP8390/SMC8216 NICs.
*/
#ifndef __PC98_PC98_IF_ED98_H__
#define __PC98_PC98_IF_ED98_H__
@@ -47,30 +47,22 @@ static int pc98_set_register_unit __P((struct ed_softc *sc, int type, int iobase
/*
* Register offsets/total
*/
-#ifdef ED_NOVELL_NIC_OFFSET
#undef ED_NOVELL_NIC_OFFSET
-#endif
#define ED_NOVELL_NIC_OFFSET sc->edreg.nic_offset
-#ifdef ED_NOVELL_ASIC_OFFSET
#undef ED_NOVELL_ASIC_OFFSET
-#endif
#define ED_NOVELL_ASIC_OFFSET sc->edreg.asic_offset
/*
* Remote DMA data register; for reading or writing to the NIC mem
* via programmed I/O (offset from ASIC base).
*/
-#ifdef ED_NOVELL_DATA
#undef ED_NOVELL_DATA
-#endif
#define ED_NOVELL_DATA sc->edreg.data
/*
* Reset register; reading from this register causes a board reset.
*/
-#ifdef ED_NOVELL_RESET
#undef ED_NOVELL_RESET
-#endif
#define ED_NOVELL_RESET sc->edreg.reset
/*
@@ -90,20 +82,20 @@ static int pc98_set_register_unit __P((struct ed_softc *sc, int type, int iobase
* 0xa0 Contec C-NET(98).
* 0xb0 Contec C-NET(98)E/L.
*/
-#define ED_TYPE98_BASE 0x10
-
-#define ED_TYPE98_GENERIC 0x10
-#define ED_TYPE98_LPC 0x11
-#define ED_TYPE98_BDN 0x12
-#define ED_TYPE98_EGY 0x13
-#define ED_TYPE98_LGY 0x14
-#define ED_TYPE98_ICM 0x15
-#define ED_TYPE98_SIC 0x16
-#define ED_TYPE98_108 0x18
-#define ED_TYPE98_LA98 0x19
-#define ED_TYPE98_CNET98 0x1a
-#define ED_TYPE98_CNET98EL 0x1b
-#define ED_TYPE98_UE2212 0x1c
+#define ED_TYPE98_BASE 0x80
+
+#define ED_TYPE98_GENERIC 0x80
+#define ED_TYPE98_LPC 0x81
+#define ED_TYPE98_BDN 0x82
+#define ED_TYPE98_EGY 0x83
+#define ED_TYPE98_LGY 0x84
+#define ED_TYPE98_ICM 0x85
+#define ED_TYPE98_SIC 0x86
+#define ED_TYPE98_108 0x88
+#define ED_TYPE98_LA98 0x89
+#define ED_TYPE98_CNET98 0x8a
+#define ED_TYPE98_CNET98EL 0x8b
+#define ED_TYPE98_UE2212 0x8c
#define ED_TYPE98(x) (((x & 0xffff0000) >> 20) | ED_TYPE98_BASE)
#define ED_TYPE98SUB(x) ((x & 0xf0000) >> 16)
@@ -255,14 +247,10 @@ static int pc98_set_register_unit __P((struct ed_softc *sc, int type, int iobase
#define ED_P2_IMR sc->edreg.port[0x0f]
/* PCCARD */
-#ifdef ED_PC_MISC
#undef ED_PC_MISC
-#endif
#define ED_PC_MISC sc->edreg.pc_misc
-#ifdef ED_PC_RESET
#undef ED_PC_RESET
-#endif
-#define ED_PC_RESET sc->edreg.pc_reset
+#define ED_PC_RESET sc->edreg.pc_reset
/* LPC-T support */
#define LPCT_1d0_ON() \
@@ -397,6 +385,9 @@ pc98_set_register_unit(struct ed_softc *sc, int type, int iobase)
int nports;
sc->type = type;
+ ED_PC_MISC = 0x18; /* dummy for NON-PCCard */
+ ED_PC_RESET = 0x1f; /* same above */
+
switch (type) {
case ED_TYPE98_GENERIC:
sc->edreg.port = edp_generic;
@@ -404,8 +395,6 @@ pc98_set_register_unit(struct ed_softc *sc, int type, int iobase)
ED_NOVELL_ASIC_OFFSET = 0x0010;
ED_NOVELL_DATA = 0x0000;
ED_NOVELL_RESET = 0x000f;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
nports = 32;
break;
@@ -415,30 +404,24 @@ pc98_set_register_unit(struct ed_softc *sc, int type, int iobase)
ED_NOVELL_ASIC_OFFSET = 0x0200;
ED_NOVELL_DATA = 0x0000;
ED_NOVELL_RESET = 0x0100;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
nports = 16;
break;
case ED_TYPE98_EGY:
sc->edreg.port = edp_egy98;
- ED_NOVELL_NIC_OFFSET = 0;
+ ED_NOVELL_NIC_OFFSET = 0x0000;
ED_NOVELL_ASIC_OFFSET = 0x0200;
ED_NOVELL_DATA = 0x0000;
ED_NOVELL_RESET = 0x0100;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
nports = 16;
break;
case ED_TYPE98_ICM:
sc->edreg.port = edp_generic;
- ED_NOVELL_NIC_OFFSET = 0;
+ ED_NOVELL_NIC_OFFSET = 0x0000;
ED_NOVELL_ASIC_OFFSET = 0x0100;
ED_NOVELL_DATA = 0x0000;
ED_NOVELL_RESET = 0x000f;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
nports = 16;
break;
@@ -446,10 +429,8 @@ pc98_set_register_unit(struct ed_softc *sc, int type, int iobase)
sc->edreg.port = edp_la98;
ED_NOVELL_NIC_OFFSET = 0x0000;
ED_NOVELL_ASIC_OFFSET = 0x0100;
- ED_NOVELL_DATA = 0;
+ ED_NOVELL_DATA = 0x0000;
ED_NOVELL_RESET = 0xc100;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
nports = 1;
break;
@@ -457,10 +438,8 @@ pc98_set_register_unit(struct ed_softc *sc, int type, int iobase)
sc->edreg.port = edp_sic98;
ED_NOVELL_NIC_OFFSET = 0x0000;
ED_NOVELL_ASIC_OFFSET = 0x2000;
- ED_NOVELL_DATA = 0x00; /* dummy */
- ED_NOVELL_RESET = 0x00;
- ED_PC_MISC = 0x18; /* dummy */
- ED_PC_RESET = 0x1f; /* dummy */
+ ED_NOVELL_DATA = 0; /* dummy */
+ ED_NOVELL_RESET = 0; /* dummy */
nports = 1;
break;
@@ -478,47 +457,58 @@ pc98_set_register_unit(struct ed_softc *sc, int type, int iobase)
case ED_TYPE98_108:
sc->edreg.port = edp_nec108;
adj = (iobase & 0xf000) / 2;
- ED_NOVELL_NIC_OFFSET = 0;
- ED_NOVELL_ASIC_OFFSET = (0x888 | adj) - iobase;
- ED_NOVELL_DATA = 0;
- ED_NOVELL_RESET = 2;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
+ ED_NOVELL_NIC_OFFSET = 0x0000;
+ ED_NOVELL_ASIC_OFFSET = (0x0888 | adj) - iobase;
+ ED_NOVELL_DATA = 0x0000;
+ ED_NOVELL_RESET = 0x0002;
nports = 16;
break;
case ED_TYPE98_LA98:
sc->edreg.port = edp_la98;
- ED_NOVELL_NIC_OFFSET = 0;
- ED_NOVELL_ASIC_OFFSET = 0x100;
+ ED_NOVELL_NIC_OFFSET = 0x0000;
+ ED_NOVELL_ASIC_OFFSET = 0x0100;
ED_NOVELL_DATA = 0x0000;
ED_NOVELL_RESET = 0xf000;
- ED_PC_MISC = 0x18;
- ED_PC_RESET = 0x1f;
nports = 1;
break;
case ED_TYPE98_CNET98EL:
sc->edreg.port = edp_generic;
- ED_NOVELL_NIC_OFFSET = 0;
+ ED_NOVELL_NIC_OFFSET = 0x0000;
ED_NOVELL_ASIC_OFFSET = 0x0400;
ED_NOVELL_DATA = 0x000e;
- ED_NOVELL_RESET = 0x0000; /* dummy */
- ED_PC_RESET = 0x1f;
+ ED_NOVELL_RESET = 0; /* dummy */
nports = 16;
break;
case ED_TYPE98_CNET98:
sc->edreg.port = edp_cnet98;
- ED_NOVELL_NIC_OFFSET = 0;
+ ED_NOVELL_NIC_OFFSET = 0x0000;
ED_NOVELL_ASIC_OFFSET = 0x0400;
- ED_NOVELL_DATA = 0x0000;
- ED_NOVELL_RESET = 0x0000; /* dummy */
- ED_PC_RESET = 0x1f;
+ ED_NOVELL_DATA = 0; /* dummy */
+ ED_NOVELL_RESET = 0; /* dummy */
nports = 16;
break;
}
return nports;
}
+/*
+ * SMC EtherEZ98(SMC8498BTA)
+ *
+ * A sample of kernel conf is as follows.
+ * #device ed0 at isa? port 0x10d0 net irq 6 iomem 0xc8000 vector edintr
+ */
+#undef ED_WD_NIC_OFFSET
+#define ED_WD_NIC_OFFSET 0x100 /* I/O base offset to NIC */
+#undef ED_WD_ASIC_OFFSET
+#define ED_WD_ASIC_OFFSET 0 /* I/O base offset to ASIC */
+/*
+ * XXX - The I/O address range is fragmented in the EtherEZ98;
+ * it occupies 16*2 I/O addresses, by the way.
+ */
+#undef ED_WD_IO_PORTS
+#define ED_WD_IO_PORTS 16 /* # of i/o addresses used */
+
#endif /* __PC98_PC98_IF_ED98_H__ */
OpenPOWER on IntegriCloud