summaryrefslogtreecommitdiff
path: root/sys/arch/powerpc/pci/mpcpcibus.c
diff options
context:
space:
mode:
authorPer Fogelstrom <pefo@cvs.openbsd.org>1997-10-20 19:52:44 +0000
committerPer Fogelstrom <pefo@cvs.openbsd.org>1997-10-20 19:52:44 +0000
commit67433305ca5eddb151d47445aa1c469184db7aa9 (patch)
tree1a6dd7591dfa14000a70ef14e7df7f8c9c3cf735 /sys/arch/powerpc/pci/mpcpcibus.c
parent2921622c84e83ffb8fd7e0365ba512211dfcc777 (diff)
Add IPSEC to GENERIC, move if_de srom emul to pci
Diffstat (limited to 'sys/arch/powerpc/pci/mpcpcibus.c')
-rw-r--r--sys/arch/powerpc/pci/mpcpcibus.c65
1 files changed, 61 insertions, 4 deletions
diff --git a/sys/arch/powerpc/pci/mpcpcibus.c b/sys/arch/powerpc/pci/mpcpcibus.c
index 0befc25c5a4..44a26e49b9f 100644
--- a/sys/arch/powerpc/pci/mpcpcibus.c
+++ b/sys/arch/powerpc/pci/mpcpcibus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mpcpcibus.c,v 1.1 1997/10/11 11:29:30 pefo Exp $ */
+/* $OpenBSD: mpcpcibus.c,v 1.2 1997/10/20 19:52:42 pefo Exp $ */
/*
* Copyright (c) 1997 Per Fogelstrom
@@ -73,7 +73,7 @@ const char *mpc_intr_string __P((void *, pci_intr_handle_t));
void *mpc_intr_establish __P((void *, pci_intr_handle_t,
int, int (*func)(void *), void *, char *));
void mpc_intr_disestablish __P((void *, void *));
-int mpc_ether_hw_addr __P((u_int8_t *));
+void mpc_ether_hw_addr __P((u_int8_t *));
struct cfattach mpcpcibr_ca = {
sizeof(struct pcibr_softc), mpcpcibrmatch, mpcpcibrattach,
@@ -87,6 +87,24 @@ static int mpcpcibrprint __P((void *, const char *pnp));
struct pcibr_config mpc_config;
+/*
+ * Code from "pci/if_de.c" used to calculate crc32 of ether rom data.
+ */
+#define TULIP_CRC32_POLY 0xEDB88320UL
+static __inline__ unsigned
+srom_crc32(
+ const unsigned char *databuf,
+ size_t datalen)
+{
+ u_int idx, bit, data, crc = 0xFFFFFFFFUL;
+
+ for (idx = 0; idx < datalen; idx++)
+ for (data = *databuf++, bit = 0; bit < 8; bit++, data >>= 1)
+ crc = (crc >> 1) ^ (((crc ^ data) & 1) ? TULIP_CRC32_POLY : 0);
+ return crc;
+}
+
+
int
mpcpcibrmatch(parent, match, aux)
struct device *parent;
@@ -188,11 +206,50 @@ mpc_attach_hook(parent, self, pba)
{
}
-int
+void
mpc_ether_hw_addr(p)
u_int8_t *p;
{
- return(0);
+ int i;
+
+ for(i = 0; i < 128; i++)
+ p[i] = 0x00;
+ p[18] = 0x03; /* Srom version. */
+ p[19] = 0x01; /* One chip. */
+/*XXX*/ p[20] = 0x00; /* Next six, ethernet address. */
+/*XXX*/ p[21] = 0xa0; /* XXX Should be read from OFW */
+/*XXX*/ p[22] = 0xf7;
+/*XXX*/ p[23] = 0x04;
+/*XXX*/ p[24] = 0x00;
+/*XXX*/ p[25] = 0x4b;
+ p[26] = 0x00; /* Chip 0 device number */
+ p[27] = 30; /* Descriptor offset */
+ p[28] = 00;
+ p[29] = 00; /* MBZ */
+ /* Descriptor */
+ p[30] = 0x00; /* Autosense. */
+ p[31] = 0x08;
+ p[32] = 0xff; /* GP cntrl */
+ p[33] = 0x01; /* Block cnt */
+#define GPR_LEN 0
+#define RES_LEN 0
+ p[34] = 0x80 + 12 + GPR_LEN + RES_LEN;
+ p[35] = 0x01; /* MII PHY type */
+ p[36] = 0x00; /* PHY number 0 */
+ p[37] = 0x00; /* GPR Length */
+ p[38] = 0x00; /* Reset Length */
+ p[39] = 0x00; /* Media capabilities */
+ p[40] = 0x78; /* Media capabilities */
+ p[41] = 0x00; /* Autoneg advertisment */
+ p[42] = 0x78; /* Autoneg advertisment */
+ p[43] = 0x00; /* Full duplex map */
+ p[44] = 0x50; /* Full duplex map */
+ p[45] = 0x00; /* Treshold map */
+ p[46] = 0x18; /* Treshold map */
+
+ i = (srom_crc32(p, 126) & 0xFFFF) ^ 0xFFFF;
+ p[126] = i;
+ p[127] = i >> 8;
}
int