Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp379162ybg; Tue, 28 Jul 2020 08:17:19 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzwONeR4DbwXxc8Aoas4b5zu/mlyp5Ih8C4g5BR6Qtf3U/XU3PufDK4goW1KBEAyNGwhqGK X-Received: by 2002:aa7:d6cf:: with SMTP id x15mr25865848edr.164.1595949439688; Tue, 28 Jul 2020 08:17:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595949439; cv=none; d=google.com; s=arc-20160816; b=dvUsBpOffhIqMB+C6MHixuENROmprxspvCnQgluFeVfGlC43EfqCucMgK+bwOf8SWb 7KlesAo8SHBImQqjY3AjH75wYAZIHSoPXAtWFNo2kZFOyZWU+bP2xPEOAZjHmZVCKIQw k29SOqyVgyjxbf/TilRhU5ikhRa6bGUHljsTyC9vZzjn8hpyG8OEnC6TNITO4ytGkZqu oC54E70Bn2PPYlRSSPY4JxhCLgeaqQoejkl79UtuGZaCNOMOyC8FpufAcBgA75sQWc1v HUL331TZVPKm8sCJcK2aEIeEkYhdDLdajNYZWqeF3aRzS6x5Rv4ouSFuwnPezQrgM0oH ESBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=XOyeIlqa39LnRMOF6oH74VoSTTsjOYwjf1aJHnVxl1k=; b=weowMAqP/DptjhRczuRtp427Kq3vNBFzyReYgnHShzykeDTPLQVxV9qeWNPMc3ClqM 23hLzG6WtyC2rvX/y8iyJT1O+T3ElhmthSbeOKtaQs05HCFKKDe7kD7YBZmeSrcscc67 PFVC/XEThQ5S49Io+yXwzeRKDrJb8FAtVcZ/hzaajqnko1oZI+9W/76vddMfdiQnSvlw VXTQiZET3wupeU9eVTyorV+EPqXcbusqxVbFG+D7rImRw2i49YCb8QArjHb99JN13HTc nZl3FndBecSo3Gy3ZuxqL1Qdluevyghwgu/V3DhLt7QH0lPxtEnlhv9oTELWmYMCLkdd 9urw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id h15si1099706ejq.463.2020.07.28.08.16.55; Tue, 28 Jul 2020 08:17:19 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730893AbgG1POb (ORCPT + 99 others); Tue, 28 Jul 2020 11:14:31 -0400 Received: from cloudserver094114.home.pl ([79.96.170.134]:44850 "EHLO cloudserver094114.home.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730887AbgG1POa (ORCPT ); Tue, 28 Jul 2020 11:14:30 -0400 Received: from 89-64-88-69.dynamic.chello.pl (89.64.88.69) (HELO kreacher.localnet) by serwer1319399.home.pl (79.96.170.134) with SMTP (IdeaSmtpServer 0.83.415) id 197c8e6c67be01ba; Tue, 28 Jul 2020 17:14:27 +0200 From: "Rafael J. Wysocki" To: Linux PM Cc: Linux Documentation , LKML , Peter Zijlstra , Srinivas Pandruvada , Giovanni Gherdovich , Doug Smythies , Francisco Jerez Subject: [PATCH v4 1/2] cpufreq: intel_pstate: Rearrange the storing of new EPP values Date: Tue, 28 Jul 2020 17:11:03 +0200 Message-ID: <1665283.zxI7kaGBi8@kreacher> In-Reply-To: <13207937.r2GEYrEf4f@kreacher> References: <4981405.3kqTVLv5tO@kreacher> <1709487.Bxjb1zNRZM@kreacher> <13207937.r2GEYrEf4f@kreacher> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Rafael J. Wysocki Move the locking away from intel_pstate_set_energy_pref_index() into its only caller and drop the (now redundant) return_pref label from it. Also move the "raw" EPP value check into the caller of that function, so as to do it before acquiring the mutex, and reduce code duplication related to the "raw" EPP values processing somewhat. No intentional functional impact. Signed-off-by: Rafael J. Wysocki --- v2 -> v3: * Fix error handling in intel_pstate_set_energy_pref_index() and rebase. v3 -> v4: No changes --- drivers/cpufreq/intel_pstate.c | 35 +++++++++++++++-------------------- 1 file changed, 15 insertions(+), 20 deletions(-) Index: linux-pm/drivers/cpufreq/intel_pstate.c =================================================================== --- linux-pm.orig/drivers/cpufreq/intel_pstate.c +++ linux-pm/drivers/cpufreq/intel_pstate.c @@ -649,28 +649,18 @@ static int intel_pstate_set_energy_pref_ if (!pref_index) epp = cpu_data->epp_default; - mutex_lock(&intel_pstate_limits_lock); - if (boot_cpu_has(X86_FEATURE_HWP_EPP)) { u64 value; ret = rdmsrl_on_cpu(cpu_data->cpu, MSR_HWP_REQUEST, &value); if (ret) - goto return_pref; + return ret; value &= ~GENMASK_ULL(31, 24); - if (use_raw) { - if (raw_epp > 255) { - ret = -EINVAL; - goto return_pref; - } - value |= (u64)raw_epp << 24; - ret = wrmsrl_on_cpu(cpu_data->cpu, MSR_HWP_REQUEST, value); - goto return_pref; - } - - if (epp == -EINVAL) + if (use_raw) + epp = raw_epp; + else if (epp == -EINVAL) epp = epp_values[pref_index - 1]; value |= (u64)epp << 24; @@ -680,8 +670,6 @@ static int intel_pstate_set_energy_pref_ epp = (pref_index - 1) << 2; ret = intel_pstate_set_epb(cpu_data->cpu, epp); } -return_pref: - mutex_unlock(&intel_pstate_limits_lock); return ret; } @@ -708,8 +696,8 @@ static ssize_t store_energy_performance_ struct cpudata *cpu_data = all_cpu_data[policy->cpu]; char str_preference[21]; bool raw = false; + ssize_t ret; u32 epp = 0; - int ret; ret = sscanf(buf, "%20s", str_preference); if (ret != 1) @@ -724,14 +712,21 @@ static ssize_t store_energy_performance_ if (ret) return ret; + if (epp > 255) + return -EINVAL; + raw = true; } + mutex_lock(&intel_pstate_limits_lock); + ret = intel_pstate_set_energy_pref_index(cpu_data, ret, raw, epp); - if (ret) - return ret; + if (!ret) + ret = count; - return count; + mutex_unlock(&intel_pstate_limits_lock); + + return ret; } static ssize_t show_energy_performance_preference(