Received: by 2002:ac0:e34a:0:0:0:0:0 with SMTP id g10csp400697imn; Thu, 28 Jul 2022 04:22:29 -0700 (PDT) X-Google-Smtp-Source: AGRyM1v1dV84KeI5fG5lk9jL4aqYHhZMQNRf++Df17jFlduKf01B/ixnBKaoFh/pNDzFMifmypTQ X-Received: by 2002:a17:906:8a5b:b0:72b:50a1:a72c with SMTP id gx27-20020a1709068a5b00b0072b50a1a72cmr21273267ejc.152.1659007348806; Thu, 28 Jul 2022 04:22:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659007348; cv=none; d=google.com; s=arc-20160816; b=bV0Rj6ZRJq/Vu2mnFCAmqv/dhPT1dB7h7Aq6lUXqljhvEbeCoCBG35bnk+12RYueFF uZXhJ9drRrVZP4VshopWs0PF+IOa6V+VRxUqbXfsvG11d3DVEEPA3FueYYT2v2e8KWmt GwN7Y+llc2CueBdwXG4w8Lk48x4tAovTE387cxDxQisiARalE4CFnwJKh8pbqV5f5GyJ mDY5BVKwYT7G7b4QttOtC1H7pVUV6RE88CZdVxRy3wWtrrJSfRSn6cIJruzwRicPPjJn 4TadkI/X4oEcTF/vfPWHqpkaNU4j/hU9SllImJG4OU/vgv1qYOkFDO2n84/1Rlou8KOt a4Wg== 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=n0UYMJA4c61I8XbWDiUPzKG7qhzI+vK46N6KQLIsBoA=; b=PPpcdOusWoOS9LbChnK2V1x++1tylvVB5Fc84UZzN28m6N/gvOgTYx5y3cmAqHP4AP Ek7tF6lhZIQ7tuOB+IMoKk8IEJMJj6s+SIzRTevguIis4XzkVQxwpgsW8i/mfyt/Ny6Y nFyX01oPv3BvnotPFtKdt0O5pZTXHYjK93/SEAv1YMtuuXwEibhbVcYCf1VGf80hf8jl wWXvbo1Gxgbqrff64nIbhCqH1SZ+PE1tbRnrtX3qBJI+0iFoNAym/3XIg0E2+BwBEyI+ CIhVF0Irnyva/9hhkHF1s74iY30TwYOwat/WoCPf7Hx1YyqrJsYUKeqSoQsACKSdsyc0 Vcdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b=Mw1zg8OW; 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 gs7-20020a1709072d0700b0072b474f829dsi578775ejc.970.2022.07.28.04.22.04; Thu, 28 Jul 2022 04:22:28 -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=Mw1zg8OW; 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 S236803AbiG1LUV (ORCPT + 99 others); Thu, 28 Jul 2022 07:20:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47896 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236473AbiG1LTo (ORCPT ); Thu, 28 Jul 2022 07:19:44 -0400 Received: from mail.baikalelectronics.com (unknown [87.245.175.230]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 610CC6714F; Thu, 28 Jul 2022 04:19:29 -0700 (PDT) Received: from mail (mail.baikal.int [192.168.51.25]) by mail.baikalelectronics.com (Postfix) with ESMTP id DF99016D0; Thu, 28 Jul 2022 14:21:49 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mail.baikalelectronics.com DF99016D0 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baikalelectronics.ru; s=mail; t=1659007309; bh=n0UYMJA4c61I8XbWDiUPzKG7qhzI+vK46N6KQLIsBoA=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=Mw1zg8OWcbl7EZhdGfvmwL1GOCkUM19qb91Go+72uXn0PhlEjX2zjaKaxl+kABh9g VOwhDKcg8rhgbOX3AOM7V4ZcGuOiSqpEkRhMwzEx838sC6yvefR0Oj4u9iz6dIzjlD +Xwkjl8+wePySjpjeO6/Nwn0kQ+7JLPoDckKG4Ug= 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:24 +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 12/23] ata: libahci: Extend port-cmd flags set with port capabilities Date: Thu, 28 Jul 2022 14:18:53 +0300 Message-ID: <20220728111905.12427-13-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 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.35.1