Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp1709040iob; Thu, 5 May 2022 06:55:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzkSMhtHqCMml52J9IhPb7Sokfu/PCg6T5SxAhYeNhIroF7LY80jcG9UDHdJTTrMfOF7Nh5 X-Received: by 2002:a17:902:a583:b0:15d:197b:9259 with SMTP id az3-20020a170902a58300b0015d197b9259mr27940786plb.51.1651758956408; Thu, 05 May 2022 06:55:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651758956; cv=none; d=google.com; s=arc-20160816; b=JM/0Zdn86Jcncaf6lkJ23vBK2uKxayse5HLzOSidDVPIwvfxtUdj9OoRwciuzxuqrq LP9PFD05sNf0bM707UQed9u2SdScOxsWugt1eNOpD1heOkG0vAUN7+CY1SDd3QzF0/wS ZFzoT73Sl1++YGWQSfl9MuC5kwU3fY36Gq7Dx+9GG9NB0+MY3YnLAP/wnaX4yWcWi0F0 +GZ9AfH7DfiEYnrdFjNvDjouDs5A3Fdw1rkLyay2O7RXgVdyDh54nwg6gloyVPSCFGl4 t6znfx7cgjJmMNuX3XgIoMORpyM2O56iRLuw+ZddPBxf7xLBDRB464mjoX5FLcPYiSKe mwgA== 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=7CTWWsQq5BGbHxa3gecG+HZy701Eady0L2z+YEQxjgA=; b=FF0USF7fS0CIAueBV5ouWFfkAlle+ekvfCQik/A6AEya1k9DuKSaEHgX1/UtCCsnKT V405kxsImC1LzwBLsjSvxqKumZTHyab1psUDuVzbyzwMwDSHxGBUanxJhLjVlboceius RqJDJz1AY/4yfQlckzYrfztheSwhtDl3ApGMVbqqiWVCeq/VX3yjAAEyN+up9ViUymgj XhReeHHgF+k6WuqxIoiW4POaUMKUCsgl+6u1kcxMERLsfDk92k6VXxnq+1bxacpsTU0z sS4AKYI7G4FvTjmXeac1YpsDEgIoNj1NF3nXA7a+Sj91K9S3ChMB+/83Eql5cmLwZz6y Aq8g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=iv+Yneqb; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hk11-20020a17090b224b00b001dcb858ec74si2595066pjb.3.2022.05.05.06.55.39; Thu, 05 May 2022 06:55:56 -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=iv+Yneqb; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241524AbiECUOq (ORCPT + 99 others); Tue, 3 May 2022 16:14:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48940 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242238AbiECUNs (ORCPT ); Tue, 3 May 2022 16:13:48 -0400 Received: from mail.baikalelectronics.ru (mail.baikalelectronics.com [87.245.175.226]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 568BFE7; Tue, 3 May 2022 13:10:13 -0700 (PDT) Received: from mail.baikalelectronics.ru (unknown [192.168.51.25]) by mail.baikalelectronics.ru (Postfix) with ESMTP id 8DDDCBC1; Tue, 3 May 2022 23:10:46 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mail.baikalelectronics.ru 8DDDCBC1 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baikalelectronics.ru; s=mail; t=1651608646; bh=7CTWWsQq5BGbHxa3gecG+HZy701Eady0L2z+YEQxjgA=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=iv+Yneqbnx4VNpFTBiyO6Dc1bay8jUqaUKy847sXXB991/BFofgvxem2f1OoUEgO5 C0s66k7116m8rhHWsWLMCqJecVBhFNnCxJJQQEQA96mUtJBKnrUYhVnN4jgqNytdmI PIXZqmEC/90NsydzPWt3nBXv6bz8bF2Vt54GANFo= Received: from localhost (192.168.53.207) by mail (192.168.51.25) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Tue, 3 May 2022 23:10:12 +0300 From: Serge Semin To: Damien Le Moal , Hans de Goede , Jens Axboe CC: Serge Semin , Serge Semin , Alexey Malahov , Pavel Parkhomenko , Rob Herring , , , Subject: [PATCH v2 13/23] ata: libahci: Extend port-cmd flags set with port capabilities Date: Tue, 3 May 2022 23:09:28 +0300 Message-ID: <20220503200938.18027-14-Sergey.Semin@baikalelectronics.ru> In-Reply-To: <20220503200938.18027-1-Sergey.Semin@baikalelectronics.ru> References: <20220503200938.18027-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_NONE,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_DEV_MPS 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.7 Signed-off-by: Serge Semin --- drivers/ata/ahci.h | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/drivers/ata/ahci.h b/drivers/ata/ahci.h index 7d834deefeb9..f501531bd1b3 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,9 @@ 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_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.35.1