Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp692917pxb; Mon, 25 Oct 2021 16:46:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyZkAnCxVMSVdEd9X4yoDJmR0TByKWt8qm24zLjz48/fSHzgjunA7yYLfkkeNlyU+iu3Aa2 X-Received: by 2002:a05:6402:128c:: with SMTP id w12mr11768808edv.107.1635205588187; Mon, 25 Oct 2021 16:46:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1635205588; cv=none; d=google.com; s=arc-20160816; b=mkuZt3ospPcMl0DiblXAG3w1/9LmCy0JhFZcuivm1Ymfv7e34JnzCyK7h7m57KXpdW /NIpYghgTe7G6PPYlXiKn+3VoGfbjt3fgNkFMHn6ww5RJtH0Vhu2DkeEpeuLKKHUcKvi op/edF4oyyGfCaE1uZXgh9B2rPwal3KVr1j3Wz6oq34NXG+92CYaQ/OkpRF2xp1aJscS paBmcn2+sLMrFAnW+fncPGqnbYKMiCrZ+W+WXN1cBSjKvMT6FMaEPTZZJXNKM0YlD9Ed FCZ4rY0lq2y0jsT/Csxp+wnV5slIj1oGEBXucfICNE32ndoNeAkN2DV7gDF6Ncj06I+M UT4g== 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=Nfa+HOEteYkc3fJ9mR1rkwSmlPVarvok/ltn2U5y3QQ=; b=YmvpTAdHwqBnKu3FDzfaABmUciuf4mb6CDcSIhPkT7kXSuav1jYh/LgB1w4nrOLKML B/2a4f7++ee1f64WPVDohtmsl00ZVXiiHQl/pxHwRTJTRerVtFFOGbQ9FnX2RB6L24r0 jaqfTw+oRZf8tWPLSwmeZmnBfC+U5Fg6leEMKS4EdrWUeTI1JpjV229feBKx8WrdekZ+ SaRovYErKJQK+NFkNQxQKvruUuq0+6QZ94CfGgkADHBEgUImWjcK3AUcyEM0eZXE0K3X tBAd4tuaOTKL8S0XYTT26OZSS3SzQoPw21BHjOThZfp2NAMyPO+Bc4HQZkiBroW2tjZ5 tHVA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=c8rHk1Og; 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 do17si3180154ejc.696.2021.10.25.16.46.05; Mon, 25 Oct 2021 16:46:28 -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=c8rHk1Og; 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 S235745AbhJYTlH (ORCPT + 99 others); Mon, 25 Oct 2021 15:41:07 -0400 Received: from mail.kernel.org ([198.145.29.99]:53202 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236462AbhJYTer (ORCPT ); Mon, 25 Oct 2021 15:34:47 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id EA40D610C7; Mon, 25 Oct 2021 19:30:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1635190250; bh=VVH7teXpOG0rBS5ztzfEEgBr0UQW99iHYWoRPaZPRdQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=c8rHk1OgbXv69ICcZT5+P3sIsPn3ZwSTRnrjKuoXJr6BsyOZR14f3xiBDGUablrg9 81/kl1IAqd7aMbObs+VUI6W/8fCHhEHiUP+oroOj49JGJ1vsYPSKA9Mft4RiVlQG4J AP/4ai/lTKRnY1VkFMsy0zcJqDKd+icXFK/e1sPs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Gerald Schaefer , Christoph Hellwig , Sasha Levin Subject: [PATCH 5.10 13/95] dma-debug: fix sg checks in debug_dma_map_sg() Date: Mon, 25 Oct 2021 21:14:10 +0200 Message-Id: <20211025190958.815473589@linuxfoundation.org> X-Mailer: git-send-email 2.33.1 In-Reply-To: <20211025190956.374447057@linuxfoundation.org> References: <20211025190956.374447057@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: Gerald Schaefer [ Upstream commit 293d92cbbd2418ca2ba43fed07f1b92e884d1c77 ] The following warning occurred sporadically on s390: DMA-API: nvme 0006:00:00.0: device driver maps memory from kernel text or rodata [addr=0000000048cc5e2f] [len=131072] WARNING: CPU: 4 PID: 825 at kernel/dma/debug.c:1083 check_for_illegal_area+0xa8/0x138 It is a false-positive warning, due to broken logic in debug_dma_map_sg(). check_for_illegal_area() checks for overlay of sg elements with kernel text or rodata. It is called with sg_dma_len(s) instead of s->length as parameter. After the call to ->map_sg(), sg_dma_len() will contain the length of possibly combined sg elements in the DMA address space, and not the individual sg element length, which would be s->length. The check will then use the physical start address of an sg element, and add the DMA length for the overlap check, which could result in the false warning, because the DMA length can be larger than the actual single sg element length. In addition, the call to check_for_illegal_area() happens in the iteration over mapped_ents, which will not include all individual sg elements if any of them were combined in ->map_sg(). Fix this by using s->length instead of sg_dma_len(s). Also put the call to check_for_illegal_area() in a separate loop, iterating over all the individual sg elements ("nents" instead of "mapped_ents"). While at it, as suggested by Robin Murphy, also move check_for_stack() inside the new loop, as it is similarly concerned with validating the individual sg elements. Link: https://lore.kernel.org/lkml/20210705185252.4074653-1-gerald.schaefer@linux.ibm.com Fixes: 884d05970bfb ("dma-debug: use sg_dma_len accessor") Signed-off-by: Gerald Schaefer Signed-off-by: Christoph Hellwig Signed-off-by: Sasha Levin --- kernel/dma/debug.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/kernel/dma/debug.c b/kernel/dma/debug.c index 445754529917..10d07ace46c1 100644 --- a/kernel/dma/debug.c +++ b/kernel/dma/debug.c @@ -1300,6 +1300,12 @@ void debug_dma_map_sg(struct device *dev, struct scatterlist *sg, if (unlikely(dma_debug_disabled())) return; + for_each_sg(sg, s, nents, i) { + check_for_stack(dev, sg_page(s), s->offset); + if (!PageHighMem(sg_page(s))) + check_for_illegal_area(dev, sg_virt(s), s->length); + } + for_each_sg(sg, s, mapped_ents, i) { entry = dma_entry_alloc(); if (!entry) @@ -1315,12 +1321,6 @@ void debug_dma_map_sg(struct device *dev, struct scatterlist *sg, entry->sg_call_ents = nents; entry->sg_mapped_ents = mapped_ents; - check_for_stack(dev, sg_page(s), s->offset); - - if (!PageHighMem(sg_page(s))) { - check_for_illegal_area(dev, sg_virt(s), sg_dma_len(s)); - } - check_sg_segment(dev, s); add_dma_entry(entry); -- 2.33.0