aboutsummaryrefslogtreecommitdiff
path: root/scripts/gcc-plugins/randomize_layout_plugin.c
diff options
context:
space:
mode:
authorJeff Layton <[email protected]>2015-08-24 12:41:47 -0400
committerJ. Bruce Fields <[email protected]>2015-08-31 16:32:15 -0400
commite85687393f3ee0a77ccca016f903d1558bb69258 (patch)
tree6683eba3ed1b59e299f085ed56d98d2fc67530f6 /scripts/gcc-plugins/randomize_layout_plugin.c
parent051ac3848a94f21cfdec899cc9c65ce7f9f116fa (diff)
nfsd: ensure that the ol stateid hash reference is only put once
When an open or lock stateid is hashed, we take an extra reference to it. When we unhash it, we drop that reference. The code however does not properly account for the case where we have two callers concurrently trying to unhash the stateid. This can lead to list corruption and the hash reference being put more than once. Fix this by having unhash_ol_stateid use list_del_init on the st_perfile list_head, and then testing to see if that list_head is empty before releasing the hash reference. This means that some of the unhashing wrappers now become bool return functions so we can test to see whether the stateid was unhashed before we put the reference. Reported-by: Andrew W Elble <[email protected]> Tested-by: Andrew W Elble <[email protected]> Reported-by: Anna Schumaker <[email protected]> Tested-by: Anna Schumaker <[email protected]> Signed-off-by: Jeff Layton <[email protected]> Cc: [email protected] Signed-off-by: J. Bruce Fields <[email protected]>
Diffstat (limited to 'scripts/gcc-plugins/randomize_layout_plugin.c')
0 files changed, 0 insertions, 0 deletions