Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp2517703pxu; Sun, 18 Oct 2020 05:36:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyETC5lyMYysEZztC/fVEcdXTZ6VcsDV6yZljwqEg2C25Fqq1m9spxFhPOALIwmh+esPYll X-Received: by 2002:a05:6402:1012:: with SMTP id c18mr13104124edu.77.1603024607781; Sun, 18 Oct 2020 05:36:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603024607; cv=none; d=google.com; s=arc-20160816; b=h/PVg8rtbsuYWSWkagJ3BJqrPWFONBEERuFj5CmwqlmWcm0k/b+n/4MM/SvFQgDHmd ofda4LKtNUVckFSpQHnr87/cNrgCpT9SLVCBtPCWQwZkyz/jeZrexUOUpOnUhDCFX2w+ VA8nZfvBPcjqECDUr7tjMhSCakzooPUOT7n5vMj2bzyPfSWK4QMY/uoOtS0vlLHkdPKB ZwlkXAHgjn/LgwrFs4pbYQlgJ9dhI3sYN7LWYDkbceQY+tArUMct6oT5TYfGnvS3Avhc 675UfsZY38ZJZXjBYMp8BsgaXh+lmKtxl0PLdmhk/FQs8ps5QLlEaKtdNcJYGTWpYs+b 9xVA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version; bh=BR4bAT5Vr/PxycFS8TzpSfye3h+0S0snmDQBRj/kypQ=; b=qPK7O9uJN2X3mwzcu42u+jgAzBlYBmBiTfR9KqABzQ65wK+SD8JYXnfL+ITEuoD+UL oCum7rLJzlv+sofSqTs+4ARU3ujFG0bFn5SZt6kY4X+aby0WrzwaFz5SYSNGiyT/916Q 8QMEpDBC4gBy5VURqrqPwg+WUwXVWVje8XRLnawhc4/CmCYsbmk1fB5NwilzNOP0H3y6 34kZpvzXuwRMeI8Pa860+6P1I/heTydlctOjigzUXK4Zjw9XWoy+N5aVQAwguadgjRoy KvJaN3Bun/jAk3lDj0sQ6HEBuB58nzrlt/3kvZb7lnX3XLVrxXRxxO7dbmgc0JiC5Nmm Wc3Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u2si2848302ejt.588.2020.10.18.05.36.24; Sun, 18 Oct 2020 05:36:47 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726793AbgJRMbs (ORCPT + 99 others); Sun, 18 Oct 2020 08:31:48 -0400 Received: from mail-ot1-f65.google.com ([209.85.210.65]:45123 "EHLO mail-ot1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726381AbgJRMbr (ORCPT ); Sun, 18 Oct 2020 08:31:47 -0400 Received: by mail-ot1-f65.google.com with SMTP id f37so7815068otf.12; Sun, 18 Oct 2020 05:31:46 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=BR4bAT5Vr/PxycFS8TzpSfye3h+0S0snmDQBRj/kypQ=; b=GbXYEiQrEGUzPDXWKoY73aRBVZey6zasOM1YRbP4RKZcRR+/nBibNbloRvBr9IQwx7 H+CwwUZ/VJpDeE2i3iUpA/5lVcry506VgzX+19tZSJ+3MlkNVIgfiRONCAiusmI1iy9B noivx+7WAj0436D+r0FySC0bLxxqLPSUiT+LhtSNvsft5aFFY3qGka62l2eo6EcxmLNN ezWz2Cm2KZewvk50DGHxofWl80OusXebXOiUxoZr8qs5qoGtfbgcY5UCIsWY3KVKLArP 4XufTe1Tf8h1Qp7HK92DasGBSv8eCFlaf5MonJt8llDRcdbMoR0Uaab1Hh2sYUuB+5nN dUeA== X-Gm-Message-State: AOAM532x0edtYClci/xLPYnXc6KJAOChS8r0dRTzlfSLpGyTZVTUmK+4 6VlPrqb+oJutendXQ490G609QIE0kFtko20bKa8khsNW X-Received: by 2002:a05:6830:18cd:: with SMTP id v13mr5082968ote.206.1603024306315; Sun, 18 Oct 2020 05:31:46 -0700 (PDT) MIME-Version: 1.0 References: <20201006122024.14539-1-daniel.lezcano@linaro.org> <8be66efd-7833-2c8a-427d-b0055c2f6ec1@linaro.org> <97e5368b-228d-eca1-85a5-b918dfcfd336@redhat.com> <63dfa6a1-0424-7985-7803-756c0c5cc4a5@redhat.com> <87d9a808-39d6-4949-c4f9-6a80d14a3768@redhat.com> <943531a7-74d6-7c7f-67bc-2645b3ba7b8a@redhat.com> <25d000cc-0c00-3b17-50f7-ca8de8b7a65b@redhat.com> In-Reply-To: <25d000cc-0c00-3b17-50f7-ca8de8b7a65b@redhat.com> From: "Rafael J. Wysocki" Date: Sun, 18 Oct 2020 14:31:36 +0200 Message-ID: Subject: Re: [RFC] Documentation: Add documentation for new performance_profile sysfs class (Also Re: [PATCH 0/4] powercap/dtpm: Add the DTPM framework) To: Hans de Goede Cc: "Rafael J. Wysocki" , Daniel Lezcano , Srinivas Pandruvada , Lukasz Luba , Linux Kernel Mailing List , Linux PM , "Zhang, Rui" , Bastien Nocera , Mark Pearson , "Limonciello, Mario" , Darren Hart , Andy Shevchenko , Mark Gross , Elia Devito , Benjamin Berg , "linux-acpi@vger.kernel.org" , "platform-driver-x86@vger.kernel.org" Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Oct 18, 2020 at 11:41 AM Hans de Goede wrote: > > Hi, > > On 10/16/20 4:51 PM, Rafael J. Wysocki wrote: > > On Fri, Oct 16, 2020 at 1:11 PM Hans de Goede wrote: > >> > >> > >> > >> Hi, > >> > >> On 10/14/20 5:42 PM, Rafael J. Wysocki wrote: > >>> On Wed, Oct 14, 2020 at 4:06 PM Hans de Goede wrote: > >>>> On 10/14/20 3:33 PM, Rafael J. Wysocki wrote: > >> > >> > >> > >>>>> First, a common place to register a DPTF system profile seems to be > >>>>> needed and, as I said above, I wouldn't expect more than one such > >>>>> thing to be present in the system at any given time, so it may be > >>>>> registered along with the list of supported profiles and user space > >>>>> will have to understand what they mean. > >>>> > >>>> Mostly Ack, I would still like to have an enum for DPTF system > >>>> profiles in the kernel and have a single piece of code map that > >>>> enum to profile names. This enum can then be extended as > >>>> necessary, but I want to avoid having one driver use > >>>> "Performance" and the other "performance" or one using > >>>> "performance-balanced" and the other "balanced-performance", etc. > >>>> > >>>> With the goal being that new drivers use existing values from > >>>> the enum as much as possible, but we extend it where necessary. > >>> > >>> IOW, just a table of known profile names with specific indices assigned to them. > >> > >> Yes. > >> > >>> This sounds reasonable. > >>> > >>>>> Second, irrespective of the above, it may be useful to have a > >>>>> consistent way to pass performance-vs-power preference information > >>>>> from user space to different parts of the kernel so as to allow them > >>>>> to adjust their operation and this could be done with a system-wide > >>>>> power profile attribute IMO. > >>>> > >>>> I agree, which is why I tried to tackle both things in one go, > >>>> but as you said doing both in 1 API is probably not the best idea. > >>>> So I believe we should park this second issue for now and revisit it > >>>> when we find a need for it. > >>> > >>> Agreed. > >>> > >>>> Do you have any specific userspace API in mind for the > >>>> DPTF system profile selection? > >>> > >>> Not really. > >> > >> So before /sys/power/profile was mentioned, but that seems more like > >> a thing which should have a set of fixed possible values, iow that is > >> out of scope for this discussion. > > > > Yes. > > > >> Since we all seem to agree that this is something which we need > >> specifically for DPTF profiles maybe just add: > >> > >> /sys/power/dptf_current_profile (rw) > >> /sys/power/dptf_available_profiles (ro) > >> > >> (which will only be visible if a dptf-profile handler > >> has been registered) ? > >> > >> Or more generic and thus better (in case other platforms > >> later need something similar) I think, mirror the: > >> > >> /sys/bus/cpu/devices/cpu#/cpufreq/energy_performance_* bits > >> for a system-wide energy-performance setting, so we get: > >> > >> /sys/power/energy_performance_preference > >> /sys/power/energy_performance_available_preferences > > > > But this is not about energy vs performance only in general, is it? > > > >> (again only visible when applicable) ? > >> > >> I personally like the second option best. > > > > But I would put it under /sys/firmware/ instead of /sys/power/ and I > > would call it something like platform_profile (and > > platform_profile_choices or similar). > > Currently we only have dirs under /sys/firmware: > > [hans@x1 ~]$ ls /sys/firmware > acpi dmi efi memmap > > But we do have /sys/firmware/apci/pm_profile: > > Documentation/ABI/stable/sysfs-acpi-pmprofile > > What: /sys/firmware/acpi/pm_profile > Date: 03-Nov-2011 > KernelVersion: v3.2 > Contact: linux-acpi@vger.kernel.org > Description: The ACPI pm_profile sysfs interface exports the platform > power management (and performance) requirement expectations > as provided by BIOS. The integer value is directly passed as > retrieved from the FADT ACPI table. > Values: For possible values see ACPI specification: > 5.2.9 Fixed ACPI Description Table (FADT) > Field: Preferred_PM_Profile > > Currently these values are defined by spec: > 0 Unspecified > 1 Desktop > 2 Mobile > 3 Workstation > 4 Enterprise Server > ... > > Since all platforms which we need this for are ACPI based > (and the involved interfaces are also all ACPI interfaces) > how about: > > /sys/firmware/acpi/platform_profile > /sys/firmware/acpi/platform_profile_choices > > ? > > I think this goes nice together with /sys/firmware/acpi/pm_profile > although that is read-only and this is a read/write setting. > > Rafel, would: > > /sys/firmware/acpi/platform_profile > /sys/firmware/acpi/platform_profile_choices > > work for you ? Yes, it would. Cheers!