All of lore.kernel.org
 help / color / mirror / Atom feed
From: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
To: linux-kernel@vger.kernel.org
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
	stable@vger.kernel.org, Dave Chiluk <chiluk+linux@indeed.com>,
	"Peter Zijlstra (Intel)" <peterz@infradead.org>,
	Phil Auld <pauld@redhat.com>, Ben Segall <bsegall@google.com>,
	Ingo Molnar <mingo@redhat.com>,
	John Hammond <jhammond@indeed.com>,
	Jonathan Corbet <corbet@lwn.net>, Kyle Anderson <kwa@yelp.com>,
	Gabriel Munos <gmunoz@netflix.com>, Peter Oskolkov <posk@posk.io>,
	Cong Wang <xiyou.wangcong@gmail.com>,
	Brendan Gregg <bgregg@netflix.com>
Subject: [PATCH 5.3 158/163] sched/fair: Fix low cpu usage with high throttling by removing expiration of cpu-local slices
Date: Mon,  4 Nov 2019 22:45:48 +0100	[thread overview]
Message-ID: <20191104212151.722322521@linuxfoundation.org> (raw)
In-Reply-To: <20191104212140.046021995@linuxfoundation.org>

From: Dave Chiluk <chiluk+linux@indeed.com>

commit de53fd7aedb100f03e5d2231cfce0e4993282425 upstream.

It has been observed, that highly-threaded, non-cpu-bound applications
running under cpu.cfs_quota_us constraints can hit a high percentage of
periods throttled while simultaneously not consuming the allocated
amount of quota. This use case is typical of user-interactive non-cpu
bound applications, such as those running in kubernetes or mesos when
run on multiple cpu cores.

This has been root caused to cpu-local run queue being allocated per cpu
bandwidth slices, and then not fully using that slice within the period.
At which point the slice and quota expires. This expiration of unused
slice results in applications not being able to utilize the quota for
which they are allocated.

The non-expiration of per-cpu slices was recently fixed by
'commit 512ac999d275 ("sched/fair: Fix bandwidth timer clock drift
condition")'. Prior to that it appears that this had been broken since
at least 'commit 51f2176d74ac ("sched/fair: Fix unlocked reads of some
cfs_b->quota/period")' which was introduced in v3.16-rc1 in 2014. That
added the following conditional which resulted in slices never being
expired.

