]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/commitdiff
s390: qdio: Convert timers to use timer_setup()
authorKees Cook <keescook@chromium.org>
Thu, 5 Oct 2017 00:54:35 +0000 (17:54 -0700)
committerHeiko Carstens <heiko.carstens@de.ibm.com>
Tue, 14 Nov 2017 10:01:33 +0000 (11:01 +0100)
In preparation for unconditionally passing the struct timer_list pointer to
all timer callbacks, switch to using the new timer_setup() and from_timer()
to pass the timer pointer explicitly.

Cc: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Kees Cook <keescook@chromium.org>
[sebott: fixed compile error due to invalid struct member]
Signed-off-by: Sebastian Ott <sebott@linux.vnet.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
drivers/s390/cio/qdio.h
drivers/s390/cio/qdio_main.c
drivers/s390/cio/qdio_setup.c

index 29d6b5222f1cdb6420c9632f9825597bb524f295..a6f7c2986b94f7a4a7ad24141ea546538ef8455d 100644 (file)
@@ -393,7 +393,7 @@ int test_nonshared_ind(struct qdio_irq *);
 /* prototypes for setup */
 void qdio_inbound_processing(unsigned long data);
 void qdio_outbound_processing(unsigned long data);
-void qdio_outbound_timer(unsigned long data);
+void qdio_outbound_timer(struct timer_list *t);
 void qdio_int_handler(struct ccw_device *cdev, unsigned long intparm,
                      struct irb *irb);
 int qdio_allocate_qs(struct qdio_irq *irq_ptr, int nr_input_qs,
index a4ad39ba3873f64911802e567b8c19a6abbad5c6..ed4852fab44b5737fa5edae05ddd640067486304 100644 (file)
@@ -894,9 +894,9 @@ void qdio_outbound_processing(unsigned long data)
        __qdio_outbound_processing(q);
 }
 
-void qdio_outbound_timer(unsigned long data)
+void qdio_outbound_timer(struct timer_list *t)
 {
-       struct qdio_q *q = (struct qdio_q *)data;
+       struct qdio_q *q = from_timer(q, t, u.out.timer);
 
        qdio_tasklet_schedule(q);
 }
index 48b3866a9ded31401d986ea79a6d3f1629c08f74..9ae1380cbc31300f5e251f03e6027ad903b2d666 100644 (file)
@@ -252,8 +252,7 @@ static void setup_queues(struct qdio_irq *irq_ptr,
 
                tasklet_init(&q->tasklet, qdio_outbound_processing,
                             (unsigned long) q);
-               setup_timer(&q->u.out.timer, (void(*)(unsigned long))
-                           &qdio_outbound_timer, (unsigned long)q);
+               timer_setup(&q->u.out.timer, qdio_outbound_timer, 0);
        }
 }