PM/devfreq: bw_hwmon: add mutex lock in polling interval case
Protect polling interval update event in the governor with mutex lock. This will avoid parallel execution of update interval event on different cores, resulting in memory poison overwritten. CRs-Fixed: 2035633 Change-Id: Ib919d9774317bc01e3cf581c169c5d18555f484f Signed-off-by: Santosh Mardi <gsantosh@codeaurora.org>
This commit is contained in:
parent
3d82d66409
commit
28aab0311c
1 changed files with 5 additions and 1 deletions
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2013-2016, The Linux Foundation. All rights reserved.
|
* Copyright (c) 2013-2017, The Linux Foundation. All rights reserved.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License version 2 and
|
* it under the terms of the GNU General Public License version 2 and
|
||||||
|
@ -86,6 +86,8 @@ static DEFINE_SPINLOCK(irq_lock);
|
||||||
|
|
||||||
static LIST_HEAD(hwmon_list);
|
static LIST_HEAD(hwmon_list);
|
||||||
static DEFINE_MUTEX(list_lock);
|
static DEFINE_MUTEX(list_lock);
|
||||||
|
static DEFINE_MUTEX(sync_lock);
|
||||||
|
|
||||||
|
|
||||||
static int use_cnt;
|
static int use_cnt;
|
||||||
static DEFINE_MUTEX(state_lock);
|
static DEFINE_MUTEX(state_lock);
|
||||||
|
@ -846,6 +848,7 @@ static int devfreq_bw_hwmon_ev_handler(struct devfreq *df,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DEVFREQ_GOV_INTERVAL:
|
case DEVFREQ_GOV_INTERVAL:
|
||||||
|
mutex_lock(&sync_lock);
|
||||||
sample_ms = *(unsigned int *)data;
|
sample_ms = *(unsigned int *)data;
|
||||||
sample_ms = max(MIN_MS, sample_ms);
|
sample_ms = max(MIN_MS, sample_ms);
|
||||||
sample_ms = min(MAX_MS, sample_ms);
|
sample_ms = min(MAX_MS, sample_ms);
|
||||||
|
@ -865,6 +868,7 @@ static int devfreq_bw_hwmon_ev_handler(struct devfreq *df,
|
||||||
"Unable to resume HW monitor (%d)\n", ret);
|
"Unable to resume HW monitor (%d)\n", ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
mutex_unlock(&sync_lock);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DEVFREQ_GOV_SUSPEND:
|
case DEVFREQ_GOV_SUSPEND:
|
||||||
|
|
Loading…
Add table
Reference in a new issue