saa7134: drop unnecessary list_empty
authorJulia Lawall <Julia.Lawall@inria.fr>
Sun, 26 Jul 2020 10:58:30 +0000 (12:58 +0200)
committerMauro Carvalho Chehab <mchehab+huawei@kernel.org>
Tue, 1 Sep 2020 11:37:53 +0000 (13:37 +0200)
list_for_each_safe is able to handle an empty list.
The only effect of avoiding the loop is not initializing the
index variable.
Drop list_empty tests in cases where these variables are not
used.

The semantic patch that makes this change is as follows:
(http://coccinelle.lip6.fr/)

<smpl>
@@
expression x,e;
iterator name list_for_each_safe;
statement S;
identifier i,j;
@@

-if (!(list_empty(x))) {
   list_for_each_safe(i,j,x) S
- }
 ... when != i
     when != j
(
  i = e;
|
? j = e;
)
</smpl>

Signed-off-by: Julia Lawall <Julia.Lawall@inria.fr>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
drivers/media/pci/saa7134/saa7134-core.c

index e3ccb464c044f7774a2cdd765bac6c4cda4d1b21..e3eedb1e96320ab7f91daea05f948cd2aa3e4b18 100644 (file)
@@ -359,14 +359,12 @@ void saa7134_stop_streaming(struct saa7134_dev *dev, struct saa7134_dmaqueue *q)
        struct saa7134_buf *tmp;
 
        spin_lock_irqsave(&dev->slock, flags);
-       if (!list_empty(&q->queue)) {
-               list_for_each_safe(pos, n, &q->queue) {
-                        tmp = list_entry(pos, struct saa7134_buf, entry);
-                        vb2_buffer_done(&tmp->vb2.vb2_buf,
-                                        VB2_BUF_STATE_ERROR);
-                        list_del(pos);
-                        tmp = NULL;
-               }
+       list_for_each_safe(pos, n, &q->queue) {
+               tmp = list_entry(pos, struct saa7134_buf, entry);
+               vb2_buffer_done(&tmp->vb2.vb2_buf,
+                               VB2_BUF_STATE_ERROR);
+               list_del(pos);
+               tmp = NULL;
        }
        spin_unlock_irqrestore(&dev->slock, flags);
        saa7134_buffer_timeout(&q->timeout); /* also calls del_timer(&q->timeout) */