summaryrefslogtreecommitdiffstats
path: root/fs/bfs
diff options
context:
space:
mode:
authorBob Peterson <rpeterso@redhat.com>2020-06-09 09:55:11 -0400
committerAndreas Gruenbacher <agruenba@redhat.com>2020-06-30 13:04:45 +0200
commit58e08e8d83ab03a1ca25d53420bd0b87f2dfe458 (patch)
treef5724a1b5c134c35cbc5281fd1c0aee76f36b7a1 /fs/bfs
parent5902f4dd6e666c4d160b2f5c4505f7e58642d2bf (diff)
downloadlinux-58e08e8d83ab03a1ca25d53420bd0b87f2dfe458.tar.bz2
gfs2: fix trans slab error when withdraw occurs inside log_flush
Log flush operations (gfs2_log_flush()) can target a specific transaction. But if the function encounters errors (e.g. io errors) and withdraws, the transaction was only freed it if was queued to one of the ail lists. If the withdraw occurred before the transaction was queued to the ail1 list, function ail_drain never freed it. The result was: BUG gfs2_trans: Objects remaining in gfs2_trans on __kmem_cache_shutdown() This patch makes log_flush() add the targeted transaction to the ail1 list so that function ail_drain() will find and free it properly. Cc: stable@vger.kernel.org # v5.7+ Signed-off-by: Bob Peterson <rpeterso@redhat.com> Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
Diffstat (limited to 'fs/bfs')
0 files changed, 0 insertions, 0 deletions