Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1571027pxj; Fri, 4 Jun 2021 19:15:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyV6CT8etSS0lYsVMS5FPon1+5FS1Kzubft+kJ2fl+Qm475AGCPMphWS5dqiGQXGK5pEzI3 X-Received: by 2002:a17:906:dc92:: with SMTP id cs18mr6871009ejc.327.1622859307780; Fri, 04 Jun 2021 19:15:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622859307; cv=none; d=google.com; s=arc-20160816; b=VcNhaPdAlNAFt1uyn/+ADC9rA8dEM4q0M6PtS6jGFTOk4ecwDy9hER57DsIN8bKW/u JlG+q6rNAa+ijgc32tw380bebc/w+QllhiUMWkzEwMmd59fO3lMowra5brT8pidmKTEE A6BolNoeHK8jNFFsE3w+vS3ntQqdNZrsU3C3DobcelzCXud/ThcJ4iut+cPvN3FGVLle rpGPqWQJlTHUf/yIfSSuJS9d1cvO+NTeQEPdBQcbeHFz2UVJcJS+N550gzWqkgOUMGAE Cq63xLbfNk6tLTUc26t3PR9IzcR5Fv4pWvb+FSgTV1KGj6lJ5IxStcA2dolnCphrZEZT 8KIw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=WNniSkgSAc5S7s5FLQAPPQEUdxZhABUBkTI5NiMDOWk=; b=nwGzrzsvUo8AePyO4XANAnzwniZsrgoa6GxxsOyklxuAmsir8f+oju2VK/UlybUJsm vFP3f3U4W51KJ9b6NN5e3GXyeYsVXTHq8d8yQbnEahTDhkVnPfqFWAEeFdAcDUeL9nS0 P2OXwHQ5gTtKjNWB5psuS3vjmPSe/XTflcW452tYjF2JWh/QeYrdRr8fpkhCYeG3Cd5U NpVkNMTolhdzenXQrJV30/YElob/Mze5v2GkXnEMOMXeak2H2uQeOccIYyKhkepxG4wr RZ11OKrEIunxZ/8xBNp4fkFiE/IstjFRIR6cPAUNj/FEzSrV4i7iI54/078b9NXCQ6US RMXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=jRrx7aGl; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j3si4064178ejo.404.2021.06.04.19.14.45; Fri, 04 Jun 2021 19:15:07 -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=@gmail.com header.s=20161025 header.b=jRrx7aGl; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230297AbhFECPd (ORCPT + 99 others); Fri, 4 Jun 2021 22:15:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60902 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230169AbhFECPd (ORCPT ); Fri, 4 Jun 2021 22:15:33 -0400 Received: from mail-lj1-x230.google.com (mail-lj1-x230.google.com [IPv6:2a00:1450:4864:20::230]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C36F1C061766 for ; Fri, 4 Jun 2021 19:13:31 -0700 (PDT) Received: by mail-lj1-x230.google.com with SMTP id m3so13906822lji.12 for ; Fri, 04 Jun 2021 19:13:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=WNniSkgSAc5S7s5FLQAPPQEUdxZhABUBkTI5NiMDOWk=; b=jRrx7aGlQeP2pPya3RfBcXZJtRjTDPZPkXpwgLqjb0WFxZtdAgBtuzbueC8OJ+eYQO XQHO9JW9liS0K3aF6cEtphm3YGwNjSXesg+vIBV/UTYQFxSdLjwPleaAP4hzNbop+iMs 7yK2jq95fRn6N9RZJWnecYlD4HrhHsTgxx+CqA4Jkc9xBB223/Ss6JOyJRsghj3uCtZ1 ru3Ql2MfQq+egezgcdGiIfu38SGRHAFOfDYC8yIFPzRzUo+1dJ/Me2yNNSytTvYVeCeD Zl4tSHccvM3tTclcPfOd1tyssOQ4oaCvZlRXd8nVk7gizKi6hamY00CeAy5jZwEtKaPR aZ/g== 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:content-transfer-encoding; bh=WNniSkgSAc5S7s5FLQAPPQEUdxZhABUBkTI5NiMDOWk=; b=q4XQZ5m9JLuo6U54Nhia9/Qpgr8+gJr6x/gth/cAYAIrsIoZeHQIyZ1wDY13YWrMZi aPbz/2S615M1yIHZJVID9/szE5OIJXkBEiFTs31Idn2k8pnSKVHV3KyVAe2ahPfrPVj2 ub5on9QBcjB9lDXZe6ijFud+TxDWR2EIyX3qtrD6J2Ni7d2k/6qtjBj8DwBqpEgoJEz+ neqTUgjeI6kmFYbM8m8sTfH6MBqgnslvHZZm6KDJ/tSIePqRv/feoa5GWIsumjDjmRO7 HdP+yhWjZW2g6L+aq3lTN/1aVb/UMaKbiyuFRmZWJHpVyjPXp2+op0Z6fYLPhvNQHXkF G7Ag== X-Gm-Message-State: AOAM533o4XD4AYgjEkUHVN/Ntfgsn5FvhEIrKte4DFkdNfQ2sDDCkm0+ T6w8T4NhU9GVjTsfkz3CYnNddenlXu+MN1XVU8o= X-Received: by 2002:a2e:a717:: with SMTP id s23mr5561084lje.282.1622859210169; Fri, 04 Jun 2021 19:13:30 -0700 (PDT) MIME-Version: 1.0 References: <20210602123803.15738-1-xuewen.yan94@gmail.com> <20210604160839.2op4ak75vle3gmt3@e107158-lin.cambridge.arm.com> In-Reply-To: <20210604160839.2op4ak75vle3gmt3@e107158-lin.cambridge.arm.com> From: Xuewen Yan Date: Sat, 5 Jun 2021 10:12:29 +0800 Message-ID: Subject: Re: [PATCH] sched/uclamp: Avoid setting cpu.uclamp.min bigger than cpu.uclamp.max To: Qais Yousef Cc: Quentin Perret , Ingo Molnar , Peter Zijlstra , Juri Lelli , Vincent Guittot , Dietmar Eggemann , Steven Rostedt , Benjamin Segall , Mel Gorman , Daniel Bristot de Oliveira , linux-kernel , Chunyan Zhang , Ryan Y , Patrick Bellasi , tj@kernel.org Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Qais, On Sat, Jun 5, 2021 at 12:08 AM Qais Yousef wrote: > > On 06/03/21 10:24, Xuewen Yan wrote: > > +CC Qais > > Thanks for the CC :) > > > > > > > Hi Quentin > > > > On Wed, Jun 2, 2021 at 9:22 PM Quentin Perret wrot= e: > > > > > > +CC Patrick and Tejun > > > > > > On Wednesday 02 Jun 2021 at 20:38:03 (+0800), Xuewen Yan wrote: > > > > From: Xuewen Yan > > > > > > > > When setting cpu.uclamp.min/max in cgroup, there is no validating > > > > like uclamp_validate() in __sched_setscheduler(). It may cause the > > > > cpu.uclamp.min is bigger than cpu.uclamp.max. > > > > > > ISTR this was intentional. We also allow child groups to ask for > > > whatever clamps they want, but that is always limited by the parent, = and > > > reflected in the 'effective' values, as per the cgroup delegation mod= el. > > As Quentin said. This intentional to comply with cgroup model. > > See Limits and Protections sections in Documentation/admin-guide/cgroup-v= 2.rst > > Specifically > > "all configuration combinations are valid" > > So user can set cpu.uclamp.min higher than cpu.uclamp.max. But when we ap= ply > the setting, cpu.uclamp.min will be capped by cpu.uclamp.max. I can see y= ou > found the cpu_util_update_eff() logic. > Thanks a lot for your patience to explain, sorry for my ignorance of Documentation/admin-guide/cgroup-v2.rst. > > > > It does not affect the 'effective' value. That because there is > > protection in cpu_util_update_eff(): > > /* Ensure protection is always capped by limit */ > > eff[UCLAMP_MIN] =3D min(eff[UCLAMP_MIN], eff[UCLAMP_MAX]); > > > > When users set the cpu.uclamp.min > cpu.uclamp.max: > > cpu.uclamp.max =3D 50; > > to set : cpu.uclamp.min =3D 60; > > That would make the uclamp_req[UCLAMP_MIN].value =3D 1024* 60% =3D 614, > > uclamp_req[UCLAMP_MAX].value =3D 1024* 50% =3D 512; > > But finally, the uclamp[UCLAMP_MIN].value =3D uclamp[UCLAMP_MAX].value > > =3D 1024* 50% =3D 512; > > > > Is it deliberately set not to validate because of the above? > > Sorry I'm not following you here. What code paths were you trying to expl= ain > here? > > Did you actually hit any problem here? I just gave an example of the difference of uclamp_req and uclamp without my patch, and can ignore it. > In addition=EF=BC=8CIn your patch: 6938840392c89 ("sched/uclamp: Fix wrong implementation of cpu.uclamp.min") https://lkml.kernel.org/r/20210510145032.1934078-2-qais.yousef@arm.com + switch (clamp_id) { + case UCLAMP_MIN: { + struct uclamp_se uc_min =3D task_group(p)->uclamp[clamp_id]; + if (uc_req.value < uc_min.value) + return uc_min; + break; When the clamp_id =3D UCLAMP_MIN, why not judge the uc_req.value is bigger than task_group(p)->uclamp[UCLAMP_MAX] ? Because when the p->uclamp_req[UCLAMP_MIN] > task_group(p)->uclamp[UCLAMP_= MAX], the patch can not clamp the p->uclamp_req[UCLAMP_MIN/MAX] into [ task_group(p)->uclamp[UCLAMP_MAX], task_group(p)->uclamp[UCLAMP_MAX] ]. Is it necessary to fix it here=EF=BC=9F Thanks xuewen