Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp2373333rwn; Fri, 9 Sep 2022 12:39:54 -0700 (PDT) X-Google-Smtp-Source: AA6agR4lQ0F+owpay4+HZOGzKSYjFlET65I/xMyjym59SwcJiEm7qdQQAMf53IesEQLVGdMISP2/ X-Received: by 2002:a17:907:2cd3:b0:741:550e:17ea with SMTP id hg19-20020a1709072cd300b00741550e17eamr10732988ejc.595.1662752394341; Fri, 09 Sep 2022 12:39:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662752394; cv=none; d=google.com; s=arc-20160816; b=FwsIHLA+tV91dcqSpWPj/E3mIZjikuglY7ftFl4hRgTG7SOQV2EcH9Y+FH3KvTc2E8 QRQXfn9Y0ZAuDKgV3q5nFp54qhR54EU0F3Qp6q8xv70cqqXOXJvfLkgWJ9jkNXQucg0u GFLsRM8pmsVygpLRD2Ob2BZ1dQafe+iWwLypbfIV2PirTWOeP+yTzA5I2gP25hhvtBMG 89hEaagiP0uIvtGGxvlOSFiarzVgNBZrlqc4yxr5BnHIsA0q4vq6gAYX8Q7cF6kBNUKQ BG6G/hqaUfIKcxsY+2WMntOJST9SGYkQB0JGXsfWXXRRHi/WyZBqTyvjt2JBFBCIuhi0 rDtg== 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=lR+XuoZ5OpBeN2gxrD/crsk4SZmx3KT/fJ296KmTZDU=; b=KqfxM/VVZkdunINubhKquqJUVl/iU3sbJ5urqANTNWWXaZ3aU0H9BlI2/LS+E7VArK ZG4MkKdgRL7NRfyaLBoj1M/OjfaYO+t9iW4OjqxYhmbop4ktw7TNmujwmAFT8oj6HVYB VIH4SxAnaOjNnZlcgev8w9vG6lAWztOhB0iRShwuWl34SNvWb4GG7WgXEn6ft5LuaT3P LelDLDlQz8SAy7qMJcT4LB+F9QQpL4JHazY6bplvh5xVIzhg0y4w/DYYygihO3+AB1cD FWv7y2a2D37cbari9a796LFha3QlOXYKxMemQz4eOIjw3r0d9n8vLdVYm+Xd+0bEqHCd iVwA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=dkQ7x92r; 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 dm20-20020a170907949400b0077967fbb569si1080558ejc.431.2022.09.09.12.39.29; Fri, 09 Sep 2022 12:39:54 -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=dkQ7x92r; 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 S231616AbiIITiP (ORCPT + 99 others); Fri, 9 Sep 2022 15:38:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38502 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231538AbiIIThM (ORCPT ); Fri, 9 Sep 2022 15:37:12 -0400 Received: from mail.baikalelectronics.com (mail.baikalelectronics.com [87.245.175.230]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 3660C11B037; Fri, 9 Sep 2022 12:36:46 -0700 (PDT) Received: from mail (mail.baikal.int [192.168.51.25]) by mail.baikalelectronics.com (Postfix) with ESMTP id BD46DDBE; Fri, 9 Sep 2022 22:40:27 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mail.baikalelectronics.com BD46DDBE DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baikalelectronics.ru; s=mail; t=1662752427; bh=lR+XuoZ5OpBeN2gxrD/crsk4SZmx3KT/fJ296KmTZDU=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=dkQ7x92rwf4ZFGPkITL4+WyM0/2sdRRqBOD8LTdLfDPJFUUgk3LyPApiRqFDlQSoF RyHGPCSvDKXnSxJmZdwaQQQnCcCP/hNo87eg2bFrQZa+AkcwQbgBO37yQyPcU10op4 fRYZi0qr6UvIg/HtJARYcugtNHtU/B6wE+38R5fM= Received: from localhost (192.168.168.10) by mail (192.168.51.25) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Fri, 9 Sep 2022 22:36:39 +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 , Krzysztof Kozlowski , , , Subject: [PATCH v8 12/23] ata: libahci: Extend port-cmd flags set with port capabilities Date: Fri, 9 Sep 2022 22:36:10 +0300 Message-ID: <20220909193621.17380-13-Sergey.Semin@baikalelectronics.ru> In-Reply-To: <20220909193621.17380-1-Sergey.Semin@baikalelectronics.ru> References: <20220909193621.17380-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,SPF_PASS, T_SCC_BODY_TEXT_LINE 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 not all of the Port-specific capabilities listed in the PORT_CMD-enumeration. Let's extend that set with the Cold Presence Detection and Mechanical Presence Switch attached to the Port flags [1] so to closeup the set of the platform-specific port-capabilities flags. Note these flags are supposed to be set by the platform firmware if there is one. Alternatively as we are about to do they can be set by means of the OF properties. While at it replace PORT_IRQ_DEV_ILCK with PORT_IRQ_DMPS and fix the comment there. In accordance with [2] that IRQ flag is supposed to indicate the state of the signal coming from the Mechanical Presence Switch. [1] Serial ATA AHCI 1.3.1 Specification, p.27 [2] Serial ATA AHCI 1.3.1 Specification, p.24, p.88 Signed-off-by: Serge Semin Reviewed-by: Hannes Reinecke --- Changelog v4: - Fix the DMPS macros name in the patch log. (@Sergei Shtylyov) Changelog v5: - Add a comment regarding the PORT_CMD_CAP enum entity purpose. (@Damien) --- drivers/ata/ahci.h | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/drivers/ata/ahci.h b/drivers/ata/ahci.h index 7d834deefeb9..27cab4e909a5 100644 --- a/drivers/ata/ahci.h +++ b/drivers/ata/ahci.h @@ -138,7 +138,7 @@ enum { PORT_IRQ_BAD_PMP = (1 << 23), /* incorrect port multiplier */ PORT_IRQ_PHYRDY = (1 << 22), /* PhyRdy changed */ - PORT_IRQ_DEV_ILCK = (1 << 7), /* device interlock */ + PORT_IRQ_DMPS = (1 << 7), /* mechanical presence status */ PORT_IRQ_CONNECT = (1 << 6), /* port connect change status */ PORT_IRQ_SG_DONE = (1 << 5), /* descriptor processed */ PORT_IRQ_UNK_FIS = (1 << 4), /* unknown FIS rx'd */ @@ -166,6 +166,8 @@ enum { PORT_CMD_ATAPI = (1 << 24), /* Device is ATAPI */ PORT_CMD_FBSCP = (1 << 22), /* FBS Capable Port */ PORT_CMD_ESP = (1 << 21), /* External Sata Port */ + PORT_CMD_CPD = (1 << 20), /* Cold Presence Detection */ + PORT_CMD_MPSP = (1 << 19), /* Mechanical Presence Switch */ PORT_CMD_HPCP = (1 << 18), /* HotPlug Capable Port */ PORT_CMD_PMP = (1 << 17), /* PMP attached */ PORT_CMD_LIST_ON = (1 << 15), /* cmd list DMA engine running */ @@ -181,6 +183,10 @@ enum { PORT_CMD_ICC_PARTIAL = (0x2 << 28), /* Put i/f in partial state */ PORT_CMD_ICC_SLUMBER = (0x6 << 28), /* Put i/f in slumber state */ + /* PORT_CMD capabilities mask */ + PORT_CMD_CAP = PORT_CMD_HPCP | PORT_CMD_MPSP | + PORT_CMD_CPD | PORT_CMD_ESP | PORT_CMD_FBSCP, + /* PORT_FBS bits */ PORT_FBS_DWE_OFFSET = 16, /* FBS device with error offset */ PORT_FBS_ADO_OFFSET = 12, /* FBS active dev optimization offset */ -- 2.37.2