exstoren.c revision 1.1 1 1.1 jruoho
2 1.1 jruoho /******************************************************************************
3 1.1 jruoho *
4 1.1 jruoho * Module Name: exstoren - AML Interpreter object store support,
5 1.1 jruoho * Store to Node (namespace object)
6 1.1 jruoho *
7 1.1 jruoho *****************************************************************************/
8 1.1 jruoho
9 1.1 jruoho /******************************************************************************
10 1.1 jruoho *
11 1.1 jruoho * 1. Copyright Notice
12 1.1 jruoho *
13 1.1 jruoho * Some or all of this work - Copyright (c) 1999 - 2010, Intel Corp.
14 1.1 jruoho * All rights reserved.
15 1.1 jruoho *
16 1.1 jruoho * 2. License
17 1.1 jruoho *
18 1.1 jruoho * 2.1. This is your license from Intel Corp. under its intellectual property
19 1.1 jruoho * rights. You may have additional license terms from the party that provided
20 1.1 jruoho * you this software, covering your right to use that party's intellectual
21 1.1 jruoho * property rights.
22 1.1 jruoho *
23 1.1 jruoho * 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
24 1.1 jruoho * copy of the source code appearing in this file ("Covered Code") an
25 1.1 jruoho * irrevocable, perpetual, worldwide license under Intel's copyrights in the
26 1.1 jruoho * base code distributed originally by Intel ("Original Intel Code") to copy,
27 1.1 jruoho * make derivatives, distribute, use and display any portion of the Covered
28 1.1 jruoho * Code in any form, with the right to sublicense such rights; and
29 1.1 jruoho *
30 1.1 jruoho * 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
31 1.1 jruoho * license (with the right to sublicense), under only those claims of Intel
32 1.1 jruoho * patents that are infringed by the Original Intel Code, to make, use, sell,
33 1.1 jruoho * offer to sell, and import the Covered Code and derivative works thereof
34 1.1 jruoho * solely to the minimum extent necessary to exercise the above copyright
35 1.1 jruoho * license, and in no event shall the patent license extend to any additions
36 1.1 jruoho * to or modifications of the Original Intel Code. No other license or right
37 1.1 jruoho * is granted directly or by implication, estoppel or otherwise;
38 1.1 jruoho *
39 1.1 jruoho * The above copyright and patent license is granted only if the following
40 1.1 jruoho * conditions are met:
41 1.1 jruoho *
42 1.1 jruoho * 3. Conditions
43 1.1 jruoho *
44 1.1 jruoho * 3.1. Redistribution of Source with Rights to Further Distribute Source.
45 1.1 jruoho * Redistribution of source code of any substantial portion of the Covered
46 1.1 jruoho * Code or modification with rights to further distribute source must include
47 1.1 jruoho * the above Copyright Notice, the above License, this list of Conditions,
48 1.1 jruoho * and the following Disclaimer and Export Compliance provision. In addition,
49 1.1 jruoho * Licensee must cause all Covered Code to which Licensee contributes to
50 1.1 jruoho * contain a file documenting the changes Licensee made to create that Covered
51 1.1 jruoho * Code and the date of any change. Licensee must include in that file the
52 1.1 jruoho * documentation of any changes made by any predecessor Licensee. Licensee
53 1.1 jruoho * must include a prominent statement that the modification is derived,
54 1.1 jruoho * directly or indirectly, from Original Intel Code.
55 1.1 jruoho *
56 1.1 jruoho * 3.2. Redistribution of Source with no Rights to Further Distribute Source.
57 1.1 jruoho * Redistribution of source code of any substantial portion of the Covered
58 1.1 jruoho * Code or modification without rights to further distribute source must
59 1.1 jruoho * include the following Disclaimer and Export Compliance provision in the
60 1.1 jruoho * documentation and/or other materials provided with distribution. In
61 1.1 jruoho * addition, Licensee may not authorize further sublicense of source of any
62 1.1 jruoho * portion of the Covered Code, and must include terms to the effect that the
63 1.1 jruoho * license from Licensee to its licensee is limited to the intellectual
64 1.1 jruoho * property embodied in the software Licensee provides to its licensee, and
65 1.1 jruoho * not to intellectual property embodied in modifications its licensee may
66 1.1 jruoho * make.
67 1.1 jruoho *
68 1.1 jruoho * 3.3. Redistribution of Executable. Redistribution in executable form of any
69 1.1 jruoho * substantial portion of the Covered Code or modification must reproduce the
70 1.1 jruoho * above Copyright Notice, and the following Disclaimer and Export Compliance
71 1.1 jruoho * provision in the documentation and/or other materials provided with the
72 1.1 jruoho * distribution.
73 1.1 jruoho *
74 1.1 jruoho * 3.4. Intel retains all right, title, and interest in and to the Original
75 1.1 jruoho * Intel Code.
76 1.1 jruoho *
77 1.1 jruoho * 3.5. Neither the name Intel nor any other trademark owned or controlled by
78 1.1 jruoho * Intel shall be used in advertising or otherwise to promote the sale, use or
79 1.1 jruoho * other dealings in products derived from or relating to the Covered Code
80 1.1 jruoho * without prior written authorization from Intel.
81 1.1 jruoho *
82 1.1 jruoho * 4. Disclaimer and Export Compliance
83 1.1 jruoho *
84 1.1 jruoho * 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
85 1.1 jruoho * HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
86 1.1 jruoho * IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
87 1.1 jruoho * INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
88 1.1 jruoho * UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
89 1.1 jruoho * IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
90 1.1 jruoho * PARTICULAR PURPOSE.
91 1.1 jruoho *
92 1.1 jruoho * 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
93 1.1 jruoho * OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
94 1.1 jruoho * COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
95 1.1 jruoho * SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
96 1.1 jruoho * CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
97 1.1 jruoho * HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
98 1.1 jruoho * SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
99 1.1 jruoho * LIMITED REMEDY.
100 1.1 jruoho *
101 1.1 jruoho * 4.3. Licensee shall not export, either directly or indirectly, any of this
102 1.1 jruoho * software or system incorporating such software without first obtaining any
103 1.1 jruoho * required license or other approval from the U. S. Department of Commerce or
104 1.1 jruoho * any other agency or department of the United States Government. In the
105 1.1 jruoho * event Licensee exports any such software from the United States or
106 1.1 jruoho * re-exports any such software from a foreign destination, Licensee shall
107 1.1 jruoho * ensure that the distribution and export/re-export of the software is in
108 1.1 jruoho * compliance with all laws, regulations, orders, or other restrictions of the
109 1.1 jruoho * U.S. Export Administration Regulations. Licensee agrees that neither it nor
110 1.1 jruoho * any of its subsidiaries will export/re-export any technical data, process,
111 1.1 jruoho * software, or service, directly or indirectly, to any country for which the
112 1.1 jruoho * United States government or any agency thereof requires an export license,
113 1.1 jruoho * other governmental approval, or letter of assurance, without first obtaining
114 1.1 jruoho * such license, approval or letter.
115 1.1 jruoho *
116 1.1 jruoho *****************************************************************************/
117 1.1 jruoho
118 1.1 jruoho #define __EXSTOREN_C__
119 1.1 jruoho
120 1.1 jruoho #include "acpi.h"
121 1.1 jruoho #include "accommon.h"
122 1.1 jruoho #include "acinterp.h"
123 1.1 jruoho #include "amlcode.h"
124 1.1 jruoho
125 1.1 jruoho
126 1.1 jruoho #define _COMPONENT ACPI_EXECUTER
127 1.1 jruoho ACPI_MODULE_NAME ("exstoren")
128 1.1 jruoho
129 1.1 jruoho
130 1.1 jruoho /*******************************************************************************
131 1.1 jruoho *
132 1.1 jruoho * FUNCTION: AcpiExResolveObject
133 1.1 jruoho *
134 1.1 jruoho * PARAMETERS: SourceDescPtr - Pointer to the source object
135 1.1 jruoho * TargetType - Current type of the target
136 1.1 jruoho * WalkState - Current walk state
137 1.1 jruoho *
138 1.1 jruoho * RETURN: Status, resolved object in SourceDescPtr.
139 1.1 jruoho *
140 1.1 jruoho * DESCRIPTION: Resolve an object. If the object is a reference, dereference
141 1.1 jruoho * it and return the actual object in the SourceDescPtr.
142 1.1 jruoho *
143 1.1 jruoho ******************************************************************************/
144 1.1 jruoho
145 1.1 jruoho ACPI_STATUS
146 1.1 jruoho AcpiExResolveObject (
147 1.1 jruoho ACPI_OPERAND_OBJECT **SourceDescPtr,
148 1.1 jruoho ACPI_OBJECT_TYPE TargetType,
149 1.1 jruoho ACPI_WALK_STATE *WalkState)
150 1.1 jruoho {
151 1.1 jruoho ACPI_OPERAND_OBJECT *SourceDesc = *SourceDescPtr;
152 1.1 jruoho ACPI_STATUS Status = AE_OK;
153 1.1 jruoho
154 1.1 jruoho
155 1.1 jruoho ACPI_FUNCTION_TRACE (ExResolveObject);
156 1.1 jruoho
157 1.1 jruoho
158 1.1 jruoho /* Ensure we have a Target that can be stored to */
159 1.1 jruoho
160 1.1 jruoho switch (TargetType)
161 1.1 jruoho {
162 1.1 jruoho case ACPI_TYPE_BUFFER_FIELD:
163 1.1 jruoho case ACPI_TYPE_LOCAL_REGION_FIELD:
164 1.1 jruoho case ACPI_TYPE_LOCAL_BANK_FIELD:
165 1.1 jruoho case ACPI_TYPE_LOCAL_INDEX_FIELD:
166 1.1 jruoho /*
167 1.1 jruoho * These cases all require only Integers or values that
168 1.1 jruoho * can be converted to Integers (Strings or Buffers)
169 1.1 jruoho */
170 1.1 jruoho
171 1.1 jruoho case ACPI_TYPE_INTEGER:
172 1.1 jruoho case ACPI_TYPE_STRING:
173 1.1 jruoho case ACPI_TYPE_BUFFER:
174 1.1 jruoho
175 1.1 jruoho /*
176 1.1 jruoho * Stores into a Field/Region or into a Integer/Buffer/String
177 1.1 jruoho * are all essentially the same. This case handles the
178 1.1 jruoho * "interchangeable" types Integer, String, and Buffer.
179 1.1 jruoho */
180 1.1 jruoho if (SourceDesc->Common.Type == ACPI_TYPE_LOCAL_REFERENCE)
181 1.1 jruoho {
182 1.1 jruoho /* Resolve a reference object first */
183 1.1 jruoho
184 1.1 jruoho Status = AcpiExResolveToValue (SourceDescPtr, WalkState);
185 1.1 jruoho if (ACPI_FAILURE (Status))
186 1.1 jruoho {
187 1.1 jruoho break;
188 1.1 jruoho }
189 1.1 jruoho }
190 1.1 jruoho
191 1.1 jruoho /* For CopyObject, no further validation necessary */
192 1.1 jruoho
193 1.1 jruoho if (WalkState->Opcode == AML_COPY_OP)
194 1.1 jruoho {
195 1.1 jruoho break;
196 1.1 jruoho }
197 1.1 jruoho
198 1.1 jruoho /* Must have a Integer, Buffer, or String */
199 1.1 jruoho
200 1.1 jruoho if ((SourceDesc->Common.Type != ACPI_TYPE_INTEGER) &&
201 1.1 jruoho (SourceDesc->Common.Type != ACPI_TYPE_BUFFER) &&
202 1.1 jruoho (SourceDesc->Common.Type != ACPI_TYPE_STRING) &&
203 1.1 jruoho !((SourceDesc->Common.Type == ACPI_TYPE_LOCAL_REFERENCE) &&
204 1.1 jruoho (SourceDesc->Reference.Class== ACPI_REFCLASS_TABLE)))
205 1.1 jruoho {
206 1.1 jruoho /* Conversion successful but still not a valid type */
207 1.1 jruoho
208 1.1 jruoho ACPI_ERROR ((AE_INFO,
209 1.1 jruoho "Cannot assign type %s to %s (must be type Int/Str/Buf)",
210 1.1 jruoho AcpiUtGetObjectTypeName (SourceDesc),
211 1.1 jruoho AcpiUtGetTypeName (TargetType)));
212 1.1 jruoho Status = AE_AML_OPERAND_TYPE;
213 1.1 jruoho }
214 1.1 jruoho break;
215 1.1 jruoho
216 1.1 jruoho
217 1.1 jruoho case ACPI_TYPE_LOCAL_ALIAS:
218 1.1 jruoho case ACPI_TYPE_LOCAL_METHOD_ALIAS:
219 1.1 jruoho
220 1.1 jruoho /*
221 1.1 jruoho * All aliases should have been resolved earlier, during the
222 1.1 jruoho * operand resolution phase.
223 1.1 jruoho */
224 1.1 jruoho ACPI_ERROR ((AE_INFO, "Store into an unresolved Alias object"));
225 1.1 jruoho Status = AE_AML_INTERNAL;
226 1.1 jruoho break;
227 1.1 jruoho
228 1.1 jruoho
229 1.1 jruoho case ACPI_TYPE_PACKAGE:
230 1.1 jruoho default:
231 1.1 jruoho
232 1.1 jruoho /*
233 1.1 jruoho * All other types than Alias and the various Fields come here,
234 1.1 jruoho * including the untyped case - ACPI_TYPE_ANY.
235 1.1 jruoho */
236 1.1 jruoho break;
237 1.1 jruoho }
238 1.1 jruoho
239 1.1 jruoho return_ACPI_STATUS (Status);
240 1.1 jruoho }
241 1.1 jruoho
242 1.1 jruoho
243 1.1 jruoho /*******************************************************************************
244 1.1 jruoho *
245 1.1 jruoho * FUNCTION: AcpiExStoreObjectToObject
246 1.1 jruoho *
247 1.1 jruoho * PARAMETERS: SourceDesc - Object to store
248 1.1 jruoho * DestDesc - Object to receive a copy of the source
249 1.1 jruoho * NewDesc - New object if DestDesc is obsoleted
250 1.1 jruoho * WalkState - Current walk state
251 1.1 jruoho *
252 1.1 jruoho * RETURN: Status
253 1.1 jruoho *
254 1.1 jruoho * DESCRIPTION: "Store" an object to another object. This may include
255 1.1 jruoho * converting the source type to the target type (implicit
256 1.1 jruoho * conversion), and a copy of the value of the source to
257 1.1 jruoho * the target.
258 1.1 jruoho *
259 1.1 jruoho * The Assignment of an object to another (not named) object
260 1.1 jruoho * is handled here.
261 1.1 jruoho * The Source passed in will replace the current value (if any)
262 1.1 jruoho * with the input value.
263 1.1 jruoho *
264 1.1 jruoho * When storing into an object the data is converted to the
265 1.1 jruoho * target object type then stored in the object. This means
266 1.1 jruoho * that the target object type (for an initialized target) will
267 1.1 jruoho * not be changed by a store operation.
268 1.1 jruoho *
269 1.1 jruoho * This module allows destination types of Number, String,
270 1.1 jruoho * Buffer, and Package.
271 1.1 jruoho *
272 1.1 jruoho * Assumes parameters are already validated. NOTE: SourceDesc
273 1.1 jruoho * resolution (from a reference object) must be performed by
274 1.1 jruoho * the caller if necessary.
275 1.1 jruoho *
276 1.1 jruoho ******************************************************************************/
277 1.1 jruoho
278 1.1 jruoho ACPI_STATUS
279 1.1 jruoho AcpiExStoreObjectToObject (
280 1.1 jruoho ACPI_OPERAND_OBJECT *SourceDesc,
281 1.1 jruoho ACPI_OPERAND_OBJECT *DestDesc,
282 1.1 jruoho ACPI_OPERAND_OBJECT **NewDesc,
283 1.1 jruoho ACPI_WALK_STATE *WalkState)
284 1.1 jruoho {
285 1.1 jruoho ACPI_OPERAND_OBJECT *ActualSrcDesc;
286 1.1 jruoho ACPI_STATUS Status = AE_OK;
287 1.1 jruoho
288 1.1 jruoho
289 1.1 jruoho ACPI_FUNCTION_TRACE_PTR (ExStoreObjectToObject, SourceDesc);
290 1.1 jruoho
291 1.1 jruoho
292 1.1 jruoho ActualSrcDesc = SourceDesc;
293 1.1 jruoho if (!DestDesc)
294 1.1 jruoho {
295 1.1 jruoho /*
296 1.1 jruoho * There is no destination object (An uninitialized node or
297 1.1 jruoho * package element), so we can simply copy the source object
298 1.1 jruoho * creating a new destination object
299 1.1 jruoho */
300 1.1 jruoho Status = AcpiUtCopyIobjectToIobject (ActualSrcDesc, NewDesc, WalkState);
301 1.1 jruoho return_ACPI_STATUS (Status);
302 1.1 jruoho }
303 1.1 jruoho
304 1.1 jruoho if (SourceDesc->Common.Type != DestDesc->Common.Type)
305 1.1 jruoho {
306 1.1 jruoho /*
307 1.1 jruoho * The source type does not match the type of the destination.
308 1.1 jruoho * Perform the "implicit conversion" of the source to the current type
309 1.1 jruoho * of the target as per the ACPI specification.
310 1.1 jruoho *
311 1.1 jruoho * If no conversion performed, ActualSrcDesc = SourceDesc.
312 1.1 jruoho * Otherwise, ActualSrcDesc is a temporary object to hold the
313 1.1 jruoho * converted object.
314 1.1 jruoho */
315 1.1 jruoho Status = AcpiExConvertToTargetType (DestDesc->Common.Type,
316 1.1 jruoho SourceDesc, &ActualSrcDesc, WalkState);
317 1.1 jruoho if (ACPI_FAILURE (Status))
318 1.1 jruoho {
319 1.1 jruoho return_ACPI_STATUS (Status);
320 1.1 jruoho }
321 1.1 jruoho
322 1.1 jruoho if (SourceDesc == ActualSrcDesc)
323 1.1 jruoho {
324 1.1 jruoho /*
325 1.1 jruoho * No conversion was performed. Return the SourceDesc as the
326 1.1 jruoho * new object.
327 1.1 jruoho */
328 1.1 jruoho *NewDesc = SourceDesc;
329 1.1 jruoho return_ACPI_STATUS (AE_OK);
330 1.1 jruoho }
331 1.1 jruoho }
332 1.1 jruoho
333 1.1 jruoho /*
334 1.1 jruoho * We now have two objects of identical types, and we can perform a
335 1.1 jruoho * copy of the *value* of the source object.
336 1.1 jruoho */
337 1.1 jruoho switch (DestDesc->Common.Type)
338 1.1 jruoho {
339 1.1 jruoho case ACPI_TYPE_INTEGER:
340 1.1 jruoho
341 1.1 jruoho DestDesc->Integer.Value = ActualSrcDesc->Integer.Value;
342 1.1 jruoho
343 1.1 jruoho /* Truncate value if we are executing from a 32-bit ACPI table */
344 1.1 jruoho
345 1.1 jruoho AcpiExTruncateFor32bitTable (DestDesc);
346 1.1 jruoho break;
347 1.1 jruoho
348 1.1 jruoho case ACPI_TYPE_STRING:
349 1.1 jruoho
350 1.1 jruoho Status = AcpiExStoreStringToString (ActualSrcDesc, DestDesc);
351 1.1 jruoho break;
352 1.1 jruoho
353 1.1 jruoho case ACPI_TYPE_BUFFER:
354 1.1 jruoho
355 1.1 jruoho Status = AcpiExStoreBufferToBuffer (ActualSrcDesc, DestDesc);
356 1.1 jruoho break;
357 1.1 jruoho
358 1.1 jruoho case ACPI_TYPE_PACKAGE:
359 1.1 jruoho
360 1.1 jruoho Status = AcpiUtCopyIobjectToIobject (ActualSrcDesc, &DestDesc,
361 1.1 jruoho WalkState);
362 1.1 jruoho break;
363 1.1 jruoho
364 1.1 jruoho default:
365 1.1 jruoho /*
366 1.1 jruoho * All other types come here.
367 1.1 jruoho */
368 1.1 jruoho ACPI_WARNING ((AE_INFO, "Store into type %s not implemented",
369 1.1 jruoho AcpiUtGetObjectTypeName (DestDesc)));
370 1.1 jruoho
371 1.1 jruoho Status = AE_NOT_IMPLEMENTED;
372 1.1 jruoho break;
373 1.1 jruoho }
374 1.1 jruoho
375 1.1 jruoho if (ActualSrcDesc != SourceDesc)
376 1.1 jruoho {
377 1.1 jruoho /* Delete the intermediate (temporary) source object */
378 1.1 jruoho
379 1.1 jruoho AcpiUtRemoveReference (ActualSrcDesc);
380 1.1 jruoho }
381 1.1 jruoho
382 1.1 jruoho *NewDesc = DestDesc;
383 1.1 jruoho return_ACPI_STATUS (Status);
384 1.1 jruoho }
385 1.1 jruoho
386 1.1 jruoho
387