Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp1008210rwd; Tue, 13 Jun 2023 03:38:07 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6hj+6YbyFp/+qsCFNsGx5uyst9+xvQ22P2RoiTExAP6rdTz81Q12pp3B/R1mBZlCUeARI/ X-Received: by 2002:a17:90a:5d18:b0:256:cf39:afce with SMTP id s24-20020a17090a5d1800b00256cf39afcemr9587064pji.43.1686652686784; Tue, 13 Jun 2023 03:38:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686652686; cv=none; d=google.com; s=arc-20160816; b=D8PICBWkZPrIwzMMLqIzIoCS5VvG5WtUJsmes5HeDdMWIRrQTK5vl33K+8qnObuFit mO/0gXUpwdSa4tZQj1AIuXjHSf6pjrBpE1N+BKI1n0h3W2GpLn86vsGpRpx8zV1VEZq5 xoYY7kG8QpRkUKYMir3ujpW8J1F9+ylG9c+TDvUda+o2Q9LAZxz42vOvmcxefkemIobQ 3vYt5yvYax4zf/bdhyAE70QP8eNA0WodorAVvpwEKiBPoEf4oKmU1kgFwcvNhlgB+r/n fAxyRu2xKTOzBB26K4eQo7tFR3k+Grhv2+ctVHDvUUW2VSfPJ0t8u/s1KYXxOZlmkCBU FAWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=FqtHUfyNE9hKB7RdGVWaTEBlqFaYncwa3Vu7I4xxlcA=; b=eCmyJuePHnK5HHysRHiJ/QeknUfPz7+qaPMyGswjueV2zItrKv73eCgJc93Q8Mf8Zb i6JEwWNxEPL1A4EhnKwH464ap5XVr3Z8+qv9mkVZPraqJubKb33aCib9kz9Nxxvp2TWF YF7ktdQMSxXfslbC3ttA83z9OYJK+gxbQPEgt9pTrxpIiS+n5KLQ6rxUzeBOgd55Mw8x akJ89TfRrxr5fUtGxgvjXQNW6m/u8cYHVmNb5hiAT6bRSnmvqGkRlo4Ov1xI6dqPDj4Z +Bq7Yed4cP2vOlVjiNAXDEriDL+I1kYunYnUTO/yWXh+bcCnMI/g9SgSuUrIZGKRTovI 3s6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=ClOzvlIq; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ls11-20020a17090b350b00b00246a6cecff8si5135806pjb.44.2023.06.13.03.37.54; Tue, 13 Jun 2023 03:38:06 -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=@redhat.com header.s=mimecast20190719 header.b=ClOzvlIq; 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=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S241600AbjFMKan (ORCPT + 99 others); Tue, 13 Jun 2023 06:30:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57226 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241996AbjFMKaD (ORCPT ); Tue, 13 Jun 2023 06:30:03 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 758C81AD for ; Tue, 13 Jun 2023 03:29:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1686652154; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=FqtHUfyNE9hKB7RdGVWaTEBlqFaYncwa3Vu7I4xxlcA=; b=ClOzvlIqL4wov34zY+/eUCPSoSax4DIyTMGZJP36CJxwKVDi9mMTI10FYD9JJswfvfiHSl mbTadMERTwqlM7Uont4U9k7GpZqMoFNrUQBi9OVC78ERyVz8sVcOPyMZdgOkLA6L35ldD2 +GFUkO+6EikMSGxnJBW8zDQ9/aJNX7A= Received: from mail-ej1-f69.google.com (mail-ej1-f69.google.com [209.85.218.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-360-7aGORabpOwOzP0ficCdx-g-1; Tue, 13 Jun 2023 06:29:13 -0400 X-MC-Unique: 7aGORabpOwOzP0ficCdx-g-1 Received: by mail-ej1-f69.google.com with SMTP id a640c23a62f3a-982180ac15cso237530466b.2 for ; Tue, 13 Jun 2023 03:29:12 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1686652151; x=1689244151; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=FqtHUfyNE9hKB7RdGVWaTEBlqFaYncwa3Vu7I4xxlcA=; b=Gh8Jb8UxmfQC1/f6sh3yfHvjlg4pDI4AdeaTkVXnQtSCy3/I5nVsBVOPEkPxVWVE2F n61tp+sJgt4lFxHrZ1B0SEVc9NJSAHz0huhG4ZHwfFoqV5RJpCYVno6nbkJmK88+zD4a ADWHgI8m+1RU0UHyWfoBJU7UQYpInLOpFc8qnM3dPZpAWl7RUz32BwUZhjUGMyOQc26i dWZVhNG3rqQJjzSt3thwatfnqVelpaytxbgEN9UruWlRQm7DWsxCAkEVDB+i+pSUiQNS x+DuNZiPkZaf87iYYuWTctehSqneqp6p9Isvj5rmQphX7TU46Bg1V4AXzC8LNhrnwCAr sfEw== X-Gm-Message-State: AC+VfDypwVpEEkWQjtIWs9/XOX177WlQ7s8MGjyj3QS+CUGa7/6Zui8+ lIRK5wC5J7GYxYc2J0im4rlMWg5J8w4Tj41bPfwSshFWvj0P4WoKFuardPpiWIIbSb6AEOsCGSi FMxDZurBrPdVA2JH0OYdfB29e4+Th71+7 X-Received: by 2002:a17:907:981:b0:96a:30b5:cfb0 with SMTP id bf1-20020a170907098100b0096a30b5cfb0mr12235651ejc.22.1686652151259; Tue, 13 Jun 2023 03:29:11 -0700 (PDT) X-Received: by 2002:a17:907:981:b0:96a:30b5:cfb0 with SMTP id bf1-20020a170907098100b0096a30b5cfb0mr12235635ejc.22.1686652150980; Tue, 13 Jun 2023 03:29:10 -0700 (PDT) Received: from ?IPV6:2001:1c00:c32:7800:5bfa:a036:83f0:f9ec? (2001-1c00-0c32-7800-5bfa-a036-83f0-f9ec.cable.dynamic.v6.ziggo.nl. [2001:1c00:c32:7800:5bfa:a036:83f0:f9ec]) by smtp.gmail.com with ESMTPSA id m25-20020a1709062b9900b0096637a19dccsm6380090ejg.210.2023.06.13.03.29.10 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 13 Jun 2023 03:29:10 -0700 (PDT) Message-ID: Date: Tue, 13 Jun 2023 12:29:09 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [PATCH V2 2/2] platform/x86/intel/pmc/mtl: Put devices in D3 during resume Content-Language: en-US, nl To: david.e.box@linux.intel.com, linux-kernel@vger.kernel.org, platform-driver-x86@vger.kernel.org Cc: markgross@kernel.org, irenic.rajneesh@gmail.com, ilpo.jarvinen@linux.intel.com, xi.pardee@intel.com, rajvi.jingar@linux.intel.com References: <20230607233849.239047-1-david.e.box@linux.intel.com> <20230607233849.239047-2-david.e.box@linux.intel.com> From: Hans de Goede In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE, SPF_NONE,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 Hi, On 6/12/23 20:02, David E. Box wrote: > Hi Hans, > > On Mon, 2023-06-12 at 11:42 +0200, Hans de Goede wrote: >> Hi David, >> >> On 6/8/23 01:38, David E. Box wrote: >>> An earlier commit placed some driverless devices in D3 during boot so that >>> they don't block package cstate entry on Meteor Lake. Also place these >>> devices in D3 after resume from suspend. >>> >>> Fixes: 336ba968d3e3 ("platform/x86/intel/pmc/mtl: Put GNA/IPU/VPU devices in >>> D3") >>> Signed-off-by: David E. Box >> >> Thank you for your patch. >> >> There is one thing which has me worried here: >> >> What about when real proper drivers show up for these blocks? >> >> I know that at least some people will likely be using the out of tree IPU6 >> driver with the IPU block. >> >> And having 2 different drivers poke at the hw state seems like a bad idea to >> me. >> >> Maybe we can add a check if no driver is bound and only set the state to D3 if >> no driver is bound? > > This check exists but is not shown in the patch. mtl_set_device_d3() gets the > device lock and checks to see if dev.driver is NULL before putting in D3. This > was checked with the GNA driver installed. Ah, yes I remember this now from the original patch adding mtl_set_device_d3(). Good. Let me go and merge this right away then. Regards, Hans >>> --- >>> >>> V2 - rename mtl_fixup to mtl_d3_fixup. Call it from new mtl_resume >>>      function, followed by the common resume. Suggested by Ilpo. >>> >>>  drivers/platform/x86/intel/pmc/mtl.c | 29 ++++++++++++++++++++-------- >>>  1 file changed, 21 insertions(+), 8 deletions(-) >>> >>> diff --git a/drivers/platform/x86/intel/pmc/mtl.c >>> b/drivers/platform/x86/intel/pmc/mtl.c >>> index e8cc156412ce..2b00ad9da621 100644 >>> --- a/drivers/platform/x86/intel/pmc/mtl.c >>> +++ b/drivers/platform/x86/intel/pmc/mtl.c >>> @@ -68,16 +68,29 @@ static void mtl_set_device_d3(unsigned int device) >>>         } >>>  } >>>   >>> -void mtl_core_init(struct pmc_dev *pmcdev) >>> +/* >>> + * Set power state of select devices that do not have drivers to D3 >>> + * so that they do not block Package C entry. >>> + */ >>> +static void mtl_d3_fixup(void) >>>  { >>> -       pmcdev->map = &mtl_reg_map; >>> -       pmcdev->core_configure = mtl_core_configure; >>> - >>> -       /* >>> -        * Set power state of select devices that do not have drivers to D3 >>> -        * so that they do not block Package C entry. >>> -        */ >>>         mtl_set_device_d3(MTL_GNA_PCI_DEV); >>>         mtl_set_device_d3(MTL_IPU_PCI_DEV); >>>         mtl_set_device_d3(MTL_VPU_PCI_DEV); >>>  } >>> + >>> +static int mtl_resume(struct pmc_dev *pmcdev) >>> +{ >>> +       mtl_d3_fixup(); >>> +       return pmc_core_resume_common(pmcdev); >>> +} >>> + >>> +void mtl_core_init(struct pmc_dev *pmcdev) >>> +{ >>> +       pmcdev->map = &mtl_reg_map; >>> +       pmcdev->core_configure = mtl_core_configure; >>> + >>> +       mtl_d3_fixup(); >>> + >>> +       pmcdev->resume = mtl_resume; >>> +} >> >