Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4672258pxj; Wed, 12 May 2021 10:33:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzg6KjjrFO4gCb2kcZCWkCf2/7Az0bqmjx7A+KKO7/ndK1kQffJf6nLS9IcXJvjZqQ6stq6 X-Received: by 2002:a05:6402:154d:: with SMTP id p13mr45644546edx.371.1620840782930; Wed, 12 May 2021 10:33:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620840782; cv=none; d=google.com; s=arc-20160816; b=pcmaDst269uGanP4Q5GiG201jlvNFpt5nN16W7tRHwPP7RGsdVT0nVX7qC+oerc0Dc mzBAEqJTj05WCELbhEyIHU7LboPDp1WVio2TrykLou5mCpIHuq/Dwi867HvwPMfsXUed jdjNbR4KxxqD9riKN83W3OzDQKb2xjt+DK3K9RhBQyyI0+Du5jsZ1C8M/jHimv2MzPkI BJLWDKuzbISToRFaLv28gNoiGlTLq6PpGwC8y7+Y7TF8kQ/FjjLTNjpwM9hK+MKTvHpn zuQp5aPYpXKarNNrMtt4pyU9AZbxTzr63OEDkHbzOjCiedGLgWJJJOhQjVYOrzZM8PM1 knDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=3gUrj5QxQyetgpJ3fcDH5iDQ32I+Dh89gm7z9dewGdI=; b=zvbEl10CexdqzJBEIEHnuXaVtTB2f/FX2eQTM1vzKrc4PoSDz8KMoosZ9SUe33m9AR QB4NnFkfdTEPps10nUxG03rcP4A1/jvxhCCw3LVKHQ48//IVviNAo/LBNpsQoWz4zZPW G3qOc2UPcFRWQ0wEiJF3S7Mkd3jIc27SLRtO+H9l7iOxCu3buKfEGUaMrFNbnXgcsZbD NREFZmPPy5JxfGD0b3s1f959uip0Ii/AkVZwwOiM8S8agoUNBLd/rPJU4JoXodCXrE9L MpBztsiv1b1wWafBbDcM6CeBN6JO+/lLEVOyxrFQykMOq4lFlhgof3iUrMUrfhdcAKO9 Wdig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JJNMHviO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n20si642599ejz.659.2021.05.12.10.32.38; Wed, 12 May 2021 10:33:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JJNMHviO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347590AbhELR3B (ORCPT + 99 others); Wed, 12 May 2021 13:29:01 -0400 Received: from mail.kernel.org ([198.145.29.99]:36284 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239386AbhELQH6 (ORCPT ); Wed, 12 May 2021 12:07:58 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 7909761D2A; Wed, 12 May 2021 15:37:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620833861; bh=lIzSTWoTMrLRGgwJlo1EfEcmVMeaSwWFPEv7qGRKZIY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JJNMHviO5mZeGnYWMjtVU767W23MUHfod48gt5XLcqJ0TwRgnoMweqCFNbCyd0A3G PXwPhzyH7ZMrHNax9xuwkiFcJSyVlxFeQp3vWa+PFwNdylT6vCUlfsnl7zLQb+pMDQ gxOJ+OVqsEXUKwrzm274Vhj20YILBRXNOyH24yFU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tasos Sahanidis , Hans Verkuil , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 5.11 317/601] media: saa7134: use sg_dma_len when building pgtable Date: Wed, 12 May 2021 16:46:34 +0200 Message-Id: <20210512144838.254903845@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144827.811958675@linuxfoundation.org> References: <20210512144827.811958675@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tasos Sahanidis [ Upstream commit 4e1cb753c04d74e06d7ca826ea0bcb02526af03e ] The new AMD IOMMU DMA implementation concatenates sglist entries under certain conditions, and because saa7134 accessed the length member directly, it did not support this scenario. This fixes IO_PAGE_FAULTs and choppy DMA audio by using the sg_dma_len macro. Fixes: be62dbf554c5 ("iommu/amd: Convert AMD iommu driver to the dma-iommu api") Signed-off-by: Tasos Sahanidis Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/pci/saa7134/saa7134-core.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/media/pci/saa7134/saa7134-core.c b/drivers/media/pci/saa7134/saa7134-core.c index 391572a6ec76..efb757d5168a 100644 --- a/drivers/media/pci/saa7134/saa7134-core.c +++ b/drivers/media/pci/saa7134/saa7134-core.c @@ -243,7 +243,7 @@ int saa7134_pgtable_build(struct pci_dev *pci, struct saa7134_pgtable *pt, ptr = pt->cpu + startpage; for (i = 0; i < length; i++, list = sg_next(list)) { - for (p = 0; p * 4096 < list->length; p++, ptr++) + for (p = 0; p * 4096 < sg_dma_len(list); p++, ptr++) *ptr = cpu_to_le32(sg_dma_address(list) + list->offset + p * 4096); } -- 2.30.2