Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp470843pxb; Thu, 21 Jan 2021 11:25:31 -0800 (PST) X-Google-Smtp-Source: ABdhPJz8OnNHkvyW/uJQ1UQm5jD2XkbjoCcxHnDNs+WI5eukzn9Gp82srF/7UrLFgleNFy/lrsOE X-Received: by 2002:a17:906:6d44:: with SMTP id a4mr679130ejt.453.1611257131111; Thu, 21 Jan 2021 11:25:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611257131; cv=none; d=google.com; s=arc-20160816; b=MygSnDLgze9VOWPqsxSWeYMbVxZ2Q3RzetyPVHx+HlM/lWtDprRE7fKN/sryKimptn +GOb6ioLYADX1zCA5h+ytvl2CCN+6nGWcObTBVJ9bAa1Z56kDCeFnjc7+zBIqLzd6D56 ltvPAGa2jwFMe8rZBqyt1olY0sMojuK7/5FQBO9d5t9B4iKCKmOmqLLt0XhV6rCaTTwy H8d011/qCZxcTUJYGngbDVD1KdJz2K1q8TX0oVchOg5m7ie1oMkbVyb8dY34w6oWiHf/ gI4uiVjGcF8NURxZbH8CNZPL7b5YNfVIadQ2upSvepaZDFJ8lxC6+B5TqsKycT+hQPAi aFyA== 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; bh=woffDF3uhRUDrdb3LU2Pk/FCA9mpI3Ytb8KoYeIYJeA=; b=PNjySr/+akjbk5yT7LDC9dqjwRwxNw5exiFMkduEYXB3X7KH/9sY43vgrWVbb9hGN1 oX0jijnvBndSClJ7QDeG7+nL3xbsESwIMzuTiRJTiLnpCHRASClh1yRd8pGdK+Ha5A8i U5GkwcS/uAXcWdd1fHTuX2DBgvmWWKhZCVjwA5U2hHGH3SEPXZ/vAbuZk3Hz4Rkxlmui S2jb+0vpjuAZwikL5R+McLMwGlmqMyIw040kmD8eUG7mOWKgAoOQPjyrQg87X55+B0PL Cs91tqK7rK3SNgLTJ0k7U5+vxU+JaJ/EOJjZjtM1zL16xCwQtSRkij/QbVcGZjFXv/0Z Wi1w== ARC-Authentication-Results: i=1; mx.google.com; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lg3si2134300ejb.158.2021.01.21.11.25.05; Thu, 21 Jan 2021 11:25:31 -0800 (PST) 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; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727284AbhAUTW7 (ORCPT + 99 others); Thu, 21 Jan 2021 14:22:59 -0500 Received: from mail-pj1-f49.google.com ([209.85.216.49]:54055 "EHLO mail-pj1-f49.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727020AbhAUTQ5 (ORCPT ); Thu, 21 Jan 2021 14:16:57 -0500 Received: by mail-pj1-f49.google.com with SMTP id p15so2259948pjv.3; Thu, 21 Jan 2021 11:16:41 -0800 (PST) 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=woffDF3uhRUDrdb3LU2Pk/FCA9mpI3Ytb8KoYeIYJeA=; b=IIU02koRSEoT4q8Q9ehofpACmz28KHNp5Hoo0ciG0PZFexGoI6CrB1+Xk8QwfjWevd 9aPp+easnrBYUHsSJIoIo5AZOwH4mPI85IjM6Ovh61PWTrjXE44HqZs+mr6em35jqaGa EeVgBUpgL7u15YnhNnXXicdzfmcBNZVH/5hhEM6nJH9R/8cjNC82E6c1SJ8m8Hb7dzhj kW7zpezLwdNWgixcStg0onr3zTfVOjazOP4jvjxtUhUy8p1UkfN8poImx0/JPZeNNM7F CGpMvXkKLf2j/lGXklS4Pm7FZva+fP1Pv0UbuLcOFEZMPdqgj79+Ud8h2x7I8r05/afi hWWg== X-Gm-Message-State: AOAM532jzK13OBfeXyDxm8FOvUju0u68R+8+TuzkaEgVQ8MogjADldH+ SIlsGdWLRU0Jex1oyeVCbaY= X-Received: by 2002:a17:902:6b0a:b029:dc:31af:8dc3 with SMTP id o10-20020a1709026b0ab02900dc31af8dc3mr1144525plk.41.1611256576405; Thu, 21 Jan 2021 11:16:16 -0800 (PST) Received: from localhost ([2601:647:5b00:1162:1ac0:17a6:4cc6:d1ef]) by smtp.gmail.com with ESMTPSA id w7sm6270590pfb.62.2021.01.21.11.16.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 21 Jan 2021 11:16:15 -0800 (PST) From: Moritz Fischer To: lorenzo.pieralisi@arm.com Cc: guohanjun@huawei.com, sudeep.holla@arm.com, rjw@rjwysocki.net, linux-acpi@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, moritzf@google.com, will@kernel.org, Moritz Fischer Subject: [PATCH] ACPI/IORT: Do not blindly trust DMA masks from firmware Date: Thu, 21 Jan 2021 11:16:12 -0800 Message-Id: <20210121191612.90387-1-mdf@kernel.org> X-Mailer: git-send-email 2.30.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Address issue observed on real world system with suboptimal IORT table where DMA masks of PCI devices would get set to 0 as result. iort_dma_setup() would query the root complex' IORT entry for a DMA mask, and use that over the one the device has been configured with earlier. Ideally we want to use the minimum mask of what the IORT contains for the root complex and what the device was configured with, but never 0. Fixes: 5ac65e8c8941 ("ACPI/IORT: Support address size limit for root complexes") Signed-off-by: Moritz Fischer --- Hi all, not sure I'm doing this right, but I think the current behavior (while a corner case) seems to also fail for 32 bit devices if the IORT specifies 64 bit. It works on my test system now with a 32 bit device. Open to suggestions for better solutions (and maybe the nc_dma_get_range() should have the same sanity check?) Thanks, Moritz --- drivers/acpi/arm64/iort.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/drivers/acpi/arm64/iort.c b/drivers/acpi/arm64/iort.c index d4eac6d7e9fb..c48eabf8c121 100644 --- a/drivers/acpi/arm64/iort.c +++ b/drivers/acpi/arm64/iort.c @@ -1126,6 +1126,11 @@ static int rc_dma_get_range(struct device *dev, u64 *size) rc = (struct acpi_iort_root_complex *)node->node_data; + if (!rc->memory_address_limit) { + dev_warn(dev, "Root complex has broken memory_address_limit\n"); + return -EINVAL; + } + *size = rc->memory_address_limit >= 64 ? U64_MAX : 1ULL<memory_address_limit; @@ -1172,9 +1177,9 @@ void iort_dma_setup(struct device *dev, u64 *dma_addr, u64 *dma_size) */ end = dmaaddr + size - 1; mask = DMA_BIT_MASK(ilog2(end) + 1); - dev->bus_dma_limit = end; - dev->coherent_dma_mask = mask; - *dev->dma_mask = mask; + dev->bus_dma_limit = min_not_zero(dev->bus_dma_limit, end); + dev->coherent_dma_mask = min_not_zero(dev->coherent_dma_mask, mask); + *dev->dma_mask = min_not_zero(*dev->dma_mask, mask); } *dma_addr = dmaaddr; -- 2.30.0