xref: /freebsd/sys/contrib/dev/acpica/components/events/evxfevnt.c (revision fcb560670601b2a4d87bb31d7531c8dcc37ee71b)
1 /******************************************************************************
2  *
3  * Module Name: evxfevnt - External Interfaces, ACPI event disable/enable
4  *
5  *****************************************************************************/
6 
7 /*
8  * Copyright (C) 2000 - 2014, Intel Corp.
9  * All rights reserved.
10  *
11  * Redistribution and use in source and binary forms, with or without
12  * modification, are permitted provided that the following conditions
13  * are met:
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions, and the following disclaimer,
16  *    without modification.
17  * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18  *    substantially similar to the "NO WARRANTY" disclaimer below
19  *    ("Disclaimer") and any redistribution must be conditioned upon
20  *    including a substantially similar Disclaimer requirement for further
21  *    binary redistribution.
22  * 3. Neither the names of the above-listed copyright holders nor the names
23  *    of any contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * Alternatively, this software may be distributed under the terms of the
27  * GNU General Public License ("GPL") version 2 as published by the Free
28  * Software Foundation.
29  *
30  * NO WARRANTY
31  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35  * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41  * POSSIBILITY OF SUCH DAMAGES.
42  */
43 
44 #define __EVXFEVNT_C__
45 #define EXPORT_ACPI_INTERFACES
46 
47 #include <contrib/dev/acpica/include/acpi.h>
48 #include <contrib/dev/acpica/include/accommon.h>
49 #include <contrib/dev/acpica/include/actables.h>
50 
51 #define _COMPONENT          ACPI_EVENTS
52         ACPI_MODULE_NAME    ("evxfevnt")
53 
54 
55 #if (!ACPI_REDUCED_HARDWARE) /* Entire module */
56 /*******************************************************************************
57  *
58  * FUNCTION:    AcpiEnable
59  *
60  * PARAMETERS:  None
61  *
62  * RETURN:      Status
63  *
64  * DESCRIPTION: Transfers the system into ACPI mode.
65  *
66  ******************************************************************************/
67 
68 ACPI_STATUS
69 AcpiEnable (
70     void)
71 {
72     ACPI_STATUS             Status = AE_OK;
73 
74 
75     ACPI_FUNCTION_TRACE (AcpiEnable);
76 
77 
78     /* ACPI tables must be present */
79 
80     if (!AcpiTbTablesLoaded ())
81     {
82         return_ACPI_STATUS (AE_NO_ACPI_TABLES);
83     }
84 
85     /* If the Hardware Reduced flag is set, machine is always in acpi mode */
86 
87     if (AcpiGbl_ReducedHardware)
88     {
89         return_ACPI_STATUS (AE_OK);
90     }
91 
92     /* Check current mode */
93 
94     if (AcpiHwGetMode() == ACPI_SYS_MODE_ACPI)
95     {
96         ACPI_DEBUG_PRINT ((ACPI_DB_INIT, "System is already in ACPI mode\n"));
97     }
98     else
99     {
100         /* Transition to ACPI mode */
101 
102         Status = AcpiHwSetMode (ACPI_SYS_MODE_ACPI);
103         if (ACPI_FAILURE (Status))
104         {
105             ACPI_ERROR ((AE_INFO, "Could not transition to ACPI mode"));
106             return_ACPI_STATUS (Status);
107         }
108 
109         ACPI_DEBUG_PRINT ((ACPI_DB_INIT,
110             "Transition to ACPI mode successful\n"));
111     }
112 
113     return_ACPI_STATUS (Status);
114 }
115 
116 ACPI_EXPORT_SYMBOL (AcpiEnable)
117 
118 
119 /*******************************************************************************
120  *
121  * FUNCTION:    AcpiDisable
122  *
123  * PARAMETERS:  None
124  *
125  * RETURN:      Status
126  *
127  * DESCRIPTION: Transfers the system into LEGACY (non-ACPI) mode.
128  *
129  ******************************************************************************/
130 
131 ACPI_STATUS
132 AcpiDisable (
133     void)
134 {
135     ACPI_STATUS             Status = AE_OK;
136 
137 
138     ACPI_FUNCTION_TRACE (AcpiDisable);
139 
140 
141     /* If the Hardware Reduced flag is set, machine is always in acpi mode */
142 
143     if (AcpiGbl_ReducedHardware)
144     {
145         return_ACPI_STATUS (AE_OK);
146     }
147 
148     if (AcpiHwGetMode() == ACPI_SYS_MODE_LEGACY)
149     {
150         ACPI_DEBUG_PRINT ((ACPI_DB_INIT,
151             "System is already in legacy (non-ACPI) mode\n"));
152     }
153     else
154     {
155         /* Transition to LEGACY mode */
156 
157         Status = AcpiHwSetMode (ACPI_SYS_MODE_LEGACY);
158 
159         if (ACPI_FAILURE (Status))
160         {
161             ACPI_ERROR ((AE_INFO,
162                 "Could not exit ACPI mode to legacy mode"));
163             return_ACPI_STATUS (Status);
164         }
165 
166         ACPI_DEBUG_PRINT ((ACPI_DB_INIT, "ACPI mode disabled\n"));
167     }
168 
169     return_ACPI_STATUS (Status);
170 }
171 
172 ACPI_EXPORT_SYMBOL (AcpiDisable)
173 
174 
175 /*******************************************************************************
176  *
177  * FUNCTION:    AcpiEnableEvent
178  *
179  * PARAMETERS:  Event           - The fixed eventto be enabled
180  *              Flags           - Reserved
181  *
182  * RETURN:      Status
183  *
184  * DESCRIPTION: Enable an ACPI event (fixed)
185  *
186  ******************************************************************************/
187 
188 ACPI_STATUS
189 AcpiEnableEvent (
190     UINT32                  Event,
191     UINT32                  Flags)
192 {
193     ACPI_STATUS             Status = AE_OK;
194     UINT32                  Value;
195 
196 
197     ACPI_FUNCTION_TRACE (AcpiEnableEvent);
198 
199 
200     /* Decode the Fixed Event */
201 
202     if (Event > ACPI_EVENT_MAX)
203     {
204         return_ACPI_STATUS (AE_BAD_PARAMETER);
205     }
206 
207     /*
208      * Enable the requested fixed event (by writing a one to the enable
209      * register bit)
210      */
211     Status = AcpiWriteBitRegister (
212                 AcpiGbl_FixedEventInfo[Event].EnableRegisterId,
213                 ACPI_ENABLE_EVENT);
214     if (ACPI_FAILURE (Status))
215     {
216         return_ACPI_STATUS (Status);
217     }
218 
219     /* Make sure that the hardware responded */
220 
221     Status = AcpiReadBitRegister (
222                 AcpiGbl_FixedEventInfo[Event].EnableRegisterId, &Value);
223     if (ACPI_FAILURE (Status))
224     {
225         return_ACPI_STATUS (Status);
226     }
227 
228     if (Value != 1)
229     {
230         ACPI_ERROR ((AE_INFO,
231             "Could not enable %s event", AcpiUtGetEventName (Event)));
232         return_ACPI_STATUS (AE_NO_HARDWARE_RESPONSE);
233     }
234 
235     return_ACPI_STATUS (Status);
236 }
237 
238 ACPI_EXPORT_SYMBOL (AcpiEnableEvent)
239 
240 
241 /*******************************************************************************
242  *
243  * FUNCTION:    AcpiDisableEvent
244  *
245  * PARAMETERS:  Event           - The fixed event to be disabled
246  *              Flags           - Reserved
247  *
248  * RETURN:      Status
249  *
250  * DESCRIPTION: Disable an ACPI event (fixed)
251  *
252  ******************************************************************************/
253 
254 ACPI_STATUS
255 AcpiDisableEvent (
256     UINT32                  Event,
257     UINT32                  Flags)
258 {
259     ACPI_STATUS             Status = AE_OK;
260     UINT32                  Value;
261 
262 
263     ACPI_FUNCTION_TRACE (AcpiDisableEvent);
264 
265 
266     /* Decode the Fixed Event */
267 
268     if (Event > ACPI_EVENT_MAX)
269     {
270         return_ACPI_STATUS (AE_BAD_PARAMETER);
271     }
272 
273     /*
274      * Disable the requested fixed event (by writing a zero to the enable
275      * register bit)
276      */
277     Status = AcpiWriteBitRegister (
278                 AcpiGbl_FixedEventInfo[Event].EnableRegisterId,
279                 ACPI_DISABLE_EVENT);
280     if (ACPI_FAILURE (Status))
281     {
282         return_ACPI_STATUS (Status);
283     }
284 
285     Status = AcpiReadBitRegister (
286                 AcpiGbl_FixedEventInfo[Event].EnableRegisterId, &Value);
287     if (ACPI_FAILURE (Status))
288     {
289         return_ACPI_STATUS (Status);
290     }
291 
292     if (Value != 0)
293     {
294         ACPI_ERROR ((AE_INFO,
295             "Could not disable %s events", AcpiUtGetEventName (Event)));
296         return_ACPI_STATUS (AE_NO_HARDWARE_RESPONSE);
297     }
298 
299     return_ACPI_STATUS (Status);
300 }
301 
302 ACPI_EXPORT_SYMBOL (AcpiDisableEvent)
303 
304 
305 /*******************************************************************************
306  *
307  * FUNCTION:    AcpiClearEvent
308  *
309  * PARAMETERS:  Event           - The fixed event to be cleared
310  *
311  * RETURN:      Status
312  *
313  * DESCRIPTION: Clear an ACPI event (fixed)
314  *
315  ******************************************************************************/
316 
317 ACPI_STATUS
318 AcpiClearEvent (
319     UINT32                  Event)
320 {
321     ACPI_STATUS             Status = AE_OK;
322 
323 
324     ACPI_FUNCTION_TRACE (AcpiClearEvent);
325 
326 
327     /* Decode the Fixed Event */
328 
329     if (Event > ACPI_EVENT_MAX)
330     {
331         return_ACPI_STATUS (AE_BAD_PARAMETER);
332     }
333 
334     /*
335      * Clear the requested fixed event (By writing a one to the status
336      * register bit)
337      */
338     Status = AcpiWriteBitRegister (
339                 AcpiGbl_FixedEventInfo[Event].StatusRegisterId,
340                 ACPI_CLEAR_STATUS);
341 
342     return_ACPI_STATUS (Status);
343 }
344 
345 ACPI_EXPORT_SYMBOL (AcpiClearEvent)
346 
347 
348 /*******************************************************************************
349  *
350  * FUNCTION:    AcpiGetEventStatus
351  *
352  * PARAMETERS:  Event           - The fixed event
353  *              EventStatus     - Where the current status of the event will
354  *                                be returned
355  *
356  * RETURN:      Status
357  *
358  * DESCRIPTION: Obtains and returns the current status of the event
359  *
360  ******************************************************************************/
361 
362 ACPI_STATUS
363 AcpiGetEventStatus (
364     UINT32                  Event,
365     ACPI_EVENT_STATUS       *EventStatus)
366 {
367     ACPI_STATUS             Status;
368     ACPI_EVENT_STATUS       LocalEventStatus = 0;
369     UINT32                  InByte;
370 
371 
372     ACPI_FUNCTION_TRACE (AcpiGetEventStatus);
373 
374 
375     if (!EventStatus)
376     {
377         return_ACPI_STATUS (AE_BAD_PARAMETER);
378     }
379 
380     /* Decode the Fixed Event */
381 
382     if (Event > ACPI_EVENT_MAX)
383     {
384         return_ACPI_STATUS (AE_BAD_PARAMETER);
385     }
386 
387     /* Fixed event currently can be dispatched? */
388 
389     if (AcpiGbl_FixedEventHandlers[Event].Handler)
390     {
391         LocalEventStatus |= ACPI_EVENT_FLAG_HAS_HANDLER;
392     }
393 
394     /* Fixed event currently enabled? */
395 
396     Status = AcpiReadBitRegister (
397                 AcpiGbl_FixedEventInfo[Event].EnableRegisterId, &InByte);
398     if (ACPI_FAILURE (Status))
399     {
400         return_ACPI_STATUS (Status);
401     }
402 
403     if (InByte)
404     {
405         LocalEventStatus |= ACPI_EVENT_FLAG_ENABLED;
406     }
407 
408     /* Fixed event currently active? */
409 
410     Status = AcpiReadBitRegister (
411                 AcpiGbl_FixedEventInfo[Event].StatusRegisterId, &InByte);
412     if (ACPI_FAILURE (Status))
413     {
414         return_ACPI_STATUS (Status);
415     }
416 
417     if (InByte)
418     {
419         LocalEventStatus |= ACPI_EVENT_FLAG_SET;
420     }
421 
422     (*EventStatus) = LocalEventStatus;
423     return_ACPI_STATUS (AE_OK);
424 }
425 
426 ACPI_EXPORT_SYMBOL (AcpiGetEventStatus)
427 
428 #endif /* !ACPI_REDUCED_HARDWARE */
429