Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp2453455imm; Mon, 28 May 2018 08:21:23 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrGbEg2jHNMoGDC+FIsc992UT4EDD+gIuEcrLbZjrZQhxT53uahmvxDEggUK/BJlL/i2PTo X-Received: by 2002:a17:902:aa04:: with SMTP id be4-v6mr14027361plb.20.1527520883401; Mon, 28 May 2018 08:21:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527520883; cv=none; d=google.com; s=arc-20160816; b=t1IPlFbwizQ9cNmx3/zFqH5fl9YKlzgkQcAt8vue11TAOc0bG8xoFtlV46ZqR1ELC6 Ig+Ox1ICKjHEwS3dfi4tVhSRlAhX7xA/F7I/DvwhPvnq21RLUAp7FNz6VF3vpOgKflJ2 ydVf8VRtYvV2UrCHMgcxweDFvHN4h6YTpZD6UgSqnnQC2MbIZ/EiReOlGvgLFCuDTxx1 /UGvROEctVKWj8Smy6vpmfNcsk4pieH8oto4SvcdRs4s0GRTekRlWmvQzAak9yVtjrDv ucMVuhWJ5DzKL9riWZnCwYCtiM1juHq4OoMZ+Et2wCHGE0f69OkhQtV2HWs7RJlCihj9 byfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=gVVsBXecrBA/5s67n56bmYwThBkgB2sM3fMNcvgkIN0=; b=NuxlPA3z/NamJI4UfbkJDszP6/3pwbtx+9geK567/U9Qg2vnfB9KevZk7XU7n5PHQM +LvdQOQ/q5h/KYsAZt3HU2ZCAvXtvKJh82x8vUH/lhIjfxAq2HciGicIP2qFyMyPil0m xXwJKW0Bvg0uDK3uKp/cWZK7X7HU1odZOM9PIkc72MRusDVj6C4eP/q/eSyNG/ahQETv xwSYJawzV9VR4C+ZFLSXa/ejallRzzN2bg2SR3lJmM2nuxAPVp3ihL9i//B6pdjJpGcx k42AztA6Js20KZ/ZP2ixd07l1/BG2MkixjqMrWSKBlEY66nQbSxl3VpcZvyZKBOVyoqD 5pww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ysCAFEHN; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h5-v6si23638479pgp.666.2018.05.28.08.21.08; Mon, 28 May 2018 08:21:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=ysCAFEHN; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1033353AbeE1KVh (ORCPT + 99 others); Mon, 28 May 2018 06:21:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:40916 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1033296AbeE1KVX (ORCPT ); Mon, 28 May 2018 06:21:23 -0400 Received: from localhost (LFbn-1-12247-202.w90-92.abo.wanadoo.fr [90.92.61.202]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D17C720844; Mon, 28 May 2018 10:21:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1527502883; bh=6PAAlnfOvDAUmxXVRA4WKozglWm2jeRNkJ4cdUdebzw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ysCAFEHNOIGgPu9m3lDLYZsNXLAAMWHzo4nOLLPXKsXZ5pCy0isUD5Eq6MiT1OMfr cKKPu8F2b+Q04MbhcgJiCa8hgnXOqVHUv8DgjcWkGgLsRESw7r/ithNiUdnsbS8N/L tJrnklwPenVuPuTTUWjSvbgxfvLzXKrlWQh3ywZg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Viresh Kumar , Shunyong Yang , "Rafael J. Wysocki" , Sasha Levin Subject: [PATCH 4.4 164/268] cpufreq: CPPC: Initialize shared perf capabilities of CPUs Date: Mon, 28 May 2018 12:02:18 +0200 Message-Id: <20180528100220.964360811@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180528100202.045206534@linuxfoundation.org> References: <20180528100202.045206534@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Shunyong Yang [ Upstream commit 8913315e9459b146e5888ab5138e10daa061b885 ] When multiple CPUs are related in one cpufreq policy, the first online CPU will be chosen by default to handle cpufreq operations. Let's take cpu0 and cpu1 as an example. When cpu0 is offline, policy->cpu will be shifted to cpu1. cpu1's perf capabilities should be initialized. Otherwise, perf capabilities are 0s and speed change can not take effect. This patch copies perf capabilities of the first online CPU to other shared CPUs when policy shared type is CPUFREQ_SHARED_TYPE_ANY. Acked-by: Viresh Kumar Signed-off-by: Shunyong Yang Signed-off-by: Rafael J. Wysocki Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- drivers/cpufreq/cppc_cpufreq.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) --- a/drivers/cpufreq/cppc_cpufreq.c +++ b/drivers/cpufreq/cppc_cpufreq.c @@ -100,9 +100,19 @@ static int cppc_cpufreq_cpu_init(struct policy->cpuinfo.max_freq = policy->max; policy->shared_type = cpu->shared_type; - if (policy->shared_type == CPUFREQ_SHARED_TYPE_ANY) + if (policy->shared_type == CPUFREQ_SHARED_TYPE_ANY) { + int i; + cpumask_copy(policy->cpus, cpu->shared_cpu_map); - else if (policy->shared_type == CPUFREQ_SHARED_TYPE_ALL) { + + for_each_cpu(i, policy->cpus) { + if (unlikely(i == policy->cpu)) + continue; + + memcpy(&all_cpu_data[i]->perf_caps, &cpu->perf_caps, + sizeof(cpu->perf_caps)); + } + } else if (policy->shared_type == CPUFREQ_SHARED_TYPE_ALL) { /* Support only SW_ANY for now. */ pr_debug("Unsupported CPU co-ord type\n"); return -EFAULT;