drivers/isdn: Drop unnecessary NULL test
authorJulia Lawall <julia@diku.dk>
Sun, 12 Jul 2009 20:05:03 +0000 (22:05 +0200)
committerKarsten Keil <keil@b1-systems.de>
Sat, 25 Jul 2009 18:22:51 +0000 (20:22 +0200)
The result of container_of should not be NULL.  In particular, in this case
the argument to the enclosing function has passed though INIT_WORK, which
dereferences it, implying that its container cannot be NULL.

A simplified version of the semantic patch that makes this change is as
follows:
(http://www.emn.fr/x-info/coccinelle/)

// <smpl>
@@
identifier fn,work,x,fld;
type T;
expression E1,E2;
statement S;
@@

static fn(struct work_struct *work) {
  ... when != work = E1
  x = container_of(work,T,fld)
  ... when != x = E2
- if (x == NULL) S
  ...
}
// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Karsten Keil <keil@b1-systems.de>
drivers/isdn/hisax/amd7930_fn.c
drivers/isdn/hisax/hfc_pci.c
drivers/isdn/hisax/hfc_sx.c
drivers/isdn/hisax/icc.c
drivers/isdn/hisax/isac.c
drivers/isdn/hisax/w6692.c

index 341faf58a65c5d76cdaa1ab252bb54186f5d9780..bf526a7a63af4a7dd763130d3e1f30c773fa2da4 100644 (file)
@@ -238,8 +238,6 @@ Amd7930_bh(struct work_struct *work)
                container_of(work, struct IsdnCardState, tqueue);
         struct PStack *stptr;
 
-       if (!cs)
-               return;
        if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
                 if (cs->debug)
                        debugl1(cs, "Amd7930: bh, D-Channel Busy cleared");
index 3d337d924c23b81750153cdf1321a9153d33fa0e..d110a77940a49a6885eda2a985ea6c2524519818 100644 (file)
@@ -1506,8 +1506,6 @@ hfcpci_bh(struct work_struct *work)
        u_long  flags;
 //      struct PStack *stptr;
 
-       if (!cs)
-               return;
        if (test_and_clear_bit(D_L1STATECHANGE, &cs->event)) {
                if (!cs->hw.hfcpci.nt_mode)
                        switch (cs->dc.hfcpci.ph_state) {
index d92e8d6c2ae22d745b295da73459c3047e710d37..419f87cad8cbeb634596f57f6c7868dde6b6e236 100644 (file)
@@ -1255,8 +1255,6 @@ hfcsx_bh(struct work_struct *work)
                container_of(work, struct IsdnCardState, tqueue);
        u_long flags;
 
-       if (!cs)
-               return;
        if (test_and_clear_bit(D_L1STATECHANGE, &cs->event)) {
                if (!cs->hw.hfcsx.nt_mode)
                        switch (cs->dc.hfcsx.ph_state) {
index 682cac32f259fc5c3be4d14f88f1c0462cea6f57..9aba646ba221c814e33cbddb0e60f9779b5a30f4 100644 (file)
@@ -83,8 +83,6 @@ icc_bh(struct work_struct *work)
                container_of(work, struct IsdnCardState, tqueue);
        struct PStack *stptr;
        
-       if (!cs)
-               return;
        if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
                if (cs->debug)
                        debugl1(cs, "D-Channel Busy cleared");
index 07b1673122b8a8a6d34cb431cb2073281af78a24..a19354d943433872d49c2e5c836cc2c21b030a6a 100644 (file)
@@ -86,8 +86,6 @@ isac_bh(struct work_struct *work)
                container_of(work, struct IsdnCardState, tqueue);
        struct PStack *stptr;
        
-       if (!cs)
-               return;
        if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
                if (cs->debug)
                        debugl1(cs, "D-Channel Busy cleared");
index bb1c8dd1a230463910283ad6b5017f94769138f8..c4d862c11a605f288aa6fa3b97cb7167132d592a 100644 (file)
@@ -105,8 +105,6 @@ W6692_bh(struct work_struct *work)
                container_of(work, struct IsdnCardState, tqueue);
        struct PStack *stptr;
 
-       if (!cs)
-               return;
        if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
                if (cs->debug)
                        debugl1(cs, "D-Channel Busy cleared");