aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorHong-Mei Li <a21834@motorola.com>2015-03-12 19:14:26 -0700
committerSimon Shields <keepcalm444@gmail.com>2016-06-13 14:47:40 +1000
commitca7c9fad094f4413dcb2ce65d6d4983201295536 (patch)
tree6f9b883e3f06f1b44e9eb2fd380286e2f5454b7a /drivers
parent2ed1b46030d9062ac9dc12ffef3beb3ece44d1a0 (diff)
downloadkernel_samsung_smdk4412-ca7c9fad094f4413dcb2ce65d6d4983201295536.tar.gz
kernel_samsung_smdk4412-ca7c9fad094f4413dcb2ce65d6d4983201295536.tar.bz2
kernel_samsung_smdk4412-ca7c9fad094f4413dcb2ce65d6d4983201295536.zip
drivers:lmk: Fix double delete issue
someone may change a process's oom_score_adj by proc fs, even though the process has exited. In that case, the task was deleted from the rb tree already, and the redundant deleting would trigger rb_erase panic finally. In this patch, we make sure to clear the node after deteting and check its empty status before rb_erase. Change-Id: I7628c7d21011099e796b7d366cbc142f96bb8aab Signed-off-by: Hong-Mei Li <a21834@motorola.com> Reviewed-on: http://gerrit.mot.com/725306 SLTApproved: Slta Waiver <sltawvr@motorola.com> SME-Granted: SME Approvals Granted Tested-by: Jira Key <jirakey@motorola.com> Reviewed-by: Sheng-Zhe Zhao <a18689@motorola.com> Submit-Approved: Jira Key <jirakey@motorola.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/staging/android/lowmemorykiller.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/staging/android/lowmemorykiller.c b/drivers/staging/android/lowmemorykiller.c
index caa7d3d392c..239d32d57b1 100644
--- a/drivers/staging/android/lowmemorykiller.c
+++ b/drivers/staging/android/lowmemorykiller.c
@@ -450,7 +450,10 @@ void add_2_adj_tree(struct task_struct *task)
void delete_from_adj_tree(struct task_struct *task)
{
spin_lock(&lmk_lock);
- rb_erase(&task->adj_node, &tasks_scoreadj);
+ if (!RB_EMPTY_NODE(&task->adj_node)) {
+ rb_erase(&task->adj_node, &tasks_scoreadj);
+ RB_CLEAR_NODE(&task->adj_node);
+ }
spin_unlock(&lmk_lock);
}