Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
05c5f695
Commit
05c5f695
authored
Jan 06, 2005
by
Jeff Garzik
Browse files
Options
Browse Files
Download
Plain Diff
Merge pobox.com:/garz/repo/netdev-2.6/sk98lin
into pobox.com:/garz/repo/net-drivers-2.6
parents
87475e1f
82cd9a70
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
845 additions
and
431 deletions
+845
-431
drivers/net/sk98lin/Makefile
drivers/net/sk98lin/Makefile
+1
-0
drivers/net/sk98lin/h/skdrv2nd.h
drivers/net/sk98lin/h/skdrv2nd.h
+3
-2
drivers/net/sk98lin/skaddr.c
drivers/net/sk98lin/skaddr.c
+1
-1
drivers/net/sk98lin/skethtool.c
drivers/net/sk98lin/skethtool.c
+555
-0
drivers/net/sk98lin/skge.c
drivers/net/sk98lin/skge.c
+125
-155
drivers/net/sk98lin/skproc.c
drivers/net/sk98lin/skproc.c
+160
-273
No files found.
drivers/net/sk98lin/Makefile
View file @
05c5f695
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
obj-$(CONFIG_SK98LIN)
+=
sk98lin.o
obj-$(CONFIG_SK98LIN)
+=
sk98lin.o
sk98lin-objs
:=
\
sk98lin-objs
:=
\
skge.o
\
skge.o
\
skethtool.o
\
skdim.o
\
skdim.o
\
skaddr.o
\
skaddr.o
\
skgehwt.o
\
skgehwt.o
\
...
...
drivers/net/sk98lin/h/skdrv2nd.h
View file @
05c5f695
...
@@ -266,7 +266,6 @@ struct s_TxD {
...
@@ -266,7 +266,6 @@ struct s_TxD {
typedef
struct
s_DevNet
DEV_NET
;
typedef
struct
s_DevNet
DEV_NET
;
struct
s_DevNet
{
struct
s_DevNet
{
struct
proc_dir_entry
*
proc
;
int
PortNr
;
int
PortNr
;
int
NetNr
;
int
NetNr
;
int
Mtu
;
int
Mtu
;
...
@@ -383,6 +382,8 @@ struct s_AC {
...
@@ -383,6 +382,8 @@ struct s_AC {
SK_CSUM
Csum
;
/* for checksum module */
SK_CSUM
Csum
;
/* for checksum module */
SK_RLMT
Rlmt
;
/* for rlmt module */
SK_RLMT
Rlmt
;
/* for rlmt module */
spinlock_t
SlowPathLock
;
/* Normal IRQ lock */
spinlock_t
SlowPathLock
;
/* Normal IRQ lock */
struct
timer_list
BlinkTimer
;
/* for LED blinking */
int
LedsOn
;
SK_PNMI_STRUCT_DATA
PnmiStruct
;
/* structure to get all Pnmi-Data */
SK_PNMI_STRUCT_DATA
PnmiStruct
;
/* structure to get all Pnmi-Data */
int
RlmtMode
;
/* link check mode to set */
int
RlmtMode
;
/* link check mode to set */
int
RlmtNets
;
/* Number of nets */
int
RlmtNets
;
/* Number of nets */
...
@@ -395,7 +396,7 @@ struct s_AC {
...
@@ -395,7 +396,7 @@ struct s_AC {
SK_U32
PciDevId
;
/* pci device id */
SK_U32
PciDevId
;
/* pci device id */
struct
SK_NET_DEVICE
*
dev
[
2
];
/* pointer to device struct */
struct
SK_NET_DEVICE
*
dev
[
2
];
/* pointer to device struct */
char
Name
[
30
];
/* driver name */
char
Name
[
30
];
/* driver name */
struct
SK_NET_DEVICE
*
Next
;
/* link all devices (for clearing) */
int
RxBufSize
;
/* length of receive buffers */
int
RxBufSize
;
/* length of receive buffers */
struct
net_device_stats
stats
;
/* linux 'netstat -i' statistics */
struct
net_device_stats
stats
;
/* linux 'netstat -i' statistics */
int
Index
;
/* internal board index number */
int
Index
;
/* internal board index number */
...
...
drivers/net/sk98lin/skaddr.c
View file @
05c5f695
...
@@ -79,7 +79,7 @@ extern "C" {
...
@@ -79,7 +79,7 @@ extern "C" {
/* 64-bit hash values with all bits set. */
/* 64-bit hash values with all bits set. */
SK_U16
OnesHash
[
4
]
=
{
0xFFFF
,
0xFFFF
,
0xFFFF
,
0xFFFF
};
static
const
SK_U16
OnesHash
[
4
]
=
{
0xFFFF
,
0xFFFF
,
0xFFFF
,
0xFFFF
};
/* local variables ************************************************************/
/* local variables ************************************************************/
...
...
drivers/net/sk98lin/skethtool.c
0 → 100644
View file @
05c5f695
/******************************************************************************
*
* Name: skethtool.c
* Project: GEnesis, PCI Gigabit Ethernet Adapter
* Version: $Revision: 1.7 $
* Date: $Date: 2004/09/29 13:32:07 $
* Purpose: All functions regarding ethtool handling
*
******************************************************************************/
/******************************************************************************
*
* (C)Copyright 1998-2002 SysKonnect GmbH.
* (C)Copyright 2002-2004 Marvell.
*
* Driver for Marvell Yukon/2 chipset and SysKonnect Gigabit Ethernet
* Server Adapters.
*
* Author: Ralph Roesler (rroesler@syskonnect.de)
* Mirko Lindner (mlindner@syskonnect.de)
*
* Address all question to: linux@syskonnect.de
*
* The technical manual for the adapters is available from SysKonnect's
* web pages: www.syskonnect.com
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* The information in this file is provided "AS IS" without warranty.
*
*****************************************************************************/
#include "h/skdrv1st.h"
#include "h/skdrv2nd.h"
#include "h/skversion.h"
#include <linux/ethtool.h>
#include <linux/timer.h>
#include <linux/delay.h>
/******************************************************************************
*
* Defines
*
*****************************************************************************/
#define SUPP_COPPER_ALL (SUPPORTED_10baseT_Half | SUPPORTED_10baseT_Full | \
SUPPORTED_100baseT_Half | SUPPORTED_100baseT_Full | \
SUPPORTED_1000baseT_Half| SUPPORTED_1000baseT_Full| \
SUPPORTED_TP)
#define ADV_COPPER_ALL (ADVERTISED_10baseT_Half | ADVERTISED_10baseT_Full | \
ADVERTISED_100baseT_Half | ADVERTISED_100baseT_Full | \
ADVERTISED_1000baseT_Half| ADVERTISED_1000baseT_Full| \
ADVERTISED_TP)
#define SUPP_FIBRE_ALL (SUPPORTED_1000baseT_Full | \
SUPPORTED_FIBRE | \
SUPPORTED_Autoneg)
#define ADV_FIBRE_ALL (ADVERTISED_1000baseT_Full | \
ADVERTISED_FIBRE | \
ADVERTISED_Autoneg)
/******************************************************************************
*
* Local Functions
*
*****************************************************************************/
/*****************************************************************************
*
* getSettings - retrieves the current settings of the selected adapter
*
* Description:
* The current configuration of the selected adapter is returned.
* This configuration involves a)speed, b)duplex and c)autoneg plus
* a number of other variables.
*
* Returns: always 0
*
*/
static
int
getSettings
(
struct
net_device
*
dev
,
struct
ethtool_cmd
*
ecmd
)
{
const
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
int
port
=
pNet
->
PortNr
;
const
SK_AC
*
pAC
=
pNet
->
pAC
;
const
SK_GEPORT
*
pPort
=
&
pAC
->
GIni
.
GP
[
port
];
static
int
DuplexAutoNegConfMap
[
9
][
3
]
=
{
{
-
1
,
-
1
,
-
1
},
{
0
,
-
1
,
-
1
},
{
SK_LMODE_HALF
,
DUPLEX_HALF
,
AUTONEG_DISABLE
},
{
SK_LMODE_FULL
,
DUPLEX_FULL
,
AUTONEG_DISABLE
},
{
SK_LMODE_AUTOHALF
,
DUPLEX_HALF
,
AUTONEG_ENABLE
},
{
SK_LMODE_AUTOFULL
,
DUPLEX_FULL
,
AUTONEG_ENABLE
},
{
SK_LMODE_AUTOBOTH
,
DUPLEX_FULL
,
AUTONEG_ENABLE
},
{
SK_LMODE_AUTOSENSE
,
-
1
,
-
1
},
{
SK_LMODE_INDETERMINATED
,
-
1
,
-
1
}
};
static
int
SpeedConfMap
[
6
][
2
]
=
{
{
0
,
-
1
},
{
SK_LSPEED_AUTO
,
-
1
},
{
SK_LSPEED_10MBPS
,
SPEED_10
},
{
SK_LSPEED_100MBPS
,
SPEED_100
},
{
SK_LSPEED_1000MBPS
,
SPEED_1000
},
{
SK_LSPEED_INDETERMINATED
,
-
1
}
};
static
int
AdvSpeedMap
[
6
][
2
]
=
{
{
0
,
-
1
},
{
SK_LSPEED_AUTO
,
-
1
},
{
SK_LSPEED_10MBPS
,
ADVERTISED_10baseT_Half
|
ADVERTISED_10baseT_Full
},
{
SK_LSPEED_100MBPS
,
ADVERTISED_100baseT_Half
|
ADVERTISED_100baseT_Full
},
{
SK_LSPEED_1000MBPS
,
ADVERTISED_1000baseT_Half
|
ADVERTISED_1000baseT_Full
},
{
SK_LSPEED_INDETERMINATED
,
-
1
}
};
ecmd
->
phy_address
=
port
;
ecmd
->
speed
=
SpeedConfMap
[
pPort
->
PLinkSpeedUsed
][
1
];
ecmd
->
duplex
=
DuplexAutoNegConfMap
[
pPort
->
PLinkModeStatus
][
1
];
ecmd
->
autoneg
=
DuplexAutoNegConfMap
[
pPort
->
PLinkModeStatus
][
2
];
ecmd
->
transceiver
=
XCVR_INTERNAL
;
if
(
pAC
->
GIni
.
GICopperType
)
{
ecmd
->
port
=
PORT_TP
;
ecmd
->
supported
=
(
SUPP_COPPER_ALL
|
SUPPORTED_Autoneg
);
if
(
pAC
->
GIni
.
GIGenesis
)
{
ecmd
->
supported
&=
~
(
SUPPORTED_10baseT_Half
);
ecmd
->
supported
&=
~
(
SUPPORTED_10baseT_Full
);
ecmd
->
supported
&=
~
(
SUPPORTED_100baseT_Half
);
ecmd
->
supported
&=
~
(
SUPPORTED_100baseT_Full
);
}
else
{
if
(
pAC
->
GIni
.
GIChipId
==
CHIP_ID_YUKON
)
{
ecmd
->
supported
&=
~
(
SUPPORTED_1000baseT_Half
);
}
#ifdef CHIP_ID_YUKON_FE
if
(
pAC
->
GIni
.
GIChipId
==
CHIP_ID_YUKON_FE
)
{
ecmd
->
supported
&=
~
(
SUPPORTED_1000baseT_Half
);
ecmd
->
supported
&=
~
(
SUPPORTED_1000baseT_Full
);
}
#endif
}
if
(
pAC
->
GIni
.
GP
[
0
].
PLinkSpeed
!=
SK_LSPEED_AUTO
)
{
ecmd
->
advertising
=
AdvSpeedMap
[
pPort
->
PLinkSpeed
][
1
];
if
(
pAC
->
GIni
.
GIChipId
==
CHIP_ID_YUKON
)
{
ecmd
->
advertising
&=
~
(
SUPPORTED_1000baseT_Half
);
}
}
else
{
ecmd
->
advertising
=
ecmd
->
supported
;
}
if
(
ecmd
->
autoneg
==
AUTONEG_ENABLE
)
ecmd
->
advertising
|=
ADVERTISED_Autoneg
;
}
else
{
ecmd
->
port
=
PORT_FIBRE
;
ecmd
->
supported
=
SUPP_FIBRE_ALL
;
ecmd
->
advertising
=
ADV_FIBRE_ALL
;
}
return
0
;
}
/*
* MIB infrastructure uses instance value starting at 1
* based on board and port.
*/
static
inline
u32
pnmiInstance
(
const
DEV_NET
*
pNet
)
{
return
1
+
(
pNet
->
pAC
->
RlmtNets
==
2
)
+
pNet
->
PortNr
;
}
/*****************************************************************************
*
* setSettings - configures the settings of a selected adapter
*
* Description:
* Possible settings that may be altered are a)speed, b)duplex or
* c)autonegotiation.
*
* Returns:
* 0: everything fine, no error
* <0: the return value is the error code of the failure
*/
static
int
setSettings
(
struct
net_device
*
dev
,
struct
ethtool_cmd
*
ecmd
)
{
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
SK_AC
*
pAC
=
pNet
->
pAC
;
u32
instance
;
char
buf
[
4
];
int
len
=
1
;
if
(
ecmd
->
speed
!=
SPEED_10
&&
ecmd
->
speed
!=
SPEED_100
&&
ecmd
->
speed
!=
SPEED_1000
)
return
-
EINVAL
;
if
(
ecmd
->
duplex
!=
DUPLEX_HALF
&&
ecmd
->
duplex
!=
DUPLEX_FULL
)
return
-
EINVAL
;
if
(
ecmd
->
autoneg
!=
AUTONEG_DISABLE
&&
ecmd
->
autoneg
!=
AUTONEG_ENABLE
)
return
-
EINVAL
;
if
(
ecmd
->
autoneg
==
AUTONEG_DISABLE
)
*
buf
=
(
ecmd
->
duplex
==
DUPLEX_FULL
)
?
SK_LMODE_FULL
:
SK_LMODE_HALF
;
else
*
buf
=
(
ecmd
->
duplex
==
DUPLEX_FULL
)
?
SK_LMODE_AUTOFULL
:
SK_LMODE_AUTOHALF
;
instance
=
pnmiInstance
(
pNet
);
if
(
SkPnmiSetVar
(
pAC
,
pAC
->
IoBase
,
OID_SKGE_LINK_MODE
,
&
buf
,
&
len
,
instance
,
pNet
->
NetNr
)
!=
SK_PNMI_ERR_OK
)
return
-
EINVAL
;
switch
(
ecmd
->
speed
)
{
case
SPEED_1000
:
*
buf
=
SK_LSPEED_1000MBPS
;
break
;
case
SPEED_100
:
*
buf
=
SK_LSPEED_100MBPS
;
break
;
case
SPEED_10
:
*
buf
=
SK_LSPEED_10MBPS
;
}
if
(
SkPnmiSetVar
(
pAC
,
pAC
->
IoBase
,
OID_SKGE_SPEED_MODE
,
&
buf
,
&
len
,
instance
,
pNet
->
NetNr
)
!=
SK_PNMI_ERR_OK
)
return
-
EINVAL
;
return
0
;
}
/*****************************************************************************
*
* getDriverInfo - returns generic driver and adapter information
*
* Description:
* Generic driver information is returned via this function, such as
* the name of the driver, its version and and firmware version.
* In addition to this, the location of the selected adapter is
* returned as a bus info string (e.g. '01:05.0').
*
* Returns: N/A
*
*/
static
void
getDriverInfo
(
struct
net_device
*
dev
,
struct
ethtool_drvinfo
*
info
)
{
const
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
const
SK_AC
*
pAC
=
pNet
->
pAC
;
char
vers
[
32
];
snprintf
(
vers
,
sizeof
(
vers
)
-
1
,
VER_STRING
"(v%d.%d)"
,
(
pAC
->
GIni
.
GIPciHwRev
>>
4
)
&
0xf
,
pAC
->
GIni
.
GIPciHwRev
&
0xf
);
strlcpy
(
info
->
driver
,
DRIVER_FILE_NAME
,
sizeof
(
info
->
driver
));
strcpy
(
info
->
version
,
vers
);
strcpy
(
info
->
fw_version
,
"N/A"
);
strlcpy
(
info
->
bus_info
,
pAC
->
PciDev
->
slot_name
,
ETHTOOL_BUSINFO_LEN
);
}
/*
* Ethtool statistics support.
*/
static
const
char
StringsStats
[][
ETH_GSTRING_LEN
]
=
{
"rx_packets"
,
"tx_packets"
,
"rx_bytes"
,
"tx_bytes"
,
"rx_errors"
,
"tx_errors"
,
"rx_dropped"
,
"tx_dropped"
,
"multicasts"
,
"collisions"
,
"rx_length_errors"
,
"rx_buffer_overflow_errors"
,
"rx_crc_errors"
,
"rx_frame_errors"
,
"rx_too_short_errors"
,
"rx_too_long_errors"
,
"rx_carrier_extension_errors"
,
"rx_symbol_errors"
,
"rx_llc_mac_size_errors"
,
"rx_carrier_errors"
,
"rx_jabber_errors"
,
"rx_missed_errors"
,
"tx_abort_collision_errors"
,
"tx_carrier_errors"
,
"tx_buffer_underrun_errors"
,
"tx_heartbeat_errors"
,
"tx_window_errors"
,
};
static
int
getStatsCount
(
struct
net_device
*
dev
)
{
return
ARRAY_SIZE
(
StringsStats
);
}
static
void
getStrings
(
struct
net_device
*
dev
,
u32
stringset
,
u8
*
data
)
{
switch
(
stringset
)
{
case
ETH_SS_STATS
:
memcpy
(
data
,
*
StringsStats
,
sizeof
(
StringsStats
));
break
;
}
}
static
void
getEthtoolStats
(
struct
net_device
*
dev
,
struct
ethtool_stats
*
stats
,
u64
*
data
)
{
const
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
const
SK_AC
*
pAC
=
pNet
->
pAC
;
const
SK_PNMI_STRUCT_DATA
*
pPnmiStruct
=
&
pAC
->
PnmiStruct
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxOkCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxOkCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxOctetsOkCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxOctetsOkCts
;
*
data
++
=
pPnmiStruct
->
InErrorsCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxSingleCollisionCts
;
*
data
++
=
pPnmiStruct
->
RxNoBufCts
;
*
data
++
=
pPnmiStruct
->
TxNoBufCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxMulticastOkCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxSingleCollisionCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxRuntCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxFifoOverflowCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxFcsCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxFramingCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxShortsCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxTooLongCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxCextCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxSymbolCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxIRLengthCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxCarrierCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxJabberCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatRxMissedCts
;
*
data
++
=
pAC
->
stats
.
tx_aborted_errors
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxCarrierCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxFifoUnderrunCts
;
*
data
++
=
pPnmiStruct
->
Stat
[
0
].
StatTxCarrierCts
;
*
data
++
=
pAC
->
stats
.
tx_window_errors
;
}
/*****************************************************************************
*
* toggleLeds - Changes the LED state of an adapter
*
* Description:
* This function changes the current state of all LEDs of an adapter so
* that it can be located by a user.
*
* Returns: N/A
*
*/
static
void
toggleLeds
(
DEV_NET
*
pNet
,
int
on
)
{
SK_AC
*
pAC
=
pNet
->
pAC
;
int
port
=
pNet
->
PortNr
;
void
__iomem
*
io
=
pAC
->
IoBase
;
if
(
pAC
->
GIni
.
GIGenesis
)
{
SK_OUT8
(
io
,
MR_ADDR
(
port
,
LNK_LED_REG
),
on
?
SK_LNK_ON
:
SK_LNK_OFF
);
SkGeYellowLED
(
pAC
,
io
,
on
?
(
LED_ON
>>
1
)
:
(
LED_OFF
>>
1
));
SkGeXmitLED
(
pAC
,
io
,
MR_ADDR
(
port
,
RX_LED_INI
),
on
?
SK_LED_TST
:
SK_LED_DIS
);
if
(
pAC
->
GIni
.
GP
[
port
].
PhyType
==
SK_PHY_BCOM
)
SkXmPhyWrite
(
pAC
,
io
,
port
,
PHY_BCOM_P_EXT_CTRL
,
on
?
PHY_B_PEC_LED_ON
:
PHY_B_PEC_LED_OFF
);
else
if
(
pAC
->
GIni
.
GP
[
port
].
PhyType
==
SK_PHY_LONE
)
SkXmPhyWrite
(
pAC
,
io
,
port
,
PHY_LONE_LED_CFG
,
on
?
0x0800
:
PHY_L_LC_LEDT
);
else
SkGeXmitLED
(
pAC
,
io
,
MR_ADDR
(
port
,
TX_LED_INI
),
on
?
SK_LED_TST
:
SK_LED_DIS
);
}
else
{
const
u16
YukLedOn
=
(
PHY_M_LED_MO_DUP
(
MO_LED_ON
)
|
PHY_M_LED_MO_10
(
MO_LED_ON
)
|
PHY_M_LED_MO_100
(
MO_LED_ON
)
|
PHY_M_LED_MO_1000
(
MO_LED_ON
)
|
PHY_M_LED_MO_RX
(
MO_LED_ON
));
const
u16
YukLedOff
=
(
PHY_M_LED_MO_DUP
(
MO_LED_OFF
)
|
PHY_M_LED_MO_10
(
MO_LED_OFF
)
|
PHY_M_LED_MO_100
(
MO_LED_OFF
)
|
PHY_M_LED_MO_1000
(
MO_LED_OFF
)
|
PHY_M_LED_MO_RX
(
MO_LED_OFF
));
SkGmPhyWrite
(
pAC
,
io
,
port
,
PHY_MARV_LED_CTRL
,
0
);
SkGmPhyWrite
(
pAC
,
io
,
port
,
PHY_MARV_LED_OVER
,
on
?
YukLedOn
:
YukLedOff
);
}
}
/*****************************************************************************
*
* skGeBlinkTimer - Changes the LED state of an adapter
*
* Description:
* This function changes the current state of all LEDs of an adapter so
* that it can be located by a user. If the requested time interval for
* this test has elapsed, this function cleans up everything that was
* temporarily setup during the locate NIC test. This involves of course
* also closing or opening any adapter so that the initial board state
* is recovered.
*
* Returns: N/A
*
*/
void
SkGeBlinkTimer
(
unsigned
long
data
)
{
struct
net_device
*
dev
=
(
struct
net_device
*
)
data
;
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
SK_AC
*
pAC
=
pNet
->
pAC
;
toggleLeds
(
pNet
,
pAC
->
LedsOn
);
pAC
->
LedsOn
=
!
pAC
->
LedsOn
;
mod_timer
(
&
pAC
->
BlinkTimer
,
jiffies
+
HZ
/
4
);
}
/*****************************************************************************
*
* locateDevice - start the locate NIC feature of the elected adapter
*
* Description:
* This function is used if the user want to locate a particular NIC.
* All LEDs are regularly switched on and off, so the NIC can easily
* be identified.
*
* Returns:
* ==0: everything fine, no error, locateNIC test was started
* !=0: one locateNIC test runs already
*
*/
static
int
locateDevice
(
struct
net_device
*
dev
,
u32
data
)
{
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
SK_AC
*
pAC
=
pNet
->
pAC
;
if
(
!
data
||
data
>
(
u32
)(
MAX_SCHEDULE_TIMEOUT
/
HZ
))
data
=
(
u32
)(
MAX_SCHEDULE_TIMEOUT
/
HZ
);
/* start blinking */
pAC
->
LedsOn
=
0
;
mod_timer
(
&
pAC
->
BlinkTimer
,
jiffies
);
msleep_interruptible
(
data
*
1000
);
set_current_state
(
TASK_INTERRUPTIBLE
);
schedule_timeout
(
data
*
HZ
);
del_timer_sync
(
&
pAC
->
BlinkTimer
);
toggleLeds
(
pNet
,
0
);
return
0
;
}
/*****************************************************************************
*
* getPauseParams - retrieves the pause parameters
*
* Description:
* All current pause parameters of a selected adapter are placed
* in the passed ethtool_pauseparam structure and are returned.
*
* Returns: N/A
*
*/
static
void
getPauseParams
(
struct
net_device
*
dev
,
struct
ethtool_pauseparam
*
epause
)
{
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
SK_AC
*
pAC
=
pNet
->
pAC
;
SK_GEPORT
*
pPort
=
&
pAC
->
GIni
.
GP
[
pNet
->
PortNr
];
epause
->
rx_pause
=
(
pPort
->
PFlowCtrlMode
==
SK_FLOW_MODE_SYMMETRIC
)
||
(
pPort
->
PFlowCtrlMode
==
SK_FLOW_MODE_SYM_OR_REM
);
epause
->
tx_pause
=
epause
->
rx_pause
||
(
pPort
->
PFlowCtrlMode
==
SK_FLOW_MODE_LOC_SEND
);
epause
->
autoneg
=
epause
->
rx_pause
||
epause
->
tx_pause
;
}
/*****************************************************************************
*
* setPauseParams - configures the pause parameters of an adapter
*
* Description:
* This function sets the Rx or Tx pause parameters
*
* Returns:
* ==0: everything fine, no error
* !=0: the return value is the error code of the failure
*/
static
int
setPauseParams
(
struct
net_device
*
dev
,
struct
ethtool_pauseparam
*
epause
)
{
DEV_NET
*
pNet
=
netdev_priv
(
dev
);
SK_AC
*
pAC
=
pNet
->
pAC
;
SK_GEPORT
*
pPort
=
&
pAC
->
GIni
.
GP
[
pNet
->
PortNr
];
u32
instance
=
pnmiInstance
(
pNet
);
struct
ethtool_pauseparam
old
;
u8
oldspeed
=
pPort
->
PLinkSpeedUsed
;
char
buf
[
4
];
int
len
=
1
;
int
ret
;
/*
** we have to determine the current settings to see if
** the operator requested any modification of the flow
** control parameters...
*/
getPauseParams
(
dev
,
&
old
);
/*
** perform modifications regarding the changes
** requested by the operator
*/
if
(
epause
->
autoneg
!=
old
.
autoneg
)
*
buf
=
epause
->
autoneg
?
SK_FLOW_MODE_NONE
:
SK_FLOW_MODE_SYMMETRIC
;
else
{
if
(
epause
->
rx_pause
&&
epause
->
tx_pause
)
*
buf
=
SK_FLOW_MODE_SYMMETRIC
;
else
if
(
epause
->
rx_pause
&&
!
epause
->
tx_pause
)
*
buf
=
SK_FLOW_MODE_SYM_OR_REM
;
else
if
(
!
epause
->
rx_pause
&&
epause
->
tx_pause
)
*
buf
=
SK_FLOW_MODE_LOC_SEND
;
else
*
buf
=
SK_FLOW_MODE_NONE
;
}
ret
=
SkPnmiSetVar
(
pAC
,
pAC
->
IoBase
,
OID_SKGE_FLOWCTRL_MODE
,
&
buf
,
&
len
,
instance
,
pNet
->
NetNr
);
if
(
ret
!=
SK_PNMI_ERR_OK
)
{
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_CTRL
,
(
"ethtool (sk98lin): error changing rx/tx pause (%i)
\n
"
,
ret
));
goto
err
;
}
/*
** It may be that autoneg has been disabled! Therefore
** set the speed to the previously used value...
*/
if
(
!
epause
->
autoneg
)
{
len
=
1
;
ret
=
SkPnmiSetVar
(
pAC
,
pAC
->
IoBase
,
OID_SKGE_SPEED_MODE
,
&
oldspeed
,
&
len
,
instance
,
pNet
->
NetNr
);
if
(
ret
!=
SK_PNMI_ERR_OK
)
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_CTRL
,
(
"ethtool (sk98lin): error setting speed (%i)
\n
"
,
ret
));
}
err:
return
ret
?
-
EIO
:
0
;
}
struct
ethtool_ops
SkGeEthtoolOps
=
{
.
get_settings
=
getSettings
,
.
set_settings
=
setSettings
,
.
get_drvinfo
=
getDriverInfo
,
.
get_strings
=
getStrings
,
.
get_stats_count
=
getStatsCount
,
.
get_ethtool_stats
=
getEthtoolStats
,
.
phys_id
=
locateDevice
,
.
get_pauseparam
=
getPauseParams
,
.
set_pauseparam
=
setPauseParams
,
};
drivers/net/sk98lin/skge.c
View file @
05c5f695
...
@@ -109,6 +109,7 @@
...
@@ -109,6 +109,7 @@
#include "h/skversion.h"
#include "h/skversion.h"
#include <linux/module.h>
#include <linux/module.h>
#include <linux/moduleparam.h>
#include <linux/init.h>
#include <linux/init.h>
#include <linux/proc_fs.h>
#include <linux/proc_fs.h>
...
@@ -233,17 +234,33 @@ static int SkDrvDeInitAdapter(SK_AC *pAC, int devNbr);
...
@@ -233,17 +234,33 @@ static int SkDrvDeInitAdapter(SK_AC *pAC, int devNbr);
* Extern Function Prototypes
* Extern Function Prototypes
*
*
******************************************************************************/
******************************************************************************/
static
const
char
SKRootName
[]
=
"sk98lin"
;
#ifdef CONFIG_PROC_FS
static
const
char
SK_Root_Dir_entry
[]
=
"sk98lin"
;
static
struct
proc_dir_entry
*
pSkRootDir
;
static
struct
proc_dir_entry
*
pSkRootDir
;
extern
struct
file_operations
sk_proc_fops
;
extern
struct
file_operations
sk_proc_fops
;
#endif
static
inline
void
SkGeProcCreate
(
struct
net_device
*
dev
)
{
struct
proc_dir_entry
*
pe
;
if
(
pSkRootDir
&&
(
pe
=
create_proc_entry
(
dev
->
name
,
S_IRUGO
,
pSkRootDir
)))
{
pe
->
proc_fops
=
&
sk_proc_fops
;
pe
->
data
=
dev
;
pe
->
owner
=
THIS_MODULE
;
}
}
static
inline
void
SkGeProcRemove
(
struct
net_device
*
dev
)
{
if
(
pSkRootDir
)
remove_proc_entry
(
dev
->
name
,
pSkRootDir
);
}
extern
void
SkDimEnableModerationIfNeeded
(
SK_AC
*
pAC
);
extern
void
SkDimEnableModerationIfNeeded
(
SK_AC
*
pAC
);
extern
void
SkDimDisplayModerationSettings
(
SK_AC
*
pAC
);
extern
void
SkDimDisplayModerationSettings
(
SK_AC
*
pAC
);
extern
void
SkDimStartModerationTimer
(
SK_AC
*
pAC
);
extern
void
SkDimStartModerationTimer
(
SK_AC
*
pAC
);
extern
void
SkDimModerate
(
SK_AC
*
pAC
);
extern
void
SkDimModerate
(
SK_AC
*
pAC
);
extern
void
SkGeBlinkTimer
(
unsigned
long
data
);
#ifdef DEBUG
#ifdef DEBUG
static
void
DumpMsg
(
struct
sk_buff
*
,
char
*
);
static
void
DumpMsg
(
struct
sk_buff
*
,
char
*
);
...
@@ -252,8 +269,8 @@ static void DumpLong(char*, int);
...
@@ -252,8 +269,8 @@ static void DumpLong(char*, int);
#endif
#endif
/* global variables *********************************************************/
/* global variables *********************************************************/
struct
SK_NET_DEVICE
*
SkGeRootDev
=
NULL
;
static
SK_BOOL
DoPrintInterfaceChange
=
SK_TRUE
;
static
SK_BOOL
DoPrintInterfaceChange
=
SK_TRUE
;
extern
struct
ethtool_ops
SkGeEthtoolOps
;
/* local variables **********************************************************/
/* local variables **********************************************************/
static
uintptr_t
TxQueueAddr
[
SK_MAX_MACS
][
2
]
=
{{
0x680
,
0x600
},{
0x780
,
0x700
}};
static
uintptr_t
TxQueueAddr
[
SK_MAX_MACS
][
2
]
=
{{
0x680
,
0x600
},{
0x780
,
0x700
}};
...
@@ -337,22 +354,20 @@ SK_U32 AllocFlag;
...
@@ -337,22 +354,20 @@ SK_U32 AllocFlag;
DEV_NET
*
pNet
;
DEV_NET
*
pNet
;
SK_AC
*
pAC
;
SK_AC
*
pAC
;
if
(
dev
->
priv
)
{
pNet
=
netdev_priv
(
dev
);
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
AllocFlag
=
pAC
->
AllocFlag
;
AllocFlag
=
pAC
->
AllocFlag
;
if
(
pAC
->
PciDev
)
{
if
(
pAC
->
PciDev
)
{
pci_release_regions
(
pAC
->
PciDev
);
pci_release_regions
(
pAC
->
PciDev
);
}
}
if
(
AllocFlag
&
SK_ALLOC_IRQ
)
{
if
(
AllocFlag
&
SK_ALLOC_IRQ
)
{
free_irq
(
dev
->
irq
,
dev
);
free_irq
(
dev
->
irq
,
dev
);
}
}
if
(
pAC
->
IoBase
)
{
if
(
pAC
->
IoBase
)
{
iounmap
(
pAC
->
IoBase
);
iounmap
(
pAC
->
IoBase
);
}
}
if
(
pAC
->
pDescrMem
)
{
if
(
pAC
->
pDescrMem
)
{
BoardFreeMem
(
pAC
);
BoardFreeMem
(
pAC
);
}
}
}
}
/* FreeResources */
}
/* FreeResources */
...
@@ -360,26 +375,6 @@ SK_AC *pAC;
...
@@ -360,26 +375,6 @@ SK_AC *pAC;
MODULE_AUTHOR
(
"Mirko Lindner <mlindner@syskonnect.de>"
);
MODULE_AUTHOR
(
"Mirko Lindner <mlindner@syskonnect.de>"
);
MODULE_DESCRIPTION
(
"SysKonnect SK-NET Gigabit Ethernet SK-98xx driver"
);
MODULE_DESCRIPTION
(
"SysKonnect SK-NET Gigabit Ethernet SK-98xx driver"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_LICENSE
(
"GPL"
);
MODULE_PARM
(
Speed_A
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
Speed_B
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
AutoNeg_A
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
AutoNeg_B
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
DupCap_A
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
DupCap_B
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
FlowCtrl_A
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
FlowCtrl_B
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
Role_A
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
Role_B
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
ConType
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
PrefPort
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
RlmtMode
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
/* used for interrupt moderation */
MODULE_PARM
(
IntsPerSec
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"i"
);
MODULE_PARM
(
Moderation
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
Stats
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
ModerationMask
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
MODULE_PARM
(
AutoSizing
,
"1-"
__MODULE_STRING
(
SK_MAX_CARD_PARAM
)
"s"
);
#ifdef LINK_SPEED_A
#ifdef LINK_SPEED_A
static
char
*
Speed_A
[
SK_MAX_CARD_PARAM
]
=
LINK_SPEED
;
static
char
*
Speed_A
[
SK_MAX_CARD_PARAM
]
=
LINK_SPEED
;
...
@@ -465,6 +460,26 @@ static char *ModerationMask[SK_MAX_CARD_PARAM];
...
@@ -465,6 +460,26 @@ static char *ModerationMask[SK_MAX_CARD_PARAM];
static
char
*
AutoSizing
[
SK_MAX_CARD_PARAM
];
static
char
*
AutoSizing
[
SK_MAX_CARD_PARAM
];
static
char
*
Stats
[
SK_MAX_CARD_PARAM
];
static
char
*
Stats
[
SK_MAX_CARD_PARAM
];
module_param_array
(
Speed_A
,
charp
,
NULL
,
0
);
module_param_array
(
Speed_B
,
charp
,
NULL
,
0
);
module_param_array
(
AutoNeg_A
,
charp
,
NULL
,
0
);
module_param_array
(
AutoNeg_B
,
charp
,
NULL
,
0
);
module_param_array
(
DupCap_A
,
charp
,
NULL
,
0
);
module_param_array
(
DupCap_B
,
charp
,
NULL
,
0
);
module_param_array
(
FlowCtrl_A
,
charp
,
NULL
,
0
);
module_param_array
(
FlowCtrl_B
,
charp
,
NULL
,
0
);
module_param_array
(
Role_A
,
charp
,
NULL
,
0
);
module_param_array
(
Role_B
,
charp
,
NULL
,
0
);
module_param_array
(
ConType
,
charp
,
NULL
,
0
);
module_param_array
(
PrefPort
,
charp
,
NULL
,
0
);
module_param_array
(
RlmtMode
,
charp
,
NULL
,
0
);
/* used for interrupt moderation */
module_param_array
(
IntsPerSec
,
int
,
NULL
,
0
);
module_param_array
(
Moderation
,
charp
,
NULL
,
0
);
module_param_array
(
Stats
,
charp
,
NULL
,
0
);
module_param_array
(
ModerationMask
,
charp
,
NULL
,
0
);
module_param_array
(
AutoSizing
,
charp
,
NULL
,
0
);
/*****************************************************************************
/*****************************************************************************
*
*
* SkGeBoardInit - do level 0 and 1 initialization
* SkGeBoardInit - do level 0 and 1 initialization
...
@@ -503,6 +518,11 @@ SK_BOOL DualNet;
...
@@ -503,6 +518,11 @@ SK_BOOL DualNet;
}
}
spin_lock_init
(
&
pAC
->
SlowPathLock
);
spin_lock_init
(
&
pAC
->
SlowPathLock
);
/* setup phy_id blink timer */
pAC
->
BlinkTimer
.
function
=
SkGeBlinkTimer
;
pAC
->
BlinkTimer
.
data
=
(
unsigned
long
)
dev
;
init_timer
(
&
pAC
->
BlinkTimer
);
/* level 0 init common modules here */
/* level 0 init common modules here */
spin_lock_irqsave
(
&
pAC
->
SlowPathLock
,
Flags
);
spin_lock_irqsave
(
&
pAC
->
SlowPathLock
,
Flags
);
...
@@ -601,12 +621,6 @@ SK_BOOL DualNet;
...
@@ -601,12 +621,6 @@ SK_BOOL DualNet;
return
(
-
EAGAIN
);
return
(
-
EAGAIN
);
}
}
/*
* Register the device here
*/
pAC
->
Next
=
SkGeRootDev
;
SkGeRootDev
=
dev
;
return
(
0
);
return
(
0
);
}
/* SkGeBoardInit */
}
/* SkGeBoardInit */
...
@@ -887,7 +901,7 @@ DEV_NET *pNet;
...
@@ -887,7 +901,7 @@ DEV_NET *pNet;
SK_AC
*
pAC
;
SK_AC
*
pAC
;
SK_U32
IntSrc
;
/* interrupts source register contents */
SK_U32
IntSrc
;
/* interrupts source register contents */
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
/*
/*
...
@@ -1036,7 +1050,7 @@ DEV_NET *pNet;
...
@@ -1036,7 +1050,7 @@ DEV_NET *pNet;
SK_AC
*
pAC
;
SK_AC
*
pAC
;
SK_U32
IntSrc
;
/* interrupts source register contents */
SK_U32
IntSrc
;
/* interrupts source register contents */
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
/*
/*
...
@@ -1126,6 +1140,24 @@ SK_U32 IntSrc; /* interrupts source register contents */
...
@@ -1126,6 +1140,24 @@ SK_U32 IntSrc; /* interrupts source register contents */
return
SkIsrRetHandled
;
return
SkIsrRetHandled
;
}
/* SkGeIsrOnePort */
}
/* SkGeIsrOnePort */
#ifdef CONFIG_NET_POLL_CONTROLLER
/****************************************************************************
*
* SkGePollController - polling receive, for netconsole
*
* Description:
* Polling receive - used by netconsole and other diagnostic tools
* to allow network i/o with interrupts disabled.
*
* Returns: N/A
*/
static
void
SkGePollController
(
struct
net_device
*
dev
)
{
disable_irq
(
dev
->
irq
);
SkGeIsr
(
dev
->
irq
,
dev
,
NULL
);
enable_irq
(
dev
->
irq
);
}
#endif
/****************************************************************************
/****************************************************************************
*
*
...
@@ -1152,7 +1184,7 @@ struct SK_NET_DEVICE *dev)
...
@@ -1152,7 +1184,7 @@ struct SK_NET_DEVICE *dev)
int
i
;
int
i
;
SK_EVPARA
EvPara
;
/* an event parameter union */
SK_EVPARA
EvPara
;
/* an event parameter union */
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
...
@@ -1166,10 +1198,6 @@ struct SK_NET_DEVICE *dev)
...
@@ -1166,10 +1198,6 @@ struct SK_NET_DEVICE *dev)
}
}
#endif
#endif
if
(
!
try_module_get
(
THIS_MODULE
))
{
return
(
-
1
);
/* increase of usage count not possible */
}
/* Set blink mode */
/* Set blink mode */
if
((
pAC
->
PciDev
->
vendor
==
0x1186
)
||
(
pAC
->
PciDev
->
vendor
==
0x11ab
))
if
((
pAC
->
PciDev
->
vendor
==
0x1186
)
||
(
pAC
->
PciDev
->
vendor
==
0x11ab
))
pAC
->
GIni
.
GILedBlinkCtrl
=
OEM_CONFIG_VALUE
;
pAC
->
GIni
.
GILedBlinkCtrl
=
OEM_CONFIG_VALUE
;
...
@@ -1177,7 +1205,6 @@ struct SK_NET_DEVICE *dev)
...
@@ -1177,7 +1205,6 @@ struct SK_NET_DEVICE *dev)
if
(
pAC
->
BoardLevel
==
SK_INIT_DATA
)
{
if
(
pAC
->
BoardLevel
==
SK_INIT_DATA
)
{
/* level 1 init common modules here */
/* level 1 init common modules here */
if
(
SkGeInit
(
pAC
,
pAC
->
IoBase
,
SK_INIT_IO
)
!=
0
)
{
if
(
SkGeInit
(
pAC
,
pAC
->
IoBase
,
SK_INIT_IO
)
!=
0
)
{
module_put
(
THIS_MODULE
);
/* decrease usage count */
printk
(
"%s: HWInit (1) failed.
\n
"
,
pAC
->
dev
[
pNet
->
PortNr
]
->
name
);
printk
(
"%s: HWInit (1) failed.
\n
"
,
pAC
->
dev
[
pNet
->
PortNr
]
->
name
);
return
(
-
1
);
return
(
-
1
);
}
}
...
@@ -1193,7 +1220,6 @@ struct SK_NET_DEVICE *dev)
...
@@ -1193,7 +1220,6 @@ struct SK_NET_DEVICE *dev)
if
(
pAC
->
BoardLevel
!=
SK_INIT_RUN
)
{
if
(
pAC
->
BoardLevel
!=
SK_INIT_RUN
)
{
/* tschilling: Level 2 init modules here, check return value. */
/* tschilling: Level 2 init modules here, check return value. */
if
(
SkGeInit
(
pAC
,
pAC
->
IoBase
,
SK_INIT_RUN
)
!=
0
)
{
if
(
SkGeInit
(
pAC
,
pAC
->
IoBase
,
SK_INIT_RUN
)
!=
0
)
{
module_put
(
THIS_MODULE
);
/* decrease usage count */
printk
(
"%s: HWInit (2) failed.
\n
"
,
pAC
->
dev
[
pNet
->
PortNr
]
->
name
);
printk
(
"%s: HWInit (2) failed.
\n
"
,
pAC
->
dev
[
pNet
->
PortNr
]
->
name
);
return
(
-
1
);
return
(
-
1
);
}
}
...
@@ -1279,19 +1305,18 @@ struct SK_NET_DEVICE *dev)
...
@@ -1279,19 +1305,18 @@ struct SK_NET_DEVICE *dev)
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
(
"SkGeClose: pAC=0x%lX "
,
(
unsigned
long
)
pAC
));
(
"SkGeClose: pAC=0x%lX "
,
(
unsigned
long
)
pAC
));
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
#ifdef SK_DIAG_SUPPORT
#ifdef SK_DIAG_SUPPORT
if
(
pAC
->
DiagModeActive
==
DIAG_ACTIVE
)
{
if
(
pAC
->
DiagModeActive
==
DIAG_ACTIVE
)
{
if
(
pAC
->
DiagFlowCtrl
==
SK_FALSE
)
{
if
(
pAC
->
DiagFlowCtrl
==
SK_FALSE
)
{
module_put
(
THIS_MODULE
);
/*
/*
** notify that the interface which has been closed
** notify that the interface which has been closed
** by operator interaction must not be started up
** by operator interaction must not be started up
** again when the DIAG has finished.
** again when the DIAG has finished.
*/
*/
newPtrNet
=
(
DEV_NET
*
)
pAC
->
dev
[
0
]
->
priv
;
newPtrNet
=
netdev_priv
(
pAC
->
dev
[
0
])
;
if
(
newPtrNet
==
pNet
)
{
if
(
newPtrNet
==
pNet
)
{
pAC
->
WasIfUp
[
0
]
=
SK_FALSE
;
pAC
->
WasIfUp
[
0
]
=
SK_FALSE
;
}
else
{
}
else
{
...
@@ -1376,7 +1401,6 @@ struct SK_NET_DEVICE *dev)
...
@@ -1376,7 +1401,6 @@ struct SK_NET_DEVICE *dev)
pAC
->
MaxPorts
--
;
pAC
->
MaxPorts
--
;
pNet
->
Up
=
0
;
pNet
->
Up
=
0
;
module_put
(
THIS_MODULE
);
return
(
0
);
return
(
0
);
}
/* SkGeClose */
}
/* SkGeClose */
...
@@ -1402,7 +1426,7 @@ DEV_NET *pNet;
...
@@ -1402,7 +1426,7 @@ DEV_NET *pNet;
SK_AC
*
pAC
;
SK_AC
*
pAC
;
int
Rc
;
/* return code of XmitFrame */
int
Rc
;
/* return code of XmitFrame */
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
if
((
!
skb_shinfo
(
skb
)
->
nr_frags
)
||
if
((
!
skb_shinfo
(
skb
)
->
nr_frags
)
||
...
@@ -2498,7 +2522,7 @@ unsigned long Flags;
...
@@ -2498,7 +2522,7 @@ unsigned long Flags;
static
int
SkGeSetMacAddr
(
struct
SK_NET_DEVICE
*
dev
,
void
*
p
)
static
int
SkGeSetMacAddr
(
struct
SK_NET_DEVICE
*
dev
,
void
*
p
)
{
{
DEV_NET
*
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
DEV_NET
*
pNet
=
netdev_priv
(
dev
)
;
SK_AC
*
pAC
=
pNet
->
pAC
;
SK_AC
*
pAC
=
pNet
->
pAC
;
struct
sockaddr
*
addr
=
p
;
struct
sockaddr
*
addr
=
p
;
...
@@ -2555,7 +2579,7 @@ unsigned long Flags;
...
@@ -2555,7 +2579,7 @@ unsigned long Flags;
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
(
"SkGeSetRxMode starts now... "
));
(
"SkGeSetRxMode starts now... "
));
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
if
(
pAC
->
RlmtNets
==
1
)
if
(
pAC
->
RlmtNets
==
1
)
PortIdx
=
pAC
->
ActivePort
;
PortIdx
=
pAC
->
ActivePort
;
...
@@ -2627,7 +2651,7 @@ SK_EVPARA EvPara;
...
@@ -2627,7 +2651,7 @@ SK_EVPARA EvPara;
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
(
"SkGeChangeMtu starts now...
\n
"
));
(
"SkGeChangeMtu starts now...
\n
"
));
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
if
((
NewMtu
<
68
)
||
(
NewMtu
>
SK_JUMBO_MTU
))
{
if
((
NewMtu
<
68
)
||
(
NewMtu
>
SK_JUMBO_MTU
))
{
...
@@ -2649,7 +2673,7 @@ SK_EVPARA EvPara;
...
@@ -2649,7 +2673,7 @@ SK_EVPARA EvPara;
#endif
#endif
pNet
->
Mtu
=
NewMtu
;
pNet
->
Mtu
=
NewMtu
;
pOtherNet
=
(
DEV_NET
*
)
pAC
->
dev
[
1
-
pNet
->
NetNr
]
->
priv
;
pOtherNet
=
netdev_priv
(
pAC
->
dev
[
1
-
pNet
->
NetNr
])
;
if
((
pOtherNet
->
Mtu
>
1500
)
&&
(
NewMtu
<=
1500
)
&&
(
pOtherNet
->
Up
==
1
))
{
if
((
pOtherNet
->
Mtu
>
1500
)
&&
(
NewMtu
<=
1500
)
&&
(
pOtherNet
->
Up
==
1
))
{
return
(
0
);
return
(
0
);
}
}
...
@@ -2855,7 +2879,7 @@ SK_EVPARA EvPara;
...
@@ -2855,7 +2879,7 @@ SK_EVPARA EvPara;
*/
*/
static
struct
net_device_stats
*
SkGeStats
(
struct
SK_NET_DEVICE
*
dev
)
static
struct
net_device_stats
*
SkGeStats
(
struct
SK_NET_DEVICE
*
dev
)
{
{
DEV_NET
*
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
DEV_NET
*
pNet
=
netdev_priv
(
dev
)
;
SK_AC
*
pAC
=
pNet
->
pAC
;
SK_AC
*
pAC
=
pNet
->
pAC
;
SK_PNMI_STRUCT_DATA
*
pPnmiStruct
;
/* structure for all Pnmi-Data */
SK_PNMI_STRUCT_DATA
*
pPnmiStruct
;
/* structure for all Pnmi-Data */
SK_PNMI_STAT
*
pPnmiStat
;
/* pointer to virtual XMAC stat. data */
SK_PNMI_STAT
*
pPnmiStat
;
/* pointer to virtual XMAC stat. data */
...
@@ -2953,7 +2977,7 @@ int HeaderLength = sizeof(SK_U32) + sizeof(SK_U32);
...
@@ -2953,7 +2977,7 @@ int HeaderLength = sizeof(SK_U32) + sizeof(SK_U32);
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
SK_DBG_MSG
(
NULL
,
SK_DBGMOD_DRV
,
SK_DBGCAT_DRV_ENTRY
,
(
"SkGeIoctl starts now...
\n
"
));
(
"SkGeIoctl starts now...
\n
"
));
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pAC
=
pNet
->
pAC
;
pAC
=
pNet
->
pAC
;
if
(
copy_from_user
(
&
Ioctl
,
rq
->
ifr_data
,
sizeof
(
SK_GE_IOCTL
)))
{
if
(
copy_from_user
(
&
Ioctl
,
rq
->
ifr_data
,
sizeof
(
SK_GE_IOCTL
)))
{
...
@@ -4539,11 +4563,8 @@ char ClassStr[80];
...
@@ -4539,11 +4563,8 @@ char ClassStr[80];
int
SkDrvEnterDiagMode
(
int
SkDrvEnterDiagMode
(
SK_AC
*
pAc
)
/* pointer to adapter context */
SK_AC
*
pAc
)
/* pointer to adapter context */
{
{
SK_AC
*
pAC
=
NULL
;
DEV_NET
*
pNet
=
netdev_priv
(
pAc
->
dev
[
0
]);
DEV_NET
*
pNet
=
NULL
;
SK_AC
*
pAC
=
pNet
->
pAC
;
pNet
=
(
DEV_NET
*
)
pAc
->
dev
[
0
]
->
priv
;
pAC
=
pNet
->
pAC
;
SK_MEMCPY
(
&
(
pAc
->
PnmiBackup
),
&
(
pAc
->
PnmiStruct
),
SK_MEMCPY
(
&
(
pAc
->
PnmiBackup
),
&
(
pAc
->
PnmiStruct
),
sizeof
(
SK_PNMI_STRUCT_DATA
));
sizeof
(
SK_PNMI_STRUCT_DATA
));
...
@@ -4558,8 +4579,8 @@ SK_AC *pAc) /* pointer to adapter context */
...
@@ -4558,8 +4579,8 @@ SK_AC *pAc) /* pointer to adapter context */
}
else
{
}
else
{
pAC
->
WasIfUp
[
0
]
=
SK_FALSE
;
pAC
->
WasIfUp
[
0
]
=
SK_FALSE
;
}
}
if
(
pNet
!=
(
DEV_NET
*
)
pAc
->
dev
[
1
]
->
priv
)
{
if
(
pNet
!=
netdev_priv
(
pAC
->
dev
[
1
])
)
{
pNet
=
(
DEV_NET
*
)
pAc
->
dev
[
1
]
->
priv
;
pNet
=
netdev_priv
(
pAC
->
dev
[
1
])
;
if
(
pNet
->
Up
)
{
if
(
pNet
->
Up
)
{
pAC
->
WasIfUp
[
1
]
=
SK_TRUE
;
pAC
->
WasIfUp
[
1
]
=
SK_TRUE
;
pAC
->
DiagFlowCtrl
=
SK_TRUE
;
/* for SkGeClose */
pAC
->
DiagFlowCtrl
=
SK_TRUE
;
/* for SkGeClose */
...
@@ -4681,20 +4702,11 @@ int devNbr) /* what device is to be handled */
...
@@ -4681,20 +4702,11 @@ int devNbr) /* what device is to be handled */
dev
=
pAC
->
dev
[
devNbr
];
dev
=
pAC
->
dev
[
devNbr
];
/*
/* On Linux 2.6 the network driver does NOT mess with reference
** Function SkGeClose() uses MOD_DEC_USE_COUNT (2.2/2.4)
** counts. The driver MUST be able to be unloaded at any time
** or module_put() (2.6) to decrease the number of users for
** due to the possibility of hotplug.
** a device, but if a device is to be put under control of
** the DIAG, that count is OK already and does not need to
** be adapted! Hence the opposite MOD_INC_USE_COUNT or
** try_module_get() needs to be used again to correct that.
*/
*/
if
(
!
try_module_get
(
THIS_MODULE
))
{
return
(
-
1
);
}
if
(
SkGeClose
(
dev
)
!=
0
)
{
if
(
SkGeClose
(
dev
)
!=
0
)
{
module_put
(
THIS_MODULE
);
return
(
-
1
);
return
(
-
1
);
}
}
return
(
0
);
return
(
0
);
...
@@ -4723,17 +4735,6 @@ int devNbr) /* what device is to be handled */
...
@@ -4723,17 +4735,6 @@ int devNbr) /* what device is to be handled */
if
(
SkGeOpen
(
dev
)
!=
0
)
{
if
(
SkGeOpen
(
dev
)
!=
0
)
{
return
(
-
1
);
return
(
-
1
);
}
else
{
/*
** Function SkGeOpen() uses MOD_INC_USE_COUNT (2.2/2.4)
** or try_module_get() (2.6) to increase the number of
** users for a device, but if a device was just under
** control of the DIAG, that count is OK already and
** does not need to be adapted! Hence the opposite
** MOD_DEC_USE_COUNT or module_put() needs to be used
** again to correct that.
*/
module_put
(
THIS_MODULE
);
}
}
/*
/*
...
@@ -4904,9 +4905,6 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -4904,9 +4905,6 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
SK_AC
*
pAC
;
SK_AC
*
pAC
;
DEV_NET
*
pNet
=
NULL
;
DEV_NET
*
pNet
=
NULL
;
struct
net_device
*
dev
=
NULL
;
struct
net_device
*
dev
=
NULL
;
#ifdef CONFIG_PROC_FS
struct
proc_dir_entry
*
pProcFile
;
#endif
static
int
boards_found
=
0
;
static
int
boards_found
=
0
;
int
error
=
-
ENODEV
;
int
error
=
-
ENODEV
;
...
@@ -4925,7 +4923,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -4925,7 +4923,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
goto
out_disable_device
;
goto
out_disable_device
;
}
}
pNet
=
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pNet
->
pAC
=
kmalloc
(
sizeof
(
SK_AC
),
GFP_KERNEL
);
pNet
->
pAC
=
kmalloc
(
sizeof
(
SK_AC
),
GFP_KERNEL
);
if
(
!
pNet
->
pAC
)
{
if
(
!
pNet
->
pAC
)
{
printk
(
KERN_ERR
"Unable to allocate adapter "
printk
(
KERN_ERR
"Unable to allocate adapter "
...
@@ -4960,8 +4958,12 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -4960,8 +4958,12 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
dev
->
set_mac_address
=
&
SkGeSetMacAddr
;
dev
->
set_mac_address
=
&
SkGeSetMacAddr
;
dev
->
do_ioctl
=
&
SkGeIoctl
;
dev
->
do_ioctl
=
&
SkGeIoctl
;
dev
->
change_mtu
=
&
SkGeChangeMtu
;
dev
->
change_mtu
=
&
SkGeChangeMtu
;
#ifdef CONFIG_NET_POLL_CONTROLLER
dev
->
poll_controller
=
&
SkGePollController
;
#endif
dev
->
flags
&=
~
IFF_RUNNING
;
dev
->
flags
&=
~
IFF_RUNNING
;
SET_NETDEV_DEV
(
dev
,
&
pdev
->
dev
);
SET_NETDEV_DEV
(
dev
,
&
pdev
->
dev
);
SET_ETHTOOL_OPS
(
dev
,
&
SkGeEthtoolOps
);
#ifdef SK_ZEROCOPY
#ifdef SK_ZEROCOPY
#ifdef USE_SK_TX_CHECKSUM
#ifdef USE_SK_TX_CHECKSUM
...
@@ -5002,14 +5004,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -5002,14 +5004,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
memcpy
(
&
dev
->
dev_addr
,
&
pAC
->
Addr
.
Net
[
0
].
CurrentMacAddress
,
6
);
memcpy
(
&
dev
->
dev_addr
,
&
pAC
->
Addr
.
Net
[
0
].
CurrentMacAddress
,
6
);
#ifdef CONFIG_PROC_FS
SkGeProcCreate
(
dev
);
pProcFile
=
create_proc_entry
(
dev
->
name
,
S_IRUGO
,
pSkRootDir
);
if
(
pProcFile
)
{
pProcFile
->
proc_fops
=
&
sk_proc_fops
;
pProcFile
->
data
=
dev
;
pProcFile
->
owner
=
THIS_MODULE
;
}
#endif
pNet
->
PortNr
=
0
;
pNet
->
PortNr
=
0
;
pNet
->
NetNr
=
0
;
pNet
->
NetNr
=
0
;
...
@@ -5025,7 +5020,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -5025,7 +5020,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
}
}
pAC
->
dev
[
1
]
=
dev
;
pAC
->
dev
[
1
]
=
dev
;
pNet
=
dev
->
priv
;
pNet
=
netdev_priv
(
dev
)
;
pNet
->
PortNr
=
1
;
pNet
->
PortNr
=
1
;
pNet
->
NetNr
=
1
;
pNet
->
NetNr
=
1
;
pNet
->
pAC
=
pAC
;
pNet
->
pAC
=
pAC
;
...
@@ -5041,6 +5036,8 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -5041,6 +5036,8 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
dev
->
do_ioctl
=
&
SkGeIoctl
;
dev
->
do_ioctl
=
&
SkGeIoctl
;
dev
->
change_mtu
=
&
SkGeChangeMtu
;
dev
->
change_mtu
=
&
SkGeChangeMtu
;
dev
->
flags
&=
~
IFF_RUNNING
;
dev
->
flags
&=
~
IFF_RUNNING
;
SET_NETDEV_DEV
(
dev
,
&
pdev
->
dev
);
SET_ETHTOOL_OPS
(
dev
,
&
SkGeEthtoolOps
);
#ifdef SK_ZEROCOPY
#ifdef SK_ZEROCOPY
#ifdef USE_SK_TX_CHECKSUM
#ifdef USE_SK_TX_CHECKSUM
...
@@ -5056,16 +5053,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -5056,16 +5053,7 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
free_netdev
(
dev
);
free_netdev
(
dev
);
pAC
->
dev
[
1
]
=
pAC
->
dev
[
0
];
pAC
->
dev
[
1
]
=
pAC
->
dev
[
0
];
}
else
{
}
else
{
#ifdef CONFIG_PROC_FS
SkGeProcCreate
(
dev
);
pProcFile
=
create_proc_entry
(
dev
->
name
,
S_IRUGO
,
pSkRootDir
);
if
(
pProcFile
)
{
pProcFile
->
proc_fops
=
&
sk_proc_fops
;
pProcFile
->
data
=
dev
;
pProcFile
->
owner
=
THIS_MODULE
;
}
#endif
memcpy
(
&
dev
->
dev_addr
,
memcpy
(
&
dev
->
dev_addr
,
&
pAC
->
Addr
.
Net
[
1
].
CurrentMacAddress
,
6
);
&
pAC
->
Addr
.
Net
[
1
].
CurrentMacAddress
,
6
);
...
@@ -5101,19 +5089,14 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
...
@@ -5101,19 +5089,14 @@ static int __devinit skge_probe_one(struct pci_dev *pdev,
static
void
__devexit
skge_remove_one
(
struct
pci_dev
*
pdev
)
static
void
__devexit
skge_remove_one
(
struct
pci_dev
*
pdev
)
{
{
struct
net_device
*
dev
=
pci_get_drvdata
(
pdev
);
struct
net_device
*
dev
=
pci_get_drvdata
(
pdev
);
DEV_NET
*
pNet
=
(
DEV_NET
*
)
dev
->
priv
;
DEV_NET
*
pNet
=
netdev_priv
(
dev
)
;
SK_AC
*
pAC
=
pNet
->
pAC
;
SK_AC
*
pAC
=
pNet
->
pAC
;
int
have_second_mac
=
0
;
struct
net_device
*
otherdev
=
pAC
->
dev
[
1
];
if
((
pAC
->
GIni
.
GIMacsFound
==
2
)
&&
pAC
->
RlmtNets
==
2
)
have_second_mac
=
1
;
remove_proc_entry
(
dev
->
name
,
pSkRootDir
);
SkGeProcRemove
(
dev
);
unregister_netdev
(
dev
);
unregister_netdev
(
dev
);
if
(
have_second_mac
)
{
if
(
otherdev
!=
dev
)
remove_proc_entry
(
pAC
->
dev
[
1
]
->
name
,
pSkRootDir
);
SkGeProcRemove
(
otherdev
);
unregister_netdev
(
pAC
->
dev
[
1
]);
}
SkGeYellowLED
(
pAC
,
pAC
->
IoBase
,
0
);
SkGeYellowLED
(
pAC
,
pAC
->
IoBase
,
0
);
...
@@ -5146,8 +5129,8 @@ static void __devexit skge_remove_one(struct pci_dev *pdev)
...
@@ -5146,8 +5129,8 @@ static void __devexit skge_remove_one(struct pci_dev *pdev)
FreeResources
(
dev
);
FreeResources
(
dev
);
free_netdev
(
dev
);
free_netdev
(
dev
);
if
(
have_second_mac
)
if
(
otherdev
!=
dev
)
free_netdev
(
pAC
->
dev
[
1
]
);
free_netdev
(
otherdev
);
kfree
(
pAC
);
kfree
(
pAC
);
}
}
...
@@ -5180,34 +5163,21 @@ static int __init skge_init(void)
...
@@ -5180,34 +5163,21 @@ static int __init skge_init(void)
{
{
int
error
;
int
error
;
#ifdef CONFIG_PROC_FS
pSkRootDir
=
proc_mkdir
(
SKRootName
,
proc_net
);
memcpy
(
&
SK_Root_Dir_entry
,
BOOT_STRING
,
sizeof
(
SK_Root_Dir_entry
)
-
1
);
if
(
pSkRootDir
)
pSkRootDir
->
owner
=
THIS_MODULE
;
pSkRootDir
=
proc_mkdir
(
SK_Root_Dir_entry
,
proc_net
);
if
(
!
pSkRootDir
)
{
error
=
pci_register_driver
(
&
skge_driver
);
printk
(
KERN_WARNING
"Unable to create /proc/net/%s"
,
if
(
error
)
SK_Root_Dir_entry
);
proc_net_remove
(
SKRootName
);
return
-
ENOMEM
;
}
pSkRootDir
->
owner
=
THIS_MODULE
;
#endif
error
=
pci_module_init
(
&
skge_driver
);
if
(
error
)
{
#ifdef CONFIG_PROC_FS
remove_proc_entry
(
pSkRootDir
->
name
,
proc_net
);
#endif
}
return
error
;
return
error
;
}
}
static
void
__exit
skge_exit
(
void
)
static
void
__exit
skge_exit
(
void
)
{
{
pci_unregister_driver
(
&
skge_driver
);
pci_unregister_driver
(
&
skge_driver
);
#ifdef CONFIG_PROC_FS
proc_net_remove
(
SKRootName
);
remove_proc_entry
(
pSkRootDir
->
name
,
proc_net
);
#endif
}
}
module_init
(
skge_init
);
module_init
(
skge_init
);
...
...
drivers/net/sk98lin/skproc.c
View file @
05c5f695
...
@@ -31,13 +31,9 @@
...
@@ -31,13 +31,9 @@
#include "h/skdrv2nd.h"
#include "h/skdrv2nd.h"
#include "h/skversion.h"
#include "h/skversion.h"
extern
struct
SK_NET_DEVICE
*
SkGeRootDev
;
static
int
sk_proc_print
(
void
*
writePtr
,
char
*
format
,
...);
static
void
sk_gen_browse
(
void
*
buffer
);
int
len
;
static
int
sk_seq_show
(
struct
seq_file
*
seq
,
void
*
v
);
static
int
sk_seq_show
(
struct
seq_file
*
seq
,
void
*
v
);
static
int
sk_proc_open
(
struct
inode
*
inode
,
struct
file
*
file
);
static
int
sk_proc_open
(
struct
inode
*
inode
,
struct
file
*
file
);
struct
file_operations
sk_proc_fops
=
{
struct
file_operations
sk_proc_fops
=
{
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
.
open
=
sk_proc_open
,
.
open
=
sk_proc_open
,
...
@@ -45,315 +41,206 @@ struct file_operations sk_proc_fops = {
...
@@ -45,315 +41,206 @@ struct file_operations sk_proc_fops = {
.
llseek
=
seq_lseek
,
.
llseek
=
seq_lseek
,
.
release
=
single_release
,
.
release
=
single_release
,
};
};
struct
net_device
*
currDev
=
NULL
;
/*****************************************************************************
/*****************************************************************************
*
*
*
sk_gen_browse -generic print "summaries" entry
*
sk_seq_show - show proc information of a particular adapter
*
*
* Description:
* Description:
* This function fills the proc entry with statistic data about
* This function fills the proc entry with statistic data about
* the ethernet device.
* the ethernet device. It invokes the generic sk_gen_browse() to
* print out all items one per one.
*
*
* Returns:
-
* Returns:
0
*
*
*/
*/
static
void
sk_gen_browse
(
void
*
buffer
)
static
int
sk_seq_show
(
struct
seq_file
*
seq
,
void
*
v
)
{
{
struct
SK_NET_DEVICE
*
SkgeProcDev
=
SkGeRootDev
;
struct
net_device
*
dev
=
seq
->
private
;
struct
SK_NET_DEVICE
*
next
;
DEV_NET
*
pNet
=
netdev_priv
(
dev
)
;
SK_
PNMI_STRUCT_DATA
*
pPnmiStruct
;
SK_
AC
*
pAC
=
pNet
->
pAC
;
SK_PNMI_ST
AT
*
pPnmiSta
t
;
SK_PNMI_ST
RUCT_DATA
*
pPnmiStruct
=
&
pAC
->
PnmiStruc
t
;
unsigned
long
Flags
;
unsigned
long
Flags
;
unsigned
int
Size
;
unsigned
int
Size
;
DEV_NET
*
pNet
;
SK_AC
*
pAC
;
char
sens_msg
[
50
];
char
sens_msg
[
50
];
int
MaxSecurityCount
=
0
;
int
t
;
int
t
;
int
i
;
int
i
;
while
(
SkgeProcDev
)
{
/* NetIndex in GetStruct is now required, zero is only dummy */
MaxSecurityCount
++
;
for
(
t
=
pAC
->
GIni
.
GIMacsFound
;
t
>
0
;
t
--
)
{
if
(
MaxSecurityCount
>
100
)
{
if
((
pAC
->
GIni
.
GIMacsFound
==
2
)
&&
pAC
->
RlmtNets
==
1
)
printk
(
"Max limit for sk_proc_read security counter!
\n
"
);
t
--
;
return
;
}
pNet
=
(
DEV_NET
*
)
SkgeProcDev
->
priv
;
pAC
=
pNet
->
pAC
;
next
=
pAC
->
Next
;
pPnmiStruct
=
&
pAC
->
PnmiStruct
;
/* NetIndex in GetStruct is now required, zero is only dummy */
for
(
t
=
pAC
->
GIni
.
GIMacsFound
;
t
>
0
;
t
--
)
{
if
((
pAC
->
GIni
.
GIMacsFound
==
2
)
&&
pAC
->
RlmtNets
==
1
)
t
--
;
spin_lock_irqsave
(
&
pAC
->
SlowPathLock
,
Flags
);
spin_lock_irqsave
(
&
pAC
->
SlowPathLock
,
Flags
);
Size
=
SK_PNMI_STRUCT_SIZE
;
Size
=
SK_PNMI_STRUCT_SIZE
;
#ifdef SK_DIAG_SUPPORT
#ifdef SK_DIAG_SUPPORT
if
(
pAC
->
BoardLevel
==
SK_INIT_DATA
)
{
if
(
pAC
->
BoardLevel
==
SK_INIT_DATA
)
{
SK_MEMCPY
(
&
(
pAC
->
PnmiStruct
),
&
(
pAC
->
PnmiBackup
),
sizeof
(
SK_PNMI_STRUCT_DATA
));
SK_MEMCPY
(
&
(
pAC
->
PnmiStruct
),
&
(
pAC
->
PnmiBackup
),
sizeof
(
SK_PNMI_STRUCT_DATA
));
if
(
pAC
->
DiagModeActive
==
DIAG_NOTACTIVE
)
{
if
(
pAC
->
DiagModeActive
==
DIAG_NOTACTIVE
)
{
pAC
->
Pnmi
.
DiagAttached
=
SK_DIAG_IDLE
;
pAC
->
Pnmi
.
DiagAttached
=
SK_DIAG_IDLE
;
}
}
else
{
SkPnmiGetStruct
(
pAC
,
pAC
->
IoBase
,
pPnmiStruct
,
&
Size
,
t
-
1
);
}
}
}
else
{
SkPnmiGetStruct
(
pAC
,
pAC
->
IoBase
,
pPnmiStruct
,
&
Size
,
t
-
1
);
}
#else
#else
SkPnmiGetStruct
(
pAC
,
pAC
->
IoBase
,
SkPnmiGetStruct
(
pAC
,
pAC
->
IoBase
,
pPnmiStruct
,
&
Size
,
t
-
1
);
pPnmiStruct
,
&
Size
,
t
-
1
);
#endif
#endif
spin_unlock_irqrestore
(
&
pAC
->
SlowPathLock
,
Flags
);
spin_unlock_irqrestore
(
&
pAC
->
SlowPathLock
,
Flags
);
if
(
strcmp
(
pAC
->
dev
[
t
-
1
]
->
name
,
currDev
->
name
)
==
0
)
{
if
(
pAC
->
dev
[
t
-
1
]
==
dev
)
{
pPnmiStat
=
&
pPnmiStruct
->
Stat
[
0
];
SK_PNMI_STAT
*
pPnmiStat
=
&
pPnmiStruct
->
Stat
[
0
];
len
=
sk_proc_print
(
buffer
,
"
\n
Detailed statistic for device %s
\n
"
,
seq_printf
(
seq
,
"
\n
Detailed statistic for device %s
\n
"
,
pAC
->
dev
[
t
-
1
]
->
name
);
pAC
->
dev
[
t
-
1
]
->
name
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"=======================================
\n
"
);
"=======================================
\n
"
);
/* Board statistics */
/* Board statistics */
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"
\n
Board statistics
\n\n
"
);
"
\n
Board statistics
\n\n
"
);
seq_printf
(
seq
,
"Active Port %c
\n
"
,
len
+=
sk_proc_print
(
buffer
,
'A'
+
pAC
->
Rlmt
.
Net
[
t
-
1
].
Port
[
pAC
->
Rlmt
.
"Active Port %c
\n
"
,
Net
[
t
-
1
].
PrefPort
]
->
PortNumber
);
'A'
+
pAC
->
Rlmt
.
Net
[
t
-
1
].
Port
[
pAC
->
Rlmt
.
seq_printf
(
seq
,
"Preferred Port %c
\n
"
,
Net
[
t
-
1
].
PrefPort
]
->
PortNumber
);
'A'
+
pAC
->
Rlmt
.
Net
[
t
-
1
].
Port
[
pAC
->
Rlmt
.
len
+=
sk_proc_print
(
buffer
,
Net
[
t
-
1
].
PrefPort
]
->
PortNumber
);
"Preferred Port %c
\n
"
,
'A'
+
pAC
->
Rlmt
.
Net
[
t
-
1
].
Port
[
pAC
->
Rlmt
.
Net
[
t
-
1
].
PrefPort
]
->
PortNumber
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Bus speed (MHz) %d
\n
"
,
"Bus speed (MHz) %d
\n
"
,
pPnmiStruct
->
BusSpeed
);
pPnmiStruct
->
BusSpeed
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Bus width (Bit) %d
\n
"
,
"Bus width (Bit) %d
\n
"
,
pPnmiStruct
->
BusWidth
);
pPnmiStruct
->
BusWidth
);
seq_printf
(
seq
,
"Driver version %s
\n
"
,
len
+=
sk_proc_print
(
buffer
,
VER_STRING
);
"Driver version %s
\n
"
,
seq_printf
(
seq
,
"Hardware revision v%d.%d
\n
"
,
VER_STRING
);
(
pAC
->
GIni
.
GIPciHwRev
>>
4
)
&
0x0F
,
len
+=
sk_proc_print
(
buffer
,
pAC
->
GIni
.
GIPciHwRev
&
0x0F
);
"Hardware revision v%d.%d
\n
"
,
(
pAC
->
GIni
.
GIPciHwRev
>>
4
)
&
0x0F
,
pAC
->
GIni
.
GIPciHwRev
&
0x0F
);
/* Print sensor informations */
/* Print sensor informations */
for
(
i
=
0
;
i
<
pAC
->
I2c
.
MaxSens
;
i
++
)
{
for
(
i
=
0
;
i
<
pAC
->
I2c
.
MaxSens
;
i
++
)
{
/* Check type */
/* Check type */
switch
(
pAC
->
I2c
.
SenTable
[
i
].
SenType
)
{
switch
(
pAC
->
I2c
.
SenTable
[
i
].
SenType
)
{
case
1
:
case
1
:
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
strcat
(
sens_msg
,
" (C)"
);
strcat
(
sens_msg
,
" (C)"
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"%-25s %d.%02d
\n
"
,
"%-25s %d.%02d
\n
"
,
sens_msg
,
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenValue
/
10
,
pAC
->
I2c
.
SenTable
[
i
].
SenValue
/
10
,
pAC
->
I2c
.
SenTable
[
i
].
SenValue
%
10
);
pAC
->
I2c
.
SenTable
[
i
].
SenValue
%
10
);
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
strcat
(
sens_msg
,
" (F)"
);
strcat
(
sens_msg
,
" (F)"
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"%-25s %d.%02d
\n
"
,
"%-25s %d.%02d
\n
"
,
sens_msg
,
sens_msg
,
((((
pAC
->
I2c
.
SenTable
[
i
].
SenValue
)
((((
pAC
->
I2c
.
SenTable
[
i
].
SenValue
)
*
10
)
*
9
)
/
5
+
3200
)
/
100
,
*
10
)
*
9
)
/
5
+
3200
)
/
100
,
((((
pAC
->
I2c
.
SenTable
[
i
].
SenValue
)
((((
pAC
->
I2c
.
SenTable
[
i
].
SenValue
)
*
10
)
*
9
)
/
5
+
3200
)
%
10
);
*
10
)
*
9
)
/
5
+
3200
)
%
10
);
break
;
break
;
case
2
:
case
2
:
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
strcat
(
sens_msg
,
" (V)"
);
strcat
(
sens_msg
,
" (V)"
);
seq_printf
(
seq
,
"%-25s %d.%03d
\n
"
,
len
+=
sk_proc_print
(
buffer
,
sens_msg
,
"%-25s %d.%03d
\n
"
,
pAC
->
I2c
.
SenTable
[
i
].
SenValue
/
1000
,
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenValue
%
1000
);
pAC
->
I2c
.
SenTable
[
i
].
SenValue
/
1000
,
break
;
pAC
->
I2c
.
SenTable
[
i
].
SenValue
%
1000
);
case
3
:
break
;
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
case
3
:
strcat
(
sens_msg
,
" (rpm)"
);
strcpy
(
sens_msg
,
pAC
->
I2c
.
SenTable
[
i
].
SenDesc
);
seq_printf
(
seq
,
"%-25s %d
\n
"
,
strcat
(
sens_msg
,
" (rpm)"
);
sens_msg
,
len
+=
sk_proc_print
(
buffer
,
pAC
->
I2c
.
SenTable
[
i
].
SenValue
);
"%-25s %d
\n
"
,
break
;
sens_msg
,
default:
pAC
->
I2c
.
SenTable
[
i
].
SenValue
);
break
;
break
;
default:
break
;
}
}
}
}
/*Receive statistics */
/*Receive statistics */
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"
\n
Receive statistics
\n\n
"
);
"
\n
Receive statistics
\n\n
"
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Received bytes %Lu
\n
"
,
"Received bytes %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxOctetsOkCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxOctetsOkCts
);
seq_printf
(
seq
,
"Received packets %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxOkCts
);
"Received packets %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxOkCts
);
#if 0
#if 0
if (pAC->GIni.GP[0].PhyType == SK_PHY_XMAC &&
if (pAC->GIni.GP[0].PhyType == SK_PHY_XMAC &&
pAC->HWRevision < 12) {
pAC->HWRevision < 12) {
pPnmiStruct->InErrorsCts = pPnmiStruct->InErrorsCts -
pPnmiStruct->InErrorsCts = pPnmiStruct->InErrorsCts -
pPnmiStat->StatRxShortsCts;
pPnmiStat->StatRxShortsCts;
pPnmiStat->StatRxShortsCts = 0;
pPnmiStat->StatRxShortsCts = 0;
}
}
#endif
#endif
if
(
pNet
->
Mtu
>
1500
)
if
(
dev
->
mtu
>
1500
)
pPnmiStruct
->
InErrorsCts
=
pPnmiStruct
->
InErrorsCts
-
pPnmiStruct
->
InErrorsCts
=
pPnmiStruct
->
InErrorsCts
-
pPnmiStat
->
StatRxTooLongCts
;
pPnmiStat
->
StatRxTooLongCts
;
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Receive errors %Lu
\n
"
,
"Receive errors %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStruct
->
InErrorsCts
);
(
unsigned
long
long
)
pPnmiStruct
->
InErrorsCts
);
seq_printf
(
seq
,
"Receive dropped %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStruct
->
RxNoBufCts
);
"Receive dropped %Lu
\n
"
,
seq_printf
(
seq
,
"Received multicast %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStruct
->
RxNoBufCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxMulticastOkCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Receive error types
\n
"
);
"Received multicast %Lu
\n
"
,
seq_printf
(
seq
,
" length %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxMulticastOkCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxRuntCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" buffer overflow %Lu
\n
"
,
"Receive error types
\n
"
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxFifoOverflowCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" bad crc %Lu
\n
"
,
" length %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxFcsCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxRuntCts
);
seq_printf
(
seq
,
" framing %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxFramingCts
);
" buffer overflow %Lu
\n
"
,
seq_printf
(
seq
,
" missed frames %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxFifoOverflowCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxMissedCts
);
len
+=
sk_proc_print
(
buffer
,
" bad crc %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxFcsCts
);
len
+=
sk_proc_print
(
buffer
,
" framing %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxFramingCts
);
len
+=
sk_proc_print
(
buffer
,
" missed frames %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxMissedCts
);
if
(
pNet
->
M
tu
>
1500
)
if
(
dev
->
m
tu
>
1500
)
pPnmiStat
->
StatRxTooLongCts
=
0
;
pPnmiStat
->
StatRxTooLongCts
=
0
;
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" too long %Lu
\n
"
,
" too long %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxTooLongCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxTooLongCts
);
seq_printf
(
seq
,
" carrier extension %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxCextCts
);
" carrier extension %Lu
\n
"
,
seq_printf
(
seq
,
" too short %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxCextCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxShortsCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" symbol %Lu
\n
"
,
" too short %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxSymbolCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxShortsCts
);
seq_printf
(
seq
,
" LLC MAC size %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxIRLengthCts
);
" symbol %Lu
\n
"
,
seq_printf
(
seq
,
" carrier event %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxSymbolCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxCarrierCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" jabber %Lu
\n
"
,
" LLC MAC size %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxJabberCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatRxIRLengthCts
);
len
+=
sk_proc_print
(
buffer
,
" carrier event %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxCarrierCts
);
len
+=
sk_proc_print
(
buffer
,
" jabber %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatRxJabberCts
);
/*Transmit statistics */
/*Transmit statistics */
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"
\n
Transmit statistics
\n\n
"
);
"
\n
Transmit statistics
\n\n
"
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Transmited bytes %Lu
\n
"
,
"Transmited bytes %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxOctetsOkCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatTxOctetsOkCts
);
seq_printf
(
seq
,
"Transmited packets %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxOkCts
);
"Transmited packets %Lu
\n
"
,
seq_printf
(
seq
,
"Transmit errors %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxOkCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatTxSingleCollisionCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
"Transmit dropped %Lu
\n
"
,
"Transmit errors %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStruct
->
TxNoBufCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatTxSingleCollisionCts
);
seq_printf
(
seq
,
"Transmit collisions %Lu
\n
"
,
len
+=
sk_proc_print
(
buffer
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxSingleCollisionCts
);
"Transmit dropped %Lu
\n
"
,
seq_printf
(
seq
,
"Transmit error types
\n
"
);
(
unsigned
long
long
)
pPnmiStruct
->
TxNoBufCts
);
seq_printf
(
seq
,
" excessive collision %ld
\n
"
,
len
+=
sk_proc_print
(
buffer
,
pAC
->
stats
.
tx_aborted_errors
);
"Transmit collisions %Lu
\n
"
,
seq_printf
(
seq
,
" carrier %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxSingleCollisionCts
);
(
unsigned
long
long
)
pPnmiStat
->
StatTxCarrierCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" fifo underrun %Lu
\n
"
,
"Transmit error types
\n
"
);
(
unsigned
long
long
)
pPnmiStat
->
StatTxFifoUnderrunCts
);
len
+=
sk_proc_print
(
buffer
,
seq_printf
(
seq
,
" heartbeat %Lu
\n
"
,
" excessive collision %ld
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxCarrierCts
);
pAC
->
stats
.
tx_aborted_errors
);
seq_printf
(
seq
,
" window %ld
\n
"
,
len
+=
sk_proc_print
(
buffer
,
pAC
->
stats
.
tx_window_errors
);
" carrier %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxCarrierCts
);
len
+=
sk_proc_print
(
buffer
,
" fifo underrun %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxFifoUnderrunCts
);
len
+=
sk_proc_print
(
buffer
,
" heartbeat %Lu
\n
"
,
(
unsigned
long
long
)
pPnmiStat
->
StatTxCarrierCts
);
len
+=
sk_proc_print
(
buffer
,
" window %ld
\n
"
,
pAC
->
stats
.
tx_window_errors
);
}
/* if (strcmp(pACname, currDeviceName) == 0) */
}
}
SkgeProcDev
=
next
;
}
}
}
return
0
;
/*****************************************************************************
*
* sk_proc_print -generic line print
*
* Description:
* This function fills the proc entry with statistic data about
* the ethernet device.
*
* Returns: number of bytes written
*
*/
static
int
sk_proc_print
(
void
*
writePtr
,
char
*
format
,
...)
{
#define MAX_LEN_SINGLE_LINE 256
char
str
[
MAX_LEN_SINGLE_LINE
];
va_list
a_start
;
int
lenght
=
0
;
struct
seq_file
*
seq
=
(
struct
seq_file
*
)
writePtr
;
SK_MEMSET
(
str
,
0
,
MAX_LEN_SINGLE_LINE
);
va_start
(
a_start
,
format
);
vsprintf
(
str
,
format
,
a_start
);
va_end
(
a_start
);
lenght
=
strlen
(
str
);
seq_printf
(
seq
,
str
);
return
lenght
;
}
/*****************************************************************************
*
* sk_seq_show - show proc information of a particular adapter
*
* Description:
* This function fills the proc entry with statistic data about
* the ethernet device. It invokes the generic sk_gen_browse() to
* print out all items one per one.
*
* Returns: number of bytes written
*
*/
static
int
sk_seq_show
(
struct
seq_file
*
seq
,
void
*
v
)
{
void
*
castedBuffer
=
(
void
*
)
seq
;
currDev
=
seq
->
private
;
sk_gen_browse
(
castedBuffer
);
return
0
;
}
}
/*****************************************************************************
/*****************************************************************************
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment