Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp3031079pxb; Mon, 19 Apr 2021 21:55:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyL6/lnDRzzJcNh3GrXXt+dOuO3SO47b1fzoxn0WQNJOjEEWh7x0rRass3EMfegLDWIRbbw X-Received: by 2002:a62:1910:0:b029:25d:44b5:2196 with SMTP id 16-20020a6219100000b029025d44b52196mr11973056pfz.44.1618894511119; Mon, 19 Apr 2021 21:55:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618894511; cv=none; d=google.com; s=arc-20160816; b=ESzJYFEArNlWshC/ZLH5LgFbaLx2KoivXw6/5vBk+SwHgeDkW/9sgbeSvKCrQhWbyU c1zNLWovu6Hh8KKrvDSsSbFMBMmRZVVh7PE2xFr9DJCS+zK4CxW9sSqzEeT9O7+iXa1s bfgiyvFZvQR9YJq/2/IYJpL9CNGCD6iW0901r01s9kD35Y3aNub298n1gO23XgMekxY8 9IEVev65z/gt/Xnbysm6OR4xB9dMeEAZ/jhWF1K5n0OjabLxLjkmtfBFebIkmJ/UGD0v zBwmAXLy/kLOC6QAEsAHAYHpkZUwVHvV8X8F057nMo1w77mvEDtozeuIX9fnlPt1G1qB uv8g== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=knEsnqVVpHBAjh8i95W10HK2zNEcEEQ59QU8Kyx/Vek=; b=zhco8M1Gf6OFF18hrj3AhIzzbdXvIaLky1BE7XrRAurOQZ5GwAElaMclW6OC0iGQcs f43rZ0MMBoMgWfPi1nCC055t2wW9EbIdrKeW3HR8Ia/6zQ7dJqvrNa9ibuN4bnSFF6lL 7jm6FOslITqMe1gBW1SEhV5toZXTlDsW9o3MdYN+itqpi5r22iAEfDZ3g1AB8HSu5UqQ xHgZ2vBCspKFitn8QIQNcLC5HPuIlQ9czIq/62RQTjtY8pwn2vU4TdW50GahiKSs3HI9 bstW8vfLhPsXcrdKcNZTAcKB1DYYR1L0qa78ZBfe33EYtr1mBLyhzqQHXckdfRjb40Oh ykFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bq2Fqkoq; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f11si20155792plo.17.2021.04.19.21.54.58; Mon, 19 Apr 2021 21:55:11 -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=@gmail.com header.s=20161025 header.b=bq2Fqkoq; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229724AbhDTEyv (ORCPT + 99 others); Tue, 20 Apr 2021 00:54:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37780 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229507AbhDTEyu (ORCPT ); Tue, 20 Apr 2021 00:54:50 -0400 Received: from mail-qk1-x732.google.com (mail-qk1-x732.google.com [IPv6:2607:f8b0:4864:20::732]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 06A1CC06174A for ; Mon, 19 Apr 2021 21:54:20 -0700 (PDT) Received: by mail-qk1-x732.google.com with SMTP id e13so28376102qkl.6 for ; Mon, 19 Apr 2021 21:54:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=knEsnqVVpHBAjh8i95W10HK2zNEcEEQ59QU8Kyx/Vek=; b=bq2FqkoqFeOqQJDjYkFKExA6zH8OpGUykxjhtJTGayymtQoErLUJeDmJs6EZ/rNSs0 ndAnArkadebgcSDRHxAknJxszrFhVcvkzaXQfDMxbYGSNXNCXouNBUJ3a/XMvXgSpK0M W2lEIcAGeetVj2JZkpxgGTxUQqiTJFqwG1Otde4GWCKdvcp2LbN3DcmQMUyC8pszxcfo WwSA46Cy3r9KdLqPaCkwthNlajAATRD0lDadB92WDtRFZY0zkotr+LBRqIm6ZS+UL+wW Ea8ZRsd5tZchDCYfRRrWT9ojV9J2CmO8S1op2ysGbDZegRIhYpmhVNdqc6HXK9+cofjr K7ng== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=knEsnqVVpHBAjh8i95W10HK2zNEcEEQ59QU8Kyx/Vek=; b=dAHvfp0daEIAH7QMxLr0RUWHLhOQsPWPjydfE2Vw7oti/Ecp8p6L+RQYou2BYgjXfu n8GB+FQRhbz+4+Rs9qoR/y0hgfIPCdLNa0FiuCdvNGbhlBgC2OTXM/2WG+tDB8oTPzWp xHYYSu15pT2ojRdSNYDHs2QD9CadK6KBdhGgW4XMzp2KAlooD7CSW7Fa2IGAlQZ7lXv0 eAPyQxx7Z4tLx37DlrBNVjCnSnLjTgtcXNfmDP6w40bbuEg5w3iAgWfrKpjro+AmxDc6 DV+8keQVi6vyqjLUi5xB1VF2gATIzxpP9cb0j0CnHp8QYNjZG+o1zbZwZnj4u+tuFhNi cP8w== X-Gm-Message-State: AOAM531ijTPNT/ZccXMxkY1dthDBZPIW2GXA2JA3xD6nfarmKVvkroad vn8+bVCUEZlltt1pGggwja0= X-Received: by 2002:ae9:e912:: with SMTP id x18mr15662415qkf.315.1618894459007; Mon, 19 Apr 2021 21:54:19 -0700 (PDT) Received: from li-908e0a4c-2250-11b2-a85c-f027e903211b.ibm.com ([177.35.200.187]) by smtp.gmail.com with ESMTPSA id y29sm10930176qtm.13.2021.04.19.21.54.16 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 19 Apr 2021 21:54:18 -0700 (PDT) From: Leonardo Bras To: Michael Ellerman , Benjamin Herrenschmidt , Paul Mackerras , Leonardo Bras , Alexey Kardashevskiy Cc: linuxppc-dev@lists.ozlabs.org, linux-kernel@vger.kernel.org Subject: [PATCH 1/1] powerpc/pseries/iommu: Fix window size for direct mapping with pmem Date: Tue, 20 Apr 2021 01:54:04 -0300 Message-Id: <20210420045404.438735-1-leobras.c@gmail.com> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As of today, if the DDW is big enough to fit (1 << MAX_PHYSMEM_BITS) it's possible to use direct DMA mapping even with pmem region. But, if that happens, the window size (len) is set to (MAX_PHYSMEM_BITS - page_shift) instead of MAX_PHYSMEM_BITS, causing a pagesize times smaller DDW to be created, being insufficient for correct usage. Fix this so the correct window size is used in this case. Fixes: bf6e2d562bbc4("powerpc/dma: Fallback to dma_ops when persistent memory present") Signed-off-by: Leonardo Bras --- arch/powerpc/platforms/pseries/iommu.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/powerpc/platforms/pseries/iommu.c b/arch/powerpc/platforms/pseries/iommu.c index 9fc5217f0c8e..836cbbe0ecc5 100644 --- a/arch/powerpc/platforms/pseries/iommu.c +++ b/arch/powerpc/platforms/pseries/iommu.c @@ -1229,7 +1229,7 @@ static u64 enable_ddw(struct pci_dev *dev, struct device_node *pdn) if (pmem_present) { if (query.largest_available_block >= (1ULL << (MAX_PHYSMEM_BITS - page_shift))) - len = MAX_PHYSMEM_BITS - page_shift; + len = MAX_PHYSMEM_BITS; else dev_info(&dev->dev, "Skipping ibm,pmemory"); } -- 2.30.2