diff options
author | Paul E. McKenney <[email protected]> | 2018-04-14 10:40:57 -0700 |
---|---|---|
committer | Paul E. McKenney <[email protected]> | 2018-05-15 10:29:33 -0700 |
commit | 51af970d19f395fc57b82514022126de6c5420cd (patch) | |
tree | 20637fb321eddd24f16483bb1ac44b9f8eb5eb57 /drivers/usb/cdns3/cdns3-trace.h | |
parent | fb31340f8a43a6f2e871164822ef4979b36232ae (diff) |
rcu: Avoid losing ->need_future_gp[] values due to GP start/end races
The rcu_cbs_completed() function provides the value of ->completed
at which new callbacks can safely be invoked. This is recorded in
two-element ->need_future_gp[] arrays in the rcu_node structure, and
the elements of these arrays corresponding to the just-completed grace
period are zeroed at the end of that grace period. However, the
rcu_cbs_completed() function can return the current ->completed value
plus either one or two, so it is possible for the corresponding
->need_future_gp[] entry to be cleared just after it was set, thus
losing a request for a future grace period.
This commit avoids this race by expanding ->need_future_gp[] to four
elements.
Signed-off-by: Paul E. McKenney <[email protected]>
Tested-by: Nicholas Piggin <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-trace.h')
0 files changed, 0 insertions, 0 deletions