diff options
-rw-r--r-- | arch/arm/oprofile/common.c | 23 |
1 files changed, 10 insertions, 13 deletions
diff --git a/arch/arm/oprofile/common.c b/arch/arm/oprofile/common.c index 6f8bc1f0e6a1..b57b6d11c9fb 100644 --- a/arch/arm/oprofile/common.c +++ b/arch/arm/oprofile/common.c | |||
@@ -11,14 +11,14 @@ | |||
11 | #include <linux/oprofile.h> | 11 | #include <linux/oprofile.h> |
12 | #include <linux/errno.h> | 12 | #include <linux/errno.h> |
13 | #include <linux/sysdev.h> | 13 | #include <linux/sysdev.h> |
14 | #include <asm/semaphore.h> | 14 | #include <linux/mutex.h> |
15 | 15 | ||
16 | #include "op_counter.h" | 16 | #include "op_counter.h" |
17 | #include "op_arm_model.h" | 17 | #include "op_arm_model.h" |
18 | 18 | ||
19 | static struct op_arm_model_spec *op_arm_model; | 19 | static struct op_arm_model_spec *op_arm_model; |
20 | static int op_arm_enabled; | 20 | static int op_arm_enabled; |
21 | static struct semaphore op_arm_sem; | 21 | static DEFINE_MUTEX(op_arm_mutex); |
22 | 22 | ||
23 | struct op_counter_config counter_config[OP_MAX_COUNTER]; | 23 | struct op_counter_config counter_config[OP_MAX_COUNTER]; |
24 | 24 | ||
@@ -57,40 +57,40 @@ static int op_arm_start(void) | |||
57 | { | 57 | { |
58 | int ret = -EBUSY; | 58 | int ret = -EBUSY; |
59 | 59 | ||
60 | down(&op_arm_sem); | 60 | mutex_lock(&op_arm_mutex); |
61 | if (!op_arm_enabled) { | 61 | if (!op_arm_enabled) { |
62 | ret = op_arm_model->start(); | 62 | ret = op_arm_model->start(); |
63 | op_arm_enabled = !ret; | 63 | op_arm_enabled = !ret; |
64 | } | 64 | } |
65 | up(&op_arm_sem); | 65 | mutex_unlock(&op_arm_mutex); |
66 | return ret; | 66 | return ret; |
67 | } | 67 | } |
68 | 68 | ||
69 | static void op_arm_stop(void) | 69 | static void op_arm_stop(void) |
70 | { | 70 | { |
71 | down(&op_arm_sem); | 71 | mutex_lock(&op_arm_mutex); |
72 | if (op_arm_enabled) | 72 | if (op_arm_enabled) |
73 | op_arm_model->stop(); | 73 | op_arm_model->stop(); |
74 | op_arm_enabled = 0; | 74 | op_arm_enabled = 0; |
75 | up(&op_arm_sem); | 75 | mutex_unlock(&op_arm_mutex); |
76 | } | 76 | } |
77 | 77 | ||
78 | #ifdef CONFIG_PM | 78 | #ifdef CONFIG_PM |
79 | static int op_arm_suspend(struct sys_device *dev, pm_message_t state) | 79 | static int op_arm_suspend(struct sys_device *dev, pm_message_t state) |
80 | { | 80 | { |
81 | down(&op_arm_sem); | 81 | mutex_lock(&op_arm_mutex); |
82 | if (op_arm_enabled) | 82 | if (op_arm_enabled) |
83 | op_arm_model->stop(); | 83 | op_arm_model->stop(); |
84 | up(&op_arm_sem); | 84 | mutex_unlock(&op_arm_mutex); |
85 | return 0; | 85 | return 0; |
86 | } | 86 | } |
87 | 87 | ||
88 | static int op_arm_resume(struct sys_device *dev) | 88 | static int op_arm_resume(struct sys_device *dev) |
89 | { | 89 | { |
90 | down(&op_arm_sem); | 90 | mutex_lock(&op_arm_mutex); |
91 | if (op_arm_enabled && op_arm_model->start()) | 91 | if (op_arm_enabled && op_arm_model->start()) |
92 | op_arm_enabled = 0; | 92 | op_arm_enabled = 0; |
93 | up(&op_arm_sem); | 93 | mutex_unlock(&op_arm_mutex); |
94 | return 0; | 94 | return 0; |
95 | } | 95 | } |
96 | 96 | ||
@@ -135,8 +135,6 @@ int __init oprofile_arch_init(struct oprofile_operations *ops) | |||
135 | #endif | 135 | #endif |
136 | 136 | ||
137 | if (spec) { | 137 | if (spec) { |
138 | init_MUTEX(&op_arm_sem); | ||
139 | |||
140 | ret = spec->init(); | 138 | ret = spec->init(); |
141 | if (ret < 0) | 139 | if (ret < 0) |
142 | return ret; | 140 | return ret; |
@@ -163,4 +161,3 @@ void oprofile_arch_exit(void) | |||
163 | op_arm_model = NULL; | 161 | op_arm_model = NULL; |
164 | } | 162 | } |
165 | } | 163 | } |
166 | |||