diff options
Diffstat (limited to 'drivers/net/skfp')
-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 |
4 files changed, 16 insertions, 105 deletions
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 | ||