Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp2779654pxf; Sun, 21 Mar 2021 06:38:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz//zfiPdCzDNUBnSLxtl0TKIG+5WcNLCd7fgdc5cQH+KP7IXlJoZNzq/Pm7Oz2qMXJviuj X-Received: by 2002:a17:906:86c6:: with SMTP id j6mr13992146ejy.197.1616333881285; Sun, 21 Mar 2021 06:38:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616333881; cv=none; d=google.com; s=arc-20160816; b=GdKydb7PY/T9+LsebztJmQlIhL9KPlWlGb7BoHEzCoVpyaCz7P315Ef9AtRNRBYf/u ufEJUfwFK5sjgMztc0uUgfH0SQQrE23oY0TyrpzQfQwdwV5GOMbepduHm13Ce5nVh/MA YG/4dvR3ctY9WRxfHr4fZEVJuVswx6cBUNOOj3wVekXbrxd4o2CDFDeLiAHPR5Nb4i/h fKBMp5ZkaxRrx92nAlZk3S17Duh8F0C7bXyBtkcKuKoLBKjDZs+mtNmHrI/YmHBeBJMA KZFiqeJTBdb48h2DGONZclklYhOsddn2n1A+3sRF8i0O77U4O1F/BZ59zrj7wOww3Uty pIgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:ironport-sdr:ironport-sdr; bh=QGNqVIV3/yga+UOtS/34Z7Xgn/mnSA2rGbqi4RP1u3E=; b=SMAattuhT2pJ1kA6jop/kL70arzdKFYpF5i0pnusZ29TsM5X2e5QtjtZbBd8YPJjCR 28Rvf8PfXXevV8B58nfef1DUJI8S9OFR97dYQwcj2jZtvaEfm6QXjK/QkdGVhR7iuJ6b SSDnu7eBRdJ+RB1HhcSL8FPR9FQFoxNkRC2OybTDBl3KjBSFhKhbiUwI40WZtbsGWfjR /zBRXRZg2sG562TSR4voR/vbiJmTaXDmbLcIf2mnQQ1qqdlMRvu2ByBMhjxF3xpoZTOy 2zLgzFE9nCEbjRe75ggls+rzNg8QmFkBpngJF7gsh88xJq+lMOH8lizIqON8UtvIH2px dZXw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id l11si9226763ejq.118.2021.03.21.06.37.37; Sun, 21 Mar 2021 06:38:01 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229863AbhCUNef (ORCPT + 99 others); Sun, 21 Mar 2021 09:34:35 -0400 Received: from mga05.intel.com ([192.55.52.43]:58283 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229784AbhCUNeQ (ORCPT ); Sun, 21 Mar 2021 09:34:16 -0400 IronPort-SDR: CJapNXC+U5AZ4f+NocdZsVc1Gn/4Z/pApWkD5vqISxYGl+IHobozYOMuWg2+cXblTeSMbK/G/z RzPxQcjj21cw== X-IronPort-AV: E=McAfee;i="6000,8403,9929"; a="275221561" X-IronPort-AV: E=Sophos;i="5.81,266,1610438400"; d="scan'208";a="275221561" Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Mar 2021 06:34:16 -0700 IronPort-SDR: xHSXSYcBsmfzYbOQu3bCj24SaiwwzkfIkNFG7DxHnbl3iP4tRLbGuMsD00nGVbNBMvpzc3lEVp vS+HhS7TrwyQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.81,266,1610438400"; d="scan'208";a="440773942" Received: from cli6-desk1.ccr.corp.intel.com (HELO [10.239.161.125]) ([10.239.161.125]) by fmsmga002.fm.intel.com with ESMTP; 21 Mar 2021 06:34:02 -0700 Subject: Re: [PATCH 1/6] sched: migration changes for core scheduling To: Peter Zijlstra , "Joel Fernandes (Google)" Cc: Nishanth Aravamudan , Julien Desfossez , Tim Chen , Vineeth Pillai , Aaron Lu , Aubrey Li , tglx@linutronix.de, linux-kernel@vger.kernel.org, mingo@kernel.org, torvalds@linux-foundation.org, fweisbec@gmail.com, keescook@chromium.org, Phil Auld , Valentin Schneider , Mel Gorman , Pawan Gupta , Paolo Bonzini , vineeth@bitbyteword.org, Chen Yu , Christian Brauner , Agata Gruza , Antonio Gomez Iglesias , graf@amazon.com, konrad.wilk@oracle.com, dfaggioli@suse.com, rostedt@goodmis.org, benbjiang@tencent.com, Alexandre Chartre , James.Bottomley@hansenpartnership.com, OWeisse@umich.edu, Dhaval Giani , chris.hyser@oracle.com, Josh Don , Hao Luo , Tom Lendacky , Aubrey Li References: <20210319203253.3352417-1-joel@joelfernandes.org> <20210319203253.3352417-2-joel@joelfernandes.org> <20210320153457.GX4746@worktop.programming.kicks-ass.net> From: "Li, Aubrey" Message-ID: <28e13609-c526-c6ee-22a3-898652aed5e6@linux.intel.com> Date: Sun, 21 Mar 2021 21:34:00 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.7.1 MIME-Version: 1.0 In-Reply-To: <20210320153457.GX4746@worktop.programming.kicks-ass.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Peter, On 2021/3/20 23:34, Peter Zijlstra wrote: > On Fri, Mar 19, 2021 at 04:32:48PM -0400, Joel Fernandes (Google) wrote: >> @@ -7530,8 +7543,9 @@ int can_migrate_task(struct task_struct *p, struct lb_env *env) >> * We do not migrate tasks that are: >> * 1) throttled_lb_pair, or >> * 2) cannot be migrated to this CPU due to cpus_ptr, or >> - * 3) running (obviously), or >> - * 4) are cache-hot on their current CPU. >> + * 3) task's cookie does not match with this CPU's core cookie >> + * 4) running (obviously), or >> + * 5) are cache-hot on their current CPU. >> */ >> if (throttled_lb_pair(task_group(p), env->src_cpu, env->dst_cpu)) >> return 0; >> @@ -7566,6 +7580,13 @@ int can_migrate_task(struct task_struct *p, struct lb_env *env) >> return 0; >> } >> >> + /* >> + * Don't migrate task if the task's cookie does not match >> + * with the destination CPU's core cookie. >> + */ >> + if (!sched_core_cookie_match(cpu_rq(env->dst_cpu), p)) >> + return 0; >> + >> /* Record that we found atleast one task that could run on dst_cpu */ >> env->flags &= ~LBF_ALL_PINNED; >> > > This one is too strong.. persistent imbalance should be able to override > it. > IIRC, this change can avoid the following scenario: One sysbench cpu thread(cookieA) and sysbench mysql thread(cookieB) running on the two siblings of core_1, the other sysbench cpu thread(cookieA) and sysbench mysql thread(cookieB) running on the two siblings of core2, which causes 50% force idle. This is not an imbalance case. Thanks, -Aubrey