1 /******************************************************************************
3 * Module Name: aslrestype2s - Serial Large resource descriptors
5 *****************************************************************************/
8 * Copyright (C) 2000 - 2013, Intel Corp.
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
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.
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.
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.
45 #include <contrib/dev/acpica/compiler/aslcompiler.h>
46 #include "aslcompiler.y.h"
47 #include <contrib/dev/acpica/include/amlcode.h>
49 #define _COMPONENT ACPI_COMPILER
50 ACPI_MODULE_NAME ("aslrestype2s")
54 RsGetBufferDataLength (
55 ACPI_PARSE_OBJECT *InitializerOp);
58 RsGetInterruptDataLength (
59 ACPI_PARSE_OBJECT *InitializerOp);
63 ACPI_PARSE_OBJECT *InitializerOp,
65 ACPI_SIZE DescriptorOffset);
68 * This module contains descriptors for serial buses and GPIO:
78 /*******************************************************************************
80 * FUNCTION: RsGetBufferDataLength
82 * PARAMETERS: InitializerOp - Current parse op, start of the resource
85 * RETURN: Length of the data buffer
87 * DESCRIPTION: Get the length of a RawDataBuffer, used for vendor data.
89 ******************************************************************************/
92 RsGetBufferDataLength (
93 ACPI_PARSE_OBJECT *InitializerOp)
95 UINT16 ExtraDataSize = 0;
96 ACPI_PARSE_OBJECT *DataList;
99 /* Find the byte-initializer list */
101 while (InitializerOp)
103 if (InitializerOp->Asl.ParseOpcode == PARSEOP_DATABUFFER)
105 /* First child is the optional length (ignore it here) */
107 DataList = InitializerOp->Asl.Child;
108 DataList = ASL_GET_PEER_NODE (DataList);
110 /* Count the data items (each one is a byte of data) */
115 DataList = ASL_GET_PEER_NODE (DataList);
118 return (ExtraDataSize);
121 InitializerOp = ASL_GET_PEER_NODE (InitializerOp);
124 return (ExtraDataSize);
128 /*******************************************************************************
130 * FUNCTION: RsGetInterruptDataLength
132 * PARAMETERS: InitializerOp - Current parse op, start of the resource
135 * RETURN: Length of the interrupt data list
137 * DESCRIPTION: Get the length of a list of interrupt DWORDs for the GPIO
140 ******************************************************************************/
143 RsGetInterruptDataLength (
144 ACPI_PARSE_OBJECT *InitializerOp)
146 UINT16 InterruptLength;
150 /* Count the interrupt numbers */
153 for (i = 0; InitializerOp; i++)
155 InitializerOp = ASL_GET_PEER_NODE (InitializerOp);
157 /* Interrupt list starts at offset 10 (Gpio descriptors) */
161 InterruptLength += 2;
165 return (InterruptLength);
169 /*******************************************************************************
171 * FUNCTION: RsGetVendorData
173 * PARAMETERS: InitializerOp - Current parse op, start of the resource
175 * VendorData - Where the vendor data is returned
176 * DescriptorOffset - Where vendor data begins in descriptor
178 * RETURN: TRUE if valid vendor data was returned, FALSE otherwise.
180 * DESCRIPTION: Extract the vendor data and construct a vendor data buffer.
182 ******************************************************************************/
186 ACPI_PARSE_OBJECT *InitializerOp,
188 ACPI_SIZE DescriptorOffset)
190 ACPI_PARSE_OBJECT *BufferOp;
191 UINT32 SpecifiedLength = ACPI_UINT32_MAX;
192 UINT16 ActualLength = 0;
195 /* Vendor Data field is always optional */
197 if (InitializerOp->Asl.ParseOpcode == PARSEOP_DEFAULT_ARG)
202 BufferOp = InitializerOp->Asl.Child;
205 AslError (ASL_ERROR, ASL_MSG_SYNTAX, InitializerOp, "");
209 /* First child is the optional buffer length (WORD) */
211 if (BufferOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
213 SpecifiedLength = (UINT16) BufferOp->Asl.Value.Integer;
216 /* Insert field tag _VEN */
218 RsCreateByteField (InitializerOp, ACPI_RESTAG_VENDORDATA,
219 (UINT16) DescriptorOffset);
221 /* Walk the list of buffer initializers (each is one byte) */
223 BufferOp = RsCompleteNodeAndGetNext (BufferOp);
224 if (BufferOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
228 *VendorData = (UINT8) BufferOp->Asl.Value.Integer;
231 BufferOp = RsCompleteNodeAndGetNext (BufferOp);
235 /* Length validation. Buffer cannot be of zero length */
237 if ((SpecifiedLength == 0) ||
238 ((SpecifiedLength == ACPI_UINT32_MAX) && (ActualLength == 0)))
240 AslError (ASL_ERROR, ASL_MSG_BUFFER_LENGTH, InitializerOp, NULL);
244 if (SpecifiedLength != ACPI_UINT32_MAX)
246 /* ActualLength > SpecifiedLength -> error */
248 if (ActualLength > SpecifiedLength)
250 AslError (ASL_ERROR, ASL_MSG_LIST_LENGTH_LONG, InitializerOp, NULL);
254 /* ActualLength < SpecifiedLength -> remark */
256 else if (ActualLength < SpecifiedLength)
258 AslError (ASL_REMARK, ASL_MSG_LIST_LENGTH_SHORT, InitializerOp, NULL);
267 /*******************************************************************************
269 * FUNCTION: RsDoGpioIntDescriptor
271 * PARAMETERS: Op - Parent resource descriptor parse node
272 * CurrentByteOffset - Offset into the resource template AML
273 * buffer (to track references to the desc)
275 * RETURN: Completed resource node
277 * DESCRIPTION: Construct a long "GpioInt" descriptor
279 ******************************************************************************/
282 RsDoGpioIntDescriptor (
283 ACPI_PARSE_OBJECT *Op,
284 UINT32 CurrentByteOffset)
286 AML_RESOURCE *Descriptor;
287 ACPI_PARSE_OBJECT *InitializerOp;
288 ASL_RESOURCE_NODE *Rnode;
289 char *ResourceSource = NULL;
290 UINT8 *VendorData = NULL;
291 UINT16 *InterruptList = NULL;
292 UINT16 ResSourceLength;
294 UINT16 InterruptLength;
295 UINT16 DescriptorSize;
299 InitializerOp = Op->Asl.Child;
302 * Calculate lengths for fields that have variable length:
303 * 1) Resource Source string
304 * 2) Vendor Data buffer
305 * 3) PIN (interrupt) list
307 ResSourceLength = RsGetStringDataLength (InitializerOp);
308 VendorLength = RsGetBufferDataLength (InitializerOp);
309 InterruptLength = RsGetInterruptDataLength (InitializerOp);
311 DescriptorSize = ACPI_AML_SIZE_LARGE (AML_RESOURCE_GPIO) +
312 ResSourceLength + VendorLength + InterruptLength;
314 /* Allocate the local resource node and initialize */
316 Rnode = RsAllocateResourceNode (DescriptorSize + sizeof (AML_RESOURCE_LARGE_HEADER));
318 Descriptor = Rnode->Buffer;
319 Descriptor->Gpio.ResourceLength = DescriptorSize;
320 Descriptor->Gpio.DescriptorType = ACPI_RESOURCE_NAME_GPIO;
321 Descriptor->Gpio.RevisionId = AML_RESOURCE_GPIO_REVISION;
322 Descriptor->Gpio.ConnectionType = AML_RESOURCE_GPIO_TYPE_INT;
324 /* Build pointers to optional areas */
326 InterruptList = ACPI_ADD_PTR (UINT16, Descriptor, sizeof (AML_RESOURCE_GPIO));
327 ResourceSource = ACPI_ADD_PTR (char, InterruptList, InterruptLength);
328 VendorData = ACPI_ADD_PTR (UINT8, ResourceSource, ResSourceLength);
330 /* Setup offsets within the descriptor */
332 Descriptor->Gpio.PinTableOffset = (UINT16)
333 ACPI_PTR_DIFF (InterruptList, Descriptor);
335 Descriptor->Gpio.ResSourceOffset = (UINT16)
336 ACPI_PTR_DIFF (ResourceSource, Descriptor);
338 DbgPrint (ASL_DEBUG_OUTPUT,
339 "%16s - Actual: %.2X, Base: %.2X, ResLen: %.2X, VendLen: %.2X, IntLen: %.2X\n",
340 "GpioInt", Descriptor->Gpio.ResourceLength, (UINT16) sizeof (AML_RESOURCE_GPIO),
341 ResSourceLength, VendorLength, InterruptLength);
343 /* Process all child initialization nodes */
345 for (i = 0; InitializerOp; i++)
349 case 0: /* Interrupt Mode - edge/level [Flag] (_MOD) */
351 RsSetFlagBits16 (&Descriptor->Gpio.IntFlags, InitializerOp, 0, 0);
352 RsCreateBitField (InitializerOp, ACPI_RESTAG_MODE,
353 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.IntFlags), 0);
356 case 1: /* Interrupt Polarity - Active high/low [Flags] (_POL) */
358 RsSetFlagBits16 (&Descriptor->Gpio.IntFlags, InitializerOp, 1, 0);
359 RsCreateMultiBitField (InitializerOp, ACPI_RESTAG_POLARITY,
360 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.IntFlags), 1, 2);
363 case 2: /* Share Type - Default: exclusive (0) [Flags] (_SHR) */
365 RsSetFlagBits16 (&Descriptor->Gpio.IntFlags, InitializerOp, 3, 0);
366 RsCreateMultiBitField (InitializerOp, ACPI_RESTAG_INTERRUPTSHARE,
367 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.IntFlags), 3, 2);
370 case 3: /* Pin Config [BYTE] (_PPI) */
372 Descriptor->Gpio.PinConfig = (UINT8) InitializerOp->Asl.Value.Integer;
373 RsCreateByteField (InitializerOp, ACPI_RESTAG_PINCONFIG,
374 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.PinConfig));
377 case 4: /* Debounce Timeout [WORD] (_DBT) */
379 Descriptor->Gpio.DebounceTimeout = (UINT16) InitializerOp->Asl.Value.Integer;
380 RsCreateWordField (InitializerOp, ACPI_RESTAG_DEBOUNCETIME,
381 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.DebounceTimeout));
384 case 5: /* ResSource [Optional Field - STRING] */
388 /* Copy string to the descriptor */
390 strcpy (ResourceSource,
391 InitializerOp->Asl.Value.String);
395 case 6: /* Resource Index */
397 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
399 Descriptor->Gpio.ResSourceIndex = (UINT8) InitializerOp->Asl.Value.Integer;
403 case 7: /* Resource Usage (consumer/producer) */
405 RsSetFlagBits16 (&Descriptor->Gpio.Flags, InitializerOp, 0, 1);
408 case 8: /* Resource Tag (Descriptor Name) */
410 UtAttachNamepathToOwner (Op, InitializerOp);
413 case 9: /* Vendor Data (Optional - Buffer of BYTEs) (_VEN) */
416 * Always set the VendorOffset even if there is no Vendor Data.
417 * This field is required in order to calculate the length
418 * of the ResourceSource at runtime.
420 Descriptor->Gpio.VendorOffset = (UINT16)
421 ACPI_PTR_DIFF (VendorData, Descriptor);
423 if (RsGetVendorData (InitializerOp, VendorData,
424 (CurrentByteOffset + Descriptor->Gpio.VendorOffset)))
426 Descriptor->Gpio.VendorLength = VendorLength;
432 * PINs come through here, repeatedly. Each PIN must be a DWORD.
433 * NOTE: there is no "length" field for this, so from ACPI spec:
434 * The number of pins in the table can be calculated from:
435 * PinCount = (Resource Source Name Offset - Pin Table Offset) / 2
436 * (implies resource source must immediately follow the pin list.)
439 *InterruptList = (UINT16) InitializerOp->Asl.Value.Integer;
442 /* Case 10: First interrupt number in list */
446 if (InitializerOp->Asl.ParseOpcode == PARSEOP_DEFAULT_ARG)
448 /* Must be at least one interrupt */
450 AslError (ASL_ERROR, ASL_MSG_EX_INTERRUPT_LIST_MIN,
451 InitializerOp, NULL);
454 /* Check now for duplicates in list */
456 RsCheckListForDuplicates (InitializerOp);
458 /* Create a named field at the start of the list */
460 RsCreateDwordField (InitializerOp, ACPI_RESTAG_PIN,
461 CurrentByteOffset + Descriptor->Gpio.PinTableOffset);
466 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
473 /*******************************************************************************
475 * FUNCTION: RsDoGpioIoDescriptor
477 * PARAMETERS: Op - Parent resource descriptor parse node
478 * CurrentByteOffset - Offset into the resource template AML
479 * buffer (to track references to the desc)
481 * RETURN: Completed resource node
483 * DESCRIPTION: Construct a long "GpioIo" descriptor
485 ******************************************************************************/
488 RsDoGpioIoDescriptor (
489 ACPI_PARSE_OBJECT *Op,
490 UINT32 CurrentByteOffset)
492 AML_RESOURCE *Descriptor;
493 ACPI_PARSE_OBJECT *InitializerOp;
494 ASL_RESOURCE_NODE *Rnode;
495 char *ResourceSource = NULL;
496 UINT8 *VendorData = NULL;
497 UINT16 *InterruptList = NULL;
498 UINT16 ResSourceLength;
500 UINT16 InterruptLength;
501 UINT16 DescriptorSize;
505 InitializerOp = Op->Asl.Child;
508 * Calculate lengths for fields that have variable length:
509 * 1) Resource Source string
510 * 2) Vendor Data buffer
511 * 3) PIN (interrupt) list
513 ResSourceLength = RsGetStringDataLength (InitializerOp);
514 VendorLength = RsGetBufferDataLength (InitializerOp);
515 InterruptLength = RsGetInterruptDataLength (InitializerOp);
517 DescriptorSize = ACPI_AML_SIZE_LARGE (AML_RESOURCE_GPIO) +
518 ResSourceLength + VendorLength + InterruptLength;
520 /* Allocate the local resource node and initialize */
522 Rnode = RsAllocateResourceNode (DescriptorSize + sizeof (AML_RESOURCE_LARGE_HEADER));
524 Descriptor = Rnode->Buffer;
525 Descriptor->Gpio.ResourceLength = DescriptorSize;
526 Descriptor->Gpio.DescriptorType = ACPI_RESOURCE_NAME_GPIO;
527 Descriptor->Gpio.RevisionId = AML_RESOURCE_GPIO_REVISION;
528 Descriptor->Gpio.ConnectionType = AML_RESOURCE_GPIO_TYPE_IO;
530 /* Build pointers to optional areas */
532 InterruptList = ACPI_ADD_PTR (UINT16, Descriptor, sizeof (AML_RESOURCE_GPIO));
533 ResourceSource = ACPI_ADD_PTR (char, InterruptList, InterruptLength);
534 VendorData = ACPI_ADD_PTR (UINT8, ResourceSource, ResSourceLength);
536 /* Setup offsets within the descriptor */
538 Descriptor->Gpio.PinTableOffset = (UINT16)
539 ACPI_PTR_DIFF (InterruptList, Descriptor);
541 Descriptor->Gpio.ResSourceOffset = (UINT16)
542 ACPI_PTR_DIFF (ResourceSource, Descriptor);
544 DbgPrint (ASL_DEBUG_OUTPUT,
545 "%16s - Actual: %.2X, Base: %.2X, ResLen: %.2X, VendLen: %.2X, IntLen: %.2X\n",
546 "GpioIo", Descriptor->Gpio.ResourceLength, (UINT16) sizeof (AML_RESOURCE_GPIO),
547 ResSourceLength, VendorLength, InterruptLength);
549 /* Process all child initialization nodes */
551 for (i = 0; InitializerOp; i++)
555 case 0: /* Share Type [Flags] (_SHR) */
557 RsSetFlagBits16 (&Descriptor->Gpio.IntFlags, InitializerOp, 3, 0);
558 RsCreateBitField (InitializerOp, ACPI_RESTAG_INTERRUPTSHARE,
559 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.IntFlags), 3);
562 case 1: /* Pin Config [BYTE] (_PPI) */
564 Descriptor->Gpio.PinConfig = (UINT8) InitializerOp->Asl.Value.Integer;
565 RsCreateByteField (InitializerOp, ACPI_RESTAG_PINCONFIG,
566 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.PinConfig));
569 case 2: /* Debounce Timeout [WORD] (_DBT) */
571 Descriptor->Gpio.DebounceTimeout = (UINT16) InitializerOp->Asl.Value.Integer;
572 RsCreateWordField (InitializerOp, ACPI_RESTAG_DEBOUNCETIME,
573 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.DebounceTimeout));
576 case 3: /* Drive Strength [WORD] (_DRS) */
578 Descriptor->Gpio.DriveStrength = (UINT16) InitializerOp->Asl.Value.Integer;
579 RsCreateWordField (InitializerOp, ACPI_RESTAG_DRIVESTRENGTH,
580 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.DriveStrength));
583 case 4: /* I/O Restriction [Flag] (_IOR) */
585 RsSetFlagBits16 (&Descriptor->Gpio.IntFlags, InitializerOp, 0, 0);
586 RsCreateMultiBitField (InitializerOp, ACPI_RESTAG_IORESTRICTION,
587 CurrentByteOffset + ASL_RESDESC_OFFSET (Gpio.IntFlags), 0, 2);
590 case 5: /* ResSource [Optional Field - STRING] */
594 /* Copy string to the descriptor */
596 strcpy (ResourceSource,
597 InitializerOp->Asl.Value.String);
601 case 6: /* Resource Index */
603 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
605 Descriptor->Gpio.ResSourceIndex = (UINT8) InitializerOp->Asl.Value.Integer;
609 case 7: /* Resource Usage (consumer/producer) */
611 RsSetFlagBits16 (&Descriptor->Gpio.Flags, InitializerOp, 0, 1);
614 case 8: /* Resource Tag (Descriptor Name) */
616 UtAttachNamepathToOwner (Op, InitializerOp);
619 case 9: /* Vendor Data (Optional - Buffer of BYTEs) (_VEN) */
621 * Always set the VendorOffset even if there is no Vendor Data.
622 * This field is required in order to calculate the length
623 * of the ResourceSource at runtime.
625 Descriptor->Gpio.VendorOffset = (UINT16)
626 ACPI_PTR_DIFF (VendorData, Descriptor);
628 if (RsGetVendorData (InitializerOp, VendorData,
629 (CurrentByteOffset + Descriptor->Gpio.VendorOffset)))
631 Descriptor->Gpio.VendorLength = VendorLength;
637 * PINs come through here, repeatedly. Each PIN must be a DWORD.
638 * NOTE: there is no "length" field for this, so from ACPI spec:
639 * The number of pins in the table can be calculated from:
640 * PinCount = (Resource Source Name Offset - Pin Table Offset) / 2
641 * (implies resource source must immediately follow the pin list.)
644 *InterruptList = (UINT16) InitializerOp->Asl.Value.Integer;
647 /* Case 10: First interrupt number in list */
651 if (InitializerOp->Asl.ParseOpcode == PARSEOP_DEFAULT_ARG)
653 /* Must be at least one interrupt */
655 AslError (ASL_ERROR, ASL_MSG_EX_INTERRUPT_LIST_MIN,
656 InitializerOp, NULL);
659 /* Check now for duplicates in list */
661 RsCheckListForDuplicates (InitializerOp);
663 /* Create a named field at the start of the list */
665 RsCreateDwordField (InitializerOp, ACPI_RESTAG_PIN,
666 CurrentByteOffset + Descriptor->Gpio.PinTableOffset);
671 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
678 /*******************************************************************************
680 * FUNCTION: RsDoI2cSerialBusDescriptor
682 * PARAMETERS: Op - Parent resource descriptor parse node
683 * CurrentByteOffset - Offset into the resource template AML
684 * buffer (to track references to the desc)
686 * RETURN: Completed resource node
688 * DESCRIPTION: Construct a long "I2cSerialBus" descriptor
690 ******************************************************************************/
693 RsDoI2cSerialBusDescriptor (
694 ACPI_PARSE_OBJECT *Op,
695 UINT32 CurrentByteOffset)
697 AML_RESOURCE *Descriptor;
698 ACPI_PARSE_OBJECT *InitializerOp;
699 ASL_RESOURCE_NODE *Rnode;
700 char *ResourceSource = NULL;
701 UINT8 *VendorData = NULL;
702 UINT16 ResSourceLength;
704 UINT16 DescriptorSize;
708 InitializerOp = Op->Asl.Child;
711 * Calculate lengths for fields that have variable length:
712 * 1) Resource Source string
713 * 2) Vendor Data buffer
715 ResSourceLength = RsGetStringDataLength (InitializerOp);
716 VendorLength = RsGetBufferDataLength (InitializerOp);
718 DescriptorSize = ACPI_AML_SIZE_LARGE (AML_RESOURCE_I2C_SERIALBUS) +
719 ResSourceLength + VendorLength;
721 /* Allocate the local resource node and initialize */
723 Rnode = RsAllocateResourceNode (DescriptorSize + sizeof (AML_RESOURCE_LARGE_HEADER));
725 Descriptor = Rnode->Buffer;
726 Descriptor->I2cSerialBus.ResourceLength = DescriptorSize;
727 Descriptor->I2cSerialBus.DescriptorType = ACPI_RESOURCE_NAME_SERIAL_BUS;
728 Descriptor->I2cSerialBus.RevisionId = AML_RESOURCE_I2C_REVISION;
729 Descriptor->I2cSerialBus.TypeRevisionId = AML_RESOURCE_I2C_TYPE_REVISION;
730 Descriptor->I2cSerialBus.Type = AML_RESOURCE_I2C_SERIALBUSTYPE;
731 Descriptor->I2cSerialBus.TypeDataLength = AML_RESOURCE_I2C_MIN_DATA_LEN + VendorLength;
733 /* Build pointers to optional areas */
735 VendorData = ACPI_ADD_PTR (UINT8, Descriptor, sizeof (AML_RESOURCE_I2C_SERIALBUS));
736 ResourceSource = ACPI_ADD_PTR (char, VendorData, VendorLength);
738 DbgPrint (ASL_DEBUG_OUTPUT,
739 "%16s - Actual: %.2X, Base: %.2X, ResLen: %.2X, VendLen: %.2X, TypLen: %.2X\n",
740 "I2cSerialBus", Descriptor->I2cSerialBus.ResourceLength,
741 (UINT16) sizeof (AML_RESOURCE_I2C_SERIALBUS), ResSourceLength,
742 VendorLength, Descriptor->I2cSerialBus.TypeDataLength);
744 /* Process all child initialization nodes */
746 for (i = 0; InitializerOp; i++)
750 case 0: /* Slave Address [WORD] (_ADR) */
752 Descriptor->I2cSerialBus.SlaveAddress = (UINT16) InitializerOp->Asl.Value.Integer;
753 RsCreateWordField (InitializerOp, ACPI_RESTAG_ADDRESS,
754 CurrentByteOffset + ASL_RESDESC_OFFSET (I2cSerialBus.SlaveAddress));
757 case 1: /* Slave Mode [Flag] (_SLV) */
759 RsSetFlagBits (&Descriptor->I2cSerialBus.Flags, InitializerOp, 0, 0);
760 RsCreateBitField (InitializerOp, ACPI_RESTAG_SLAVEMODE,
761 CurrentByteOffset + ASL_RESDESC_OFFSET (I2cSerialBus.Flags), 0);
764 case 2: /* Connection Speed [DWORD] (_SPE) */
766 Descriptor->I2cSerialBus.ConnectionSpeed = (UINT32) InitializerOp->Asl.Value.Integer;
767 RsCreateDwordField (InitializerOp, ACPI_RESTAG_SPEED,
768 CurrentByteOffset + ASL_RESDESC_OFFSET (I2cSerialBus.ConnectionSpeed));
771 case 3: /* Addressing Mode [Flag] (_MOD) */
773 RsSetFlagBits16 (&Descriptor->I2cSerialBus.TypeSpecificFlags, InitializerOp, 0, 0);
774 RsCreateBitField (InitializerOp, ACPI_RESTAG_MODE,
775 CurrentByteOffset + ASL_RESDESC_OFFSET (I2cSerialBus.TypeSpecificFlags), 0);
778 case 4: /* ResSource [Optional Field - STRING] */
782 /* Copy string to the descriptor */
784 strcpy (ResourceSource,
785 InitializerOp->Asl.Value.String);
789 case 5: /* Resource Index */
791 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
793 Descriptor->I2cSerialBus.ResSourceIndex = (UINT8) InitializerOp->Asl.Value.Integer;
797 case 6: /* Resource Usage (consumer/producer) */
799 RsSetFlagBits (&Descriptor->I2cSerialBus.Flags, InitializerOp, 1, 1);
802 case 7: /* Resource Tag (Descriptor Name) */
804 UtAttachNamepathToOwner (Op, InitializerOp);
807 case 8: /* Vendor Data (Optional - Buffer of BYTEs) (_VEN) */
809 RsGetVendorData (InitializerOp, VendorData,
810 CurrentByteOffset + sizeof (AML_RESOURCE_I2C_SERIALBUS));
813 default: /* Ignore any extra nodes */
818 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
825 /*******************************************************************************
827 * FUNCTION: RsDoSpiSerialBusDescriptor
829 * PARAMETERS: Op - Parent resource descriptor parse node
830 * CurrentByteOffset - Offset into the resource template AML
831 * buffer (to track references to the desc)
833 * RETURN: Completed resource node
835 * DESCRIPTION: Construct a long "SPI Serial Bus" descriptor
837 ******************************************************************************/
840 RsDoSpiSerialBusDescriptor (
841 ACPI_PARSE_OBJECT *Op,
842 UINT32 CurrentByteOffset)
844 AML_RESOURCE *Descriptor;
845 ACPI_PARSE_OBJECT *InitializerOp;
846 ASL_RESOURCE_NODE *Rnode;
847 char *ResourceSource = NULL;
848 UINT8 *VendorData = NULL;
849 UINT16 ResSourceLength;
851 UINT16 DescriptorSize;
855 InitializerOp = Op->Asl.Child;
858 * Calculate lengths for fields that have variable length:
859 * 1) Resource Source string
860 * 2) Vendor Data buffer
862 ResSourceLength = RsGetStringDataLength (InitializerOp);
863 VendorLength = RsGetBufferDataLength (InitializerOp);
865 DescriptorSize = ACPI_AML_SIZE_LARGE (AML_RESOURCE_SPI_SERIALBUS) +
866 ResSourceLength + VendorLength;
868 /* Allocate the local resource node and initialize */
870 Rnode = RsAllocateResourceNode (DescriptorSize + sizeof (AML_RESOURCE_LARGE_HEADER));
872 Descriptor = Rnode->Buffer;
873 Descriptor->SpiSerialBus.ResourceLength = DescriptorSize;
874 Descriptor->SpiSerialBus.DescriptorType = ACPI_RESOURCE_NAME_SERIAL_BUS;
875 Descriptor->SpiSerialBus.RevisionId = AML_RESOURCE_SPI_REVISION;
876 Descriptor->SpiSerialBus.TypeRevisionId = AML_RESOURCE_SPI_TYPE_REVISION;
877 Descriptor->SpiSerialBus.Type = AML_RESOURCE_SPI_SERIALBUSTYPE;
878 Descriptor->SpiSerialBus.TypeDataLength = AML_RESOURCE_SPI_MIN_DATA_LEN + VendorLength;
880 /* Build pointers to optional areas */
882 VendorData = ACPI_ADD_PTR (UINT8, Descriptor, sizeof (AML_RESOURCE_SPI_SERIALBUS));
883 ResourceSource = ACPI_ADD_PTR (char, VendorData, VendorLength);
885 DbgPrint (ASL_DEBUG_OUTPUT,
886 "%16s - Actual: %.2X, Base: %.2X, ResLen: %.2X, VendLen: %.2X, TypLen: %.2X\n",
887 "SpiSerialBus", Descriptor->SpiSerialBus.ResourceLength,
888 (UINT16) sizeof (AML_RESOURCE_SPI_SERIALBUS), ResSourceLength,
889 VendorLength, Descriptor->SpiSerialBus.TypeDataLength);
891 /* Process all child initialization nodes */
893 for (i = 0; InitializerOp; i++)
897 case 0: /* Device Selection [WORD] (_ADR) */
899 Descriptor->SpiSerialBus.DeviceSelection = (UINT16) InitializerOp->Asl.Value.Integer;
900 RsCreateWordField (InitializerOp, ACPI_RESTAG_ADDRESS,
901 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.DeviceSelection));
904 case 1: /* Device Polarity [Flag] (_DPL) */
906 RsSetFlagBits16 (&Descriptor->SpiSerialBus.TypeSpecificFlags, InitializerOp, 1, 0);
907 RsCreateBitField (InitializerOp, ACPI_RESTAG_DEVICEPOLARITY,
908 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.TypeSpecificFlags), 1);
911 case 2: /* Wire Mode [Flag] (_MOD) */
913 RsSetFlagBits16 (&Descriptor->SpiSerialBus.TypeSpecificFlags, InitializerOp, 0, 0);
914 RsCreateBitField (InitializerOp, ACPI_RESTAG_MODE,
915 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.TypeSpecificFlags), 0);
918 case 3: /* Device Bit Length [BYTE] (_LEN) */
920 Descriptor->SpiSerialBus.DataBitLength = (UINT8) InitializerOp->Asl.Value.Integer;
921 RsCreateByteField (InitializerOp, ACPI_RESTAG_LENGTH,
922 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.DataBitLength));
925 case 4: /* Slave Mode [Flag] (_SLV) */
927 RsSetFlagBits (&Descriptor->SpiSerialBus.Flags, InitializerOp, 0, 0);
928 RsCreateBitField (InitializerOp, ACPI_RESTAG_SLAVEMODE,
929 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.Flags), 0);
932 case 5: /* Connection Speed [DWORD] (_SPE) */
934 Descriptor->SpiSerialBus.ConnectionSpeed = (UINT32) InitializerOp->Asl.Value.Integer;
935 RsCreateDwordField (InitializerOp, ACPI_RESTAG_SPEED,
936 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.ConnectionSpeed));
939 case 6: /* Clock Polarity [BYTE] (_POL) */
941 Descriptor->SpiSerialBus.ClockPolarity = (UINT8) InitializerOp->Asl.Value.Integer;
942 RsCreateByteField (InitializerOp, ACPI_RESTAG_POLARITY,
943 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.ClockPolarity));
946 case 7: /* Clock Phase [BYTE] (_PHA) */
948 Descriptor->SpiSerialBus.ClockPhase = (UINT8) InitializerOp->Asl.Value.Integer;
949 RsCreateByteField (InitializerOp, ACPI_RESTAG_PHASE,
950 CurrentByteOffset + ASL_RESDESC_OFFSET (SpiSerialBus.ClockPhase));
953 case 8: /* ResSource [Optional Field - STRING] */
957 /* Copy string to the descriptor */
959 strcpy (ResourceSource,
960 InitializerOp->Asl.Value.String);
964 case 9: /* Resource Index */
966 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
968 Descriptor->SpiSerialBus.ResSourceIndex = (UINT8) InitializerOp->Asl.Value.Integer;
972 case 10: /* Resource Usage (consumer/producer) */
974 RsSetFlagBits (&Descriptor->SpiSerialBus.Flags, InitializerOp, 1, 1);
977 case 11: /* Resource Tag (Descriptor Name) */
979 UtAttachNamepathToOwner (Op, InitializerOp);
982 case 12: /* Vendor Data (Optional - Buffer of BYTEs) (_VEN) */
984 RsGetVendorData (InitializerOp, VendorData,
985 CurrentByteOffset + sizeof (AML_RESOURCE_SPI_SERIALBUS));
988 default: /* Ignore any extra nodes */
993 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);
1000 /*******************************************************************************
1002 * FUNCTION: RsDoUartSerialBusDescriptor
1004 * PARAMETERS: Op - Parent resource descriptor parse node
1005 * CurrentByteOffset - Offset into the resource template AML
1006 * buffer (to track references to the desc)
1008 * RETURN: Completed resource node
1010 * DESCRIPTION: Construct a long "UART Serial Bus" descriptor
1012 ******************************************************************************/
1015 RsDoUartSerialBusDescriptor (
1016 ACPI_PARSE_OBJECT *Op,
1017 UINT32 CurrentByteOffset)
1019 AML_RESOURCE *Descriptor;
1020 ACPI_PARSE_OBJECT *InitializerOp;
1021 ASL_RESOURCE_NODE *Rnode;
1022 char *ResourceSource = NULL;
1023 UINT8 *VendorData = NULL;
1024 UINT16 ResSourceLength;
1025 UINT16 VendorLength;
1026 UINT16 DescriptorSize;
1030 InitializerOp = Op->Asl.Child;
1033 * Calculate lengths for fields that have variable length:
1034 * 1) Resource Source string
1035 * 2) Vendor Data buffer
1037 ResSourceLength = RsGetStringDataLength (InitializerOp);
1038 VendorLength = RsGetBufferDataLength (InitializerOp);
1040 DescriptorSize = ACPI_AML_SIZE_LARGE (AML_RESOURCE_UART_SERIALBUS) +
1041 ResSourceLength + VendorLength;
1043 /* Allocate the local resource node and initialize */
1045 Rnode = RsAllocateResourceNode (DescriptorSize + sizeof (AML_RESOURCE_LARGE_HEADER));
1047 Descriptor = Rnode->Buffer;
1048 Descriptor->UartSerialBus.ResourceLength = DescriptorSize;
1049 Descriptor->UartSerialBus.DescriptorType = ACPI_RESOURCE_NAME_SERIAL_BUS;
1050 Descriptor->UartSerialBus.RevisionId = AML_RESOURCE_UART_REVISION;
1051 Descriptor->UartSerialBus.TypeRevisionId = AML_RESOURCE_UART_TYPE_REVISION;
1052 Descriptor->UartSerialBus.Type = AML_RESOURCE_UART_SERIALBUSTYPE;
1053 Descriptor->UartSerialBus.TypeDataLength = AML_RESOURCE_UART_MIN_DATA_LEN + VendorLength;
1055 /* Build pointers to optional areas */
1057 VendorData = ACPI_ADD_PTR (UINT8, Descriptor, sizeof (AML_RESOURCE_UART_SERIALBUS));
1058 ResourceSource = ACPI_ADD_PTR (char, VendorData, VendorLength);
1060 DbgPrint (ASL_DEBUG_OUTPUT,
1061 "%16s - Actual: %.2X, Base: %.2X, ResLen: %.2X, VendLen: %.2X, TypLen: %.2X\n",
1062 "UartSerialBus", Descriptor->UartSerialBus.ResourceLength,
1063 (UINT16) sizeof (AML_RESOURCE_UART_SERIALBUS), ResSourceLength,
1064 VendorLength, Descriptor->UartSerialBus.TypeDataLength);
1066 /* Process all child initialization nodes */
1068 for (i = 0; InitializerOp; i++)
1072 case 0: /* Connection Speed (Baud Rate) [DWORD] (_SPE) */
1074 Descriptor->UartSerialBus.DefaultBaudRate = (UINT32) InitializerOp->Asl.Value.Integer;
1075 RsCreateDwordField (InitializerOp, ACPI_RESTAG_SPEED,
1076 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.DefaultBaudRate));
1079 case 1: /* Bits Per Byte [Flags] (_LEN) */
1081 RsSetFlagBits16 (&Descriptor->UartSerialBus.TypeSpecificFlags, InitializerOp, 4, 3);
1082 RsCreateMultiBitField (InitializerOp, ACPI_RESTAG_LENGTH,
1083 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.TypeSpecificFlags), 4, 3);
1086 case 2: /* Stop Bits [Flags] (_STB) */
1088 RsSetFlagBits16 (&Descriptor->UartSerialBus.TypeSpecificFlags, InitializerOp, 2, 1);
1089 RsCreateMultiBitField (InitializerOp, ACPI_RESTAG_STOPBITS,
1090 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.TypeSpecificFlags), 2, 2);
1093 case 3: /* Lines In Use [BYTE] (_LIN) */
1095 Descriptor->UartSerialBus.LinesEnabled = (UINT8) InitializerOp->Asl.Value.Integer;
1096 RsCreateByteField (InitializerOp, ACPI_RESTAG_LINE,
1097 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.LinesEnabled));
1100 case 4: /* Endianness [Flag] (_END) */
1102 RsSetFlagBits16 (&Descriptor->UartSerialBus.TypeSpecificFlags, InitializerOp, 7, 0);
1103 RsCreateBitField (InitializerOp, ACPI_RESTAG_ENDIANNESS,
1104 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.TypeSpecificFlags), 7);
1107 case 5: /* Parity [BYTE] (_PAR) */
1109 Descriptor->UartSerialBus.Parity = (UINT8) InitializerOp->Asl.Value.Integer;
1110 RsCreateByteField (InitializerOp, ACPI_RESTAG_PARITY,
1111 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.Parity));
1114 case 6: /* Flow Control [Flags] (_FLC) */
1116 RsSetFlagBits16 (&Descriptor->UartSerialBus.TypeSpecificFlags, InitializerOp, 0, 0);
1117 RsCreateMultiBitField (InitializerOp, ACPI_RESTAG_FLOWCONTROL,
1118 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.TypeSpecificFlags), 0, 2);
1121 case 7: /* Rx Buffer Size [WORD] (_RXL) */
1123 Descriptor->UartSerialBus.RxFifoSize = (UINT16) InitializerOp->Asl.Value.Integer;
1124 RsCreateWordField (InitializerOp, ACPI_RESTAG_LENGTH_RX,
1125 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.RxFifoSize));
1128 case 8: /* Tx Buffer Size [WORD] (_TXL) */
1130 Descriptor->UartSerialBus.TxFifoSize = (UINT16) InitializerOp->Asl.Value.Integer;
1131 RsCreateWordField (InitializerOp, ACPI_RESTAG_LENGTH_TX,
1132 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.TxFifoSize));
1135 case 9: /* ResSource [Optional Field - STRING] */
1137 if (ResSourceLength)
1139 /* Copy string to the descriptor */
1141 strcpy (ResourceSource,
1142 InitializerOp->Asl.Value.String);
1146 case 10: /* Resource Index */
1148 if (InitializerOp->Asl.ParseOpcode != PARSEOP_DEFAULT_ARG)
1150 Descriptor->UartSerialBus.ResSourceIndex = (UINT8) InitializerOp->Asl.Value.Integer;
1154 case 11: /* Resource Usage (consumer/producer) */
1156 RsSetFlagBits (&Descriptor->UartSerialBus.Flags, InitializerOp, 1, 1);
1159 * Slave Mode [Flag] (_SLV)
1161 * Note: There is no SlaveMode argument to the UartSerialBus macro, but
1162 * we add this name anyway to allow the flag to be set by ASL in the
1163 * rare case where there is a slave mode associated with the UART.
1165 RsCreateBitField (InitializerOp, ACPI_RESTAG_SLAVEMODE,
1166 CurrentByteOffset + ASL_RESDESC_OFFSET (UartSerialBus.Flags), 0);
1169 case 12: /* Resource Tag (Descriptor Name) */
1171 UtAttachNamepathToOwner (Op, InitializerOp);
1174 case 13: /* Vendor Data (Optional - Buffer of BYTEs) (_VEN) */
1176 RsGetVendorData (InitializerOp, VendorData,
1177 CurrentByteOffset + sizeof (AML_RESOURCE_UART_SERIALBUS));
1180 default: /* Ignore any extra nodes */
1185 InitializerOp = RsCompleteNodeAndGetNext (InitializerOp);