Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp159803pxb; Wed, 18 Nov 2020 19:56:09 -0800 (PST) X-Google-Smtp-Source: ABdhPJzWOyb+G/Ax92Z6In2mV5df7EkwPYLCdnzZvzVO+JQn0e+RotmQA47LFXk7pNpC/YYdoora X-Received: by 2002:a17:906:eb46:: with SMTP id mc6mr10186938ejb.54.1605758169715; Wed, 18 Nov 2020 19:56:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605758169; cv=none; d=google.com; s=arc-20160816; b=HzRu6iJR9Vrq2rgJZgQiFEZ2RYGGeeqkZ4uiwKuzpxr8l/kDrWq+YUAti3q2m+rQ5l R8gEyTAbTFylmfUiRRK+1gxmqKibOdZTpLvN0uhWJX09SHEknQAhbOuZtyUj4CVG3Hh3 Ju5BQI8drYvqYwiQT2JDoQ2zIoXv+Gr8GF+J0FAhQU5/qbp4hXYki05pt4RN6DcMg5tB u2TDkYGFve790j+IYUz3iKWCy/VGqGXkX3lWqkp8K9r2FFO8AR5YxVA9C5BILSRNrshz q/hUAp60XQnNhkIdwP4FG40xjF9tCr7HPFGHOkX0hWYZBpzwTGGeCqZvJntzrhPksLjY 6BPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=kSokh3hSyp9Wrxw7u+Bsx/a3PrubmjReLxXi4etOleQ=; b=QXdsHD/PaCyigWwUFmPbEPFjzuCjeCp30QZhxYE0bxhyBbbQGzT6CT/OlfvyPbHT8a BawTPdJnM92K8BJKHUQQvPp4AcWWC9Nri80ul5FTCxNif/OzUyYpPo+fv0n6sGZ7BWo/ TSEVZIx7txvPc/58ACRuHWyukQh7HAENssWh6lPR0TlteKAhdVBe2w3W1Y6OZxMz2bGO kqtdSa1Q8DqppLQs3ib5z1Q2pVFufPDC5SyYUvrlMVCCzyqyZ9tBFMhmZrUUjDBrZ0EV 670JqtNYD42IosH48uRc1Ys+qaaq2NHphfToa/cBIKXh1lv34/J5X33B+CqWkJ16BsuV 1R5g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=dTdWIuI1; 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 p62si16312959edd.213.2020.11.18.19.55.40; Wed, 18 Nov 2020 19:56:09 -0800 (PST) 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=dTdWIuI1; 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 S1726269AbgKSDxC (ORCPT + 99 others); Wed, 18 Nov 2020 22:53:02 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50502 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725767AbgKSDxB (ORCPT ); Wed, 18 Nov 2020 22:53:01 -0500 Received: from mail-oi1-x241.google.com (mail-oi1-x241.google.com [IPv6:2607:f8b0:4864:20::241]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 837DBC0613D4; Wed, 18 Nov 2020 19:53:01 -0800 (PST) Received: by mail-oi1-x241.google.com with SMTP id t16so4820024oie.11; Wed, 18 Nov 2020 19:53:01 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=kSokh3hSyp9Wrxw7u+Bsx/a3PrubmjReLxXi4etOleQ=; b=dTdWIuI1swXKTAkItc38BwjeWtAd8tefm2iJMSO69NfaUgmkIMni2W99ZJKT5nchCU cbmCsQPxhL1nJo+uO2GxhKK3JUvFVxssiHPfGzUAf+vRjJmiAVMTmiMAs7SgYxKCc2SE TMwhQCDxNyxFnJ4dFPEf/XcatNemUaONpayB0+9hg7tsudZOKCaSaYGf4g4mUeLma5sY ZWCjVYebeDbcdOWkBp3ZvGEVwY2BbGYfh9IDN7LzCBcfqq5HNi6Web3f3W+nGipy2oR1 0atjOFrBRNL+Vlvcb8KusBvluBiEJwVCTwtbNZVw0s0VUWxytyjJtVFTiI5EalkclXOi HwrA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=kSokh3hSyp9Wrxw7u+Bsx/a3PrubmjReLxXi4etOleQ=; b=HZYTFmyE1aWv0ZkYwe9GMJnOHrdDszCXt2yfFRbdT96SdFGQfJ+XiKekwApR6LMTGA 4F0Q1cDxBN7376+KuFQ3VhgiT3r/2phJ9R87YwhOcHfWllkHlfqDMvLrSmRmSM/y9eVQ N4RwVfDTnB+FGJdaww8dXs1a+Ych4Gb7hQpDuzUYBDC0TjwfpPBcr715/GxBG1AkKSvH kyJjrzlUG1D54DG+dENCgGk0fn1LukOikDPqbf+DmybMv7Z6Yw2/JQfucA/ATLXeJHfJ 1bMgwJbVVM1SviN2lwGp7dt1Pb0Mp+INWlyzyJjBdlcC63hPFkRtlIWqwlGZL476kqW+ MKpg== X-Gm-Message-State: AOAM530qerlrfB6WIEo2516OIchVHCqMTGWXDoQnkBJ3uiInxMi8zK1X BJ/p1f7TPsQkRrCED/DWhAk= X-Received: by 2002:aca:d19:: with SMTP id 25mr1690322oin.112.1605757981016; Wed, 18 Nov 2020 19:53:01 -0800 (PST) Received: from localhost.localdomain ([50.236.19.102]) by smtp.gmail.com with ESMTPSA id k20sm8320926ots.53.2020.11.18.19.52.53 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Wed, 18 Nov 2020 19:53:00 -0800 (PST) From: Yafang Shao To: mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org, dietmar.eggemann@arm.com, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de, bristot@redhat.com Cc: linux-kernel@vger.kernel.org, linux-rt-users@vger.kernel.org, Yafang Shao Subject: [RFC PATCH 0/4] sched: support schedstat for RT sched class Date: Thu, 19 Nov 2020 11:52:26 +0800 Message-Id: <20201119035230.45330-1-laoar.shao@gmail.com> X-Mailer: git-send-email 2.24.3 (Apple Git-128) MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We want to measure the latency of RT tasks in our production environment with schedstat facility, but currently schedstat is only supported for fair sched class. This patchset enable it for RT sched class as well. The schedstat statistics are defined in struct sched_entity, which is a member of struct task_struct, so we can resue it for RT sched class. The schedstat usage in RT sched class is similar with fair sched class, for example, fair RT enqueue update_stats_enqueue_fair update_stats_enqueue_rt dequeue update_stats_dequeue_fair update_stats_dequeue_rt put_prev_task update_stats_wait_start update_stats_wait_start set_next_task update_stats_wait_end update_stats_wait_end show /proc/[pid]/sched /proc/[pid]/sched The sched:sched_stats_* tracepoints can be used to trace RT tasks as well after that patchset. PATCH #1 ~ #3 are the preparation of PATCH #4. Yafang Shao (4): sched: define task_of() as a common helper sched: make schedstats helpers not depend on cfs_rq sched: define update_stats_curr_start() as a common helper sched, rt: support schedstat for RT sched class kernel/sched/fair.c | 173 ++----------------------------------------- kernel/sched/rt.c | 63 +++++++++++++++- kernel/sched/sched.h | 23 ++++++ kernel/sched/stats.c | 134 +++++++++++++++++++++++++++++++++ kernel/sched/stats.h | 11 +++ 5 files changed, 236 insertions(+), 168 deletions(-) -- 2.18.4