padata: Fix list iterator in padata_do_serial()
authorDaniel Jordan <daniel.m.jordan@oracle.com>
Thu, 17 Nov 2022 01:28:04 +0000 (20:28 -0500)
committerHerbert Xu <herbert@gondor.apana.org.au>
Fri, 25 Nov 2022 09:39:18 +0000 (17:39 +0800)
commit57ddfecc72a6c9941d159543e1c0c0a74fe9afdd
treef8f6c9dd7f6b34d3ca82df157e16f21da2ca7de7
parent34c3a47d20ae55b3600fed733bf96eafe9c500d5
padata: Fix list iterator in padata_do_serial()

list_for_each_entry_reverse() assumes that the iterated list is nonempty
and that every list_head is embedded in the same type, but its use in
padata_do_serial() breaks both rules.

This doesn't cause any issues now because padata_priv and padata_list
happen to have their list fields at the same offset, but we really
shouldn't be relying on that.

Fixes: bfde23ce200e ("padata: unbind parallel jobs from specific CPUs")
Signed-off-by: Daniel Jordan <daniel.m.jordan@oracle.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
kernel/padata.c