if (cfs_rq->runtime_expires != cfs_b->runtime_expires) {
	/* extend local deadline, drift is bounded above by 2 ticks */
	cfs_rq->runtime_expires += TICK_NSEC;

Because this was broken for nearly 5 years, and has recently been fixed
and is now being noticed by many users running kubernetes
(https://github.com/kubernetes/kubernetes/issues/67577) it is my opinion
that the mechanisms around expiring runtime should be removed
altogether.

This allows quota already allocated to per-cpu run-queues to live longer
than the period boundary. This allows threads on runqueues that do not
use much CPU to continue to use their remaining slice over a longer
period of time than cpu.cfs_period_us. However, this helps prevent the
above condition of hitting throttling while also not fully utilizing
your cpu quota.

This theoretically allows a machine to use slightly more than its
allotted quota in some periods. This overflow would be bounded by the
remaining quota left on each per-cpu runqueueu. This is typically no
more than min_cfs_rq_runtime=1ms per cpu. For CPU bound tasks this will
change nothing, as they should theoretically fully utilize all of their
quota in each period. For user-interactive tasks as described above this
provides a much better user/application experience as their cpu
utilization will more closely match the amount they requested when they
hit throttling. This means that cpu limits no longer strictly apply per
period for non-cpu bound applications, but that they are still accurate
over longer timeframes.

This greatly improves performance of high-thread-count, non-cpu bound
applications with low cfs_quota_us allocation on high-core-count
machines. In the case of an artificial testcase (10ms/100ms of quota on
80 CPU machine), this commit resulted in almost 30x performance
improvement, while still maintaining correct cpu quota restrictions.
That testcase is available at https://github.com/indeedeng/fibtest.

Fixes: 512ac999d275 ("sched/fair: Fix bandwidth timer clock drift condition")
Signed-off-by: Dave Chiluk <chiluk+linux@indeed.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: Phil Auld <pauld@redhat.com>
Reviewed-by: Ben Segall <bsegall@google.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: John Hammond <jhammond@indeed.com>
Cc: Jonathan Corbet <corbet@lwn.net>
Cc: Kyle Anderson <kwa@yelp.com>
Cc: Gabriel Munos <gmunoz@netflix.com>
Cc: Peter Oskolkov <posk@posk.io>
Cc: Cong Wang <xiyou.wangcong@gmail.com>
Cc: Brendan Gregg <bgregg@netflix.com>
Link: https://lkml.kernel.org/r/1563900266-19734-2-git-send-email-chiluk+linux@indeed.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

---
 Documentation/scheduler/sched-bwc.rst |   74 +++++++++++++++++++++++++++-------
 kernel/sched/fair.c                   |   72 +++------------------------------
 kernel/sched/sched.h                  |    4 -
 3 files changed, 67 insertions(+), 83 deletions(-)

--- a/Documentation/scheduler/sched-bwc.rst
+++ b/Documentation/scheduler/sched-bwc.rst
@@ -9,15 +9,16 @@ CFS bandwidth control is a CONFIG_FAIR_G
 specification of the maximum CPU bandwidth available to a group or hierarchy.
 
 The bandwidth allowed for a group is specified using a quota and period. Within
-each given "period" (microseconds), a group is allowed to consume only up to
-"quota" microseconds of CPU time.  When the CPU bandwidth consumption of a
-group exceeds this limit (for that period), the tasks belonging to its
-hierarchy will be throttled and are not allowed to run again until the next
-period.
-
-A group's unused runtime is globally tracked, being refreshed with quota units
-above at each period boundary.  As threads consume this bandwidth it is
-transferred to cpu-local "silos" on a demand basis.  The amount transferred
+each given "period" (microseconds), a task group is allocated up to "quota"
+microseconds of CPU time. That quota is assigned to per-cpu run queues in
+slices as threads in the cgroup become runnable. Once all quota has been
+assigned any additional requests for quota will result in those threads being
+throttled. Throttled threads will not be able to run again until the next
+period when the quota is replenished.
+
+A group's unassigned quota is globally tracked, being refreshed back to
+cfs_quota units at each period boundary. As threads consume this bandwidth it
+is transferred to cpu-local "silos" on a demand basis. The amount transferred
 within each of these updates is tunable and described as the "slice".
 
 Management
@@ -35,12 +36,12 @@ The default values are::
 
 A value of -1 for cpu.cfs_quota_us indicates that the group does not have any
 bandwidth restriction in place, such a group is described as an unconstrained
-bandwidth group.  This represents the traditional work-conserving behavior for
+bandwidth group. This represents the traditional work-conserving behavior for
 CFS.
 
 Writing any (valid) positive value(s) will enact the specified bandwidth limit.
-The minimum quota allowed for the quota or period is 1ms.  There is also an
-upper bound on the period length of 1s.  Additional restrictions exist when
+The minimum quota allowed for the quota or period is 1ms. There is also an
+upper bound on the period length of 1s. Additional restrictions exist when
 bandwidth limits are used in a hierarchical fashion, these are explained in
 more detail below.
 
@@ -53,8 +54,8 @@ unthrottled if it is in a constrained st
 System wide settings
 --------------------
 For efficiency run-time is transferred between the global pool and CPU local
-"silos" in a batch fashion.  This greatly reduces global accounting pressure
-on large systems.  The amount transferred each time such an update is required
+"silos" in a batch fashion. This greatly reduces global accounting pressure
+on large systems. The amount transferred each time such an update is required
 is described as the "slice".
 
 This is tunable via procfs::
@@ -97,6 +98,51 @@ There are two ways in which a group may
 In case b) above, even though the child may have runtime remaining it will not
 be allowed to until the parent's runtime is refreshed.
 
+CFS Bandwidth Quota Caveats
+---------------------------
+Once a slice is assigned to a cpu it does not expire.  However all but 1ms of
+the slice may be returned to the global pool if all threads on that cpu become
+unrunnable. This is configured at compile time by the min_cfs_rq_runtime
+variable. This is a performance tweak that helps prevent added contention on
+the global lock.
+
+The fact that cpu-local slices do not expire results in some interesting corner
+cases that should be understood.
+
+For cgroup cpu constrained applications that are cpu limited this is a
+relatively moot point because they will naturally consume the entirety of their
+quota as well as the entirety of each cpu-local slice in each period. As a
+result it is expected that nr_periods roughly equal nr_throttled, and that
+cpuacct.usage will increase roughly equal to cfs_quota_us in each period.
+
+For highly-threaded, non-cpu bound applications this non-expiration nuance
+allows applications to briefly burst past their quota limits by the amount of
+unused slice on each cpu that the task group is running on (typically at most
+1ms per cpu or as defined by min_cfs_rq_runtime).  This slight burst only
+applies if quota had been assigned to a cpu and then not fully used or returned
+in previous periods. This burst amount will not be transferred between cores.
+As a result, this mechanism still strictly limits the task group to quota
+average usage, albeit over a longer time window than a single period.  This
+also limits the burst ability to no more than 1ms per cpu.  This provides
+better more predictable user experience for highly threaded applications with
+small quota limits on high core count machines. It also eliminates the
+propensity to throttle these applications while simultanously using less than
+quota amounts of cpu. Another way to say this, is that by allowing the unused
+portion of a slice to remain valid across periods we have decreased the
+possibility of wastefully expiring quota on cpu-local silos that don't need a
+full slice's amount of cpu time.
+
+The interaction between cpu-bound and non-cpu-bound-interactive applications
+should also be considered, especially when single core usage hits 100%. If you
+gave each of these applications half of a cpu-core and they both got scheduled
+on the same CPU it is theoretically possible that the non-cpu bound application
+will use up to 1ms additional quota in some periods, thereby preventing the
+cpu-bound application from fully using its quota by that same amount. In these
+instances it will be up to the CFS algorithm (see sched-design-CFS.rst) to
+decide which application is chosen to run, as they will both be runnable and
+have remaining quota. This runtime discrepancy will be made up in the following
+periods when the interactive application idles.
+
 Examples
 --------
 1. Limit a group to 1 CPU worth of runtime::
--- a/kernel/sched/fair.c
+++ b/kernel/sched/fair.c
@@ -4370,8 +4370,6 @@ void __refill_cfs_bandwidth_runtime(stru
 
 	now = sched_clock_cpu(smp_processor_id());
 	cfs_b->runtime = cfs_b->quota;
-	cfs_b->runtime_expires = now + ktime_to_ns(cfs_b->period);
-	cfs_b->expires_seq++;
 }
 
 static inline struct cfs_bandwidth *tg_cfs_bandwidth(struct task_group *tg)
@@ -4393,8 +4391,7 @@ static int assign_cfs_rq_runtime(struct
 {
 	struct task_group *tg = cfs_rq->tg;
 	struct cfs_bandwidth *cfs_b = tg_cfs_bandwidth(tg);
-	u64 amount = 0, min_amount, expires;
-	int expires_seq;
+	u64 amount = 0, min_amount;
 
 	/* note: this is a positive sum as runtime_remaining <= 0 */
 	min_amount = sched_cfs_bandwidth_slice() - cfs_rq->runtime_remaining;
@@ -4411,61 +4408,17 @@ static int assign_cfs_rq_runtime(struct
 			cfs_b->idle = 0;
 		}
 	}
-	expires_seq = cfs_b->expires_seq;
-	expires = cfs_b->runtime_expires;
 	raw_spin_unlock(&cfs_b->lock);
 
 	cfs_rq->runtime_remaining += amount;
-	/*
-	 * we may have advanced our local expiration to account for allowed
-	 * spread between our sched_clock and the one on which runtime was
-	 * issued.
-	 */
-	if (cfs_rq->expires_seq != expires_seq) {
-		cfs_rq->expires_seq = expires_seq;
-		cfs_rq->runtime_expires = expires;
-	}
 
 	return cfs_rq->runtime_remaining > 0;
 }
 
-/*
- * Note: This depends on the synchronization provided by sched_clock and the
- * fact that rq->clock snapshots this value.
- */
-static void expire_cfs_rq_runtime(struct cfs_rq *cfs_rq)
-{
-	struct cfs_bandwidth *cfs_b = tg_cfs_bandwidth(cfs_rq->tg);
-
-	/* if the deadline is ahead of our clock, nothing to do */
-	if (likely((s64)(rq_clock(rq_of(cfs_rq)) - cfs_rq->runtime_expires) < 0))
-		return;
-
-	if (cfs_rq->runtime_remaining < 0)
-		return;
-
-	/*
-	 * If the local deadline has passed we have to consider the
-	 * possibility that our sched_clock is 'fast' and the global deadline
-	 * has not truly expired.
-	 *
-	 * Fortunately we can check determine whether this the case by checking
-	 * whether the global deadline(cfs_b->expires_seq) has advanced.
-	 */
-	if (cfs_rq->expires_seq == cfs_b->expires_seq) {
-		/* extend local deadline, drift is bounded above by 2 ticks */
-		cfs_rq->runtime_expires += TICK_NSEC;
-	} else {
-		/* global deadline is ahead, expiration has passed */
-		cfs_rq->runtime_remaining = 0;
-	}
-}
-
 static void __account_cfs_rq_runtime(struct cfs_rq *cfs_rq, u64 delta_exec)
 {
 	/* dock delta_exec before expiring quota (as it could span periods) */
 	cfs_rq->runtime_remaining -= delta_exec;
-	expire_cfs_rq_runtime(cfs_rq);
 
 	if (likely(cfs_rq->runtime_remaining > 0))
 		return;
@@ -4658,8 +4611,7 @@ void unthrottle_cfs_rq(struct cfs_rq *cf
 		resched_curr(rq);
 }
 
-static u64 distribute_cfs_runtime(struct cfs_bandwidth *cfs_b,
-		u64 remaining, u64 expires)
+static u64 distribute_cfs_runtime(struct cfs_bandwidth *cfs_b, u64 remaining)
 {
 	struct cfs_rq *cfs_rq;
 	u64 runtime;
@@ -4684,7 +4636,6 @@ static u64 distribute_cfs_runtime(struct
 		remaining -= runtime;
 
 		cfs_rq->runtime_remaining += runtime;
-		cfs_rq->runtime_expires = expires;
 
 		/* we check whether we're throttled above */
 		if (cfs_rq->runtime_remaining > 0)
@@ -4709,7 +4660,7 @@ next:
  */
 static int do_sched_cfs_period_timer(struct cfs_bandwidth *cfs_b, int overrun, unsigned long flags)
 {
-	u64 runtime, runtime_expires;
+	u64 runtime;
 	int throttled;
 
 	/* no need to continue the timer with no bandwidth constraint */
@@ -4737,8 +4688,6 @@ static int do_sched_cfs_period_timer(str
 	/* account preceding periods in which throttling occurred */
 	cfs_b->nr_throttled += overrun;
 
-	runtime_expires = cfs_b->runtime_expires;
-
 	/*
 	 * This check is repeated as we are holding onto the new bandwidth while
 	 * we unthrottle. This can potentially race with an unthrottled group
@@ -4751,8 +4700,7 @@ static int do_sched_cfs_period_timer(str
 		cfs_b->distribute_running = 1;
 		raw_spin_unlock_irqrestore(&cfs_b->lock, flags);
 		/* we can't nest cfs_b->lock while distributing bandwidth */
-		runtime = distribute_cfs_runtime(cfs_b, runtime,
-						 runtime_expires);
+		runtime = distribute_cfs_runtime(cfs_b, runtime);
 		raw_spin_lock_irqsave(&cfs_b->lock, flags);
 
 		cfs_b->distribute_running = 0;
@@ -4834,8 +4782,7 @@ static void __return_cfs_rq_runtime(stru
 		return;
 
 	raw_spin_lock(&cfs_b->lock);
-	if (cfs_b->quota != RUNTIME_INF &&
-	    cfs_rq->runtime_expires == cfs_b->runtime_expires) {
+	if (cfs_b->quota != RUNTIME_INF) {
 		cfs_b->runtime += slack_runtime;
 
 		/* we are under rq->lock, defer unthrottling using a timer */
@@ -4868,7 +4815,6 @@ static void do_sched_cfs_slack_timer(str
 {
 	u64 runtime = 0, slice = sched_cfs_bandwidth_slice();
 	unsigned long flags;
-	u64 expires;
 
 	/* confirm we're still not at a refresh boundary */
 	raw_spin_lock_irqsave(&cfs_b->lock, flags);
@@ -4886,7 +4832,6 @@ static void do_sched_cfs_slack_timer(str
 	if (cfs_b->quota != RUNTIME_INF && cfs_b->runtime > slice)
 		runtime = cfs_b->runtime;
 
-	expires = cfs_b->runtime_expires;
 	if (runtime)
 		cfs_b->distribute_running = 1;
 
@@ -4895,11 +4840,10 @@ static void do_sched_cfs_slack_timer(str
 	if (!runtime)
 		return;
 
-	runtime = distribute_cfs_runtime(cfs_b, runtime, expires);
+	runtime = distribute_cfs_runtime(cfs_b, runtime);
 
 	raw_spin_lock_irqsave(&cfs_b->lock, flags);
-	if (expires == cfs_b->runtime_expires)
-		lsub_positive(&cfs_b->runtime, runtime);
+	lsub_positive(&cfs_b->runtime, runtime);
 	cfs_b->distribute_running = 0;
 	raw_spin_unlock_irqrestore(&cfs_b->lock, flags);
 }
@@ -5064,8 +5008,6 @@ void start_cfs_bandwidth(struct cfs_band
 
 	cfs_b->period_active = 1;
 	overrun = hrtimer_forward_now(&cfs_b->period_timer, cfs_b->period);
-	cfs_b->runtime_expires += (overrun + 1) * ktime_to_ns(cfs_b->period);
-	cfs_b->expires_seq++;
 	hrtimer_start_expires(&cfs_b->period_timer, HRTIMER_MODE_ABS_PINNED);
 }
 
--- a/kernel/sched/sched.h
+++ b/kernel/sched/sched.h
@@ -335,8 +335,6 @@ struct cfs_bandwidth {
 	u64			quota;
 	u64			runtime;
 	s64			hierarchical_quota;
-	u64			runtime_expires;
-	int			expires_seq;
 
 	u8			idle;
 	u8			period_active;
@@ -556,8 +554,6 @@ struct cfs_rq {
 
 #ifdef CONFIG_CFS_BANDWIDTH
 	int			runtime_enabled;
-	int			expires_seq;
-	u64			runtime_expires;
 	s64			runtime_remaining;
 
 	u64			throttled_clock;



  parent reply	other threads:[~2019-11-04 22:11 UTC|newest]

Thread overview: 175+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-11-04 21:43 [PATCH 5.3 000/163] 5.3.9-stable review Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 001/163] io_uring: fix up O_NONBLOCK handling for sockets Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 002/163] dm snapshot: introduce account_start_copy() and account_end_copy() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 003/163] dm snapshot: rework COW throttling to fix deadlock Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 004/163] Btrfs: fix inode cache block reserve leak on failure to allocate data space Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 005/163] btrfs: qgroup: Always free PREALLOC META reserve in btrfs_delalloc_release_extents() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 006/163] iio: adc: meson_saradc: Fix memory allocation order Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 007/163] iio: fix center temperature of bmc150-accel-core Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 008/163] libsubcmd: Make _FORTIFY_SOURCE defines dependent on the feature Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 009/163] perf tests: Avoid raising SEGV using an obvious NULL dereference Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 010/163] perf map: Fix overlapped map handling Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 011/163] perf script brstackinsn: Fix recovery from LBR/binary mismatch Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 012/163] perf jevents: Fix period for Intel fixed counters Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 013/163] perf tools: Propagate get_cpuid() error Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 014/163] perf annotate: Propagate perf_env__arch() error Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 015/163] perf annotate: Fix the signedness of failure returns Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 016/163] perf annotate: Propagate the symbol__annotate() error return Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 017/163] perf annotate: Fix arch specific ->init() failure errors Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 018/163] perf annotate: Return appropriate error code for allocation failures Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 019/163] perf annotate: Dont return -1 for error when doing BPF disassembly Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 020/163] staging: rtl8188eu: fix null dereference when kzalloc fails Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 021/163] RDMA/siw: Fix serialization issue in write_space() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 022/163] RDMA/hfi1: Prevent memory leak in sdma_init Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 023/163] RDMA/iw_cxgb4: fix SRQ access from dump_qp() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 024/163] RDMA/iwcm: Fix a lock inversion issue Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 025/163] HID: hyperv: Use in-place iterator API in the channel callback Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 026/163] kselftest: exclude failed TARGETS from runlist Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 027/163] selftests/kselftest/runner.sh: Add 45 second timeout per test Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 028/163] nfs: Fix nfsi->nrequests count error on nfs_inode_remove_request Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 029/163] arm64: cpufeature: Effectively expose FRINT capability to userspace Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 030/163] arm64: Fix incorrect irqflag restore for priority masking for compat Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 031/163] arm64: ftrace: Ensure synchronisation in PLT setup for Neoverse-N1 #1542419 Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 032/163] tty: serial: owl: Fix the link time qualifier of owl_uart_exit() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 033/163] tty: serial: rda: Fix the link time qualifier of rda_uart_exit() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 034/163] serial/sifive: select SERIAL_EARLYCON Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 035/163] tty: n_hdlc: fix build on SPARC Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 036/163] misc: fastrpc: prevent memory leak in fastrpc_dma_buf_attach Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 037/163] RDMA/core: Fix an error handling path in res_get_common_doit() Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 038/163] RDMA/cm: Fix memory leak in cm_add/remove_one Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 039/163] RDMA/nldev: Reshuffle the code to avoid need to rebind QP in error path Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 040/163] RDMA/mlx5: Do not allow rereg of a ODP MR Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 041/163] RDMA/mlx5: Order num_pending_prefetch properly with synchronize_srcu Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 042/163] RDMA/mlx5: Add missing synchronize_srcu() for MW cases Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 043/163] gpio: max77620: Use correct unit for debounce times Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 044/163] fs: cifs: mute -Wunused-const-variable message Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 045/163] arm64: vdso32: Fix broken compat vDSO build warnings Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 046/163] arm64: vdso32: Detect binutils support for dmb ishld Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 047/163] serial: mctrl_gpio: Check for NULL pointer Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 048/163] serial: 8250_omap: Fix gpio check for auto RTS/CTS Greg Kroah-Hartman
2019-11-04 21:43 ` [PATCH 5.3 049/163] arm64: Default to building compat vDSO with clang when CONFIG_CC_IS_CLANG Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 050/163] arm64: vdso32: Dont use KBUILD_CPPFLAGS unconditionally Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 051/163] efi/cper: Fix endianness of PCIe class code Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 052/163] efi/x86: Do not clean dummy variable in kexec path Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 053/163] MIPS: include: Mark __cmpxchg as __always_inline Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 054/163] riscv: avoid kernel hangs when trapped in BUG() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 055/163] riscv: avoid sending a SIGTRAP to a user thread trapped in WARN() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 056/163] riscv: Correct the handling of unexpected ebreak in do_trap_break() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 057/163] x86/xen: Return from panic notifier Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 058/163] ocfs2: clear zero in unaligned direct IO Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 059/163] fs: ocfs2: fix possible null-pointer dereferences in ocfs2_xa_prepare_entry() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 060/163] fs: ocfs2: fix a possible null-pointer dereference in ocfs2_write_end_nolock() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 061/163] fs: ocfs2: fix a possible null-pointer dereference in ocfs2_info_scan_inode_alloc() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 062/163] btrfs: silence maybe-uninitialized warning in clone_range Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 063/163] arm64: armv8_deprecated: Checking return value for memory allocation Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 064/163] x86/cpu: Add Comet Lake to the Intel CPU models header Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 065/163] sched/fair: Scale bandwidth quota and period without losing quota/period ratio precision Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 066/163] sched/vtime: Fix guest/system mis-accounting on task switch Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 067/163] perf/core: Rework memory accounting in perf_mmap() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 068/163] perf/core: Fix corner case in perf_rotate_context() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 069/163] perf/x86/amd: Change/fix NMI latency mitigation to use a timestamp Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 070/163] drm/amdgpu: fix memory leak Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 071/163] iio: imu: adis16400: release allocated memory on failure Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 072/163] iio: imu: adis16400: fix memory leak Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 073/163] iio: imu: st_lsm6dsx: fix waitime for st_lsm6dsx i2c controller Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 074/163] MIPS: include: Mark __xchg as __always_inline Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 075/163] MIPS: fw: sni: Fix out of bounds init of o32 stack Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 076/163] s390/cio: fix virtio-ccw DMA without PV Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 077/163] virt: vbox: fix memory leak in hgcm_call_preprocess_linaddr Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 078/163] nbd: fix possible sysfs duplicate warning Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 079/163] NFSv4: Fix leak of clp->cl_acceptor string Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 080/163] SUNRPC: fix race to sk_err after xs_error_report Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 081/163] s390/uaccess: avoid (false positive) compiler warnings Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 082/163] tracing: Initialize iter->seq after zeroing in tracing_read_pipe() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 083/163] perf annotate: Fix multiple memory and file descriptor leaks Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 084/163] perf/aux: Fix tracking of auxiliary trace buffer allocation Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 085/163] USB: legousbtower: fix a signedness bug in tower_probe() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 086/163] nbd: verify socket is supported during setup Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 087/163] arm64: dts: qcom: Add Lenovo Miix 630 Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 088/163] arm64: dts: qcom: Add HP Envy x2 Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 089/163] arm64: dts: qcom: Add Asus NovaGo TP370QL Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 090/163] rtw88: Fix misuse of GENMASK macro Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 091/163] s390/pci: fix MSI message data Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 092/163] thunderbolt: Correct path indices for PCIe tunnel Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 093/163] thunderbolt: Use 32-bit writes when writing ring producer/consumer Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 094/163] ath6kl: fix a NULL-ptr-deref bug in ath6kl_usb_alloc_urb_from_pipe() Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 095/163] fuse: flush dirty data/metadata before non-truncate setattr Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 096/163] fuse: truncate pending writes on O_TRUNC Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 097/163] ALSA: bebob: Fix prototype of helper function to return negative value Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 098/163] ALSA: timer: Fix mutex deadlock at releasing card Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 099/163] ALSA: hda/realtek - Fix 2 front mics of codec 0x623 Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 100/163] ALSA: hda/realtek - Add support for ALC623 Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 101/163] ath10k: fix latency issue for QCA988x Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 102/163] UAS: Revert commit 3ae62a42090f ("UAS: fix alignment of scatter/gather segments") Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 103/163] nl80211: fix validation of mesh path nexthop Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 104/163] USB: gadget: Reject endpoints with 0 maxpacket value Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 105/163] usb-storage: Revert commit 747668dbc061 ("usb-storage: Set virt_boundary_mask to avoid SG overflows") Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 106/163] USB: ldusb: fix ring-buffer locking Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 107/163] USB: ldusb: fix control-message timeout Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 108/163] usb: xhci: fix Immediate Data Transfer endianness Greg Kroah-Hartman
2019-11-04 21:44 ` [PATCH 5.3 109/163] usb: xhci: fix __le32/__le64 accessors in debugfs code Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 110/163] USB: serial: whiteheat: fix potential slab corruption Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 111/163] USB: serial: whiteheat: fix line-speed endianness Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 112/163] xhci: Fix use-after-free regression in xhci clear hub TT implementation Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 113/163] scsi: qla2xxx: Fix partial flash write of MBI Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 114/163] scsi: target: cxgbit: Fix cxgbit_fw4_ack() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 115/163] HID: i2c-hid: add Trekstor Primebook C11B to descriptor override Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 116/163] HID: Fix assumption that devices have inputs Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 117/163] HID: fix error message in hid_open_report() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 118/163] HID: logitech-hidpp: split g920_get_config() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 119/163] HID: logitech-hidpp: rework device validation Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 120/163] HID: logitech-hidpp: do all FF cleanup in hidpp_ff_destroy() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 121/163] um-ubd: Entrust re-queue to the upper layers Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 122/163] s390/unwind: fix mixing regs and sp Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 123/163] s390/cmm: fix information leak in cmm_timeout_handler() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 124/163] s390/idle: fix cpu idle time calculation Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 125/163] ARC: perf: Accommodate big-endian CPU Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 126/163] IB/hfi1: Avoid excessive retry for TID RDMA READ request Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 127/163] arm64: Ensure VM_WRITE|VM_SHARED ptes are clean by default Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 128/163] arm64: cpufeature: Enable Qualcomm Falkor/Kryo errata 1003 Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 129/163] virtio_ring: fix stalls for packed rings Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 130/163] rtlwifi: rtl_pci: Fix problem of too small skb->len Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 131/163] rtlwifi: Fix potential overflow on P2P code Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 132/163] KVM: vmx, svm: always run with EFER.NXE=1 when shadow paging is active Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 133/163] dmaengine: qcom: bam_dma: Fix resource leak Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 134/163] dmaengine: tegra210-adma: fix transfer failure Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 135/163] dmaengine: imx-sdma: fix size check for sdma script_number Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 136/163] dmaengine: cppi41: Fix cppi41_dma_prep_slave_sg() when idle Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 137/163] drm/amdgpu/gmc10: properly set BANK_SELECT and FRAGMENT_SIZE Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 138/163] drm/i915: Fix PCH reference clock for FDI on HSW/BDW Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 139/163] drm/amdgpu/gfx10: update gfx golden settings Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 140/163] drm/amdgpu/powerplay/vega10: allow undervolting in p7 Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 141/163] drm/amdgpu: Fix SDMA hang when performing VKexample test Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 142/163] NFS: Fix an RCU lock leak in nfs4_refresh_delegation_stateid() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 143/163] io_uring: ensure we clear io_kiocb->result before each issue Greg Kroah-Hartman
2019-11-05 18:08   ` Bijan Mottahedeh
2019-11-04 21:45 ` [PATCH 5.3 144/163] iommu/vt-d: Fix panic after kexec -p for kdump Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 145/163] batman-adv: Avoid free/alloc race when handling OGM buffer Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 146/163] llc: fix sk_buff leak in llc_sap_state_process() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 147/163] llc: fix sk_buff leak in llc_conn_service() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 148/163] rxrpc: Fix call ref leak Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 149/163] rxrpc: rxrpc_peer needs to hold a ref on the rxrpc_local record Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 150/163] rxrpc: Fix trace-after-put looking at the put peer record Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 151/163] NFC: pn533: fix use-after-free and memleaks Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 152/163] bonding: fix potential NULL deref in bond_update_slave_arr Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 153/163] netfilter: conntrack: avoid possible false sharing Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 154/163] net: usb: sr9800: fix uninitialized local variable Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 155/163] sch_netem: fix rcu splat in netem_enqueue() Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 156/163] net: sched: sch_sfb: dont call qdisc_put() while holding tree lock Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 157/163] iwlwifi: exclude GEO SAR support for 3168 Greg Kroah-Hartman
2019-11-04 21:45 ` Greg Kroah-Hartman [this message]
2019-11-04 21:45 ` [PATCH 5.3 159/163] ALSA: usb-audio: DSD auto-detection for Playback Designs Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 160/163] ALSA: usb-audio: Update DSD support quirks for Oppo and Rotel Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 161/163] ALSA: usb-audio: Add DSD support for Gustard U16/X26 USB Interface Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 162/163] RDMA/mlx5: Use irq xarray locking for mkey_table Greg Kroah-Hartman
2019-11-04 21:45 ` [PATCH 5.3 163/163] sched/fair: Fix -Wunused-but-set-variable warnings Greg Kroah-Hartman
2019-11-05  5:16 ` [PATCH 5.3 000/163] 5.3.9-stable review kernelci.org bot
2019-11-05  6:26 ` Naresh Kamboju
2019-11-05  7:33   ` Greg Kroah-Hartman
2019-11-05 14:26 ` Guenter Roeck
2019-11-05 16:37   ` Greg Kroah-Hartman
2019-11-05 16:51 ` shuah
2019-11-06 10:46   ` Greg Kroah-Hartman
2019-11-05 23:41 ` Jon Hunter
2019-11-05 23:41   ` Jon Hunter
2019-11-06 10:49   ` Greg Kroah-Hartman

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20191104212151.722322521@linuxfoundation.org \
    --to=gregkh@linuxfoundation.org \
    --cc=bgregg@netflix.com \
    --cc=bsegall@google.com \
    --cc=chiluk+linux@indeed.com \
    --cc=corbet@lwn.net \
    --cc=gmunoz@netflix.com \
    --cc=jhammond@indeed.com \
    --cc=kwa@yelp.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mingo@redhat.com \
    --cc=pauld@redhat.com \
    --cc=peterz@infradead.org \
    --cc=posk@posk.io \
    --cc=stable@vger.kernel.org \
    --cc=xiyou.wangcong@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.