Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp779987ybe; Fri, 13 Sep 2019 06:17:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqyMrrUaHPpTYyQt0nhcShEwqh55xq3al6o6DdFAAGf8PJpZyBeqKSdxzYViNsPCyGSmap3Z X-Received: by 2002:a05:6402:3ca:: with SMTP id t10mr48055654edw.271.1568380622333; Fri, 13 Sep 2019 06:17:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568380622; cv=none; d=google.com; s=arc-20160816; b=eKaMNhZn1E/rt+2GC3OmeoJig99L2h+M1hJs1MEWtsRs7j+SI8nDMBnYIbCFCUJjB6 HpWyAz79YOqpcCayU5vNdno/A9Lp51kgylLca+QHcUnn0jFsKtv3a2Lw1Ju5yCdckAeW u2Iecp80iSQvvycDplqaDTonCOdY8RGiEp99RCWzKDM1VTK4ews+VGNaRJLm/VDpH8I2 vfSy2WfT4h0Xi+I8Op7Q15GwOG9QZo1HZvLWAfkped9cnhlozrCqPfwyfPx4AZ8VG2iW s9czoa+Hct10TSRZAcBcgkyswBmlJyo/gfrwaVvTipqG5APH7l+ysFUY35kT9VU27P1K vsLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Z3QFQw1XMbCvJlIOC38EGz5riY6a3nMDlMdFuKhbpWI=; b=ILDV3RDkqmwpIEHAaP6sX7n8twqsuq9FDvIMC4LAHDX0i9N685viR5Qz0ONkEoMerU AzJKfuSsZpb+Ukc8CIhrdUtU0pPOnbCUVjjAASMY4kjfoIWrp9QD2fhifGIuBCjIUZPJ UWMrvPlVMsfUP91Aa6Vb7/gjkrIzoYeYnSFRJTo/7WhUUO9HXGx1WTCUuD9MWvI9B66P 1xz4LPfFh9PDHKF7/44EWyEG1wuQmnULcDgt/XJa9NbW/x54Fg/MMTZZKm9+BKzopbqB RgipmEub62tkvD20hfTVaulDZ5QSRI3Zja58G12W5QkEq9Eu88fOPtwmG7sGFv5Sifq+ BfIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=h4QLQQxP; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w21si17480765edc.93.2019.09.13.06.16.38; Fri, 13 Sep 2019 06:17:02 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=h4QLQQxP; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389389AbfIMNNq (ORCPT + 99 others); Fri, 13 Sep 2019 09:13:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:39486 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389375AbfIMNNn (ORCPT ); Fri, 13 Sep 2019 09:13:43 -0400 Received: from localhost (unknown [104.132.45.99]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5241720CC7; Fri, 13 Sep 2019 13:13:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1568380422; bh=Bd8Qequ8n2mZaBqAuBld6JpPLMWGNs9uxKxrnYRPmAg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=h4QLQQxPd/aHBhfdFYZ0X2z4R7ujVMn54BNEijbv2pWPJzfj7oh1MI+qqQTLjHTUq tI+9lJDZhBceIvbqdUpkKp+j7leEoklDRC0JHyXaegN1xGZ+LSrnjguoukxX6hCkW1 RCQjVjZtENw00CleRi9gL75H2XsvztO+tPRSIcqE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hans Verkuil , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 4.19 060/190] media: vim2m: use workqueue Date: Fri, 13 Sep 2019 14:05:15 +0100 Message-Id: <20190913130604.552595407@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20190913130559.669563815@linuxfoundation.org> References: <20190913130559.669563815@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [ Upstream commit 144bd0ee304c7d0690eec285aee93019d3f30fc8 ] v4l2_ctrl uses mutexes, so we can't setup a ctrl_handler in interrupt context. Switch to a workqueue instead and drop the timer. Signed-off-by: Hans Verkuil Reviewed-by: Mauro Carvalho Chehab Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/platform/vim2m.c | 25 ++++++++++--------------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/drivers/media/platform/vim2m.c b/drivers/media/platform/vim2m.c index 462099a141e4a..6f87ef025ff19 100644 --- a/drivers/media/platform/vim2m.c +++ b/drivers/media/platform/vim2m.c @@ -3,7 +3,8 @@ * * This is a virtual device driver for testing mem-to-mem videobuf framework. * It simulates a device that uses memory buffers for both source and - * destination, processes the data and issues an "irq" (simulated by a timer). + * destination, processes the data and issues an "irq" (simulated by a delayed + * workqueue). * The device is capable of multi-instance, multi-buffer-per-transaction * operation (via the mem2mem framework). * @@ -19,7 +20,6 @@ #include #include #include -#include #include #include @@ -148,7 +148,7 @@ struct vim2m_dev { struct mutex dev_mutex; spinlock_t irqlock; - struct timer_list timer; + struct delayed_work work_run; struct v4l2_m2m_dev *m2m_dev; }; @@ -336,12 +336,6 @@ static int device_process(struct vim2m_ctx *ctx, return 0; } -static void schedule_irq(struct vim2m_dev *dev, int msec_timeout) -{ - dprintk(dev, "Scheduling a simulated irq\n"); - mod_timer(&dev->timer, jiffies + msecs_to_jiffies(msec_timeout)); -} - /* * mem2mem callbacks */ @@ -387,13 +381,14 @@ static void device_run(void *priv) device_process(ctx, src_buf, dst_buf); - /* Run a timer, which simulates a hardware irq */ - schedule_irq(dev, ctx->transtime); + /* Run delayed work, which simulates a hardware irq */ + schedule_delayed_work(&dev->work_run, msecs_to_jiffies(ctx->transtime)); } -static void device_isr(struct timer_list *t) +static void device_work(struct work_struct *w) { - struct vim2m_dev *vim2m_dev = from_timer(vim2m_dev, t, timer); + struct vim2m_dev *vim2m_dev = + container_of(w, struct vim2m_dev, work_run.work); struct vim2m_ctx *curr_ctx; struct vb2_v4l2_buffer *src_vb, *dst_vb; unsigned long flags; @@ -805,6 +800,7 @@ static void vim2m_stop_streaming(struct vb2_queue *q) struct vb2_v4l2_buffer *vbuf; unsigned long flags; + flush_scheduled_work(); for (;;) { if (V4L2_TYPE_IS_OUTPUT(q->type)) vbuf = v4l2_m2m_src_buf_remove(ctx->fh.m2m_ctx); @@ -1015,6 +1011,7 @@ static int vim2m_probe(struct platform_device *pdev) vfd = &dev->vfd; vfd->lock = &dev->dev_mutex; vfd->v4l2_dev = &dev->v4l2_dev; + INIT_DELAYED_WORK(&dev->work_run, device_work); ret = video_register_device(vfd, VFL_TYPE_GRABBER, 0); if (ret) { @@ -1026,7 +1023,6 @@ static int vim2m_probe(struct platform_device *pdev) v4l2_info(&dev->v4l2_dev, "Device registered as /dev/video%d\n", vfd->num); - timer_setup(&dev->timer, device_isr, 0); platform_set_drvdata(pdev, dev); dev->m2m_dev = v4l2_m2m_init(&m2m_ops); @@ -1083,7 +1079,6 @@ static int vim2m_remove(struct platform_device *pdev) media_device_cleanup(&dev->mdev); #endif v4l2_m2m_release(dev->m2m_dev); - del_timer_sync(&dev->timer); video_unregister_device(&dev->vfd); v4l2_device_unregister(&dev->v4l2_dev); -- 2.20.1