Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp2274656imb; Mon, 4 Mar 2019 00:27:25 -0800 (PST) X-Google-Smtp-Source: APXvYqxZW3r5AqkENe8G2SguVZYJViaFfeNb2e6aRFJHqpGbTmAOtv2Bd6c9rtIsdkcPXC/cZ9aU X-Received: by 2002:a17:902:9307:: with SMTP id bc7mr19057486plb.234.1551688044962; Mon, 04 Mar 2019 00:27:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551688044; cv=none; d=google.com; s=arc-20160816; b=QuI+NnjzReAn+KNpaO5p1oxKG/T68S0iKvNYJ1d3OPViRQUET2Su2HcFVMlaKlmL3/ uC7aUtiZhbeRRyYBohrYZatDs0KEPuimYzuhFnA1/A29eI/eOMXD7YM7QY5dwToXGuT9 T+crZqdCoCbfHCOrMhKxfRt3FAmbXf4RIY7IV1yTVIxZEbGJKiLxPqFvk/waR4eG3jBF SId6YggH/cPLOxVOZ5kOp42kE2WNutI4wF0hu+dyxNodBJo3OHUJub4LzrDsMvYEBJNq OxijZRo0oJb07QxpxZ3I4UGXVdghpbV6HoGSQf0tiUaHwh33tdhI71jrimU42T3jsoz9 UDNw== 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=qyEUKaUDYHqEmD0A6aj2Sk7D649HyYEc2kqhcY5rhow=; b=b/Zt/FNOs2aazZs/wbdnV+GyfLxLe8B1p7yof6HfzwbZCbM3ktVofCDRLEU3aAeY7H amKfGEQbnlooBQI4Subc/AKGqVHwiSqAoNBiHTYTTOH2HsufOzuJ3aFZypuhJzk3cQHe seaiFfssoN07jZ5MRx6UsAwFfzQcAv1fZZ4WG3TzH1HCG9Rvksf0txzxTkZ/BrBPJtz6 DWvo2mHBQ1ClHxsXCubQtObm9hKk92+H5hdGr9JzWEcD1Ff7V+0L3aw+CIKg2cVPgFJl yZAdqPZspM8eGnO0spb22GCg2vS7TuddzbCp9HiJmDTyYU0Mv4LGXq4/5g1VZ7/7wnef nTrw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UNLtbzxl; 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 a16si4499613pgw.75.2019.03.04.00.27.06; Mon, 04 Mar 2019 00:27:24 -0800 (PST) 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=UNLtbzxl; 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 S1726774AbfCDIZ5 (ORCPT + 99 others); Mon, 4 Mar 2019 03:25:57 -0500 Received: from mail.kernel.org ([198.145.29.99]:45034 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726620AbfCDIZX (ORCPT ); Mon, 4 Mar 2019 03:25:23 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.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 3290820823; Mon, 4 Mar 2019 08:25:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1551687922; bh=0p8AZC2HaXunAYoPZc7xTCeytp0Y/XYTL7kJf3f8U7A=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UNLtbzxlfpQY4MxoFj3EbeKR61SgpwPe41ifHD4yPZ13Co4XULVSQIzhQ/oa+oxTh eeLUtNT97ZpxegA/UHKCoYuOm2lsm2NVpLCR5Nsn02D9RgbNhQh4j557YA0y1Q/uOD OHUFmgafSToKTFqxmHTMBPPXi+iWtXn7EEo8KC0M= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Liam Mark , Laura Abbott , "Andrew F. Davis" , Sasha Levin Subject: [PATCH 4.14 30/52] staging: android: ion: Support cpu access during dma_buf_detach Date: Mon, 4 Mar 2019 09:22:28 +0100 Message-Id: <20190304081618.906201602@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190304081617.159014799@linuxfoundation.org> References: <20190304081617.159014799@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore 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 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit 31eb79db420a3f94c4c45a8c0a05cd30e333f981 ] Often userspace doesn't know when the kernel will be calling dma_buf_detach on the buffer. If userpace starts its CPU access at the same time as the sg list is being freed it could end up accessing the sg list after it has been freed. Thread A Thread B - DMA_BUF_IOCTL_SYNC IOCT - ion_dma_buf_begin_cpu_access - list_for_each_entry - ion_dma_buf_detatch - free_duped_table - dma_sync_sg_for_cpu Fix this by getting the ion_buffer lock before freeing the sg table memory. Fixes: 2a55e7b5e544 ("staging: android: ion: Call dma_map_sg for syncing and mapping") Signed-off-by: Liam Mark Acked-by: Laura Abbott Acked-by: Andrew F. Davis Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/staging/android/ion/ion.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/staging/android/ion/ion.c b/drivers/staging/android/ion/ion.c index 24cb666c92242..dd96ca61a5152 100644 --- a/drivers/staging/android/ion/ion.c +++ b/drivers/staging/android/ion/ion.c @@ -257,10 +257,10 @@ static void ion_dma_buf_detatch(struct dma_buf *dmabuf, struct ion_dma_buf_attachment *a = attachment->priv; struct ion_buffer *buffer = dmabuf->priv; - free_duped_table(a->table); mutex_lock(&buffer->lock); list_del(&a->list); mutex_unlock(&buffer->lock); + free_duped_table(a->table); kfree(a); } -- 2.19.1