Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp11515ybt; Tue, 23 Jun 2020 13:58:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwzneI+MD2AJb+6/ZrxKynHd618OKO2VYDDialH6Ia3LtNzpE1HFG3R+CXq+Kied2WhPcn+ X-Received: by 2002:a50:cd17:: with SMTP id z23mr23319624edi.326.1592945906963; Tue, 23 Jun 2020 13:58:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592945906; cv=none; d=google.com; s=arc-20160816; b=kphfun+JP8j1yhA13eVyQMsLoOKkTBERVwC99TM0mkLc9IPjz17gNTN3XQuM4KdGH1 R3WuVqzB0Bso98atIX5RtG6NoYIRWLKFbtbHRwawf5rDzdSESxe/Tx4/FzJMYnJtlSDC 9fXIKTHme7uwRKKx+/IXcOD2WpTY3XsYdE7nqxkp9blb00rUtunPXN6iUuXwOvkoi662 f9YAycZy8nIk8xSDGglB6qfIKXo57ExK1wxDiCCBp6INd2W9JTYs5iZ2Udw/SZ7e9Lk7 HujRTDdqf72OgkrxpAeGFtIxGnSRKXcCaCVRqvDHqMNO4oZv4hHVuy0x5EhUDfwxCfeM bdjA== 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=XAQ5ZrOZ7eS7zQb52L7D7H1VpoePqKolmaSpAdcTyfU=; b=fi+wiwNKAYcIHWwzjeb3S7UNPIFlFU14iI4i/HTE1WTzDEo6371oWvngKYza6Pvlxh zcznG9PPaRATCHELonI7TQkhO9jx7HQ6vBYltLoHNxmRrLHcmatjvao/1EI5o+BRwYp/ d7c+12cUgelIXI1yD7gM+wYZTXigyyPGO9Nn4AfwxuYKH7LPD+uBnCNdyJ6AgsTb+lcw K1FBoeVrRZG0S1aP+Bto0ua0Jzdl9PTFEAKN2WZdoYMdkTvAcpxh1AoCmJWYf+e2jKOR bcO14mX04CpOpw0Y9BZY1/FvzX2HG7oQfye4JvEdFkhe1n3jWWcWvAxoUa6AZGnNw8NY 0i8A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Mx6plFsM; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z39si11506254ede.374.2020.06.23.13.58.03; Tue, 23 Jun 2020 13:58:26 -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=@kernel.org header.s=default header.b=Mx6plFsM; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2392746AbgFWUph (ORCPT + 99 others); Tue, 23 Jun 2020 16:45:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:42746 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2392651AbgFWUpT (ORCPT ); Tue, 23 Jun 2020 16:45:19 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.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 309C220781; Tue, 23 Jun 2020 20:45:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592945118; bh=hSEyuqMwO7cIXgTwp0Er+rWUOFbcA7OU5KskqUi6M3g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Mx6plFsMo99MRP728TIqaVthIhFfKA+XCGsFU0z/K09YqT/dFPBOw8TA8go8pbE0R 8cSxu+x2sadkLVFZ3WsHgmHSu3rj6dBU9spjyW2lmvCbunoq5W9ybabFpZhv1Hy5a6 qMID+ElWhdfb+piuqFoRy32Us1TMVfgAOtKkjoSA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Marek Vasut , Andrew Murray , Lorenzo Pieralisi , Sasha Levin Subject: [PATCH 4.14 047/136] PCI: rcar: Fix incorrect programming of OB windows Date: Tue, 23 Jun 2020 21:58:23 +0200 Message-Id: <20200623195306.008927678@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200623195303.601828702@linuxfoundation.org> References: <20200623195303.601828702@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Andrew Murray [ Upstream commit 2b9f217433e31d125fb697ca7974d3de3ecc3e92 ] The outbound windows (PCIEPAUR(x), PCIEPALR(x)) describe a mapping between a CPU address (which is determined by the window number 'x') and a programmed PCI address - Thus allowing the controller to translate CPU accesses into PCI accesses. However the existing code incorrectly writes the CPU address - lets fix this by writing the PCI address instead. For memory transactions, existing DT users describe a 1:1 identity mapping and thus this change should have no effect. However the same isn't true for I/O. Link: https://lore.kernel.org/r/20191004132941.6660-1-andrew.murray@arm.com Fixes: c25da4778803 ("PCI: rcar: Add Renesas R-Car PCIe driver") Tested-by: Marek Vasut Signed-off-by: Andrew Murray Signed-off-by: Lorenzo Pieralisi Reviewed-by: Marek Vasut Signed-off-by: Sasha Levin --- drivers/pci/host/pcie-rcar.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/drivers/pci/host/pcie-rcar.c b/drivers/pci/host/pcie-rcar.c index 2b0a1f3b8265f..0077afca24932 100644 --- a/drivers/pci/host/pcie-rcar.c +++ b/drivers/pci/host/pcie-rcar.c @@ -328,11 +328,12 @@ static struct pci_ops rcar_pcie_ops = { }; static void rcar_pcie_setup_window(int win, struct rcar_pcie *pcie, - struct resource *res) + struct resource_entry *window) { /* Setup PCIe address space mappings for each resource */ resource_size_t size; resource_size_t res_start; + struct resource *res = window->res; u32 mask; rcar_pci_write_reg(pcie, 0x00000000, PCIEPTCTLR(win)); @@ -346,9 +347,9 @@ static void rcar_pcie_setup_window(int win, struct rcar_pcie *pcie, rcar_pci_write_reg(pcie, mask << 7, PCIEPAMR(win)); if (res->flags & IORESOURCE_IO) - res_start = pci_pio_to_address(res->start); + res_start = pci_pio_to_address(res->start) - window->offset; else - res_start = res->start; + res_start = res->start - window->offset; rcar_pci_write_reg(pcie, upper_32_bits(res_start), PCIEPAUR(win)); rcar_pci_write_reg(pcie, lower_32_bits(res_start) & ~0x7F, @@ -377,7 +378,7 @@ static int rcar_pcie_setup(struct list_head *resource, struct rcar_pcie *pci) switch (resource_type(res)) { case IORESOURCE_IO: case IORESOURCE_MEM: - rcar_pcie_setup_window(i, pci, res); + rcar_pcie_setup_window(i, pci, win); i++; break; case IORESOURCE_BUS: -- 2.25.1