aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/acpi/acpica/hwgpe.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/acpi/acpica/hwgpe.c')
-rw-r--r--drivers/acpi/acpica/hwgpe.c52
1 files changed, 40 insertions, 12 deletions
diff --git a/drivers/acpi/acpica/hwgpe.c b/drivers/acpi/acpica/hwgpe.c
index bd72319a38f..d989b8e786c 100644
--- a/drivers/acpi/acpica/hwgpe.c
+++ b/drivers/acpi/acpica/hwgpe.c
@@ -57,6 +57,27 @@ acpi_hw_enable_wakeup_gpe_block(struct acpi_gpe_xrupt_info *gpe_xrupt_info,
57 57
58/****************************************************************************** 58/******************************************************************************
59 * 59 *
60 * FUNCTION: acpi_hw_gpe_register_bit
61 *
62 * PARAMETERS: gpe_event_info - Info block for the GPE
63 * gpe_register_info - Info block for the GPE register
64 *
65 * RETURN: Status
66 *
67 * DESCRIPTION: Compute GPE enable mask with one bit corresponding to the given
68 * GPE set.
69 *
70 ******************************************************************************/
71
72u32 acpi_hw_gpe_register_bit(struct acpi_gpe_event_info *gpe_event_info,
73 struct acpi_gpe_register_info *gpe_register_info)
74{
75 return (u32)1 << (gpe_event_info->gpe_number -
76 gpe_register_info->base_gpe_number);
77}
78
79/******************************************************************************
80 *
60 * FUNCTION: acpi_hw_low_disable_gpe 81 * FUNCTION: acpi_hw_low_disable_gpe
61 * 82 *
62 * PARAMETERS: gpe_event_info - Info block for the GPE to be disabled 83 * PARAMETERS: gpe_event_info - Info block for the GPE to be disabled
@@ -72,6 +93,7 @@ acpi_status acpi_hw_low_disable_gpe(struct acpi_gpe_event_info *gpe_event_info)
72 struct acpi_gpe_register_info *gpe_register_info; 93 struct acpi_gpe_register_info *gpe_register_info;
73 acpi_status status; 94 acpi_status status;
74 u32 enable_mask; 95 u32 enable_mask;
96 u32 register_bit;
75 97
76 /* Get the info block for the entire GPE register */ 98 /* Get the info block for the entire GPE register */
77 99
@@ -89,9 +111,9 @@ acpi_status acpi_hw_low_disable_gpe(struct acpi_gpe_event_info *gpe_event_info)
89 111
90 /* Clear just the bit that corresponds to this GPE */ 112 /* Clear just the bit that corresponds to this GPE */
91 113
92 ACPI_CLEAR_BIT(enable_mask, ((u32)1 << 114 register_bit = acpi_hw_gpe_register_bit(gpe_event_info,
93 (gpe_event_info->gpe_number - 115 gpe_register_info);
94 gpe_register_info->base_gpe_number))); 116 ACPI_CLEAR_BIT(enable_mask, register_bit);
95 117
96 /* Write the updated enable mask */ 118 /* Write the updated enable mask */
97 119
@@ -150,21 +172,28 @@ acpi_hw_write_gpe_enable_reg(struct acpi_gpe_event_info * gpe_event_info)
150 172
151acpi_status acpi_hw_clear_gpe(struct acpi_gpe_event_info * gpe_event_info) 173acpi_status acpi_hw_clear_gpe(struct acpi_gpe_event_info * gpe_event_info)
152{ 174{
175 struct acpi_gpe_register_info *gpe_register_info;
153 acpi_status status; 176 acpi_status status;
154 u8 register_bit; 177 u32 register_bit;
155 178
156 ACPI_FUNCTION_ENTRY(); 179 ACPI_FUNCTION_ENTRY();
157 180
158 register_bit = (u8)(1 << 181 /* Get the info block for the entire GPE register */
159 (gpe_event_info->gpe_number - 182
160 gpe_event_info->register_info->base_gpe_number)); 183 gpe_register_info = gpe_event_info->register_info;
184 if (!gpe_register_info) {
185 return (AE_NOT_EXIST);
186 }
187
188 register_bit = acpi_hw_gpe_register_bit(gpe_event_info,
189 gpe_register_info);
161 190
162 /* 191 /*
163 * Write a one to the appropriate bit in the status register to 192 * Write a one to the appropriate bit in the status register to
164 * clear this GPE. 193 * clear this GPE.
165 */ 194 */
166 status = acpi_hw_write(register_bit, 195 status = acpi_hw_write(register_bit,
167 &gpe_event_info->register_info->status_address); 196 &gpe_register_info->status_address);
168 197
169 return (status); 198 return (status);
170} 199}
@@ -187,7 +216,7 @@ acpi_hw_get_gpe_status(struct acpi_gpe_event_info * gpe_event_info,
187 acpi_event_status * event_status) 216 acpi_event_status * event_status)
188{ 217{
189 u32 in_byte; 218 u32 in_byte;
190 u8 register_bit; 219 u32 register_bit;
191 struct acpi_gpe_register_info *gpe_register_info; 220 struct acpi_gpe_register_info *gpe_register_info;
192 acpi_status status; 221 acpi_status status;
193 acpi_event_status local_event_status = 0; 222 acpi_event_status local_event_status = 0;
@@ -204,9 +233,8 @@ acpi_hw_get_gpe_status(struct acpi_gpe_event_info * gpe_event_info,
204 233
205 /* Get the register bitmask for this GPE */ 234 /* Get the register bitmask for this GPE */
206 235
207 register_bit = (u8)(1 << 236 register_bit = acpi_hw_gpe_register_bit(gpe_event_info,
208 (gpe_event_info->gpe_number - 237 gpe_register_info);
209 gpe_event_info->register_info->base_gpe_number));
210 238
211 /* GPE currently enabled? (enabled for runtime?) */ 239 /* GPE currently enabled? (enabled for runtime?) */
212 240