提交 3cad3da3 编写于 作者: J Julia Lawall 提交者: Karsten Keil

drivers/isdn: Drop unnecessary NULL test

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: NJulia Lawall <julia@diku.dk>
Signed-off-by: NKarsten Keil <keil@b1-systems.de>
上级 a900845e
...@@ -238,8 +238,6 @@ Amd7930_bh(struct work_struct *work) ...@@ -238,8 +238,6 @@ Amd7930_bh(struct work_struct *work)
container_of(work, struct IsdnCardState, tqueue); container_of(work, struct IsdnCardState, tqueue);
struct PStack *stptr; struct PStack *stptr;
if (!cs)
return;
if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) { if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
if (cs->debug) if (cs->debug)
debugl1(cs, "Amd7930: bh, D-Channel Busy cleared"); debugl1(cs, "Amd7930: bh, D-Channel Busy cleared");
......
...@@ -1506,8 +1506,6 @@ hfcpci_bh(struct work_struct *work) ...@@ -1506,8 +1506,6 @@ hfcpci_bh(struct work_struct *work)
u_long flags; u_long flags;
// struct PStack *stptr; // struct PStack *stptr;
if (!cs)
return;
if (test_and_clear_bit(D_L1STATECHANGE, &cs->event)) { if (test_and_clear_bit(D_L1STATECHANGE, &cs->event)) {
if (!cs->hw.hfcpci.nt_mode) if (!cs->hw.hfcpci.nt_mode)
switch (cs->dc.hfcpci.ph_state) { switch (cs->dc.hfcpci.ph_state) {
......
...@@ -1255,8 +1255,6 @@ hfcsx_bh(struct work_struct *work) ...@@ -1255,8 +1255,6 @@ hfcsx_bh(struct work_struct *work)
container_of(work, struct IsdnCardState, tqueue); container_of(work, struct IsdnCardState, tqueue);
u_long flags; u_long flags;
if (!cs)
return;
if (test_and_clear_bit(D_L1STATECHANGE, &cs->event)) { if (test_and_clear_bit(D_L1STATECHANGE, &cs->event)) {
if (!cs->hw.hfcsx.nt_mode) if (!cs->hw.hfcsx.nt_mode)
switch (cs->dc.hfcsx.ph_state) { switch (cs->dc.hfcsx.ph_state) {
......
...@@ -83,8 +83,6 @@ icc_bh(struct work_struct *work) ...@@ -83,8 +83,6 @@ icc_bh(struct work_struct *work)
container_of(work, struct IsdnCardState, tqueue); container_of(work, struct IsdnCardState, tqueue);
struct PStack *stptr; struct PStack *stptr;
if (!cs)
return;
if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) { if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
if (cs->debug) if (cs->debug)
debugl1(cs, "D-Channel Busy cleared"); debugl1(cs, "D-Channel Busy cleared");
......
...@@ -86,8 +86,6 @@ isac_bh(struct work_struct *work) ...@@ -86,8 +86,6 @@ isac_bh(struct work_struct *work)
container_of(work, struct IsdnCardState, tqueue); container_of(work, struct IsdnCardState, tqueue);
struct PStack *stptr; struct PStack *stptr;
if (!cs)
return;
if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) { if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
if (cs->debug) if (cs->debug)
debugl1(cs, "D-Channel Busy cleared"); debugl1(cs, "D-Channel Busy cleared");
......
...@@ -105,8 +105,6 @@ W6692_bh(struct work_struct *work) ...@@ -105,8 +105,6 @@ W6692_bh(struct work_struct *work)
container_of(work, struct IsdnCardState, tqueue); container_of(work, struct IsdnCardState, tqueue);
struct PStack *stptr; struct PStack *stptr;
if (!cs)
return;
if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) { if (test_and_clear_bit(D_CLEARBUSY, &cs->event)) {
if (cs->debug) if (cs->debug)
debugl1(cs, "D-Channel Busy cleared"); debugl1(cs, "D-Channel Busy cleared");
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册