Received: by 2002:a05:7412:f584:b0:e2:908c:2ebd with SMTP id eh4csp1962413rdb; Tue, 5 Sep 2023 10:00:04 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFvWfr6S00bi5B1zNpuZpErCgz6sVV3xw78UyPQAHTSzfMBe8HIalF4A+/E34B60SvA4gTU X-Received: by 2002:a92:d952:0:b0:346:1919:7cb1 with SMTP id l18-20020a92d952000000b0034619197cb1mr12650916ilq.2.1693933203234; Tue, 05 Sep 2023 10:00:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1693933203; cv=none; d=google.com; s=arc-20160816; b=hMitnw7EJhwc9fJgCoRoJ/e+sIBYLxnf2sXolj+Phzjetcd1sVtrT35qI3Ek3196AT D5MBxuQUjoraRDryQ9P0VBB3/UBR892SxFIwqX5o14jsxwr9uX1OiI1WQ1QIwrTboivl dthE1d8FK3BLwdO0uljtYB4VDhIwLc4XuOtOnz6ZSx+4yf9NnyuHEn0Fazl4UY6Eyh8v XHL74fvPVoMgwdfIAIrQ89etKlbe1n90Otc6NxOkokrZlW4dr853AEQI0hdIda4d2v4A pMtmZXVmYFBQ8hI3KmWdQK/w7/E3aM74cU6GxUYbLZbX5tgFsBBxbn2UFO5h6+uOvl3o Q7uw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=2wN1X5fBI4q9X5EmxRXxR3Y4mZ7KwP1OsUi7wgvSTwU=; fh=TqUufSrsSTunWvlKWl6WsuSIqHx0uhxZWTQpn6Im9mg=; b=ONooYhr6mDcYZppgvV/Fy6IxpeJPeLgoEzOUKHBjGI47gIQNqV0pj4f6Aq5llYR7v4 D/nL1MGWG+vsecpDiqUU95nl+lM25L6rcJ8qCd0NWJnXUrTGyEsHqmmm5Bjlf5/jQ9I9 07CfYIKdew/i3qI/48nxlS+dmqoGx2Z0aJGM6lEx7K2FmxEbh2P7w6+b+vH1MY1INKE0 eef3lOtdulXZIZ3rENQZ7eHOM8upDvjFHOpaZz8u7Pcj2fRGRwXxZErK6ViMK9sb5LwJ dVe4TDCJZX44FjbqmKQ2gFY5KXAPnWDHZD0zFfcPfG12OAJCB+fDHBv6v04JBJGGeYNi LpFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b=mMf5Nkib; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nh4-20020a17090b364400b00271c377a534si9814015pjb.104.2023.09.05.09.59.49; Tue, 05 Sep 2023 10:00:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b=mMf5Nkib; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234512AbjIEQlc (ORCPT + 99 others); Tue, 5 Sep 2023 12:41:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1354735AbjIENz1 (ORCPT ); Tue, 5 Sep 2023 09:55:27 -0400 Received: from desiato.infradead.org (desiato.infradead.org [IPv6:2001:8b0:10b:1:d65d:64ff:fe57:4e05]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DEF33CE for ; Tue, 5 Sep 2023 06:55:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=desiato.20200630; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=2wN1X5fBI4q9X5EmxRXxR3Y4mZ7KwP1OsUi7wgvSTwU=; b=mMf5NkibFQ3qJ9YZ822tgtfwkY s8DuaIlFcLj/Xz+ocUqZnnfu9fJT+XlomEawIUfq9/sIXhxOeYXdiFM6rMih4kusTg/OQsfmTQm97 2FaHjndgUCcobDZc7e7fZrC7nznty1nz0EdyjTUykRL8r2He1OFP7JG8YRk2LZK0mW4e0xZbS6GC/ 1be3Y4QabE0WfGYtx1Hvgr4/z9oWUzLa8M8xEY6Bo0iqHzHva7k5BnNdjZd/oVaSLgSDD60zLZ8Kl w3pT/GiHtN5qxhgbjaPe98czf/+vdNElsU/Srtdzgkpbod4JwZ8KNRBbKbtCzg/LAKVSqlTDuQljK ShDdVamg==; Received: from j130084.upc-j.chello.nl ([24.132.130.84] helo=noisy.programming.kicks-ass.net) by desiato.infradead.org with esmtpsa (Exim 4.96 #2 (Red Hat Linux)) id 1qdWWB-000Wbq-2F; Tue, 05 Sep 2023 13:55:01 +0000 Received: by noisy.programming.kicks-ass.net (Postfix, from userid 1000) id BD043300687; Tue, 5 Sep 2023 15:55:00 +0200 (CEST) Date: Tue, 5 Sep 2023 15:55:00 +0200 From: Peter Zijlstra To: Daniel Bristot de Oliveira Cc: Ingo Molnar , Juri Lelli , Vincent Guittot , Dietmar Eggemann , Steven Rostedt , Ben Segall , Mel Gorman , Daniel Bristot de Oliveira , Valentin Schneider , linux-kernel@vger.kernel.org, Luca Abeni , Tommaso Cucinotta , Thomas Gleixner , Joel Fernandes , Vineeth Pillai , Shuah Khan , Phil Auld Subject: Re: [PATCH v4 7/7] sched/fair: Fair server interface Message-ID: <20230905135500.GB20703@noisy.programming.kicks-ass.net> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_BLOCKED, SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Aug 31, 2023 at 10:28:58PM +0200, Daniel Bristot de Oliveira wrote: > +static ssize_t > +sched_fair_server_runtime_write(struct file *filp, const char __user *ubuf, > + size_t cnt, loff_t *ppos) > +{ > + long cpu = (long) ((struct seq_file *) filp->private_data)->private; > + struct rq *rq = cpu_rq(cpu); > + unsigned long flags; > + u64 runtime; > + int err; > + > + err = kstrtoull_from_user(ubuf, cnt, 10, &runtime); > + if (err) > + return err; > + > + raw_spin_rq_lock_irqsave(rq, flags); > + if (runtime > rq->fair_server.dl_period) > + err = -EINVAL; > + else > + rq->fair_server.dl_runtime = runtime; > + raw_spin_rq_unlock_irqrestore(rq, flags); > + > + if (err) > + return err; > + > + *ppos += cnt; > + return cnt; > +} > +static ssize_t > +sched_fair_server_period_write(struct file *filp, const char __user *ubuf, > + size_t cnt, loff_t *ppos) > +{ > + long cpu = (long) ((struct seq_file *) filp->private_data)->private; > + struct rq *rq = cpu_rq(cpu); > + unsigned long flags; > + u64 period; > + int err; > + > + err = kstrtoull_from_user(ubuf, cnt, 10, &period); > + if (err) > + return err; > + > + if (period < fair_server_period_min || period > fair_server_period_max) > + return -EINVAL; > + > + raw_spin_rq_lock_irqsave(rq, flags); > + if (period < rq->fair_server.dl_runtime) > + err = -EINVAL; > + else > + rq->fair_server.dl_period = period; > + raw_spin_rq_unlock_irqrestore(rq, flags); > + > + if (err) > + return err; > + > + *ppos += cnt; > + return cnt; > +} > +static ssize_t > +sched_fair_server_defer_write(struct file *filp, const char __user *ubuf, > + size_t cnt, loff_t *ppos) > +{ > + long cpu = (long) ((struct seq_file *) filp->private_data)->private; > + struct rq *rq = cpu_rq(cpu); > + unsigned long flags; > + u64 defer; > + int err; > + > + err = kstrtoull_from_user(ubuf, cnt, 10, &defer); > + if (err) > + return err; > + > + if (defer < 0 || defer > 1) > + return -EINVAL; > + > + raw_spin_rq_lock_irqsave(rq, flags); > + rq->fair_server_defer = defer; > + raw_spin_rq_unlock_irqrestore(rq, flags); > + > + *ppos += cnt; > + return cnt; > +} Surely we can write a single function that does all of that with less duplication? Additionally, should not the deadline parameters be vetted by access control before being accepted ? Perhaps something like so: static ssize_t sched_fair_server_write(struct file *filp, const char __user *ubuf, size_t cnt, loff_t *ppos, enum dl_param param) { long cpu = (long) ((struct seq_file *) filp->private_data)->private; struct rq *rq = cpu_rq(cpu); u64 value; err = kstrtoull_from_user(ubuf, cnt, 10, &value); if (err) return err; scoped_guard (rq_lock_irqsave, rq) { u64 runtime, deadline, period; runtime = rq->fair_server.dl_runtime; deadline = rq->fair_server.dl_deadline; period = rq->fair_server.dl_period; switch (param) { case dl_runtime: runtime = value; break; case dl_deadline: deadline = value; break; case dl_period: period = value; break; } if (runtime > deadline || deadline > period || /* more stuff like access controll */) return -EINVAL; rq->fair_server.dl_runtime = runtime; rq->fair_server.dl_deadline = deadline; rq->fair_server.dl_period = period; } *ppos += cnt; return cnt; }