2 /******************************************************************************
4 * Module Name: aslrestype2q - Large QWord address resource descriptors
6 *****************************************************************************/
9 * Copyright (C) 2000 - 2011, Intel Corp.
10 * All rights reserved.
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
15 * 1. Redistributions of source code must retain the above copyright
16 * notice, this list of conditions, and the following disclaimer,
17 * without modification.
18 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
19 * substantially similar to the "NO WARRANTY" disclaimer below
20 * ("Disclaimer") and any redistribution must be conditioned upon
21 * including a substantially similar Disclaimer requirement for further
22 * binary redistribution.
23 * 3. Neither the names of the above-listed copyright holders nor the names
24 * of any contributors may be used to endorse or promote products derived
25 * from this software without specific prior written permission.
27 * Alternatively, this software may be distributed under the terms of the
28 * GNU General Public License ("GPL") version 2 as published by the Free
29 * Software Foundation.
32 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
33 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
34 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
35 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
36 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
37 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
38 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
39 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
40 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
41 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
42 * POSSIBILITY OF SUCH DAMAGES.
46 #include <contrib/dev/acpica/compiler/aslcompiler.h>
47 #include "aslcompiler.y.h"
49 #define _COMPONENT ACPI_COMPILER
50 ACPI_MODULE_NAME ("aslrestype2q")
53 * This module contains the QWord (64-bit) address space descriptors:
60 /*******************************************************************************
62 * FUNCTION: RsDoQwordIoDescriptor
64 * PARAMETERS: Op - Parent resource descriptor parse node
65 * CurrentByteOffset - Offset into the resource template AML
66 * buffer (to track references to the desc)
68 * RETURN: Completed resource node
70 * DESCRIPTION: Construct a long "QwordIO" descriptor
72 ******************************************************************************/
75 RsDoQwordIoDescriptor (
76 ACPI_PARSE_OBJECT *Op,
77 UINT32 CurrentByteOffset)
79 AML_RESOURCE *Descriptor;
80 ACPI_PARSE_OBJECT *InitializerOp;
81 ACPI_PARSE_OBJECT *MinOp = NULL;
82 ACPI_PARSE_OBJECT *MaxOp = NULL;
83 ACPI_PARSE_OBJECT *LengthOp = NULL;
84 ACPI_PARSE_OBJECT *GranOp = NULL;
85 ASL_RESOURCE_NODE *Rnode;
86 UINT8 *OptionalFields;
87 UINT16 StringLength = 0;
88 UINT32 OptionIndex = 0;
90 BOOLEAN ResSourceIndex = FALSE;
93 InitializerOp = Op->Asl.Child;
94 StringLength = RsGetStringDataLength (InitializerOp);
96 Rnode = RsAllocateResourceNode (
97 sizeof (AML_RESOURCE_ADDRESS64) + 1 + StringLength);
99 Descriptor = Rnode->Buffer;
100 Descriptor->Address64.DescriptorType = ACPI_RESOURCE_NAME_ADDRESS64;
101 Descriptor->Address64.ResourceType = ACPI_ADDRESS_TYPE_IO_RANGE;
104 * Initial descriptor length -- may be enlarged if there are
105 * optional fields present
107 OptionalFields = ((UINT8 *) Descriptor) + sizeof (AML_RESOURCE_ADDRESS64);
108 Descriptor->Address64.ResourceLength = (UINT16)
109 (sizeof (AML_RESOURCE_ADDRESS64) -
110 sizeof (AML_RESOURCE_LARGE_HEADER));
112 /* Process all child initialization nodes */
114 for (i = 0; InitializerOp; i++)
118 case 0: /* Resource Usage */
120 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 0, 1);
123 case 1: /* MinType */
125 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 2, 0);
126 RsCreateBitField (InitializerOp, ACPI_RESTAG_MINTYPE,
127 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 2);
130 case 2: /* MaxType */
132 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 3, 0);
133 RsCreateBitField (InitializerOp, ACPI_RESTAG_MAXTYPE,
134 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 3);
137 case 3: /* DecodeType */
139 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 1, 0);
140 RsCreateBitField (InitializerOp, ACPI_RESTAG_DECODE,
141 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 1);
144 case 4: /* Range Type */
146 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 0, 3);
147 RsCreateBitField (InitializerOp, ACPI_RESTAG_RANGETYPE,
148 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 0);
151 case 5: /* Address Granularity */
153 Descriptor->Address64.Granularity = InitializerOp->Asl.Value.Integer;
154 RsCreateByteField (InitializerOp, ACPI_RESTAG_GRANULARITY,
155 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Granularity));
156 GranOp = InitializerOp;
159 case 6: /* Address Min */
161 Descriptor->Address64.Minimum = InitializerOp->Asl.Value.Integer;
162 RsCreateByteField (InitializerOp, ACPI_RESTAG_MINADDR,
163 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Minimum));
164 MinOp = InitializerOp;
167 case 7: /* Address Max */
169 Descriptor->Address64.Maximum = InitializerOp->Asl.Value.Integer;
170 RsCreateByteField (InitializerOp, ACPI_RESTAG_MAXADDR,
171 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Maximum));
172 MaxOp = InitializerOp;
175 case 8: /* Translation Offset */
177 Descriptor->Address64.TranslationOffset = InitializerOp->Asl.Value.Integer;
178 RsCreateByteField (InitializerOp, ACPI_RESTAG_TRANSLATION,
179 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.TranslationOffset));
182 case 9: /* Address Length */
184 Descriptor->Address64.AddressLength = InitializerOp->Asl.Value.Integer;
185 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
186 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.AddressLength));
187 LengthOp = InitializerOp;
190 case 10: /* ResSourceIndex [Optional Field - BYTE] */
192 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
194 OptionalFields[0] = (UINT8) InitializerOp->Asl.Value.Integer;
196 Descriptor->Address64.ResourceLength++;
197 ResSourceIndex = TRUE;
201 case 11: /* ResSource [Optional Field - STRING] */
203 if ((InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG) &&
204 (InitializerOp->Asl.Value.String))
208 Descriptor->Address64.ResourceLength = (UINT16)
209 (Descriptor->Address64.ResourceLength + StringLength);
212 &OptionalFields[OptionIndex],
213 InitializerOp->Asl.Value.String);
215 /* ResourceSourceIndex must also be valid */
219 AslError (ASL_ERROR, ASL_MSG_RESOURCE_INDEX,
220 InitializerOp, NULL);
227 * Not a valid ResourceSource, ResourceSourceIndex must also
230 else if (ResSourceIndex)
232 AslError (ASL_ERROR, ASL_MSG_RESOURCE_SOURCE,
233 InitializerOp, NULL);
238 case 12: /* ResourceTag */
240 UtAttachNamepathToOwner (Op, InitializerOp);
245 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 4, 0);
246 RsCreateBitField (InitializerOp, ACPI_RESTAG_TYPE,
247 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 4);
250 case 14: /* Translation Type */
252 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 5, 0);
253 RsCreateBitField (InitializerOp, ACPI_RESTAG_TRANSTYPE,
254 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 5);
259 AslError (ASL_ERROR, ASL_MSG_RESOURCE_LIST, InitializerOp, NULL);
263 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
266 /* Validate the Min/Max/Len/Gran values */
268 RsLargeAddressCheck (
269 Descriptor->Address64.Minimum,
270 Descriptor->Address64.Maximum,
271 Descriptor->Address64.AddressLength,
272 Descriptor->Address64.Granularity,
273 Descriptor->Address64.Flags,
274 MinOp, MaxOp, LengthOp, GranOp, Op);
276 Rnode->BufferLength = sizeof (AML_RESOURCE_ADDRESS64) +
277 OptionIndex + StringLength;
282 /*******************************************************************************
284 * FUNCTION: RsDoQwordMemoryDescriptor
286 * PARAMETERS: Op - Parent resource descriptor parse node
287 * CurrentByteOffset - Offset into the resource template AML
288 * buffer (to track references to the desc)
290 * RETURN: Completed resource node
292 * DESCRIPTION: Construct a long "QwordMemory" descriptor
294 ******************************************************************************/
297 RsDoQwordMemoryDescriptor (
298 ACPI_PARSE_OBJECT *Op,
299 UINT32 CurrentByteOffset)
301 AML_RESOURCE *Descriptor;
302 ACPI_PARSE_OBJECT *InitializerOp;
303 ACPI_PARSE_OBJECT *MinOp = NULL;
304 ACPI_PARSE_OBJECT *MaxOp = NULL;
305 ACPI_PARSE_OBJECT *LengthOp = NULL;
306 ACPI_PARSE_OBJECT *GranOp = NULL;
307 ASL_RESOURCE_NODE *Rnode;
308 UINT8 *OptionalFields;
309 UINT16 StringLength = 0;
310 UINT32 OptionIndex = 0;
312 BOOLEAN ResSourceIndex = FALSE;
315 InitializerOp = Op->Asl.Child;
316 StringLength = RsGetStringDataLength (InitializerOp);
318 Rnode = RsAllocateResourceNode (
319 sizeof (AML_RESOURCE_ADDRESS64) + 1 + StringLength);
321 Descriptor = Rnode->Buffer;
322 Descriptor->Address64.DescriptorType = ACPI_RESOURCE_NAME_ADDRESS64;
323 Descriptor->Address64.ResourceType = ACPI_ADDRESS_TYPE_MEMORY_RANGE;
326 * Initial descriptor length -- may be enlarged if there are
327 * optional fields present
329 OptionalFields = ((UINT8 *) Descriptor) + sizeof (AML_RESOURCE_ADDRESS64);
330 Descriptor->Address64.ResourceLength = (UINT16)
331 (sizeof (AML_RESOURCE_ADDRESS64) -
332 sizeof (AML_RESOURCE_LARGE_HEADER));
334 /* Process all child initialization nodes */
336 for (i = 0; InitializerOp; i++)
340 case 0: /* Resource Usage */
342 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 0, 1);
345 case 1: /* DecodeType */
347 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 1, 0);
348 RsCreateBitField (InitializerOp, ACPI_RESTAG_DECODE,
349 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 1);
352 case 2: /* MinType */
354 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 2, 0);
355 RsCreateBitField (InitializerOp, ACPI_RESTAG_MINTYPE,
356 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 2);
359 case 3: /* MaxType */
361 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 3, 0);
362 RsCreateBitField (InitializerOp, ACPI_RESTAG_MAXTYPE,
363 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 3);
366 case 4: /* Memory Type */
368 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 1, 0);
369 RsCreateBitField (InitializerOp, ACPI_RESTAG_MEMTYPE,
370 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 1);
373 case 5: /* Read/Write Type */
375 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 0, 1);
376 RsCreateBitField (InitializerOp, ACPI_RESTAG_READWRITETYPE,
377 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 0);
380 case 6: /* Address Granularity */
382 Descriptor->Address64.Granularity = InitializerOp->Asl.Value.Integer;
383 RsCreateByteField (InitializerOp, ACPI_RESTAG_GRANULARITY,
384 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Granularity));
385 GranOp = InitializerOp;
388 case 7: /* Min Address */
390 Descriptor->Address64.Minimum = InitializerOp->Asl.Value.Integer;
391 RsCreateByteField (InitializerOp, ACPI_RESTAG_MINADDR,
392 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Minimum));
393 MinOp = InitializerOp;
396 case 8: /* Max Address */
398 Descriptor->Address64.Maximum = InitializerOp->Asl.Value.Integer;
399 RsCreateByteField (InitializerOp, ACPI_RESTAG_MAXADDR,
400 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Maximum));
401 MaxOp = InitializerOp;
404 case 9: /* Translation Offset */
406 Descriptor->Address64.TranslationOffset = InitializerOp->Asl.Value.Integer;
407 RsCreateByteField (InitializerOp, ACPI_RESTAG_TRANSLATION,
408 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.TranslationOffset));
411 case 10: /* Address Length */
413 Descriptor->Address64.AddressLength = InitializerOp->Asl.Value.Integer;
414 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
415 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.AddressLength));
416 LengthOp = InitializerOp;
419 case 11: /* ResSourceIndex [Optional Field - BYTE] */
421 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
423 OptionalFields[0] = (UINT8) InitializerOp->Asl.Value.Integer;
425 Descriptor->Address64.ResourceLength++;
426 ResSourceIndex = TRUE;
430 case 12: /* ResSource [Optional Field - STRING] */
432 if ((InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG) &&
433 (InitializerOp->Asl.Value.String))
437 Descriptor->Address64.ResourceLength = (UINT16)
438 (Descriptor->Address64.ResourceLength + StringLength);
441 &OptionalFields[OptionIndex],
442 InitializerOp->Asl.Value.String);
444 /* ResourceSourceIndex must also be valid */
448 AslError (ASL_ERROR, ASL_MSG_RESOURCE_INDEX,
449 InitializerOp, NULL);
456 * Not a valid ResourceSource, ResourceSourceIndex must also
459 else if (ResSourceIndex)
461 AslError (ASL_ERROR, ASL_MSG_RESOURCE_SOURCE,
462 InitializerOp, NULL);
467 case 13: /* ResourceTag */
469 UtAttachNamepathToOwner (Op, InitializerOp);
473 case 14: /* Address Range */
475 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 3, 0);
476 RsCreateBitField (InitializerOp, ACPI_RESTAG_MEMATTRIBUTES,
477 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 3);
482 RsSetFlagBits (&Descriptor->Address64.SpecificFlags, InitializerOp, 5, 0);
483 RsCreateBitField (InitializerOp, ACPI_RESTAG_TYPE,
484 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.SpecificFlags), 5);
489 AslError (ASL_ERROR, ASL_MSG_RESOURCE_LIST, InitializerOp, NULL);
493 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
496 /* Validate the Min/Max/Len/Gran values */
498 RsLargeAddressCheck (
499 Descriptor->Address64.Minimum,
500 Descriptor->Address64.Maximum,
501 Descriptor->Address64.AddressLength,
502 Descriptor->Address64.Granularity,
503 Descriptor->Address64.Flags,
504 MinOp, MaxOp, LengthOp, GranOp, Op);
506 Rnode->BufferLength = sizeof (AML_RESOURCE_ADDRESS64) +
507 OptionIndex + StringLength;
512 /*******************************************************************************
514 * FUNCTION: RsDoQwordSpaceDescriptor
516 * PARAMETERS: Op - Parent resource descriptor parse node
517 * CurrentByteOffset - Offset into the resource template AML
518 * buffer (to track references to the desc)
520 * RETURN: Completed resource node
522 * DESCRIPTION: Construct a long "QwordSpace" descriptor
524 ******************************************************************************/
527 RsDoQwordSpaceDescriptor (
528 ACPI_PARSE_OBJECT *Op,
529 UINT32 CurrentByteOffset)
531 AML_RESOURCE *Descriptor;
532 ACPI_PARSE_OBJECT *InitializerOp;
533 ACPI_PARSE_OBJECT *MinOp = NULL;
534 ACPI_PARSE_OBJECT *MaxOp = NULL;
535 ACPI_PARSE_OBJECT *LengthOp = NULL;
536 ACPI_PARSE_OBJECT *GranOp = NULL;
537 ASL_RESOURCE_NODE *Rnode;
538 UINT8 *OptionalFields;
539 UINT16 StringLength = 0;
540 UINT32 OptionIndex = 0;
542 BOOLEAN ResSourceIndex = FALSE;
545 InitializerOp = Op->Asl.Child;
546 StringLength = RsGetStringDataLength (InitializerOp);
548 Rnode = RsAllocateResourceNode (
549 sizeof (AML_RESOURCE_ADDRESS64) + 1 + StringLength);
551 Descriptor = Rnode->Buffer;
552 Descriptor->Address64.DescriptorType = ACPI_RESOURCE_NAME_ADDRESS64;
555 * Initial descriptor length -- may be enlarged if there are
556 * optional fields present
558 OptionalFields = ((UINT8 *) Descriptor) + sizeof (AML_RESOURCE_ADDRESS64);
559 Descriptor->Address64.ResourceLength = (UINT16)
560 (sizeof (AML_RESOURCE_ADDRESS64) -
561 sizeof (AML_RESOURCE_LARGE_HEADER));
563 /* Process all child initialization nodes */
565 for (i = 0; InitializerOp; i++)
569 case 0: /* Resource Type */
571 Descriptor->Address64.ResourceType =
572 (UINT8) InitializerOp->Asl.Value.Integer;
575 case 1: /* Resource Usage */
577 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 0, 1);
580 case 2: /* DecodeType */
582 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 1, 0);
583 RsCreateBitField (InitializerOp, ACPI_RESTAG_DECODE,
584 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 1);
587 case 3: /* MinType */
589 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 2, 0);
590 RsCreateBitField (InitializerOp, ACPI_RESTAG_MINTYPE,
591 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 2);
594 case 4: /* MaxType */
596 RsSetFlagBits (&Descriptor->Address64.Flags, InitializerOp, 3, 0);
597 RsCreateBitField (InitializerOp, ACPI_RESTAG_MAXTYPE,
598 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Flags), 3);
601 case 5: /* Type-Specific flags */
603 Descriptor->Address64.SpecificFlags =
604 (UINT8) InitializerOp->Asl.Value.Integer;
607 case 6: /* Address Granularity */
609 Descriptor->Address64.Granularity = InitializerOp->Asl.Value.Integer;
610 RsCreateByteField (InitializerOp, ACPI_RESTAG_GRANULARITY,
611 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Granularity));
612 GranOp = InitializerOp;
615 case 7: /* Min Address */
617 Descriptor->Address64.Minimum = InitializerOp->Asl.Value.Integer;
618 RsCreateByteField (InitializerOp, ACPI_RESTAG_MINADDR,
619 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Minimum));
620 MinOp = InitializerOp;
623 case 8: /* Max Address */
625 Descriptor->Address64.Maximum = InitializerOp->Asl.Value.Integer;
626 RsCreateByteField (InitializerOp, ACPI_RESTAG_MAXADDR,
627 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.Maximum));
628 MaxOp = InitializerOp;
631 case 9: /* Translation Offset */
633 Descriptor->Address64.TranslationOffset = InitializerOp->Asl.Value.Integer;
634 RsCreateByteField (InitializerOp, ACPI_RESTAG_TRANSLATION,
635 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.TranslationOffset));
638 case 10: /* Address Length */
640 Descriptor->Address64.AddressLength = InitializerOp->Asl.Value.Integer;
641 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
642 CurrentByteOffset + ASL_RESDESC_OFFSET (Address64.AddressLength));
643 LengthOp = InitializerOp;
646 case 11: /* ResSourceIndex [Optional Field - BYTE] */
648 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
650 OptionalFields[0] = (UINT8) InitializerOp->Asl.Value.Integer;
652 Descriptor->Address64.ResourceLength++;
653 ResSourceIndex = TRUE;
657 case 12: /* ResSource [Optional Field - STRING] */
659 if ((InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG) &&
660 (InitializerOp->Asl.Value.String))
664 Descriptor->Address64.ResourceLength = (UINT16)
665 (Descriptor->Address64.ResourceLength + StringLength);
668 &OptionalFields[OptionIndex],
669 InitializerOp->Asl.Value.String);
671 /* ResourceSourceIndex must also be valid */
675 AslError (ASL_ERROR, ASL_MSG_RESOURCE_INDEX,
676 InitializerOp, NULL);
683 * Not a valid ResourceSource, ResourceSourceIndex must also
686 else if (ResSourceIndex)
688 AslError (ASL_ERROR, ASL_MSG_RESOURCE_SOURCE,
689 InitializerOp, NULL);
694 case 13: /* ResourceTag */
696 UtAttachNamepathToOwner (Op, InitializerOp);
701 AslError (ASL_ERROR, ASL_MSG_RESOURCE_LIST, InitializerOp, NULL);
705 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
708 /* Validate the Min/Max/Len/Gran values */
710 RsLargeAddressCheck (
711 Descriptor->Address64.Minimum,
712 Descriptor->Address64.Maximum,
713 Descriptor->Address64.AddressLength,
714 Descriptor->Address64.Granularity,
715 Descriptor->Address64.Flags,
716 MinOp, MaxOp, LengthOp, GranOp, Op);
718 Rnode->BufferLength = sizeof (AML_RESOURCE_ADDRESS64) +
719 OptionIndex + StringLength;