Received: by 2002:ac0:e34a:0:0:0:0:0 with SMTP id g10csp407270imn; Thu, 28 Jul 2022 04:34:25 -0700 (PDT) X-Google-Smtp-Source: AGRyM1t+2x7oD1GZ3PGBJWfZ3guc+E9xaFWSdLsC/Z0cuumaeExEX05duEwCRV5+Ws4q0OiBp5zm X-Received: by 2002:a17:90b:3a82:b0:1f2:18ea:90e5 with SMTP id om2-20020a17090b3a8200b001f218ea90e5mr9937876pjb.199.1659008065447; Thu, 28 Jul 2022 04:34:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659008065; cv=none; d=google.com; s=arc-20160816; b=kQe7ikJSQ6x/hOdnbfcfEDsIc7TDCSB1toEKXh2DDOMUjqVa6Bc1y9qzoFdo/R5ht2 gHkfq/FK/6hhQRV3xSxYNpaVw/0/uiPMb7QMKNaclL1tRyh7KPjhbJu0ss146wpC262K ucHfVZDunn6tiD5E33CeOoyyrsaZZEavKIZgDr+mqmBPi6H1xSRf4vVmIXEjjHbFRWv4 Gvr6Np5kTaBFTve65/5YYSRUsU+VsYkH/fevTUYEBa8+uRifejqT9gi4Av7+jOwG3yLu qGEahuWk4QK/9sCQ/olyTt+8KBpuDan9gxMXjQznJXUUllN4Vfa4fYtlFUAFmu0kTSq8 uLjw== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=6quWTjpWV5I5nvvlfLaHvQO0AsMBbCA9KCjJzXHXt+k=; b=LE+sX0dyfDVd4s083aC0wUqU8cBa8HLT8vwxwCQh9fLrjNS6kK47tSpSVHJAYFxXRn AZq9+EVatg3l/eXVPYDvgvJQbq1LFZ/rhrfH4NSXfAeXcMLLgcUrVoqKhPZKg4Un//WB 2bP4cZQsStfFPn+DOW5sP1AeUh7Mkh3dsYnAG80I81aYCee0ZLPs8MfoZE5tN2qpwho5 GfOFOvuc8IX4A43db4YGarod/YJG/my5mBziI+SKZaZkviRqVobuD6yhDDqaTVmjePV6 0sJG62zpKWn8iEmqNJ3JvwU2YQuZ5Z0ILs9/e9Ut9afGe/t+tnb+T6mKqwHAN1WrVanG oCSA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=kwm3KiyA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=baikalelectronics.ru Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id bg24-20020a17090b0d9800b001efc1b228f4si4498541pjb.104.2022.07.28.04.34.10; Thu, 28 Jul 2022 04:34:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=kwm3KiyA; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=baikalelectronics.ru Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236127AbiG1LV0 (ORCPT + 99 others); Thu, 28 Jul 2022 07:21:26 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47042 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236067AbiG1LTs (ORCPT ); Thu, 28 Jul 2022 07:19:48 -0400 Received: from mail.baikalelectronics.com (unknown [87.245.175.230]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 5467567589; Thu, 28 Jul 2022 04:19:30 -0700 (PDT) Received: from mail (mail.baikal.int [192.168.51.25]) by mail.baikalelectronics.com (Postfix) with ESMTP id 36F9116D1; Thu, 28 Jul 2022 14:21:51 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mail.baikalelectronics.com 36F9116D1 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baikalelectronics.ru; s=mail; t=1659007311; bh=6quWTjpWV5I5nvvlfLaHvQO0AsMBbCA9KCjJzXHXt+k=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=kwm3KiyAg/CEg8WJUGsN+C5wmENR8vIRhoI82KFVLMZ1B3P974dFVV2NWKkQDSipn 0q9U62yu6dRBJMLyvB4zWUQhXocAH0IAjLph4Pkr0PcdzmeuKE+xpr6FnOctHZjfLC ba/YzWgbdEgeCzQ/dI5DWRW4rebu7QYmySLzPR0E= Received: from localhost (192.168.53.207) by mail (192.168.51.25) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Thu, 28 Jul 2022 14:19:26 +0300 From: Serge Semin To: Damien Le Moal , Hans de Goede , Jens Axboe , Hannes Reinecke CC: Serge Semin , Serge Semin , Alexey Malahov , Pavel Parkhomenko , Rob Herring , , , Subject: [PATCH RESEND v6 13/23] ata: libahci: Discard redundant force_port_map parameter Date: Thu, 28 Jul 2022 14:18:54 +0300 Message-ID: <20220728111905.12427-14-Sergey.Semin@baikalelectronics.ru> In-Reply-To: <20220728111905.12427-1-Sergey.Semin@baikalelectronics.ru> References: <20220728111905.12427-1-Sergey.Semin@baikalelectronics.ru> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: MAIL.baikal.int (192.168.51.25) To mail (192.168.51.25) X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,T_SPF_PERMERROR autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently there are four port-map-related fields declared in the ahci_host_priv structure and used to setup the HBA ports mapping. First the ports-mapping is read from the PI register and immediately stored in the saved_port_map field. If forced_port_map is initialized with non-zero value then its value will have greater priority over the value read from PI, thus it will override the saved_port_map field. That value will be then masked by a non-zero mask_port_map field and after some sanity checks it will be stored in the ahci_host_priv.port_map field as a final port mapping. As you can see the logic is a bit too complicated for such a simple task. We can freely get rid from at least one of the fields with no change to the implemented semantic. The force_port_map field can be replaced with taking non-zero saved_port_map value into account. So if saved_port_map is pre-initialized by the low level drivers (platform drivers) then it will have greater priority over the value read from PI register and will be used as actual HBA ports mapping later on. Thus the ports map forcing task will be just transferred from force_port_map to the saved_port_map field. This modification will perfectly fit into the feature of having OF-based initialization of the HW-init HBA CSR fields we are about to introduce in the next commit. Signed-off-by: Serge Semin Reviewed-by: Hannes Reinecke --- drivers/ata/ahci.c | 2 +- drivers/ata/ahci.h | 1 - drivers/ata/libahci.c | 10 ++++++---- drivers/ata/libahci_platform.c | 2 +- 4 files changed, 8 insertions(+), 7 deletions(-) diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c index c1eca72b4575..bacb597a0d32 100644 --- a/drivers/ata/ahci.c +++ b/drivers/ata/ahci.c @@ -657,7 +657,7 @@ static void ahci_pci_save_initial_config(struct pci_dev *pdev, { if (pdev->vendor == PCI_VENDOR_ID_JMICRON && pdev->device == 0x2361) { dev_info(&pdev->dev, "JMB361 has only one port\n"); - hpriv->force_port_map = 1; + hpriv->saved_port_map = 1; } /* diff --git a/drivers/ata/ahci.h b/drivers/ata/ahci.h index 27cab4e909a5..cc4f40e6c924 100644 --- a/drivers/ata/ahci.h +++ b/drivers/ata/ahci.h @@ -328,7 +328,6 @@ struct ahci_port_priv { struct ahci_host_priv { /* Input fields */ unsigned int flags; /* AHCI_HFLAG_* */ - u32 force_port_map; /* force port map */ u32 mask_port_map; /* mask out particular bits */ void __iomem * mmio; /* bus-independent mem map */ diff --git a/drivers/ata/libahci.c b/drivers/ata/libahci.c index cf8c7fd59ada..000a7072614f 100644 --- a/drivers/ata/libahci.c +++ b/drivers/ata/libahci.c @@ -453,7 +453,6 @@ void ahci_save_initial_config(struct device *dev, struct ahci_host_priv *hpriv) * reset. Values without are used for driver operation. */ hpriv->saved_cap = cap = readl(mmio + HOST_CAP); - hpriv->saved_port_map = port_map = readl(mmio + HOST_PORTS_IMPL); /* CAP2 register is only defined for AHCI 1.2 and later */ vers = readl(mmio + HOST_VERSION); @@ -517,10 +516,13 @@ void ahci_save_initial_config(struct device *dev, struct ahci_host_priv *hpriv) cap &= ~HOST_CAP_SXS; } - if (hpriv->force_port_map && port_map != hpriv->force_port_map) { + /* Override the HBA ports mapping if the platform needs it */ + port_map = readl(mmio + HOST_PORTS_IMPL); + if (hpriv->saved_port_map && port_map != hpriv->saved_port_map) { dev_info(dev, "forcing port_map 0x%x -> 0x%x\n", - port_map, hpriv->force_port_map); - port_map = hpriv->force_port_map; + port_map, hpriv->saved_port_map); + port_map = hpriv->saved_port_map; + } else { hpriv->saved_port_map = port_map; } diff --git a/drivers/ata/libahci_platform.c b/drivers/ata/libahci_platform.c index 307908a0d69d..691737b1a5ba 100644 --- a/drivers/ata/libahci_platform.c +++ b/drivers/ata/libahci_platform.c @@ -527,7 +527,7 @@ struct ahci_host_priv *ahci_platform_get_resources(struct platform_device *pdev, } of_property_read_u32(dev->of_node, - "ports-implemented", &hpriv->force_port_map); + "ports-implemented", &hpriv->saved_port_map); if (child_nodes) { for_each_child_of_node(dev->of_node, child) { -- 2.35.1