2 /******************************************************************************
4 * Module Name: aslrestype2w - Large Word 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 ("aslrestype2w")
53 * This module contains the Word (16-bit) address space descriptors:
60 /*******************************************************************************
62 * FUNCTION: RsDoWordIoDescriptor
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 "WordIO" descriptor
72 ******************************************************************************/
75 RsDoWordIoDescriptor (
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_ADDRESS16) + 1 + StringLength);
99 Descriptor = Rnode->Buffer;
100 Descriptor->Address16.DescriptorType = ACPI_RESOURCE_NAME_ADDRESS16;
101 Descriptor->Address16.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_ADDRESS16);
108 Descriptor->Address16.ResourceLength = (UINT16)
109 (sizeof (AML_RESOURCE_ADDRESS16) -
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->Address16.Flags, InitializerOp, 0, 1);
123 case 1: /* MinType */
125 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 2, 0);
126 RsCreateBitField (InitializerOp, ACPI_RESTAG_MINTYPE,
127 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 2);
130 case 2: /* MaxType */
132 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 3, 0);
133 RsCreateBitField (InitializerOp, ACPI_RESTAG_MAXTYPE,
134 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 3);
137 case 3: /* DecodeType */
139 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 1, 0);
140 RsCreateBitField (InitializerOp, ACPI_RESTAG_DECODE,
141 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 1);
144 case 4: /* Range Type */
146 RsSetFlagBits (&Descriptor->Address16.SpecificFlags, InitializerOp, 0, 3);
147 RsCreateBitField (InitializerOp, ACPI_RESTAG_RANGETYPE,
148 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.SpecificFlags), 0);
151 case 5: /* Address Granularity */
153 Descriptor->Address16.Granularity = (UINT16) InitializerOp->Asl.Value.Integer;
154 RsCreateByteField (InitializerOp, ACPI_RESTAG_GRANULARITY,
155 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Granularity));
156 GranOp = InitializerOp;
159 case 6: /* Address Min */
161 Descriptor->Address16.Minimum = (UINT16) InitializerOp->Asl.Value.Integer;
162 RsCreateByteField (InitializerOp, ACPI_RESTAG_MINADDR,
163 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Minimum));
164 MinOp = InitializerOp;
167 case 7: /* Address Max */
169 Descriptor->Address16.Maximum = (UINT16) InitializerOp->Asl.Value.Integer;
170 RsCreateByteField (InitializerOp, ACPI_RESTAG_MAXADDR,
171 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Maximum));
172 MaxOp = InitializerOp;
175 case 8: /* Translation Offset */
177 Descriptor->Address16.TranslationOffset = (UINT16) InitializerOp->Asl.Value.Integer;
178 RsCreateByteField (InitializerOp, ACPI_RESTAG_TRANSLATION,
179 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.TranslationOffset));
182 case 9: /* Address Length */
184 Descriptor->Address16.AddressLength = (UINT16) InitializerOp->Asl.Value.Integer;
185 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
186 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.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->Address16.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->Address16.ResourceLength = (UINT16)
209 (Descriptor->Address16.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->Address16.SpecificFlags, InitializerOp, 4, 0);
246 RsCreateBitField (InitializerOp, ACPI_RESTAG_TYPE,
247 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.SpecificFlags), 4);
250 case 14: /* Translation Type */
252 RsSetFlagBits (&Descriptor->Address16.SpecificFlags, InitializerOp, 5, 0);
253 RsCreateBitField (InitializerOp, ACPI_RESTAG_TRANSTYPE,
254 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.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 (UINT64) Descriptor->Address16.Minimum,
270 (UINT64) Descriptor->Address16.Maximum,
271 (UINT64) Descriptor->Address16.AddressLength,
272 (UINT64) Descriptor->Address16.Granularity,
273 Descriptor->Address16.Flags,
274 MinOp, MaxOp, LengthOp, GranOp, Op);
276 Rnode->BufferLength = sizeof (AML_RESOURCE_ADDRESS16) +
277 OptionIndex + StringLength;
282 /*******************************************************************************
284 * FUNCTION: RsDoWordBusNumberDescriptor
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 "WordBusNumber" descriptor
294 ******************************************************************************/
297 RsDoWordBusNumberDescriptor (
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_ADDRESS16) + 1 + StringLength);
321 Descriptor = Rnode->Buffer;
322 Descriptor->Address16.DescriptorType = ACPI_RESOURCE_NAME_ADDRESS16;
323 Descriptor->Address16.ResourceType = ACPI_ADDRESS_TYPE_BUS_NUMBER_RANGE;
326 * Initial descriptor length -- may be enlarged if there are
327 * optional fields present
329 OptionalFields = ((UINT8 *) Descriptor) + sizeof (AML_RESOURCE_ADDRESS16);
330 Descriptor->Address16.ResourceLength = (UINT16)
331 (sizeof (AML_RESOURCE_ADDRESS16) -
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->Address16.Flags, InitializerOp, 0, 1);
345 case 1: /* MinType */
347 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 2, 0);
348 RsCreateBitField (InitializerOp, ACPI_RESTAG_MINTYPE,
349 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 2);
352 case 2: /* MaxType */
354 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 3, 0);
355 RsCreateBitField (InitializerOp, ACPI_RESTAG_MAXTYPE,
356 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 3);
359 case 3: /* DecodeType */
361 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 1, 0);
362 RsCreateBitField (InitializerOp, ACPI_RESTAG_DECODE,
363 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 1);
366 case 4: /* Address Granularity */
368 Descriptor->Address16.Granularity =
369 (UINT16) InitializerOp->Asl.Value.Integer;
370 RsCreateByteField (InitializerOp, ACPI_RESTAG_GRANULARITY,
371 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Granularity));
372 GranOp = InitializerOp;
375 case 5: /* Min Address */
377 Descriptor->Address16.Minimum =
378 (UINT16) InitializerOp->Asl.Value.Integer;
379 RsCreateByteField (InitializerOp, ACPI_RESTAG_MINADDR,
380 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Minimum));
381 MinOp = InitializerOp;
384 case 6: /* Max Address */
386 Descriptor->Address16.Maximum =
387 (UINT16) InitializerOp->Asl.Value.Integer;
388 RsCreateByteField (InitializerOp, ACPI_RESTAG_MAXADDR,
389 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Maximum));
390 MaxOp = InitializerOp;
393 case 7: /* Translation Offset */
395 Descriptor->Address16.TranslationOffset =
396 (UINT16) InitializerOp->Asl.Value.Integer;
397 RsCreateByteField (InitializerOp, ACPI_RESTAG_TRANSLATION,
398 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.TranslationOffset));
401 case 8: /* Address Length */
403 Descriptor->Address16.AddressLength =
404 (UINT16) InitializerOp->Asl.Value.Integer;
405 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
406 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.AddressLength));
407 LengthOp = InitializerOp;
410 case 9: /* ResSourceIndex [Optional Field - BYTE] */
412 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
414 OptionalFields[0] = (UINT8) InitializerOp->Asl.Value.Integer;
416 Descriptor->Address16.ResourceLength++;
417 ResSourceIndex = TRUE;
421 case 10: /* ResSource [Optional Field - STRING] */
423 if ((InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG) &&
424 (InitializerOp->Asl.Value.String))
428 Descriptor->Address16.ResourceLength = (UINT16)
429 (Descriptor->Address16.ResourceLength + StringLength);
432 &OptionalFields[OptionIndex],
433 InitializerOp->Asl.Value.String);
435 /* ResourceSourceIndex must also be valid */
439 AslError (ASL_ERROR, ASL_MSG_RESOURCE_INDEX,
440 InitializerOp, NULL);
447 * Not a valid ResourceSource, ResourceSourceIndex must also
450 else if (ResSourceIndex)
452 AslError (ASL_ERROR, ASL_MSG_RESOURCE_SOURCE,
453 InitializerOp, NULL);
458 case 11: /* ResourceTag */
460 UtAttachNamepathToOwner (Op, InitializerOp);
465 AslError (ASL_ERROR, ASL_MSG_RESOURCE_LIST, InitializerOp, NULL);
469 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
472 /* Validate the Min/Max/Len/Gran values */
474 RsLargeAddressCheck (
475 (UINT64) Descriptor->Address16.Minimum,
476 (UINT64) Descriptor->Address16.Maximum,
477 (UINT64) Descriptor->Address16.AddressLength,
478 (UINT64) Descriptor->Address16.Granularity,
479 Descriptor->Address16.Flags,
480 MinOp, MaxOp, LengthOp, GranOp, Op);
482 Rnode->BufferLength = sizeof (AML_RESOURCE_ADDRESS16) +
483 OptionIndex + StringLength;
488 /*******************************************************************************
490 * FUNCTION: RsDoWordSpaceDescriptor
492 * PARAMETERS: Op - Parent resource descriptor parse node
493 * CurrentByteOffset - Offset into the resource template AML
494 * buffer (to track references to the desc)
496 * RETURN: Completed resource node
498 * DESCRIPTION: Construct a long "WordSpace" descriptor
500 ******************************************************************************/
503 RsDoWordSpaceDescriptor (
504 ACPI_PARSE_OBJECT *Op,
505 UINT32 CurrentByteOffset)
507 AML_RESOURCE *Descriptor;
508 ACPI_PARSE_OBJECT *InitializerOp;
509 ACPI_PARSE_OBJECT *MinOp = NULL;
510 ACPI_PARSE_OBJECT *MaxOp = NULL;
511 ACPI_PARSE_OBJECT *LengthOp = NULL;
512 ACPI_PARSE_OBJECT *GranOp = NULL;
513 ASL_RESOURCE_NODE *Rnode;
514 UINT8 *OptionalFields;
515 UINT16 StringLength = 0;
516 UINT32 OptionIndex = 0;
518 BOOLEAN ResSourceIndex = FALSE;
521 InitializerOp = Op->Asl.Child;
522 StringLength = RsGetStringDataLength (InitializerOp);
524 Rnode = RsAllocateResourceNode (
525 sizeof (AML_RESOURCE_ADDRESS16) + 1 + StringLength);
527 Descriptor = Rnode->Buffer;
528 Descriptor->Address16.DescriptorType = ACPI_RESOURCE_NAME_ADDRESS16;
531 * Initial descriptor length -- may be enlarged if there are
532 * optional fields present
534 OptionalFields = ((UINT8 *) Descriptor) + sizeof (AML_RESOURCE_ADDRESS16);
535 Descriptor->Address16.ResourceLength = (UINT16)
536 (sizeof (AML_RESOURCE_ADDRESS16) -
537 sizeof (AML_RESOURCE_LARGE_HEADER));
539 /* Process all child initialization nodes */
541 for (i = 0; InitializerOp; i++)
545 case 0: /* Resource Type */
547 Descriptor->Address16.ResourceType =
548 (UINT8) InitializerOp->Asl.Value.Integer;
551 case 1: /* Resource Usage */
553 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 0, 1);
556 case 2: /* DecodeType */
558 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 1, 0);
559 RsCreateBitField (InitializerOp, ACPI_RESTAG_DECODE,
560 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 1);
563 case 3: /* MinType */
565 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 2, 0);
566 RsCreateBitField (InitializerOp, ACPI_RESTAG_MINTYPE,
567 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 2);
570 case 4: /* MaxType */
572 RsSetFlagBits (&Descriptor->Address16.Flags, InitializerOp, 3, 0);
573 RsCreateBitField (InitializerOp, ACPI_RESTAG_MAXTYPE,
574 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Flags), 3);
577 case 5: /* Type-Specific flags */
579 Descriptor->Address16.SpecificFlags =
580 (UINT8) InitializerOp->Asl.Value.Integer;
583 case 6: /* Address Granularity */
585 Descriptor->Address16.Granularity =
586 (UINT16) InitializerOp->Asl.Value.Integer;
587 RsCreateByteField (InitializerOp, ACPI_RESTAG_GRANULARITY,
588 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Granularity));
589 GranOp = InitializerOp;
592 case 7: /* Min Address */
594 Descriptor->Address16.Minimum =
595 (UINT16) InitializerOp->Asl.Value.Integer;
596 RsCreateByteField (InitializerOp, ACPI_RESTAG_MINADDR,
597 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Minimum));
598 MinOp = InitializerOp;
601 case 8: /* Max Address */
603 Descriptor->Address16.Maximum =
604 (UINT16) InitializerOp->Asl.Value.Integer;
605 RsCreateByteField (InitializerOp, ACPI_RESTAG_MAXADDR,
606 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.Maximum));
607 MaxOp = InitializerOp;
610 case 9: /* Translation Offset */
612 Descriptor->Address16.TranslationOffset =
613 (UINT16) InitializerOp->Asl.Value.Integer;
614 RsCreateByteField (InitializerOp, ACPI_RESTAG_TRANSLATION,
615 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.TranslationOffset));
618 case 10: /* Address Length */
620 Descriptor->Address16.AddressLength =
621 (UINT16) InitializerOp->Asl.Value.Integer;
622 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
623 CurrentByteOffset + ASL_RESDESC_OFFSET (Address16.AddressLength));
624 LengthOp = InitializerOp;
627 case 11: /* ResSourceIndex [Optional Field - BYTE] */
629 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
631 OptionalFields[0] = (UINT8) InitializerOp->Asl.Value.Integer;
633 Descriptor->Address16.ResourceLength++;
634 ResSourceIndex = TRUE;
638 case 12: /* ResSource [Optional Field - STRING] */
640 if ((InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG) &&
641 (InitializerOp->Asl.Value.String))
645 Descriptor->Address16.ResourceLength = (UINT16)
646 (Descriptor->Address16.ResourceLength + StringLength);
649 &OptionalFields[OptionIndex],
650 InitializerOp->Asl.Value.String);
652 /* ResourceSourceIndex must also be valid */
656 AslError (ASL_ERROR, ASL_MSG_RESOURCE_INDEX,
657 InitializerOp, NULL);
664 * Not a valid ResourceSource, ResourceSourceIndex must also
667 else if (ResSourceIndex)
669 AslError (ASL_ERROR, ASL_MSG_RESOURCE_SOURCE,
670 InitializerOp, NULL);
675 case 13: /* ResourceTag */
677 UtAttachNamepathToOwner (Op, InitializerOp);
682 AslError (ASL_ERROR, ASL_MSG_RESOURCE_LIST, InitializerOp, NULL);
686 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
689 /* Validate the Min/Max/Len/Gran values */
691 RsLargeAddressCheck (
692 (UINT64) Descriptor->Address16.Minimum,
693 (UINT64) Descriptor->Address16.Maximum,
694 (UINT64) Descriptor->Address16.AddressLength,
695 (UINT64) Descriptor->Address16.Granularity,
696 Descriptor->Address16.Flags,
697 MinOp, MaxOp, LengthOp, GranOp, Op);
699 Rnode->BufferLength = sizeof (AML_RESOURCE_ADDRESS16) +
700 OptionIndex + StringLength;