diff options
author | J. Bruce Fields <bfields@redhat.com> | 2011-12-22 18:22:49 -0700 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2012-01-25 17:24:47 -0800 |
commit | b09577ca6680033a4315e2f5cb3a95ebbb8dea79 (patch) | |
tree | 687c2010f9cfb888dd0e3cc196bd4be76453b565 /mm/slob.c | |
parent | adc0186cfa38e2736048a638681db511e65e51fd (diff) | |
download | kernel_samsung_tuna-b09577ca6680033a4315e2f5cb3a95ebbb8dea79.zip kernel_samsung_tuna-b09577ca6680033a4315e2f5cb3a95ebbb8dea79.tar.gz kernel_samsung_tuna-b09577ca6680033a4315e2f5cb3a95ebbb8dea79.tar.bz2 |
svcrpc: fix double-free on shutdown of nfsd after changing pool mode
commit 61c8504c428edcebf23b97775a129c5b393a302b upstream.
The pool_to and to_pool fields of the global svc_pool_map are freed on
shutdown, but are initialized in nfsd startup only in the
SVC_POOL_PERCPU and SVC_POOL_PERNODE cases.
They *are* initialized to zero on kernel startup. So as long as you use
only SVC_POOL_GLOBAL (the default), this will never be a problem.
You're also OK if you only ever use SVC_POOL_PERCPU or SVC_POOL_PERNODE.
However, the following sequence events leads to a double-free:
1. set SVC_POOL_PERCPU or SVC_POOL_PERNODE
2. start nfsd: both fields are initialized.
3. shutdown nfsd: both fields are freed.
4. set SVC_POOL_GLOBAL
5. start nfsd: the fields are left untouched.
6. shutdown nfsd: now we try to free them again.
Step 4 is actually unnecessary, since (for some bizarre reason), nfsd
automatically resets the pool mode to SVC_POOL_GLOBAL on shutdown.
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'mm/slob.c')
0 files changed, 0 insertions, 0 deletions