diff options
author | Akinobu Mita <akinobu.mita@gmail.com> | 2006-12-19 16:09:08 -0500 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2007-02-05 16:58:47 -0500 |
commit | bc63eb9c7ec0eb7b091db2d82d46d1e68ff9e231 (patch) | |
tree | dfcbc44d49a516eb2c95ac2f724fbee52427d0fd /drivers | |
parent | 079ca7da1e6d05c7cb82e9c4f2e1d98839332664 (diff) |
net: use bitrev8
Use bitrev8 for bmac, mace, macmace, macsonic, and skfp drivers.
[akpm@osdl.org: use the API, not the array]
Cc: Jeff Garzik <jgarzik@pobox.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Mirko Lindner <mlindner@syskonnect.de>
Cc: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
Signed-off-by: Akinobu Mita <akinobu.mita@gmail.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/Kconfig | 1 | ||||
-rw-r--r-- | drivers/net/bmac.c | 20 | ||||
-rw-r--r-- | drivers/net/mace.c | 16 | ||||
-rw-r--r-- | drivers/net/macmace.c | 18 | ||||
-rw-r--r-- | drivers/net/macsonic.c | 6 | ||||
-rw-r--r-- | drivers/net/skfp/can.c | 83 | ||||
-rw-r--r-- | drivers/net/skfp/drvfbi.c | 24 | ||||
-rw-r--r-- | drivers/net/skfp/fplustm.c | 4 | ||||
-rw-r--r-- | drivers/net/skfp/smt.c | 10 |
9 files changed, 27 insertions, 155 deletions
diff --git a/drivers/net/Kconfig b/drivers/net/Kconfig index 01ddcbc14fa0..8ffa82559116 100644 --- a/drivers/net/Kconfig +++ b/drivers/net/Kconfig | |||
@@ -2546,6 +2546,7 @@ config DEFXX | |||
2546 | config SKFP | 2546 | config SKFP |
2547 | tristate "SysKonnect FDDI PCI support" | 2547 | tristate "SysKonnect FDDI PCI support" |
2548 | depends on FDDI && PCI | 2548 | depends on FDDI && PCI |
2549 | select BITREVERSE | ||
2549 | ---help--- | 2550 | ---help--- |
2550 | Say Y here if you have a SysKonnect FDDI PCI adapter. | 2551 | Say Y here if you have a SysKonnect FDDI PCI adapter. |
2551 | The following adapters are supported by this driver: | 2552 | The following adapters are supported by this driver: |
diff --git a/drivers/net/bmac.c b/drivers/net/bmac.c index 4528ce9c4e43..c143304dcff5 100644 --- a/drivers/net/bmac.c +++ b/drivers/net/bmac.c | |||
@@ -18,6 +18,7 @@ | |||
18 | #include <linux/init.h> | 18 | #include <linux/init.h> |
19 | #include <linux/spinlock.h> | 19 | #include <linux/spinlock.h> |
20 | #include <linux/crc32.h> | 20 | #include <linux/crc32.h> |
21 | #include <linux/bitrev.h> | ||
21 | #include <asm/prom.h> | 22 | #include <asm/prom.h> |
22 | #include <asm/dbdma.h> | 23 | #include <asm/dbdma.h> |
23 | #include <asm/io.h> | 24 | #include <asm/io.h> |
@@ -140,7 +141,6 @@ static unsigned char *bmac_emergency_rxbuf; | |||
140 | + (N_RX_RING + N_TX_RING + 4) * sizeof(struct dbdma_cmd) \ | 141 | + (N_RX_RING + N_TX_RING + 4) * sizeof(struct dbdma_cmd) \ |
141 | + sizeof(struct sk_buff_head)) | 142 | + sizeof(struct sk_buff_head)) |
142 | 143 | ||
143 | static unsigned char bitrev(unsigned char b); | ||
144 | static int bmac_open(struct net_device *dev); | 144 | static int bmac_open(struct net_device *dev); |
145 | static int bmac_close(struct net_device *dev); | 145 | static int bmac_close(struct net_device *dev); |
146 | static int bmac_transmit_packet(struct sk_buff *skb, struct net_device *dev); | 146 | static int bmac_transmit_packet(struct sk_buff *skb, struct net_device *dev); |
@@ -586,18 +586,6 @@ bmac_construct_rxbuff(struct sk_buff *skb, volatile struct dbdma_cmd *cp) | |||
586 | virt_to_bus(addr), 0); | 586 | virt_to_bus(addr), 0); |
587 | } | 587 | } |
588 | 588 | ||
589 | /* Bit-reverse one byte of an ethernet hardware address. */ | ||
590 | static unsigned char | ||
591 | bitrev(unsigned char b) | ||
592 | { | ||
593 | int d = 0, i; | ||
594 | |||
595 | for (i = 0; i < 8; ++i, b >>= 1) | ||
596 | d = (d << 1) | (b & 1); | ||
597 | return d; | ||
598 | } | ||
599 | |||
600 | |||
601 | static void | 589 | static void |
602 | bmac_init_tx_ring(struct bmac_data *bp) | 590 | bmac_init_tx_ring(struct bmac_data *bp) |
603 | { | 591 | { |
@@ -1224,8 +1212,8 @@ bmac_get_station_address(struct net_device *dev, unsigned char *ea) | |||
1224 | { | 1212 | { |
1225 | reset_and_select_srom(dev); | 1213 | reset_and_select_srom(dev); |
1226 | data = read_srom(dev, i + EnetAddressOffset/2, SROMAddressBits); | 1214 | data = read_srom(dev, i + EnetAddressOffset/2, SROMAddressBits); |
1227 | ea[2*i] = bitrev(data & 0x0ff); | 1215 | ea[2*i] = bitrev8(data & 0x0ff); |
1228 | ea[2*i+1] = bitrev((data >> 8) & 0x0ff); | 1216 | ea[2*i+1] = bitrev8((data >> 8) & 0x0ff); |
1229 | } | 1217 | } |
1230 | } | 1218 | } |
1231 | 1219 | ||
@@ -1315,7 +1303,7 @@ static int __devinit bmac_probe(struct macio_dev *mdev, const struct of_device_i | |||
1315 | 1303 | ||
1316 | rev = addr[0] == 0 && addr[1] == 0xA0; | 1304 | rev = addr[0] == 0 && addr[1] == 0xA0; |
1317 | for (j = 0; j < 6; ++j) | 1305 | for (j = 0; j < 6; ++j) |
1318 | dev->dev_addr[j] = rev? bitrev(addr[j]): addr[j]; | 1306 | dev->dev_addr[j] = rev ? bitrev8(addr[j]): addr[j]; |
1319 | 1307 | ||
1320 | /* Enable chip without interrupts for now */ | 1308 | /* Enable chip without interrupts for now */ |
1321 | bmac_enable_and_reset_chip(dev); | 1309 | bmac_enable_and_reset_chip(dev); |
diff --git a/drivers/net/mace.c b/drivers/net/mace.c index 2907cfb12ada..9ec24f0d5d68 100644 --- a/drivers/net/mace.c +++ b/drivers/net/mace.c | |||
@@ -15,6 +15,7 @@ | |||
15 | #include <linux/init.h> | 15 | #include <linux/init.h> |
16 | #include <linux/crc32.h> | 16 | #include <linux/crc32.h> |
17 | #include <linux/spinlock.h> | 17 | #include <linux/spinlock.h> |
18 | #include <linux/bitrev.h> | ||
18 | #include <asm/prom.h> | 19 | #include <asm/prom.h> |
19 | #include <asm/dbdma.h> | 20 | #include <asm/dbdma.h> |
20 | #include <asm/io.h> | 21 | #include <asm/io.h> |
@@ -74,7 +75,6 @@ struct mace_data { | |||
74 | #define PRIV_BYTES (sizeof(struct mace_data) \ | 75 | #define PRIV_BYTES (sizeof(struct mace_data) \ |
75 | + (N_RX_RING + NCMDS_TX * N_TX_RING + 3) * sizeof(struct dbdma_cmd)) | 76 | + (N_RX_RING + NCMDS_TX * N_TX_RING + 3) * sizeof(struct dbdma_cmd)) |
76 | 77 | ||
77 | static int bitrev(int); | ||
78 | static int mace_open(struct net_device *dev); | 78 | static int mace_open(struct net_device *dev); |
79 | static int mace_close(struct net_device *dev); | 79 | static int mace_close(struct net_device *dev); |
80 | static int mace_xmit_start(struct sk_buff *skb, struct net_device *dev); | 80 | static int mace_xmit_start(struct sk_buff *skb, struct net_device *dev); |
@@ -96,18 +96,6 @@ static void __mace_set_address(struct net_device *dev, void *addr); | |||
96 | */ | 96 | */ |
97 | static unsigned char *dummy_buf; | 97 | static unsigned char *dummy_buf; |
98 | 98 | ||
99 | /* Bit-reverse one byte of an ethernet hardware address. */ | ||
100 | static inline int | ||
101 | bitrev(int b) | ||
102 | { | ||
103 | int d = 0, i; | ||
104 | |||
105 | for (i = 0; i < 8; ++i, b >>= 1) | ||
106 | d = (d << 1) | (b & 1); | ||
107 | return d; | ||
108 | } | ||
109 | |||
110 | |||
111 | static int __devinit mace_probe(struct macio_dev *mdev, const struct of_device_id *match) | 99 | static int __devinit mace_probe(struct macio_dev *mdev, const struct of_device_id *match) |
112 | { | 100 | { |
113 | struct device_node *mace = macio_get_of_node(mdev); | 101 | struct device_node *mace = macio_get_of_node(mdev); |
@@ -173,7 +161,7 @@ static int __devinit mace_probe(struct macio_dev *mdev, const struct of_device_i | |||
173 | 161 | ||
174 | rev = addr[0] == 0 && addr[1] == 0xA0; | 162 | rev = addr[0] == 0 && addr[1] == 0xA0; |
175 | for (j = 0; j < 6; ++j) { | 163 | for (j = 0; j < 6; ++j) { |
176 | dev->dev_addr[j] = rev? bitrev(addr[j]): addr[j]; | 164 | dev->dev_addr[j] = rev ? bitrev8(addr[j]): addr[j]; |
177 | } | 165 | } |
178 | mp->chipid = (in_8(&mp->mace->chipid_hi) << 8) | | 166 | mp->chipid = (in_8(&mp->mace->chipid_hi) << 8) | |
179 | in_8(&mp->mace->chipid_lo); | 167 | in_8(&mp->mace->chipid_lo); |
diff --git a/drivers/net/macmace.c b/drivers/net/macmace.c index 464e4a6f3d5f..5d541e873041 100644 --- a/drivers/net/macmace.c +++ b/drivers/net/macmace.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/delay.h> | 22 | #include <linux/delay.h> |
23 | #include <linux/string.h> | 23 | #include <linux/string.h> |
24 | #include <linux/crc32.h> | 24 | #include <linux/crc32.h> |
25 | #include <linux/bitrev.h> | ||
25 | #include <asm/io.h> | 26 | #include <asm/io.h> |
26 | #include <asm/pgtable.h> | 27 | #include <asm/pgtable.h> |
27 | #include <asm/irq.h> | 28 | #include <asm/irq.h> |
@@ -81,19 +82,6 @@ static irqreturn_t mace_interrupt(int irq, void *dev_id); | |||
81 | static irqreturn_t mace_dma_intr(int irq, void *dev_id); | 82 | static irqreturn_t mace_dma_intr(int irq, void *dev_id); |
82 | static void mace_tx_timeout(struct net_device *dev); | 83 | static void mace_tx_timeout(struct net_device *dev); |
83 | 84 | ||
84 | /* Bit-reverse one byte of an ethernet hardware address. */ | ||
85 | |||
86 | static int bitrev(int b) | ||
87 | { | ||
88 | int d = 0, i; | ||
89 | |||
90 | for (i = 0; i < 8; ++i, b >>= 1) { | ||
91 | d = (d << 1) | (b & 1); | ||
92 | } | ||
93 | |||
94 | return d; | ||
95 | } | ||
96 | |||
97 | /* | 85 | /* |
98 | * Load a receive DMA channel with a base address and ring length | 86 | * Load a receive DMA channel with a base address and ring length |
99 | */ | 87 | */ |
@@ -219,12 +207,12 @@ struct net_device *mace_probe(int unit) | |||
219 | addr = (void *)MACE_PROM; | 207 | addr = (void *)MACE_PROM; |
220 | 208 | ||
221 | for (j = 0; j < 6; ++j) { | 209 | for (j = 0; j < 6; ++j) { |
222 | u8 v=bitrev(addr[j<<4]); | 210 | u8 v = bitrev8(addr[j<<4]); |
223 | checksum ^= v; | 211 | checksum ^= v; |
224 | dev->dev_addr[j] = v; | 212 | dev->dev_addr[j] = v; |
225 | } | 213 | } |
226 | for (; j < 8; ++j) { | 214 | for (; j < 8; ++j) { |
227 | checksum ^= bitrev(addr[j<<4]); | 215 | checksum ^= bitrev8(addr[j<<4]); |
228 | } | 216 | } |
229 | 217 | ||
230 | if (checksum != 0xFF) { | 218 | if (checksum != 0xFF) { |
diff --git a/drivers/net/macsonic.c b/drivers/net/macsonic.c index 393d995f1919..24f6050fbf33 100644 --- a/drivers/net/macsonic.c +++ b/drivers/net/macsonic.c | |||
@@ -121,16 +121,12 @@ enum macsonic_type { | |||
121 | * For reversing the PROM address | 121 | * For reversing the PROM address |
122 | */ | 122 | */ |
123 | 123 | ||
124 | static unsigned char nibbletab[] = {0, 8, 4, 12, 2, 10, 6, 14, | ||
125 | 1, 9, 5, 13, 3, 11, 7, 15}; | ||
126 | |||
127 | static inline void bit_reverse_addr(unsigned char addr[6]) | 124 | static inline void bit_reverse_addr(unsigned char addr[6]) |
128 | { | 125 | { |
129 | int i; | 126 | int i; |
130 | 127 | ||
131 | for(i = 0; i < 6; i++) | 128 | for(i = 0; i < 6; i++) |
132 | addr[i] = ((nibbletab[addr[i] & 0xf] << 4) | | 129 | addr[i] = bitrev8(addr[i]); |
133 | nibbletab[(addr[i] >> 4) &0xf]); | ||
134 | } | 130 | } |
135 | 131 | ||
136 | int __init macsonic_init(struct net_device* dev) | 132 | int __init macsonic_init(struct net_device* dev) |
diff --git a/drivers/net/skfp/can.c b/drivers/net/skfp/can.c deleted file mode 100644 index 8a49abce7961..000000000000 --- a/drivers/net/skfp/can.c +++ /dev/null | |||
@@ -1,83 +0,0 @@ | |||
1 | /****************************************************************************** | ||
2 | * | ||
3 | * (C)Copyright 1998,1999 SysKonnect, | ||
4 | * a business unit of Schneider & Koch & Co. Datensysteme GmbH. | ||
5 | * | ||
6 | * See the file "skfddi.c" for further information. | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License as published by | ||
10 | * the Free Software Foundation; either version 2 of the License, or | ||
11 | * (at your option) any later version. | ||
12 | * | ||
13 | * The information in this file is provided "AS IS" without warranty. | ||
14 | * | ||
15 | ******************************************************************************/ | ||
16 | |||
17 | #ifndef lint | ||
18 | static const char xID_sccs[] = "@(#)can.c 1.5 97/04/07 (C) SK " ; | ||
19 | #endif | ||
20 | |||
21 | /* | ||
22 | * canonical bit order | ||
23 | */ | ||
24 | const u_char canonical[256] = { | ||
25 | 0x00,0x80,0x40,0xc0,0x20,0xa0,0x60,0xe0, | ||
26 | 0x10,0x90,0x50,0xd0,0x30,0xb0,0x70,0xf0, | ||
27 | 0x08,0x88,0x48,0xc8,0x28,0xa8,0x68,0xe8, | ||
28 | 0x18,0x98,0x58,0xd8,0x38,0xb8,0x78,0xf8, | ||
29 | 0x04,0x84,0x44,0xc4,0x24,0xa4,0x64,0xe4, | ||
30 | 0x14,0x94,0x54,0xd4,0x34,0xb4,0x74,0xf4, | ||
31 | 0x0c,0x8c,0x4c,0xcc,0x2c,0xac,0x6c,0xec, | ||
32 | 0x1c,0x9c,0x5c,0xdc,0x3c,0xbc,0x7c,0xfc, | ||
33 | 0x02,0x82,0x42,0xc2,0x22,0xa2,0x62,0xe2, | ||
34 | 0x12,0x92,0x52,0xd2,0x32,0xb2,0x72,0xf2, | ||
35 | 0x0a,0x8a,0x4a,0xca,0x2a,0xaa,0x6a,0xea, | ||
36 | 0x1a,0x9a,0x5a,0xda,0x3a,0xba,0x7a,0xfa, | ||
37 | 0x06,0x86,0x46,0xc6,0x26,0xa6,0x66,0xe6, | ||
38 | 0x16,0x96,0x56,0xd6,0x36,0xb6,0x76,0xf6, | ||
39 | 0x0e,0x8e,0x4e,0xce,0x2e,0xae,0x6e,0xee, | ||
40 | 0x1e,0x9e,0x5e,0xde,0x3e,0xbe,0x7e,0xfe, | ||
41 | 0x01,0x81,0x41,0xc1,0x21,0xa1,0x61,0xe1, | ||
42 | 0x11,0x91,0x51,0xd1,0x31,0xb1,0x71,0xf1, | ||
43 | 0x09,0x89,0x49,0xc9,0x29,0xa9,0x69,0xe9, | ||
44 | 0x19,0x99,0x59,0xd9,0x39,0xb9,0x79,0xf9, | ||
45 | 0x05,0x85,0x45,0xc5,0x25,0xa5,0x65,0xe5, | ||
46 | 0x15,0x95,0x55,0xd5,0x35,0xb5,0x75,0xf5, | ||
47 | 0x0d,0x8d,0x4d,0xcd,0x2d,0xad,0x6d,0xed, | ||
48 | 0x1d,0x9d,0x5d,0xdd,0x3d,0xbd,0x7d,0xfd, | ||
49 | 0x03,0x83,0x43,0xc3,0x23,0xa3,0x63,0xe3, | ||
50 | 0x13,0x93,0x53,0xd3,0x33,0xb3,0x73,0xf3, | ||
51 | 0x0b,0x8b,0x4b,0xcb,0x2b,0xab,0x6b,0xeb, | ||
52 | 0x1b,0x9b,0x5b,0xdb,0x3b,0xbb,0x7b,0xfb, | ||
53 | 0x07,0x87,0x47,0xc7,0x27,0xa7,0x67,0xe7, | ||
54 | 0x17,0x97,0x57,0xd7,0x37,0xb7,0x77,0xf7, | ||
55 | 0x0f,0x8f,0x4f,0xcf,0x2f,0xaf,0x6f,0xef, | ||
56 | 0x1f,0x9f,0x5f,0xdf,0x3f,0xbf,0x7f,0xff | ||
57 | } ; | ||
58 | |||
59 | #ifdef MAKE_TABLE | ||
60 | int byte_reverse(x) | ||
61 | int x ; | ||
62 | { | ||
63 | int y = 0 ; | ||
64 | |||
65 | if (x & 0x01) | ||
66 | y |= 0x80 ; | ||
67 | if (x & 0x02) | ||
68 | y |= 0x40 ; | ||
69 | if (x & 0x04) | ||
70 | y |= 0x20 ; | ||
71 | if (x & 0x08) | ||
72 | y |= 0x10 ; | ||
73 | if (x & 0x10) | ||
74 | y |= 0x08 ; | ||
75 | if (x & 0x20) | ||
76 | y |= 0x04 ; | ||
77 | if (x & 0x40) | ||
78 | y |= 0x02 ; | ||
79 | if (x & 0x80) | ||
80 | y |= 0x01 ; | ||
81 | return(y) ; | ||
82 | } | ||
83 | #endif | ||
diff --git a/drivers/net/skfp/drvfbi.c b/drivers/net/skfp/drvfbi.c index 5b475833f645..4fe624b0dd25 100644 --- a/drivers/net/skfp/drvfbi.c +++ b/drivers/net/skfp/drvfbi.c | |||
@@ -23,6 +23,7 @@ | |||
23 | #include "h/smc.h" | 23 | #include "h/smc.h" |
24 | #include "h/supern_2.h" | 24 | #include "h/supern_2.h" |
25 | #include "h/skfbiinc.h" | 25 | #include "h/skfbiinc.h" |
26 | #include <linux/bitrev.h> | ||
26 | 27 | ||
27 | #ifndef lint | 28 | #ifndef lint |
28 | static const char ID_sccs[] = "@(#)drvfbi.c 1.63 99/02/11 (C) SK " ; | 29 | static const char ID_sccs[] = "@(#)drvfbi.c 1.63 99/02/11 (C) SK " ; |
@@ -445,16 +446,14 @@ void read_address(struct s_smc *smc, u_char *mac_addr) | |||
445 | char PmdType ; | 446 | char PmdType ; |
446 | int i ; | 447 | int i ; |
447 | 448 | ||
448 | extern const u_char canonical[256] ; | ||
449 | |||
450 | #if (defined(ISA) || defined(MCA)) | 449 | #if (defined(ISA) || defined(MCA)) |
451 | for (i = 0; i < 4 ;i++) { /* read mac address from board */ | 450 | for (i = 0; i < 4 ;i++) { /* read mac address from board */ |
452 | smc->hw.fddi_phys_addr.a[i] = | 451 | smc->hw.fddi_phys_addr.a[i] = |
453 | canonical[(inpw(PR_A(i+SA_MAC))&0xff)] ; | 452 | bitrev8(inpw(PR_A(i+SA_MAC))); |
454 | } | 453 | } |
455 | for (i = 4; i < 6; i++) { | 454 | for (i = 4; i < 6; i++) { |
456 | smc->hw.fddi_phys_addr.a[i] = | 455 | smc->hw.fddi_phys_addr.a[i] = |
457 | canonical[(inpw(PR_A(i+SA_MAC+PRA_OFF))&0xff)] ; | 456 | bitrev8(inpw(PR_A(i+SA_MAC+PRA_OFF))); |
458 | } | 457 | } |
459 | #endif | 458 | #endif |
460 | #ifdef EISA | 459 | #ifdef EISA |
@@ -464,17 +463,17 @@ void read_address(struct s_smc *smc, u_char *mac_addr) | |||
464 | */ | 463 | */ |
465 | for (i = 0; i < 4 ;i++) { /* read mac address from board */ | 464 | for (i = 0; i < 4 ;i++) { /* read mac address from board */ |
466 | smc->hw.fddi_phys_addr.a[i] = | 465 | smc->hw.fddi_phys_addr.a[i] = |
467 | canonical[inp(PR_A(i+SA_MAC))] ; | 466 | bitrev8(inp(PR_A(i+SA_MAC))); |
468 | } | 467 | } |
469 | for (i = 4; i < 6; i++) { | 468 | for (i = 4; i < 6; i++) { |
470 | smc->hw.fddi_phys_addr.a[i] = | 469 | smc->hw.fddi_phys_addr.a[i] = |
471 | canonical[inp(PR_A(i+SA_MAC+PRA_OFF))] ; | 470 | bitrev8(inp(PR_A(i+SA_MAC+PRA_OFF))); |
472 | } | 471 | } |
473 | #endif | 472 | #endif |
474 | #ifdef PCI | 473 | #ifdef PCI |
475 | for (i = 0; i < 6; i++) { /* read mac address from board */ | 474 | for (i = 0; i < 6; i++) { /* read mac address from board */ |
476 | smc->hw.fddi_phys_addr.a[i] = | 475 | smc->hw.fddi_phys_addr.a[i] = |
477 | canonical[inp(ADDR(B2_MAC_0+i))] ; | 476 | bitrev8(inp(ADDR(B2_MAC_0+i))); |
478 | } | 477 | } |
479 | #endif | 478 | #endif |
480 | #ifndef PCI | 479 | #ifndef PCI |
@@ -493,7 +492,7 @@ void read_address(struct s_smc *smc, u_char *mac_addr) | |||
493 | if (mac_addr) { | 492 | if (mac_addr) { |
494 | for (i = 0; i < 6 ;i++) { | 493 | for (i = 0; i < 6 ;i++) { |
495 | smc->hw.fddi_canon_addr.a[i] = mac_addr[i] ; | 494 | smc->hw.fddi_canon_addr.a[i] = mac_addr[i] ; |
496 | smc->hw.fddi_home_addr.a[i] = canonical[mac_addr[i]] ; | 495 | smc->hw.fddi_home_addr.a[i] = bitrev8(mac_addr[i]); |
497 | } | 496 | } |
498 | return ; | 497 | return ; |
499 | } | 498 | } |
@@ -501,7 +500,7 @@ void read_address(struct s_smc *smc, u_char *mac_addr) | |||
501 | 500 | ||
502 | for (i = 0; i < 6 ;i++) { | 501 | for (i = 0; i < 6 ;i++) { |
503 | smc->hw.fddi_canon_addr.a[i] = | 502 | smc->hw.fddi_canon_addr.a[i] = |
504 | canonical[smc->hw.fddi_phys_addr.a[i]] ; | 503 | bitrev8(smc->hw.fddi_phys_addr.a[i]); |
505 | } | 504 | } |
506 | } | 505 | } |
507 | 506 | ||
@@ -1269,11 +1268,8 @@ void driver_get_bia(struct s_smc *smc, struct fddi_addr *bia_addr) | |||
1269 | { | 1268 | { |
1270 | int i ; | 1269 | int i ; |
1271 | 1270 | ||
1272 | extern const u_char canonical[256] ; | 1271 | for (i = 0 ; i < 6 ; i++) |
1273 | 1272 | bia_addr->a[i] = bitrev8(smc->hw.fddi_phys_addr.a[i]); | |
1274 | for (i = 0 ; i < 6 ; i++) { | ||
1275 | bia_addr->a[i] = canonical[smc->hw.fddi_phys_addr.a[i]] ; | ||
1276 | } | ||
1277 | } | 1273 | } |
1278 | 1274 | ||
1279 | void smt_start_watchdog(struct s_smc *smc) | 1275 | void smt_start_watchdog(struct s_smc *smc) |
diff --git a/drivers/net/skfp/fplustm.c b/drivers/net/skfp/fplustm.c index 0784f558ca9a..a45205da8033 100644 --- a/drivers/net/skfp/fplustm.c +++ b/drivers/net/skfp/fplustm.c | |||
@@ -22,7 +22,7 @@ | |||
22 | #include "h/fddi.h" | 22 | #include "h/fddi.h" |
23 | #include "h/smc.h" | 23 | #include "h/smc.h" |
24 | #include "h/supern_2.h" | 24 | #include "h/supern_2.h" |
25 | #include "can.c" | 25 | #include <linux/bitrev.h> |
26 | 26 | ||
27 | #ifndef lint | 27 | #ifndef lint |
28 | static const char ID_sccs[] = "@(#)fplustm.c 1.32 99/02/23 (C) SK " ; | 28 | static const char ID_sccs[] = "@(#)fplustm.c 1.32 99/02/23 (C) SK " ; |
@@ -1073,7 +1073,7 @@ static struct s_fpmc* mac_get_mc_table(struct s_smc *smc, | |||
1073 | if (can) { | 1073 | if (can) { |
1074 | p = own->a ; | 1074 | p = own->a ; |
1075 | for (i = 0 ; i < 6 ; i++, p++) | 1075 | for (i = 0 ; i < 6 ; i++, p++) |
1076 | *p = canonical[*p] ; | 1076 | *p = bitrev8(*p); |
1077 | } | 1077 | } |
1078 | slot = NULL; | 1078 | slot = NULL; |
1079 | for (i = 0, tb = smc->hw.fp.mc.table ; i < FPMAX_MULTICAST ; i++, tb++){ | 1079 | for (i = 0, tb = smc->hw.fp.mc.table ; i < FPMAX_MULTICAST ; i++, tb++){ |
diff --git a/drivers/net/skfp/smt.c b/drivers/net/skfp/smt.c index 99a776a51fb5..fe847800acdc 100644 --- a/drivers/net/skfp/smt.c +++ b/drivers/net/skfp/smt.c | |||
@@ -18,6 +18,7 @@ | |||
18 | #include "h/fddi.h" | 18 | #include "h/fddi.h" |
19 | #include "h/smc.h" | 19 | #include "h/smc.h" |
20 | #include "h/smt_p.h" | 20 | #include "h/smt_p.h" |
21 | #include <linux/bitrev.h> | ||
21 | 22 | ||
22 | #define KERNEL | 23 | #define KERNEL |
23 | #include "h/smtstate.h" | 24 | #include "h/smtstate.h" |
@@ -26,8 +27,6 @@ | |||
26 | static const char ID_sccs[] = "@(#)smt.c 2.43 98/11/23 (C) SK " ; | 27 | static const char ID_sccs[] = "@(#)smt.c 2.43 98/11/23 (C) SK " ; |
27 | #endif | 28 | #endif |
28 | 29 | ||
29 | extern const u_char canonical[256] ; | ||
30 | |||
31 | /* | 30 | /* |
32 | * FC in SMbuf | 31 | * FC in SMbuf |
33 | */ | 32 | */ |
@@ -180,7 +179,7 @@ void smt_agent_init(struct s_smc *smc) | |||
180 | driver_get_bia(smc,&smc->mib.fddiSMTStationId.sid_node) ; | 179 | driver_get_bia(smc,&smc->mib.fddiSMTStationId.sid_node) ; |
181 | for (i = 0 ; i < 6 ; i ++) { | 180 | for (i = 0 ; i < 6 ; i ++) { |
182 | smc->mib.fddiSMTStationId.sid_node.a[i] = | 181 | smc->mib.fddiSMTStationId.sid_node.a[i] = |
183 | canonical[smc->mib.fddiSMTStationId.sid_node.a[i]] ; | 182 | bitrev8(smc->mib.fddiSMTStationId.sid_node.a[i]); |
184 | } | 183 | } |
185 | smc->mib.fddiSMTManufacturerData[0] = | 184 | smc->mib.fddiSMTManufacturerData[0] = |
186 | smc->mib.fddiSMTStationId.sid_node.a[0] ; | 185 | smc->mib.fddiSMTStationId.sid_node.a[0] ; |
@@ -2049,9 +2048,8 @@ static void hwm_conv_can(struct s_smc *smc, char *data, int len) | |||
2049 | 2048 | ||
2050 | SK_UNUSED(smc) ; | 2049 | SK_UNUSED(smc) ; |
2051 | 2050 | ||
2052 | for (i = len; i ; i--, data++) { | 2051 | for (i = len; i ; i--, data++) |
2053 | *data = canonical[*(u_char *)data] ; | 2052 | *data = bitrev8(*data); |
2054 | } | ||
2055 | } | 2053 | } |
2056 | #endif | 2054 | #endif |
2057 | 2055 | ||