Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp10376782ybi; Wed, 24 Jul 2019 22:04:25 -0700 (PDT) X-Google-Smtp-Source: APXvYqywpSaigb9NVh8OmU29YGst18j865jUZr90hIw9KRwtjS4UXCZnBxN+PEnN6dZnb4zBCTi5 X-Received: by 2002:a17:902:724c:: with SMTP id c12mr87615490pll.219.1564031065194; Wed, 24 Jul 2019 22:04:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564031065; cv=none; d=google.com; s=arc-20160816; b=RO5ZbkGqgpiKKInOdv68SDZyHrQgGarz93llcamcE4AQjXFLjHgSuU2bJq4fAJM8xE iuJuv0iiICH58kxaqlldBn03cC1uI6csOHia4AuimQtoCW3CqhXfuOgSV2ViMcs3x/BW WrP3Wj0ua8zOi38gamMEp44FkO/ffWQGE+gsgavuSNXH5ScPXA2PsDeklf8n3MFVX5NO sLomHM2T+VP6dYGm7vFJVCnNsSOM/YH/c88u+OG7OahYEt12v0D7DXFt4hSyAATaDEGC 7Ijcrm3eGzUgHTnjiDLCNy9Yr3JshiwZZGrTWyftfxsIXDBw5jXC7fku4s7rlIOd7nIy kzYw== 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=B42Y83KMQAnP2QeN8ey7bP9415QtfgBID7Mbd1/Gztw=; b=azlRRW/f3l3NTKsFKzU31pfkSS7yGnHWJ0yupERjSFgZe8v/rBN+A7yxPaNykErYYO mZzsmtJ7xcfiTqO+59HJI/6k9fYM6XoTewG/KjPXKcCAq08HssKtrU5IyIUTQeEblnAM aqL4+4tdEb4dPjZDPzkE8ZvWDpGixVaq06sa5Akb0Tpt5HLmP4+fVAosey3dVj5eZD5z y4PfJ+xhLFjKIJ4xBYyGdNW3L9AcHW2uil7IrNHQ432K6vbtbC7V5Ljc4NjoQLXjwGLr ttnJPHtSe+YaP0eenkdvmaSX42+fZcW8/fYzbisYSfhZwgb7u3IGPv+TtbsEu71K0d8E lktA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=zh97Spk+; 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 f131si15037370pgc.265.2019.07.24.22.04.10; Wed, 24 Jul 2019 22:04:25 -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=zh97Spk+; 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 S2390994AbfGXTtg (ORCPT + 99 others); Wed, 24 Jul 2019 15:49:36 -0400 Received: from mail.kernel.org ([198.145.29.99]:57572 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2391234AbfGXTt0 (ORCPT ); Wed, 24 Jul 2019 15:49:26 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 B18F020665; Wed, 24 Jul 2019 19:49:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1563997765; bh=yL+KvxT1tNhcgqkhv++XfEEuUzH9j4v+N/fbQYIOX4c=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zh97Spk+jyxp1k/Qsm9KZ0HcTED+bb+PCrwChhf8bf4fxhmLlB+hfbV312sdYLAKY +qr3lnXthPLz7d/9du/nIXyWraENk/ONCyfaO/ETt21JvfE7xKXO6EFfz0eIPHAuha 4BAI9+niGNPKSzTyU795L+L4GXjER3DOFPO4RMpI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marco Felsch , Lucas Stach , Philipp Zabel , Hans Verkuil , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 5.1 136/371] media: coda: fix last buffer handling in V4L2_ENC_CMD_STOP Date: Wed, 24 Jul 2019 21:18:08 +0200 Message-Id: <20190724191735.187565291@linuxfoundation.org> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190724191724.382593077@linuxfoundation.org> References: <20190724191724.382593077@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 f3775f89852d167990b0d718587774cf00d22ac2 ] coda_encoder_cmd() is racy, as the last scheduled picture run worker can still be in-flight while the ENC_CMD_STOP command is issued. Depending on the exact timing the sequence numbers might already be changed, but the last buffer might not have been put on the destination queue yet. In this case the current implementation would prematurely wake the destination queue with last_buffer_dequeued=true, causing userspace to call streamoff before the last buffer is handled. Close this race window by synchronizing with the pic_run_worker before doing the sequence check. Signed-off-by: Marco Felsch [l.stach@pengutronix.de: switch to flush_work, reword commit message] Signed-off-by: Lucas Stach Signed-off-by: Philipp Zabel Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/platform/coda/coda-common.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/media/platform/coda/coda-common.c b/drivers/media/platform/coda/coda-common.c index fa0b22fb7991..9bf2116ffc76 100644 --- a/drivers/media/platform/coda/coda-common.c +++ b/drivers/media/platform/coda/coda-common.c @@ -1007,6 +1007,8 @@ static int coda_encoder_cmd(struct file *file, void *fh, /* Set the stream-end flag on this context */ ctx->bit_stream_param |= CODA_BIT_STREAM_END_FLAG; + flush_work(&ctx->pic_run_work); + /* If there is no buffer in flight, wake up */ if (!ctx->streamon_out || ctx->qsequence == ctx->osequence) { dst_vq = v4l2_m2m_get_vq(ctx->fh.m2m_ctx, -- 2.20.1