Received: by 2002:a25:f815:0:0:0:0:0 with SMTP id u21csp2694522ybd; Thu, 27 Jun 2019 17:45:19 -0700 (PDT) X-Google-Smtp-Source: APXvYqydD2QQTG1/wjYSJy/Gc72frWr4vgDK4nhnDNQRv8jGKK52a+0P6GkPFDfi/da/516o60Wu X-Received: by 2002:a17:902:9896:: with SMTP id s22mr7719298plp.4.1561682719261; Thu, 27 Jun 2019 17:45:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561682719; cv=none; d=google.com; s=arc-20160816; b=goMWsvKn0UCmR58R3MuLuydhQhJrPjbS3yxCcdJorrlhB3B5oV2V2fWylyWypjNvDs fDUIpO/4s0WqJoCML6PJZ2enxA9x+TwbcZBW7z4z1oWmpms8jOI2tQBG7OdUtCLc5nvX SMFC5FvMmFdjueayCPGaFYOoZzkKQDP9ClWATOo/t37RlQZQw0lX9wEqezjNlPA68VtS 0A1vUxWsmBoAwAZWb+JHTQlCuM6UefhkTIWevFdNto+hvpK2yJgmqMRb84iACvE5mol2 VbwVhnno1EkIRMTvruUfp4G2+ZKnt6Np/+kgA9qOvLyxUa6VwZtjfJ29PZo9HkyulrSC ve2w== 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:dkim-signature; bh=d162iqtuNRNjSY3NyB0aYNZBj8AFFyHaBGabROY5zB0=; b=Mvx23iSzNDPJZtJpNC9ds9KhFtGlFQqv1f2u4Ta2P2c1B3avbgk/z+QmVvu0Tvjvwg IvY4VGQPjlgM3bo6zJ1WjSWVZ3krclA6ZCLUwaTM1tRYqtOqIZ1eRDCIoDPUJqHnPna9 YvY2+2aXN/ewE7WXgrQbl8zksQ3pXuOZO80C3SwCo4bRJ44TJTPq0FNDPogcoFGPzWpT lUB01drsQttGD/9ibtKNBI0qSmAiNSE2ja3JzYug6Z3RAe6uI2KQgryxPGo9S8Hydo2I oXQxLtlTIFOROfFOzHeLm+5/jwCZI6dDJEFo7s7j3JijzD6TjKJZXBgpCkWkF+xDP3rd qo+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=YHZTLQ59; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id a2si669505pgb.166.2019.06.27.17.45.02; Thu, 27 Jun 2019 17:45:19 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=YHZTLQ59; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1726707AbfF1AnX (ORCPT + 99 others); Thu, 27 Jun 2019 20:43:23 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:40124 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726579AbfF1AnW (ORCPT ); Thu, 27 Jun 2019 20:43:22 -0400 Received: by mail-pf1-f196.google.com with SMTP id p184so2049157pfp.7 for ; Thu, 27 Jun 2019 17:43:21 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=d162iqtuNRNjSY3NyB0aYNZBj8AFFyHaBGabROY5zB0=; b=YHZTLQ59iv53WzHQFefXff3T56dcMxiJD5Yctll4VgHgaQgI4i3ZrviitjnvQGXV+r BuCh2omzPIM+C2pkLzOmE9Jc5FH3pDKkJfdP1qkHjI2Ef31JGHo1RuCHFwcdN4HmE+AL I14oFVB5nj3oYfn/jeqXY2x/qhpP94moQHLjMDmLNPO39wT04oJgXQu9xduuOzsJwt/7 BKG++PDEmepZGsiQLRJ6Il+wOePVG+23eyEABZMSVEijkbisWLuTGiE+JTrbixCpaXF7 RDJF2tiY190d21PRwcKzT7WicYf8U4ts1Jmer3/y2sYjjEmGjI+V43FlWJd7WlR1BjEP SPrQ== 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:in-reply-to :references; bh=d162iqtuNRNjSY3NyB0aYNZBj8AFFyHaBGabROY5zB0=; b=cvE0jQEQTZZ0QFKDJ7Ax7SM6f37/MEpmFQpPLD0+wU/eql27MhyelZsSYySQTCkSn/ /pqADDOY4QktrZhP9hCEPRSiDKqPEKTk9ZuFjLIWp2ZMyIKr/NH3uwyTfZcv+tkxeec8 2YQSLKwH6x3P09IhTdZ4GU6MxlpRMA7EgxfvKDwbmHBpFGlDM6ZJYJveh28S7MKoXu4x J30c8jPcPiuasxeOunrTLp/INnFmwUadE6RhFapZDU8FeVCibpBGdGpojz4VmN/XFM2J xLe+JwUP5UZFvRTs+iicHMXo0k8XQESYF1FurdLIzaci1fVpvEUjjLLOqpNpqGl9Vc47 ZtgA== X-Gm-Message-State: APjAAAVDkjCjBX6RrTxpPd4aDYicqRvWVmacppv6iZi6+Xw+Hey6uY7W 1v/2oiOGltLy7QMwESaoBdgbGWRdvtM= X-Received: by 2002:a17:90a:d817:: with SMTP id a23mr9417481pjv.54.1561682601211; Thu, 27 Jun 2019 17:43:21 -0700 (PDT) Received: from localhost.localdomain ([203.205.141.123]) by smtp.googlemail.com with ESMTPSA id n89sm11927802pjc.0.2019.06.27.17.43.19 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 27 Jun 2019 17:43:20 -0700 (PDT) From: Wanpeng Li X-Google-Original-From: Wanpeng Li To: linux-kernel@vger.kernel.org Cc: Ingo Molnar , Peter Zijlstra , Ingo Molnar , Frederic Weisbecker , Thomas Gleixner Subject: [PATCH RESEND v3] sched/isolation: Prefer housekeeping cpu in local node Date: Fri, 28 Jun 2019 08:43:13 +0800 Message-Id: <1561682593-12071-2-git-send-email-wanpengli@tencent.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1561682593-12071-1-git-send-email-wanpengli@tencent.com> References: <1561682593-12071-1-git-send-email-wanpengli@tencent.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wanpeng Li In real product setup, there will be houseeking cpus in each nodes, it is prefer to do housekeeping from local node, fallback to global online cpumask if failed to find houseeking cpu from local node. Cc: Ingo Molnar Cc: Peter Zijlstra Cc: Frederic Weisbecker Cc: Thomas Gleixner Signed-off-by: Wanpeng Li --- v2 -> v3: * add sched_numa_find_closest comments v1 -> v2: * introduce sched_numa_find_closest kernel/sched/isolation.c | 12 ++++++++++-- kernel/sched/sched.h | 5 ++--- kernel/sched/topology.c | 22 ++++++++++++++++++++++ 3 files changed, 34 insertions(+), 5 deletions(-) diff --git a/kernel/sched/isolation.c b/kernel/sched/isolation.c index 123ea07..589afba 100644 --- a/kernel/sched/isolation.c +++ b/kernel/sched/isolation.c @@ -16,9 +16,17 @@ static unsigned int housekeeping_flags; int housekeeping_any_cpu(enum hk_flags flags) { - if (static_branch_unlikely(&housekeeping_overridden)) - if (housekeeping_flags & flags) + int cpu; + + if (static_branch_unlikely(&housekeeping_overridden)) { + if (housekeeping_flags & flags) { + cpu = sched_numa_find_closest(housekeeping_mask, smp_processor_id()); + if (cpu < nr_cpu_ids) + return cpu; + return cpumask_any_and(housekeeping_mask, cpu_online_mask); + } + } return smp_processor_id(); } EXPORT_SYMBOL_GPL(housekeeping_any_cpu); diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h index b08dee2..0db7431 100644 --- a/kernel/sched/sched.h +++ b/kernel/sched/sched.h @@ -1212,9 +1212,6 @@ enum numa_topology_type { extern enum numa_topology_type sched_numa_topology_type; extern int sched_max_numa_distance; extern bool find_numa_distance(int distance); -#endif - -#ifdef CONFIG_NUMA extern void sched_init_numa(void); extern void sched_domains_numa_masks_set(unsigned int cpu); extern void sched_domains_numa_masks_clear(unsigned int cpu); @@ -1224,6 +1221,8 @@ static inline void sched_domains_numa_masks_set(unsigned int cpu) { } static inline void sched_domains_numa_masks_clear(unsigned int cpu) { } #endif +extern int sched_numa_find_closest(const struct cpumask *cpus, int cpu); + #ifdef CONFIG_NUMA_BALANCING /* The regions in numa_faults array from task_struct */ enum numa_faults_stats { diff --git a/kernel/sched/topology.c b/kernel/sched/topology.c index 63184cf..083ef23 100644 --- a/kernel/sched/topology.c +++ b/kernel/sched/topology.c @@ -1726,6 +1726,28 @@ void sched_domains_numa_masks_clear(unsigned int cpu) #endif /* CONFIG_NUMA */ +/* + * sched_numa_find_closest() - given the NUMA topology, find the cpu + * closest to @cpu from @cpumask. + * cpumask: cpumask to find a cpu from + * cpu: cpu to be close to + * + * returns: cpu, or >= nr_cpu_ids when nothing found (or !NUMA). + */ +int sched_numa_find_closest(const struct cpumask *cpus, int cpu) +{ +#ifdef CONFIG_NUMA + int i, j = cpu_to_node(cpu); + + for (i = 0; i < sched_domains_numa_levels; i++) { + cpu = cpumask_any_and(cpus, sched_domains_numa_masks[i][j]); + if (cpu < nr_cpu_ids) + return cpu; + } +#endif + return nr_cpu_ids; +} + static int __sdt_alloc(const struct cpumask *cpu_map) { struct sched_domain_topology_level *tl; -- 2.7.4