Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp2483703pxu; Sun, 18 Oct 2020 04:21:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwnFHIGfpuVfTWkg44fpQW1NCU9ye4NL+Fc343b1Aba+si6EOMGIX72oTAhHg/ymRZbD0GE X-Received: by 2002:a17:906:3559:: with SMTP id s25mr1461699eja.376.1603020091730; Sun, 18 Oct 2020 04:21:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603020091; cv=none; d=google.com; s=arc-20160816; b=MxmRoQ7PAulRjdkoQKND/5EClGD50Xs9LPiRbD2PTlDz+gOdhzt/X41dPDeSerYZud hlGs4bf3I+ZUE6qXCD4mP5iXPh6As7zBuNUiBOG2ZCu8aDBL9qlD+ZvnRP5BA2Z9I0EC /BfrhIIAmqbSfJUbm6Z4K3uogUcv1Q4njzwHo25pivdHtiZHZHVxtoBTONPuXQ0LK8CM O8HRrStvlbPY2rSSsreDGVhIJ38c3n7h4NqsQ8e9MLiXQG8vVoW1kQ/W9ZNEkSa5Dbtd NMansBMD7Ktj0Chj1t/goH5S0zjLhEs19p6KoY8nIKR3BjI9DVzkUHOe8U3ZT/G71FaK wGKQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=TudAeQsUJ5pd5Y9j32+DABfeXi6VPO6ucETRD2xY/80=; b=iXtPw/74394u1HcCYm+gCcFL0vJbzhZ6Azq2jpla0X6C44PNiiSp9yOa6XgdFshp3h rDYZAUyWv4DNULartvM5FUD/JSaQMUIMbVuiM/nqVDY/7JAlwbd36Irng3OtHzTqvQWH xU+xE8mCp5Q2G4OgtrMBTiBXUP0thTR3vBl6bzL+7p5sYQUwZAoiuvnVXGgV+sbCYG6l 7CQ5cBl+lSOr1RXPS1ITm+ew3ojEnNj1ovxOJawIARdgEn+o8j4Wjndf4p04UmRZPONC 1WcS8ibHQIqPwu8tSIytIlNRMLB61jyeWz0/hcJ5JAQ+ElBp9DS+hkryELQYt3QTn6Qz nJFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=SgwDQIIu; 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g10si5629999edy.201.2020.10.18.04.20.53; Sun, 18 Oct 2020 04:21:31 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=SgwDQIIu; 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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725904AbgJRJlw (ORCPT + 99 others); Sun, 18 Oct 2020 05:41:52 -0400 Received: from us-smtp-delivery-124.mimecast.com ([63.128.21.124]:25624 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725320AbgJRJlw (ORCPT ); Sun, 18 Oct 2020 05:41:52 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1603014110; 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=TudAeQsUJ5pd5Y9j32+DABfeXi6VPO6ucETRD2xY/80=; b=SgwDQIIu0A04Xnf99o+R1ehtC2qY8Jx449HjFD8ccCmoVaCOFpifg4D21gZt9gvOSIhcu2 sVs44E7mP8Cvt8IcdrE8dOovPmJmuDCCT+Zx90X8r1EoUwHqQoodx8WcjZd8ua/8fhnG0v zFZKZWDLroYgEcnv7v2BK8TbXl7UBTA= Received: from mail-ed1-f69.google.com (mail-ed1-f69.google.com [209.85.208.69]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-462-frHi3uxJPhm0NouIukaJng-1; Sun, 18 Oct 2020 05:41:48 -0400 X-MC-Unique: frHi3uxJPhm0NouIukaJng-1 Received: by mail-ed1-f69.google.com with SMTP id h6so3506696edt.12 for ; Sun, 18 Oct 2020 02:41:48 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=TudAeQsUJ5pd5Y9j32+DABfeXi6VPO6ucETRD2xY/80=; b=c0JfmSQPeGhqhXBitkRN7ZIiHrs+9RtuOGF7UYQ+ki31BQo1LXuLXQWfed1p3Yu1gF uZz1WrXpXzKXcAwbfwbxvZGdF+/tSAToNnGytBgdN5LAfX7PoP1vPrTkqO8IdBZVwMOD AxqBHAx0oKBE4KDX3pB1YbsbzlTxHhAb1CD8PelWEMTi1wFRUYd9ac9vsVzkDeZNq9dk HfiZ83eb6knZDCpqoeJ5gCtscrCsKGD8ZOrMRwycYIbamRwajR0HBstmJVOacm3QACJF FfJKN6gsArAGNvWQUpElBGDxnWNM2fxhOPlTLS4GPx6a/7IdLLK7tHXyYh1fihU/HIHH N5gw== X-Gm-Message-State: AOAM533oPG/vUANemq+BF0htnnakQZ4Dy4aVkN3PX8WcNGOHCcojCPU6 1T+W5TMPCRBzBbCy3Tvskurz3okgkCmjKdeR2AGMUgSQq9+40vsD5U+vyTRURe8IjxZxkqsGIoq bdj5fycHQnOQluSu9U0gljQF3 X-Received: by 2002:a17:906:4b10:: with SMTP id y16mr12440824eju.395.1603014106693; Sun, 18 Oct 2020 02:41:46 -0700 (PDT) X-Received: by 2002:a17:906:4b10:: with SMTP id y16mr12440808eju.395.1603014106415; Sun, 18 Oct 2020 02:41:46 -0700 (PDT) Received: from x1.localdomain (2001-1c00-0c0c-fe00-d2ea-f29d-118b-24dc.cable.dynamic.v6.ziggo.nl. [2001:1c00:c0c:fe00:d2ea:f29d:118b:24dc]) by smtp.gmail.com with ESMTPSA id os11sm7040204ejb.104.2020.10.18.02.41.45 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sun, 18 Oct 2020 02:41:45 -0700 (PDT) Subject: Re: [RFC] Documentation: Add documentation for new performance_profile sysfs class (Also Re: [PATCH 0/4] powercap/dtpm: Add the DTPM framework) To: "Rafael J. Wysocki" Cc: 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" 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> From: Hans de Goede Message-ID: <25d000cc-0c00-3b17-50f7-ca8de8b7a65b@redhat.com> Date: Sun, 18 Oct 2020 11:41:45 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.3.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 ? Regards, Hans