xref: /freebsd/sys/contrib/dev/acpica/include/acnamesp.h (revision c6db8143eda5c775467145ac73e8ebec47afdd8f)
1 /******************************************************************************
2  *
3  * Name: acnamesp.h - Namespace subcomponent prototypes and defines
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 #ifndef __ACNAMESP_H__
45 #define __ACNAMESP_H__
46 
47 
48 /* To search the entire name space, pass this as SearchBase */
49 
50 #define ACPI_NS_ALL                 ((ACPI_HANDLE)0)
51 
52 /*
53  * Elements of AcpiNsProperties are bit significant
54  * and should be one-to-one with values of ACPI_OBJECT_TYPE
55  */
56 #define ACPI_NS_NORMAL              0
57 #define ACPI_NS_NEWSCOPE            1   /* a definition of this type opens a name scope */
58 #define ACPI_NS_LOCAL               2   /* suppress search of enclosing scopes */
59 
60 /* Flags for AcpiNsLookup, AcpiNsSearchAndEnter */
61 
62 #define ACPI_NS_NO_UPSEARCH         0
63 #define ACPI_NS_SEARCH_PARENT       0x01
64 #define ACPI_NS_DONT_OPEN_SCOPE     0x02
65 #define ACPI_NS_NO_PEER_SEARCH      0x04
66 #define ACPI_NS_ERROR_IF_FOUND      0x08
67 #define ACPI_NS_PREFIX_IS_SCOPE     0x10
68 #define ACPI_NS_EXTERNAL            0x20
69 #define ACPI_NS_TEMPORARY           0x40
70 
71 /* Flags for AcpiNsWalkNamespace */
72 
73 #define ACPI_NS_WALK_NO_UNLOCK      0
74 #define ACPI_NS_WALK_UNLOCK         0x01
75 #define ACPI_NS_WALK_TEMP_NODES     0x02
76 
77 /* Object is not a package element */
78 
79 #define ACPI_NOT_PACKAGE_ELEMENT    ACPI_UINT32_MAX
80 
81 /* Always emit warning message, not dependent on node flags */
82 
83 #define ACPI_WARN_ALWAYS            0
84 
85 
86 /*
87  * nsinit - Namespace initialization
88  */
89 ACPI_STATUS
90 AcpiNsInitializeObjects (
91     void);
92 
93 ACPI_STATUS
94 AcpiNsInitializeDevices (
95     void);
96 
97 
98 /*
99  * nsload -  Namespace loading
100  */
101 ACPI_STATUS
102 AcpiNsLoadNamespace (
103     void);
104 
105 ACPI_STATUS
106 AcpiNsLoadTable (
107     UINT32                  TableIndex,
108     ACPI_NAMESPACE_NODE     *Node);
109 
110 
111 /*
112  * nswalk - walk the namespace
113  */
114 ACPI_STATUS
115 AcpiNsWalkNamespace (
116     ACPI_OBJECT_TYPE        Type,
117     ACPI_HANDLE             StartObject,
118     UINT32                  MaxDepth,
119     UINT32                  Flags,
120     ACPI_WALK_CALLBACK      DescendingCallback,
121     ACPI_WALK_CALLBACK      AscendingCallback,
122     void                    *Context,
123     void                    **ReturnValue);
124 
125 ACPI_NAMESPACE_NODE *
126 AcpiNsGetNextNode (
127     ACPI_NAMESPACE_NODE     *Parent,
128     ACPI_NAMESPACE_NODE     *Child);
129 
130 ACPI_NAMESPACE_NODE *
131 AcpiNsGetNextNodeTyped (
132     ACPI_OBJECT_TYPE        Type,
133     ACPI_NAMESPACE_NODE     *Parent,
134     ACPI_NAMESPACE_NODE     *Child);
135 
136 /*
137  * nsparse - table parsing
138  */
139 ACPI_STATUS
140 AcpiNsParseTable (
141     UINT32                  TableIndex,
142     ACPI_NAMESPACE_NODE     *StartNode);
143 
144 ACPI_STATUS
145 AcpiNsOneCompleteParse (
146     UINT32                  PassNumber,
147     UINT32                  TableIndex,
148     ACPI_NAMESPACE_NODE     *StartNode);
149 
150 
151 /*
152  * nsaccess - Top-level namespace access
153  */
154 ACPI_STATUS
155 AcpiNsRootInitialize (
156     void);
157 
158 ACPI_STATUS
159 AcpiNsLookup (
160     ACPI_GENERIC_STATE      *ScopeInfo,
161     char                    *Name,
162     ACPI_OBJECT_TYPE        Type,
163     ACPI_INTERPRETER_MODE   InterpreterMode,
164     UINT32                  Flags,
165     ACPI_WALK_STATE         *WalkState,
166     ACPI_NAMESPACE_NODE     **RetNode);
167 
168 
169 /*
170  * nsalloc - Named object allocation/deallocation
171  */
172 ACPI_NAMESPACE_NODE *
173 AcpiNsCreateNode (
174     UINT32                  Name);
175 
176 void
177 AcpiNsDeleteNode (
178     ACPI_NAMESPACE_NODE     *Node);
179 
180 void
181 AcpiNsRemoveNode (
182     ACPI_NAMESPACE_NODE     *Node);
183 
184 void
185 AcpiNsDeleteNamespaceSubtree (
186     ACPI_NAMESPACE_NODE     *ParentHandle);
187 
188 void
189 AcpiNsDeleteNamespaceByOwner (
190     ACPI_OWNER_ID           OwnerId);
191 
192 void
193 AcpiNsDetachObject (
194     ACPI_NAMESPACE_NODE     *Node);
195 
196 void
197 AcpiNsDeleteChildren (
198     ACPI_NAMESPACE_NODE     *Parent);
199 
200 int
201 AcpiNsCompareNames (
202     char                    *Name1,
203     char                    *Name2);
204 
205 
206 /*
207  * nsconvert - Dynamic object conversion routines
208  */
209 ACPI_STATUS
210 AcpiNsConvertToInteger (
211     ACPI_OPERAND_OBJECT     *OriginalObject,
212     ACPI_OPERAND_OBJECT     **ReturnObject);
213 
214 ACPI_STATUS
215 AcpiNsConvertToString (
216     ACPI_OPERAND_OBJECT     *OriginalObject,
217     ACPI_OPERAND_OBJECT     **ReturnObject);
218 
219 ACPI_STATUS
220 AcpiNsConvertToBuffer (
221     ACPI_OPERAND_OBJECT     *OriginalObject,
222     ACPI_OPERAND_OBJECT     **ReturnObject);
223 
224 ACPI_STATUS
225 AcpiNsConvertToUnicode (
226     ACPI_OPERAND_OBJECT     *OriginalObject,
227     ACPI_OPERAND_OBJECT     **ReturnObject);
228 
229 ACPI_STATUS
230 AcpiNsConvertToResource (
231     ACPI_OPERAND_OBJECT     *OriginalObject,
232     ACPI_OPERAND_OBJECT     **ReturnObject);
233 
234 
235 /*
236  * nsdump - Namespace dump/print utilities
237  */
238 void
239 AcpiNsDumpTables (
240     ACPI_HANDLE             SearchBase,
241     UINT32                  MaxDepth);
242 
243 void
244 AcpiNsDumpEntry (
245     ACPI_HANDLE             Handle,
246     UINT32                  DebugLevel);
247 
248 void
249 AcpiNsDumpPathname (
250     ACPI_HANDLE             Handle,
251     char                    *Msg,
252     UINT32                  Level,
253     UINT32                  Component);
254 
255 void
256 AcpiNsPrintPathname (
257     UINT32                  NumSegments,
258     char                    *Pathname);
259 
260 ACPI_STATUS
261 AcpiNsDumpOneObject (
262     ACPI_HANDLE             ObjHandle,
263     UINT32                  Level,
264     void                    *Context,
265     void                    **ReturnValue);
266 
267 void
268 AcpiNsDumpObjects (
269     ACPI_OBJECT_TYPE        Type,
270     UINT8                   DisplayType,
271     UINT32                  MaxDepth,
272     ACPI_OWNER_ID           OwnerId,
273     ACPI_HANDLE             StartHandle);
274 
275 void
276 AcpiNsDumpObjectPaths (
277     ACPI_OBJECT_TYPE        Type,
278     UINT8                   DisplayType,
279     UINT32                  MaxDepth,
280     ACPI_OWNER_ID           OwnerId,
281     ACPI_HANDLE             StartHandle);
282 
283 
284 /*
285  * nseval - Namespace evaluation functions
286  */
287 ACPI_STATUS
288 AcpiNsEvaluate (
289     ACPI_EVALUATE_INFO      *Info);
290 
291 void
292 AcpiNsExecModuleCodeList (
293     void);
294 
295 
296 /*
297  * nsarguments - Argument count/type checking for predefined/reserved names
298  */
299 void
300 AcpiNsCheckArgumentCount (
301     char                        *Pathname,
302     ACPI_NAMESPACE_NODE         *Node,
303     UINT32                      UserParamCount,
304     const ACPI_PREDEFINED_INFO  *Info);
305 
306 void
307 AcpiNsCheckAcpiCompliance (
308     char                        *Pathname,
309     ACPI_NAMESPACE_NODE         *Node,
310     const ACPI_PREDEFINED_INFO  *Predefined);
311 
312 void
313 AcpiNsCheckArgumentTypes (
314     ACPI_EVALUATE_INFO          *Info);
315 
316 
317 /*
318  * nspredef - Return value checking for predefined/reserved names
319  */
320 ACPI_STATUS
321 AcpiNsCheckReturnValue (
322     ACPI_NAMESPACE_NODE         *Node,
323     ACPI_EVALUATE_INFO          *Info,
324     UINT32                      UserParamCount,
325     ACPI_STATUS                 ReturnStatus,
326     ACPI_OPERAND_OBJECT         **ReturnObject);
327 
328 ACPI_STATUS
329 AcpiNsCheckObjectType (
330     ACPI_EVALUATE_INFO          *Info,
331     ACPI_OPERAND_OBJECT         **ReturnObjectPtr,
332     UINT32                      ExpectedBtypes,
333     UINT32                      PackageIndex);
334 
335 
336 /*
337  * nsprepkg - Validation of predefined name packages
338  */
339 ACPI_STATUS
340 AcpiNsCheckPackage (
341     ACPI_EVALUATE_INFO          *Info,
342     ACPI_OPERAND_OBJECT         **ReturnObjectPtr);
343 
344 
345 /*
346  * nsnames - Name and Scope manipulation
347  */
348 UINT32
349 AcpiNsOpensScope (
350     ACPI_OBJECT_TYPE        Type);
351 
352 ACPI_STATUS
353 AcpiNsBuildExternalPath (
354     ACPI_NAMESPACE_NODE     *Node,
355     ACPI_SIZE               Size,
356     char                    *NameBuffer);
357 
358 char *
359 AcpiNsGetExternalPathname (
360     ACPI_NAMESPACE_NODE     *Node);
361 
362 char *
363 AcpiNsNameOfCurrentScope (
364     ACPI_WALK_STATE         *WalkState);
365 
366 ACPI_STATUS
367 AcpiNsHandleToPathname (
368     ACPI_HANDLE             TargetHandle,
369     ACPI_BUFFER             *Buffer);
370 
371 BOOLEAN
372 AcpiNsPatternMatch (
373     ACPI_NAMESPACE_NODE     *ObjNode,
374     char                    *SearchFor);
375 
376 ACPI_STATUS
377 AcpiNsGetNode (
378     ACPI_NAMESPACE_NODE     *PrefixNode,
379     const char              *ExternalPathname,
380     UINT32                  Flags,
381     ACPI_NAMESPACE_NODE     **OutNode);
382 
383 ACPI_SIZE
384 AcpiNsGetPathnameLength (
385     ACPI_NAMESPACE_NODE     *Node);
386 
387 
388 /*
389  * nsobject - Object management for namespace nodes
390  */
391 ACPI_STATUS
392 AcpiNsAttachObject (
393     ACPI_NAMESPACE_NODE     *Node,
394     ACPI_OPERAND_OBJECT     *Object,
395     ACPI_OBJECT_TYPE        Type);
396 
397 ACPI_OPERAND_OBJECT *
398 AcpiNsGetAttachedObject (
399     ACPI_NAMESPACE_NODE     *Node);
400 
401 ACPI_OPERAND_OBJECT *
402 AcpiNsGetSecondaryObject (
403     ACPI_OPERAND_OBJECT     *ObjDesc);
404 
405 ACPI_STATUS
406 AcpiNsAttachData (
407     ACPI_NAMESPACE_NODE     *Node,
408     ACPI_OBJECT_HANDLER     Handler,
409     void                    *Data);
410 
411 ACPI_STATUS
412 AcpiNsDetachData (
413     ACPI_NAMESPACE_NODE     *Node,
414     ACPI_OBJECT_HANDLER     Handler);
415 
416 ACPI_STATUS
417 AcpiNsGetAttachedData (
418     ACPI_NAMESPACE_NODE     *Node,
419     ACPI_OBJECT_HANDLER     Handler,
420     void                    **Data);
421 
422 
423 /*
424  * nsrepair - General return object repair for all
425  * predefined methods/objects
426  */
427 ACPI_STATUS
428 AcpiNsSimpleRepair (
429     ACPI_EVALUATE_INFO      *Info,
430     UINT32                  ExpectedBtypes,
431     UINT32                  PackageIndex,
432     ACPI_OPERAND_OBJECT     **ReturnObjectPtr);
433 
434 ACPI_STATUS
435 AcpiNsWrapWithPackage (
436     ACPI_EVALUATE_INFO      *Info,
437     ACPI_OPERAND_OBJECT     *OriginalObject,
438     ACPI_OPERAND_OBJECT     **ObjDescPtr);
439 
440 ACPI_STATUS
441 AcpiNsRepairNullElement (
442     ACPI_EVALUATE_INFO      *Info,
443     UINT32                  ExpectedBtypes,
444     UINT32                  PackageIndex,
445     ACPI_OPERAND_OBJECT     **ReturnObjectPtr);
446 
447 void
448 AcpiNsRemoveNullElements (
449     ACPI_EVALUATE_INFO      *Info,
450     UINT8                   PackageType,
451     ACPI_OPERAND_OBJECT     *ObjDesc);
452 
453 
454 /*
455  * nsrepair2 - Return object repair for specific
456  * predefined methods/objects
457  */
458 ACPI_STATUS
459 AcpiNsComplexRepairs (
460     ACPI_EVALUATE_INFO      *Info,
461     ACPI_NAMESPACE_NODE     *Node,
462     ACPI_STATUS             ValidateStatus,
463     ACPI_OPERAND_OBJECT     **ReturnObjectPtr);
464 
465 
466 /*
467  * nssearch - Namespace searching and entry
468  */
469 ACPI_STATUS
470 AcpiNsSearchAndEnter (
471     UINT32                  EntryName,
472     ACPI_WALK_STATE         *WalkState,
473     ACPI_NAMESPACE_NODE     *Node,
474     ACPI_INTERPRETER_MODE   InterpreterMode,
475     ACPI_OBJECT_TYPE        Type,
476     UINT32                  Flags,
477     ACPI_NAMESPACE_NODE     **RetNode);
478 
479 ACPI_STATUS
480 AcpiNsSearchOneScope (
481     UINT32                  EntryName,
482     ACPI_NAMESPACE_NODE     *Node,
483     ACPI_OBJECT_TYPE        Type,
484     ACPI_NAMESPACE_NODE     **RetNode);
485 
486 void
487 AcpiNsInstallNode (
488     ACPI_WALK_STATE         *WalkState,
489     ACPI_NAMESPACE_NODE     *ParentNode,
490     ACPI_NAMESPACE_NODE     *Node,
491     ACPI_OBJECT_TYPE        Type);
492 
493 
494 /*
495  * nsutils - Utility functions
496  */
497 ACPI_OBJECT_TYPE
498 AcpiNsGetType (
499     ACPI_NAMESPACE_NODE     *Node);
500 
501 UINT32
502 AcpiNsLocal (
503     ACPI_OBJECT_TYPE        Type);
504 
505 void
506 AcpiNsPrintNodePathname (
507     ACPI_NAMESPACE_NODE     *Node,
508     const char              *Msg);
509 
510 ACPI_STATUS
511 AcpiNsBuildInternalName (
512     ACPI_NAMESTRING_INFO    *Info);
513 
514 void
515 AcpiNsGetInternalNameLength (
516     ACPI_NAMESTRING_INFO    *Info);
517 
518 ACPI_STATUS
519 AcpiNsInternalizeName (
520     const char              *DottedName,
521     char                    **ConvertedName);
522 
523 ACPI_STATUS
524 AcpiNsExternalizeName (
525     UINT32                  InternalNameLength,
526     const char              *InternalName,
527     UINT32                  *ConvertedNameLength,
528     char                    **ConvertedName);
529 
530 ACPI_NAMESPACE_NODE *
531 AcpiNsValidateHandle (
532     ACPI_HANDLE             Handle);
533 
534 void
535 AcpiNsTerminate (
536     void);
537 
538 #endif /* __ACNAMESP_H__ */
539