Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp764736pxb; Wed, 25 Aug 2021 14:41:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJziKodAybYO4x+Xz9adVKH2FngJJXA7Ri3TZ/Danj1uQiW+vxsHo5zmB1Sy1BDFTjP5Y547 X-Received: by 2002:a02:2348:: with SMTP id u69mr453608jau.141.1629927709724; Wed, 25 Aug 2021 14:41:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629927709; cv=none; d=google.com; s=arc-20160816; b=AKZqlfujlD/P9aXbBE2ixcC4hPvo+Y/N4Ktw0k+I0EE8Tl1WkeRfKKHVGg3PpZduyy UeeydrUGFvv4QPBKqo+INMaQOGGwyVQejptyNcdd3gTq7bxm7v4yOIFHRk9cb1a1Rkfs 48Avz5I3ab8ow8yRT1XaoyUxz+y5fJcV2DWBkFNPLo3bECRKShEno30pnhKaHpc3wLPU 7SwUeNPKWpYwLvVsSSiVJwTkB0qv84bhdRRI2ISddnQ6yiTcZj9SsvtCDp6uqb6mHHGb oBj9c6Ot+TdM1vsVdhSRctx8H4FurMWlFw6TCPe3xdrTYnIlKQQ/DXqj2iluavsZLwyH X2Mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from :dkim-signature; bh=CxAroS7sIZX9mrxN+Q1ftZvesv/+pNbSAsaThJf3nu8=; b=0kn92lycyStQvwfmKsTJGfhoS3g3Bpj6eoPttdkuAsv3tWWnbnoeEP8dgEnbuitQK/ NZe8O4mSP6XRVTj+N6Ixh0+RVw3hOhTK2+Yptrx0ClcOmdrbaGyJjoweo5Vzr96gV32p a4S4p//IHPWyVm7ilS9lcp9mUN5nOwddORG7px14ZDKGyk5I/xbTlzz4eqCFHw36d3L5 X/g4uHOO1o1stPZH2V2ObqApbduCezy3zEiDOsPzoPGfTvGlm2aD8GjkOXDbYoRMz7t5 56aQByLctYdo6WQhxOX7V65NkezAkYkv5wJwZkBlVu7WZ1WffnkYRToNNPjnKxGkaEv0 qd+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KuaxiiGp; 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=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i31si405315jac.56.2021.08.25.14.41.36; Wed, 25 Aug 2021 14:41:49 -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; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=KuaxiiGp; 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=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231535AbhHYVkz (ORCPT + 99 others); Wed, 25 Aug 2021 17:40:55 -0400 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:58453 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229599AbhHYVkz (ORCPT ); Wed, 25 Aug 2021 17:40:55 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1629927608; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc; bh=CxAroS7sIZX9mrxN+Q1ftZvesv/+pNbSAsaThJf3nu8=; b=KuaxiiGpL7lVKy/YErcyonR0lcv+fwYMrUoPfBiZ1tmMkoWB8x69eG2Aq2BKKve3E3coyq mwDpHQTinkxWOOoAUuxjQEZ/CdxtoA2lpf/c2+BRotRKIxYtV7Ke5V+9P6m7wWnIS5Qexz JLA7yGOrGiZaDfa/KzV2Wkv9PtVbUWw= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-540-GqJenG2xNI2d9Se4AYBgBw-1; Wed, 25 Aug 2021 17:40:05 -0400 X-MC-Unique: GqJenG2xNI2d9Se4AYBgBw-1 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 179D28015C7; Wed, 25 Aug 2021 21:40:03 +0000 (UTC) Received: from llong.com (unknown [10.22.18.37]) by smtp.corp.redhat.com (Postfix) with ESMTP id D23991B472; Wed, 25 Aug 2021 21:39:53 +0000 (UTC) From: Waiman Long To: Tejun Heo , Zefan Li , Johannes Weiner , Jonathan Corbet , Shuah Khan Cc: cgroups@vger.kernel.org, linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org, linux-kselftest@vger.kernel.org, Andrew Morton , Roman Gushchin , Phil Auld , Peter Zijlstra , Juri Lelli , Frederic Weisbecker , Marcelo Tosatti , =?UTF-8?q?Michal=20Koutn=C3=BD?= , Waiman Long Subject: [PATCH v7 0/6] cgroup/cpuset: Add new cpuset partition type & empty effecitve cpus Date: Wed, 25 Aug 2021 17:37:44 -0400 Message-Id: <20210825213750.6933-1-longman@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org v7: - Simplify the documentation patch (patch 5) as suggested by Tejun. - Fix a typo in patch 2 and improper commit log in patch 3. v6: - Remove duplicated tmpmask from update_prstate() which should fix the frame size too large problem reported by kernel test robot. v5: - Rebased to the latest for-5.15 branch of cgroup git tree and drop the 1st v4 patch as it has been merged. - Update patch 1 to always allow changing partition root back to member even if it invalidates child partitions undeneath it. - Adjust the empty effective cpu partition patch to not allow 0 effective cpu for terminal partition which will make it invalid). - Add a new patch to enable reading of cpuset.cpus.partition to display the reason that causes invalid partition. - Adjust the documentation and testing patch accordingly. This patchset makes four enhancements to the cpuset v2 code. Patch 1: Properly handle partition root tree and make partition invalid in case changes to cpuset.cpus violate any of the partition root constraints. Patch 2: Enable the "cpuset.cpus.partition" file to show the reason that causes invalid partition like "root invalid (No cpu available due to hotplug)". Patch 3: Add a new partition state "isolated" to create a partition root without load balancing. This is for handling intermitten workloads that have a strict low latency requirement. Patch 4: Allow partition roots that are not the top cpuset to distribute all its cpus to child partitions as long as there is no task associated with that partition root. This allows more flexibility for middleware to manage multiple partitions. Patch 5 updates the cgroup-v2.rst file accordingly. Patch 6 adds a new cpuset test to test the new cpuset partition code. Waiman Long (6): cgroup/cpuset: Properly transition to invalid partition cgroup/cpuset: Show invalid partition reason string cgroup/cpuset: Add a new isolated cpus.partition type cgroup/cpuset: Allow non-top parent partition to distribute out all CPUs cgroup/cpuset: Update description of cpuset.cpus.partition in cgroup-v2.rst kselftest/cgroup: Add cpuset v2 partition root state test Documentation/admin-guide/cgroup-v2.rst | 112 +-- kernel/cgroup/cpuset.c | 337 ++++++--- tools/testing/selftests/cgroup/Makefile | 5 +- .../selftests/cgroup/test_cpuset_prs.sh | 663 ++++++++++++++++++ tools/testing/selftests/cgroup/wait_inotify.c | 86 +++ 5 files changed, 1050 insertions(+), 153 deletions(-) create mode 100755 tools/testing/selftests/cgroup/test_cpuset_prs.sh create mode 100644 tools/testing/selftests/cgroup/wait_inotify.c -- 2.18.1