diff options
author | Weijie Yang <weijie.yang@samsung.com> | 2014-10-29 17:50:57 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-10-29 19:33:15 -0400 |
commit | 5a99e95b8d1cd47f6feddcdca6c71d22060df8a2 (patch) | |
tree | 51384759dcfdc6e189139a5a58a5df7f6e16f56b /arch/sh/kernel/head_32.S | |
parent | 8aba7e0a2c02355f9a7dec629635cb7093fe0508 (diff) |
zram: avoid NULL pointer access in concurrent situation
There is a rare NULL pointer bug in mem_used_total_show() and
mem_used_max_store() in concurrent situation, like this:
zram is not initialized, process A is a mem_used_total reader which runs
periodically, while process B try to init zram.
process A process B
access meta, get a NULL value
init zram, done
init_done() is true
access meta->mem_pool, get a NULL pointer BUG
This patch fixes this issue.
Signed-off-by: Weijie Yang <weijie.yang@samsung.com>
Acked-by: Minchan Kim <minchan@kernel.org>
Acked-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/sh/kernel/head_32.S')
0 files changed, 0 insertions, 0 deletions