Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1002326ybt; Fri, 19 Jun 2020 21:13:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxHra1xXM+8dN0kiqx0SsY6QQp1HitgwWp7tk3VPRLuIMZtpjw7tTmtjoUBpb/yKAQMrcgC X-Received: by 2002:a17:906:8401:: with SMTP id n1mr6190882ejx.479.1592626431239; Fri, 19 Jun 2020 21:13:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592626431; cv=none; d=google.com; s=arc-20160816; b=OSYYNk0v5lD+MlCrn9/a2bpaEthuNIuomIIHBlueZwl6sJYXLNB8Q4GWFSWB/YYZpG nGbZTCfBZyr3NorXS3FSkaU95XqhgmA30EOR2T01tl/ZOwHAALZjLnbQL8iUWrBhKGWc 93doJ2+X38hyJ3dmCVuUBk1kBsXhbk8MJJayGAhJZUZXM7eebyM+5pS8EEAgSLY+mXJ4 vjzc1XU5CM3KrXNe70YIlVjcs+sHXVJWQa1qMlDX9f8SEObQom9drgDv6lDZyysUVUOi fuXFZ4wY4R/dYMwLYJa3eCl5h/6eTOnZ65RlS1NJpAZfMs36jhxvK9JBz2elCvcT9z5r wPKw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=Iznt+RQPabXJSKHaQCaBJhReQnFglAwYviCKeUpz5CI=; b=UN2F4VmKBv8apiXcwDpqfW89y1NF0NqD6sbNPsBAZkTjcSYW1EHPkDCnVu83sD0hKf ELl8PXomWOEp7IYr9pdUih/bc5mB3ycj4R2egJqRGSWVmUju+TFsEDD21oePHDTeGwxL w6MYm+naapj4wht0B3d4xKMUAM+7kYNY1hdWl6aymx8p3VOVsMPZ5YwmmAwK/ufVWcH4 k9MKykYi4kKbN7ly55tPmyW1016tOj5NvJ196dwu8x/GErHDhz8oWYdcQYa647b7q0tt uHajLRZwI0uZQfxL+cDTSWDaEtiG4jW6tBOsRCnW5X7KxX3bO4KLuBz2aMutZ4TASj8A gDNQ== 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 mj14si5156601ejb.464.2020.06.19.21.13.29; Fri, 19 Jun 2020 21:13:51 -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 S2390466AbgFSRUm (ORCPT + 99 others); Fri, 19 Jun 2020 13:20:42 -0400 Received: from foss.arm.com ([217.140.110.172]:49132 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725788AbgFSRUl (ORCPT ); Fri, 19 Jun 2020 13:20:41 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id D6EA3D6E; Fri, 19 Jun 2020 10:20:40 -0700 (PDT) Received: from e107158-lin.cambridge.arm.com (e107158-lin.cambridge.arm.com [10.1.195.21]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 385403F71F; Fri, 19 Jun 2020 10:20:39 -0700 (PDT) From: Qais Yousef To: Ingo Molnar , Peter Zijlstra Cc: Qais Yousef , Juri Lelli , Vincent Guittot , Dietmar Eggemann , Steven Rostedt , Ben Segall , Mel Gorman , Patrick Bellasi , Chris Redpath , Lukasz Luba , linux-kernel@vger.kernel.org Subject: [PATCH v2 1/2] sched/uclamp: Fix initialization of strut uclamp_rq Date: Fri, 19 Jun 2020 18:20:10 +0100 Message-Id: <20200619172011.5810-2-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200619172011.5810-1-qais.yousef@arm.com> References: <20200619172011.5810-1-qais.yousef@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org struct uclamp_rq was zeroed out entirely in assumption that in the first call to uclamp_rq_inc() they'd be initialized correctly in accordance to default settings. But when next patch introduces a static key to skip uclamp_rq_{inc,dec}() until userspace opts in to use uclamp, schedutil will fail to perform any frequency changes because the rq->uclamp[UCLAMP_MAX].value is zeroed at init and stays as such. Which means all rqs are capped to 0 by default. Fix it by making sure we do proper initialization at init without relying on uclamp_rq_inc() doing it later. Fixes: 69842cba9ace ("sched/uclamp: Add CPU's clamp buckets refcounting") Signed-off-by: Qais Yousef Cc: Juri Lelli Cc: Vincent Guittot Cc: Dietmar Eggemann Cc: Steven Rostedt Cc: Ben Segall Cc: Mel Gorman CC: Patrick Bellasi Cc: Chris Redpath Cc: Lukasz Luba Cc: linux-kernel@vger.kernel.org --- kernel/sched/core.c | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) diff --git a/kernel/sched/core.c b/kernel/sched/core.c index a43c84c27c6f..4265861e13e9 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -1248,6 +1248,22 @@ static void uclamp_fork(struct task_struct *p) } } +static void __init init_uclamp_rq(struct rq *rq) +{ + enum uclamp_id clamp_id; + struct uclamp_rq *uc_rq = rq->uclamp; + + for_each_clamp_id(clamp_id) { + memset(uc_rq[clamp_id].bucket, + 0, + sizeof(struct uclamp_bucket)*UCLAMP_BUCKETS); + + uc_rq[clamp_id].value = uclamp_none(clamp_id); + } + + rq->uclamp_flags = 0; +} + static void __init init_uclamp(void) { struct uclamp_se uc_max = {}; @@ -1256,11 +1272,8 @@ static void __init init_uclamp(void) mutex_init(&uclamp_mutex); - for_each_possible_cpu(cpu) { - memset(&cpu_rq(cpu)->uclamp, 0, - sizeof(struct uclamp_rq)*UCLAMP_CNT); - cpu_rq(cpu)->uclamp_flags = 0; - } + for_each_possible_cpu(cpu) + init_uclamp_rq(cpu_rq(cpu)); for_each_clamp_id(clamp_id) { uclamp_se_set(&init_task.uclamp_req[clamp_id], -- 2.17.1