padata: upgrade smp_mb__after_atomic to smp_mb in padata_do_serial
authorDaniel Jordan <daniel.m.jordan@oracle.com>
Mon, 8 Jun 2020 21:26:52 +0000 (17:26 -0400)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 18 Jun 2020 07:09:54 +0000 (17:09 +1000)
commite04ec0de61c1eb9693179093e83ab8ca68a30d08
treec9659db2092a276ee7a64922be0c57e0526f4c07
parent34c86f4c4a7be3b3e35aa48bd18299d4c756064d
padata: upgrade smp_mb__after_atomic to smp_mb in padata_do_serial

A 5.7 kernel hangs during a tcrypt test of padata that waits for an AEAD
request to finish.  This is only seen on large machines running many
concurrent requests.

The issue is that padata never serializes the request.  The removal of
the reorder_objects atomic missed that the memory barrier in
padata_do_serial() depends on it.

Upgrade the barrier from smp_mb__after_atomic to smp_mb to get correct
ordering again.

Fixes: 3facced7aeed1 ("padata: remove reorder_objects")
Signed-off-by: Daniel Jordan <daniel.m.jordan@oracle.com>
Cc: Steffen Klassert <steffen.klassert@secunet.com>
Cc: linux-kernel@vger.kernel.org
Cc: <stable@vger.kernel.org>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
kernel/padata.c