Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp104092pxa; Fri, 31 Jul 2020 07:29:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy8fRRAlJZxT0R66qXEOOvAMn9+xgxIaSRST8LffslILyM87Ex5CqVwawKgtEnKXkKs+adO X-Received: by 2002:a17:906:289a:: with SMTP id o26mr4194067ejd.309.1596205787627; Fri, 31 Jul 2020 07:29:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596205787; cv=none; d=google.com; s=arc-20160816; b=LdQzaIJ/bqbOnF32fYgznmjTpSSahUyBkGVj8hf7QjisXjXIbxashIlGwZKQMLiYXk sUno5E4G+ZIO+ROgcIBu+/zVlJGufu1189aEDrFsYeKvdSOIeA+u6DPrWRZaYnT2J6vl /JeeqJ/MSCfBR9AbgH0IEXPMiBXQtG+HfNQvmBmNbTTwk8ayFWg/eDcEnQVR5yAJWTlK ea/E9SBlO+NOLjBewMXj5y9wEwuGpqms/F20vVySMT20HzRGgmIRbgaWM1Tt7gpsx0Ky 32al8QkcaDJslp+OsbUif3tdvR1Tomk4JQMn+AX3+W8bmBB60mw3j+MvgIcSMa39WkOn TbYg== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=L/yeg35uqv40+HRDA42qHFMPJctfnO1XRNKJxq09ZC8=; b=kSxclnYN0wxlpTgAcyS0cTA4OUZxGhL3U6Aw/ksNNRtk9js/buoE4jgHIBsw5uSJi9 LbH/+6KItXUAHIDCsFfamohuFQM45hhl6Kx6o6P0Svk0Y804xGFzYkWjqZrsHf/0E0zu vwYSaBAJjWl9CTJEKqCJQLC5z/A+YhcxzaiYja+699Pxhl6SnufcuIFwkU8uGLaxTk8G IOk41dND9TDefsEBkjNWyFLo8TRezxWUytj+SApdl2/VY9M6usEIyfxUMHZXoChtkBuM PaEefKdUBnHUsEImdfdJAJPdv52j989mEff/uJXMhSrPdpoldhETyOEpixDSNGeAMNAY mvcA== 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 bt10si4779476ejb.491.2020.07.31.07.29.24; Fri, 31 Jul 2020 07:29:47 -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 S1728853AbgGaO0Z (ORCPT + 99 others); Fri, 31 Jul 2020 10:26:25 -0400 Received: from foss.arm.com ([217.140.110.172]:60984 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728597AbgGaO0Z (ORCPT ); Fri, 31 Jul 2020 10:26:25 -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 B61BD31B; Fri, 31 Jul 2020 07:26:24 -0700 (PDT) Received: from [192.168.178.2] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 8B9013F66E; Fri, 31 Jul 2020 07:26:05 -0700 (PDT) Subject: Re: [PATCH v2] sched: Provide USF for the portable equipment. To: Dongdong Yang , gregkh@linuxfoundation.org, rjw@rjwysocki.net, viresh.kumar@linaro.org, mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de Cc: linux-kernel@vger.kernel.org, devel@driverdev.osuosl.org, linux-pm@vger.kernel.org, yangdongdong@xiaomi.com, tanggeliang@xiaomi.com, taojun@xiaomi.com, huangqiwu@xiaomi.com, rocking@linux.alibaba.com, fengwei@xiaomi.com, zhangguoquan@xiaomi.com, gulinghua@xiaomi.com, duhui@xiaomi.com References: From: Dietmar Eggemann Message-ID: <67e5566b-2ec5-0a1d-87e1-88e90a8fa715@arm.com> Date: Fri, 31 Jul 2020 16:25:56 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 31/07/2020 14:46, Dongdong Yang wrote: > From: Dongdong Yang [...] > + if (unlikely(usf_vdev.enable_debug)) > + trace_printk > + ("%s: cpu_id=%d non_ux=%d usf_up=%d usf_down=%d util=%lu\n", > + USF_TAG, cpuid, usf_vdev.usf_non_ux, > + usf_vdev.usf_up_l0, usf_vdev.usf_down, *util); trace_printk in code ? > +static int usf_lcd_notifier(struct notifier_block *nb, > + unsigned long val, void *data) > +{ > + struct fb_event *evdata = data; > + unsigned int blank; > + > + if (!evdata) > + return 0; > + > + if (val != FB_EVENT_BLANK) > + return 0; > + > + if (evdata->data && val == FB_EVENT_BLANK) { > + blank = *(int *)(evdata->data); > + > + switch (blank) { > + case FB_BLANK_POWERDOWN: > + usf_vdev.is_screen_on = 0; > + if (usf_vdev.sysctl_sched_usf_non_ux != 0) > + static_branch_enable(&adjust_task_pred_set); > + else > + static_branch_disable(&adjust_task_pred_set); > + > + break; > + > + case FB_BLANK_UNBLANK: > + usf_vdev.is_screen_on = 1; > + if (usf_vdev.sysctl_sched_usf_up_l0 != 0 || > + usf_vdev.sysctl_sched_usf_down != 0) > + static_branch_enable(&adjust_task_pred_set); > + else > + static_branch_disable(&adjust_task_pred_set); > + break; > + default: > + break; > + } > + > + usf_vdev.is_sched_usf_enabled = 1; > + if (usf_vdev.enable_debug) > + trace_printk("%s : usf_vdev.is_screen_on:%d\n", > + __func__, usf_vdev.is_screen_on); > + } > + return NOTIFY_OK; > +} > + > +static struct notifier_block usf_lcd_nb = { > + .notifier_call = usf_lcd_notifier, > + .priority = INT_MAX, > +}; Looks like those notifications should enable/disable the schedutil extension adjust_task_pred_demand(). Who's calling them? The 3 sched_usf_FOO sys files somehow have an influence here too. How should this work? I see a fb_register_client() in intera_monitor_init further below. [...] > +usf_attr_rw(sched_usf_up_l0_r); > +usf_attr_rw(sched_usf_down_r); > +usf_attr_rw(sched_usf_non_ux_r); What can I do with these three files? What do they stand for? root@h620:/sys/devices/system/cpu/sched_usf# ls sched_usf_down_r sched_usf_non_ux_r sched_usf_up_l0_r [...] > +static int __init intera_monitor_init(void) > +{ > + int res = -1; > + struct attribute_group *attr_group; > + > + res = fb_register_client(&usf_lcd_nb); > + if (res < 0) { > + pr_err("Failed to register usf_lcd_nb!\n"); > + return res; [...]