Commit c2f8c900 authored by Sebastian Andrzej Siewior's avatar Sebastian Andrzej Siewior Committed by David S. Miller

net: wan/lmc: Remove lmc_trace()

lmc_trace() was first introduced in commit e7a392d5 ("Import
2.3.99pre6-5") and was not touched ever since.

The reason for looking at this was to get rid of the in_interrupt() usage,
but while looking at it the following observations were made:

 - At least lmc_get_stats() (->ndo_get_stats()) is invoked with disabled
   preemption which is not detected by the in_interrupt() check, which
   would cause schedule() to be called from invalid context.

 - The code is hidden behind #ifdef LMC_TRACE which is not defined within
   the kernel and wasn't at the time it was introduced.

 - Three jiffies don't match 50ms. msleep() would be a better match which
   would also avoid the schedule() invocation. But why have it to begin
   with?

 - Nobody would do something like this today. Either netdev_dbg() or
   trace_printk() or a trace event would be used.  If only the functions
   related to this driver are interesting then ftrace can be used with
   filtering.

As it is obviously broken for years, simply remove it.
Signed-off-by: default avatarSebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent cfa1b493
...@@ -62,22 +62,4 @@ void lmcEventLog(u32 EventNum, u32 arg2, u32 arg3) ...@@ -62,22 +62,4 @@ void lmcEventLog(u32 EventNum, u32 arg2, u32 arg3)
} }
#endif /* DEBUG */ #endif /* DEBUG */
void lmc_trace(struct net_device *dev, char *msg){
#ifdef LMC_TRACE
unsigned long j = jiffies + 3; /* Wait for 50 ms */
if(in_interrupt()){
printk("%s: * %s\n", dev->name, msg);
// while(time_before(jiffies, j+10))
// ;
}
else {
printk("%s: %s\n", dev->name, msg);
while(time_before(jiffies, j))
schedule();
}
#endif
}
/* --------------------------- end if_lmc_linux.c ------------------------ */ /* --------------------------- end if_lmc_linux.c ------------------------ */
...@@ -48,6 +48,5 @@ extern u32 lmcEventLogBuf[LMC_EVENTLOGSIZE * LMC_EVENTLOGARGS]; ...@@ -48,6 +48,5 @@ extern u32 lmcEventLogBuf[LMC_EVENTLOGSIZE * LMC_EVENTLOGARGS];
void lmcConsoleLog(char *type, unsigned char *ucData, int iLen); void lmcConsoleLog(char *type, unsigned char *ucData, int iLen);
void lmcEventLog(u32 EventNum, u32 arg2, u32 arg3); void lmcEventLog(u32 EventNum, u32 arg2, u32 arg3);
void lmc_trace(struct net_device *dev, char *msg);
#endif #endif
This diff is collapsed.
...@@ -1026,7 +1026,6 @@ lmc_t1_get_link_status (lmc_softc_t * const sc) ...@@ -1026,7 +1026,6 @@ lmc_t1_get_link_status (lmc_softc_t * const sc)
* led3 red = Loss of Signal (LOS) or out of frame (OOF) * led3 red = Loss of Signal (LOS) or out of frame (OOF)
* conditions detected on T3 receive signal * conditions detected on T3 receive signal
*/ */
lmc_trace(sc->lmc_device, "lmc_t1_get_link_status in");
lmc_led_on(sc, LMC_DS3_LED2); lmc_led_on(sc, LMC_DS3_LED2);
lmc_mii_writereg (sc, 0, 17, T1FRAMER_ALARM1_STATUS); lmc_mii_writereg (sc, 0, 17, T1FRAMER_ALARM1_STATUS);
...@@ -1120,9 +1119,6 @@ lmc_t1_get_link_status (lmc_softc_t * const sc) ...@@ -1120,9 +1119,6 @@ lmc_t1_get_link_status (lmc_softc_t * const sc)
lmc_mii_writereg (sc, 0, 17, T1FRAMER_ALARM2_STATUS); lmc_mii_writereg (sc, 0, 17, T1FRAMER_ALARM2_STATUS);
sc->lmc_xinfo.t1_alarm2_status = lmc_mii_readreg (sc, 0, 18); sc->lmc_xinfo.t1_alarm2_status = lmc_mii_readreg (sc, 0, 18);
lmc_trace(sc->lmc_device, "lmc_t1_get_link_status out");
return ret; return ret;
} }
......
...@@ -47,7 +47,6 @@ ...@@ -47,7 +47,6 @@
// attach // attach
void lmc_proto_attach(lmc_softc_t *sc) /*FOLD00*/ void lmc_proto_attach(lmc_softc_t *sc) /*FOLD00*/
{ {
lmc_trace(sc->lmc_device, "lmc_proto_attach in");
if (sc->if_type == LMC_NET) { if (sc->if_type == LMC_NET) {
struct net_device *dev = sc->lmc_device; struct net_device *dev = sc->lmc_device;
/* /*
...@@ -57,12 +56,10 @@ void lmc_proto_attach(lmc_softc_t *sc) /*FOLD00*/ ...@@ -57,12 +56,10 @@ void lmc_proto_attach(lmc_softc_t *sc) /*FOLD00*/
dev->hard_header_len = 0; dev->hard_header_len = 0;
dev->addr_len = 0; dev->addr_len = 0;
} }
lmc_trace(sc->lmc_device, "lmc_proto_attach out");
} }
int lmc_proto_ioctl(lmc_softc_t *sc, struct ifreq *ifr, int cmd) int lmc_proto_ioctl(lmc_softc_t *sc, struct ifreq *ifr, int cmd)
{ {
lmc_trace(sc->lmc_device, "lmc_proto_ioctl");
if (sc->if_type == LMC_PPP) if (sc->if_type == LMC_PPP)
return hdlc_ioctl(sc->lmc_device, ifr, cmd); return hdlc_ioctl(sc->lmc_device, ifr, cmd);
return -EOPNOTSUPP; return -EOPNOTSUPP;
...@@ -72,32 +69,23 @@ int lmc_proto_open(lmc_softc_t *sc) ...@@ -72,32 +69,23 @@ int lmc_proto_open(lmc_softc_t *sc)
{ {
int ret = 0; int ret = 0;
lmc_trace(sc->lmc_device, "lmc_proto_open in");
if (sc->if_type == LMC_PPP) { if (sc->if_type == LMC_PPP) {
ret = hdlc_open(sc->lmc_device); ret = hdlc_open(sc->lmc_device);
if (ret < 0) if (ret < 0)
printk(KERN_WARNING "%s: HDLC open failed: %d\n", printk(KERN_WARNING "%s: HDLC open failed: %d\n",
sc->name, ret); sc->name, ret);
} }
lmc_trace(sc->lmc_device, "lmc_proto_open out");
return ret; return ret;
} }
void lmc_proto_close(lmc_softc_t *sc) void lmc_proto_close(lmc_softc_t *sc)
{ {
lmc_trace(sc->lmc_device, "lmc_proto_close in");
if (sc->if_type == LMC_PPP) if (sc->if_type == LMC_PPP)
hdlc_close(sc->lmc_device); hdlc_close(sc->lmc_device);
lmc_trace(sc->lmc_device, "lmc_proto_close out");
} }
__be16 lmc_proto_type(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/ __be16 lmc_proto_type(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/
{ {
lmc_trace(sc->lmc_device, "lmc_proto_type in");
switch(sc->if_type){ switch(sc->if_type){
case LMC_PPP: case LMC_PPP:
return hdlc_type_trans(skb, sc->lmc_device); return hdlc_type_trans(skb, sc->lmc_device);
...@@ -113,13 +101,10 @@ __be16 lmc_proto_type(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/ ...@@ -113,13 +101,10 @@ __be16 lmc_proto_type(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/
return htons(ETH_P_802_2); return htons(ETH_P_802_2);
break; break;
} }
lmc_trace(sc->lmc_device, "lmc_proto_tye out");
} }
void lmc_proto_netif(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/ void lmc_proto_netif(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/
{ {
lmc_trace(sc->lmc_device, "lmc_proto_netif in");
switch(sc->if_type){ switch(sc->if_type){
case LMC_PPP: case LMC_PPP:
case LMC_NET: case LMC_NET:
...@@ -129,5 +114,4 @@ void lmc_proto_netif(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/ ...@@ -129,5 +114,4 @@ void lmc_proto_netif(lmc_softc_t *sc, struct sk_buff *skb) /*FOLD00*/
case LMC_RAW: case LMC_RAW:
break; break;
} }
lmc_trace(sc->lmc_device, "lmc_proto_netif out");
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment