xref: /freebsd/sys/contrib/dev/acpica/compiler/aslresources.y (revision 93a065e7496dfbfbd0a5b0208ef763f37ea975c7)
1 NoEcho('
2 /******************************************************************************
3  *
4  * Module Name: aslresources.y - Bison/Yacc production rules for resources
5  *
6  *****************************************************************************/
7 
8 /*
9  * Copyright (C) 2000 - 2017, Intel Corp.
10  * All rights reserved.
11  *
12  * Redistribution and use in source and binary forms, with or without
13  * modification, are permitted provided that the following conditions
14  * are met:
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.
26  *
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.
30  *
31  * NO WARRANTY
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.
43  */
44 
45 ')
46 
47 
48 /*******************************************************************************
49  *
50  * ASL Resource Template Terms
51  *
52  ******************************************************************************/
53 
54 /*
55  * Note: Create two default nodes to allow conversion to a Buffer AML opcode
56  * Also, insert the EndTag at the end of the template.
57  */
58 ResourceTemplateTerm
59     : PARSEOP_RESOURCETEMPLATE
60         OptionalParentheses
61         '{'
62         ResourceMacroList '}'       {$$ = TrCreateNode (PARSEOP_RESOURCETEMPLATE,4,
63                                           TrCreateLeafNode (PARSEOP_DEFAULT_ARG),
64                                           TrCreateLeafNode (PARSEOP_DEFAULT_ARG),
65                                           $4,
66                                           TrCreateLeafNode (PARSEOP_ENDTAG));}
67     ;
68 
69 OptionalParentheses
70     :                               {$$ = NULL;}
71     | PARSEOP_OPEN_PAREN
72         PARSEOP_CLOSE_PAREN         {$$ = NULL;}
73     ;
74 
75 ResourceMacroList
76     :                               {$$ = NULL;}
77     | ResourceMacroList
78         ResourceMacroTerm           {$$ = TrLinkPeerNode ($1,$2);}
79     ;
80 
81 ResourceMacroTerm
82     : DMATerm                       {}
83     | DWordIOTerm                   {}
84     | DWordMemoryTerm               {}
85     | DWordSpaceTerm                {}
86     | EndDependentFnTerm            {}
87     | ExtendedIOTerm                {}
88     | ExtendedMemoryTerm            {}
89     | ExtendedSpaceTerm             {}
90     | FixedDmaTerm                  {}
91     | FixedIOTerm                   {}
92     | GpioIntTerm                   {}
93     | GpioIoTerm                    {}
94     | I2cSerialBusTerm              {}
95     | I2cSerialBusTermV2            {}
96     | InterruptTerm                 {}
97     | IOTerm                        {}
98     | IRQNoFlagsTerm                {}
99     | IRQTerm                       {}
100     | Memory24Term                  {}
101     | Memory32FixedTerm             {}
102     | Memory32Term                  {}
103     | QWordIOTerm                   {}
104     | QWordMemoryTerm               {}
105     | QWordSpaceTerm                {}
106     | RegisterTerm                  {}
107     | SpiSerialBusTerm              {}
108     | SpiSerialBusTermV2            {}
109     | StartDependentFnNoPriTerm     {}
110     | StartDependentFnTerm          {}
111     | UartSerialBusTerm             {}
112     | UartSerialBusTermV2           {}
113     | VendorLongTerm                {}
114     | VendorShortTerm               {}
115     | WordBusNumberTerm             {}
116     | WordIOTerm                    {}
117     | WordSpaceTerm                 {}
118     ;
119 
120 DMATerm
121     : PARSEOP_DMA
122         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_DMA);}
123         DMATypeKeyword
124         OptionalBusMasterKeyword
125         ',' XferTypeKeyword
126         OptionalNameString_Last
127         PARSEOP_CLOSE_PAREN '{'
128             ByteList '}'            {$$ = TrLinkChildren ($<n>3,5,$4,$5,$7,$8,$11);}
129     | PARSEOP_DMA
130         PARSEOP_OPEN_PAREN
131         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
132     ;
133 
134 DWordIOTerm
135     : PARSEOP_DWORDIO
136         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_DWORDIO);}
137         OptionalResourceType_First
138         OptionalMinType
139         OptionalMaxType
140         OptionalDecodeType
141         OptionalRangeType
142         ',' DWordConstExpr
143         ',' DWordConstExpr
144         ',' DWordConstExpr
145         ',' DWordConstExpr
146         ',' DWordConstExpr
147         OptionalByteConstExpr
148         OptionalStringData
149         OptionalNameString
150         OptionalType
151         OptionalTranslationType_Last
152         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,15,
153                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22,$23);}
154     | PARSEOP_DWORDIO
155         PARSEOP_OPEN_PAREN
156         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
157     ;
158 
159 DWordMemoryTerm
160     : PARSEOP_DWORDMEMORY
161         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_DWORDMEMORY);}
162         OptionalResourceType_First
163         OptionalDecodeType
164         OptionalMinType
165         OptionalMaxType
166         OptionalMemType
167         ',' OptionalReadWriteKeyword
168         ',' DWordConstExpr
169         ',' DWordConstExpr
170         ',' DWordConstExpr
171         ',' DWordConstExpr
172         ',' DWordConstExpr
173         OptionalByteConstExpr
174         OptionalStringData
175         OptionalNameString
176         OptionalAddressRange
177         OptionalType_Last
178         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,16,
179                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$20,$21,$22,$23,$24,$25);}
180     | PARSEOP_DWORDMEMORY
181         PARSEOP_OPEN_PAREN
182         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
183     ;
184 
185 DWordSpaceTerm
186     : PARSEOP_DWORDSPACE
187         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_DWORDSPACE);}
188         ByteConstExpr               {UtCheckIntegerRange ($4, 0xC0, 0xFF);}
189         OptionalResourceType
190         OptionalDecodeType
191         OptionalMinType
192         OptionalMaxType
193         ',' ByteConstExpr
194         ',' DWordConstExpr
195         ',' DWordConstExpr
196         ',' DWordConstExpr
197         ',' DWordConstExpr
198         ',' DWordConstExpr
199         OptionalByteConstExpr
200         OptionalStringData
201         OptionalNameString_Last
202         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,14,
203                                         $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23,$24);}
204     | PARSEOP_DWORDSPACE
205         PARSEOP_OPEN_PAREN
206         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
207     ;
208 
209 EndDependentFnTerm
210     : PARSEOP_ENDDEPENDENTFN
211         PARSEOP_OPEN_PAREN
212         PARSEOP_CLOSE_PAREN         {$$ = TrCreateLeafNode (PARSEOP_ENDDEPENDENTFN);}
213     | PARSEOP_ENDDEPENDENTFN
214         PARSEOP_OPEN_PAREN
215         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
216     ;
217 
218 ExtendedIOTerm
219     : PARSEOP_EXTENDEDIO
220         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_EXTENDEDIO);}
221         OptionalResourceType_First
222         OptionalMinType
223         OptionalMaxType
224         OptionalDecodeType
225         OptionalRangeType
226         ',' QWordConstExpr
227         ',' QWordConstExpr
228         ',' QWordConstExpr
229         ',' QWordConstExpr
230         ',' QWordConstExpr
231         OptionalQWordConstExpr
232         OptionalNameString
233         OptionalType
234         OptionalTranslationType_Last
235         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,14,
236                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22);}
237     | PARSEOP_EXTENDEDIO
238         PARSEOP_OPEN_PAREN
239         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
240     ;
241 
242 ExtendedMemoryTerm
243     : PARSEOP_EXTENDEDMEMORY
244         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_EXTENDEDMEMORY);}
245         OptionalResourceType_First
246         OptionalDecodeType
247         OptionalMinType
248         OptionalMaxType
249         OptionalMemType
250         ',' OptionalReadWriteKeyword
251         ',' QWordConstExpr
252         ',' QWordConstExpr
253         ',' QWordConstExpr
254         ',' QWordConstExpr
255         ',' QWordConstExpr
256         OptionalQWordConstExpr
257         OptionalNameString
258         OptionalAddressRange
259         OptionalType_Last
260         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,15,
261                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$20,$21,$22,$23,$24);}
262     | PARSEOP_EXTENDEDMEMORY
263         PARSEOP_OPEN_PAREN
264         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
265     ;
266 
267 ExtendedSpaceTerm
268     : PARSEOP_EXTENDEDSPACE PARSEOP_OPEN_PAREN     {$<n>$ = TrCreateLeafNode (PARSEOP_EXTENDEDSPACE);}
269         ByteConstExpr               {UtCheckIntegerRange ($4, 0xC0, 0xFF);}
270         OptionalResourceType
271         OptionalDecodeType
272         OptionalMinType
273         OptionalMaxType
274         ',' ByteConstExpr
275         ',' QWordConstExpr
276         ',' QWordConstExpr
277         ',' QWordConstExpr
278         ',' QWordConstExpr
279         ',' QWordConstExpr
280         OptionalQWordConstExpr
281         OptionalNameString_Last
282         PARSEOP_CLOSE_PAREN                         {$$ = TrLinkChildren ($<n>3,13,
283                                         $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23);}
284     | PARSEOP_EXTENDEDSPACE
285         PARSEOP_OPEN_PAREN
286         error PARSEOP_CLOSE_PAREN                   {$$ = AslDoError(); yyclearin;}
287     ;
288 
289 FixedDmaTerm
290     : PARSEOP_FIXEDDMA
291         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_FIXEDDMA);}
292         WordConstExpr               /* 04: DMA RequestLines */
293         ',' WordConstExpr           /* 06: DMA Channels */
294         OptionalXferSize            /* 07: DMA TransferSize */
295         OptionalNameString          /* 08: DescriptorName */
296         PARSEOP_CLOSE_PAREN                         {$$ = TrLinkChildren ($<n>3,4,$4,$6,$7,$8);}
297     | PARSEOP_FIXEDDMA
298         PARSEOP_OPEN_PAREN
299         error PARSEOP_CLOSE_PAREN                   {$$ = AslDoError(); yyclearin;}
300     ;
301 
302 FixedIOTerm
303     : PARSEOP_FIXEDIO
304         PARSEOP_OPEN_PAREN           {$<n>$ = TrCreateLeafNode (PARSEOP_FIXEDIO);}
305         WordConstExpr
306         ',' ByteConstExpr
307         OptionalNameString_Last
308         PARSEOP_CLOSE_PAREN                         {$$ = TrLinkChildren ($<n>3,3,$4,$6,$7);}
309     | PARSEOP_FIXEDIO
310         PARSEOP_OPEN_PAREN
311         error PARSEOP_CLOSE_PAREN                   {$$ = AslDoError(); yyclearin;}
312     ;
313 
314 GpioIntTerm
315     : PARSEOP_GPIO_INT
316         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_GPIO_INT);}
317         InterruptTypeKeyword        /* 04: InterruptType */
318         ',' InterruptLevel          /* 06: InterruptLevel */
319         OptionalShareType           /* 07: SharedType */
320         ',' PinConfigByte           /* 09: PinConfig */
321         OptionalWordConstExpr       /* 10: DebounceTimeout */
322         ',' StringData              /* 12: ResourceSource */
323         OptionalByteConstExpr       /* 13: ResourceSourceIndex */
324         OptionalResourceType        /* 14: ResourceType */
325         OptionalNameString          /* 15: DescriptorName */
326         OptionalBuffer_Last         /* 16: VendorData */
327         PARSEOP_CLOSE_PAREN '{'
328             DWordConstExpr '}'      {$$ = TrLinkChildren ($<n>3,11,
329                                         $4,$6,$7,$9,$10,$12,$13,$14,$15,$16,$19);}
330     | PARSEOP_GPIO_INT
331         PARSEOP_OPEN_PAREN
332         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
333     ;
334 
335 GpioIoTerm
336     : PARSEOP_GPIO_IO
337         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_GPIO_IO);}
338         OptionalShareType_First     /* 04: SharedType */
339         ',' PinConfigByte           /* 06: PinConfig */
340         OptionalWordConstExpr       /* 07: DebounceTimeout */
341         OptionalWordConstExpr       /* 08: DriveStrength */
342         OptionalIoRestriction       /* 09: IoRestriction */
343         ',' StringData              /* 11: ResourceSource */
344         OptionalByteConstExpr       /* 12: ResourceSourceIndex */
345         OptionalResourceType        /* 13: ResourceType */
346         OptionalNameString          /* 14: DescriptorName */
347         OptionalBuffer_Last         /* 15: VendorData */
348         PARSEOP_CLOSE_PAREN '{'
349             DWordList '}'           {$$ = TrLinkChildren ($<n>3,11,
350                                         $4,$6,$7,$8,$9,$11,$12,$13,$14,$15,$18);}
351     | PARSEOP_GPIO_IO
352         PARSEOP_OPEN_PAREN
353         error PARSEOP_CLOSE_PAREN                   {$$ = AslDoError(); yyclearin;}
354     ;
355 
356 I2cSerialBusTerm
357     : PARSEOP_I2C_SERIALBUS
358         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_I2C_SERIALBUS);}
359         WordConstExpr               /* 04: SlaveAddress */
360         OptionalSlaveMode           /* 05: SlaveMode */
361         ',' DWordConstExpr          /* 07: ConnectionSpeed */
362         OptionalAddressingMode      /* 08: AddressingMode */
363         ',' StringData              /* 10: ResourceSource */
364         OptionalByteConstExpr       /* 11: ResourceSourceIndex */
365         OptionalResourceType        /* 12: ResourceType */
366         OptionalNameString          /* 13: DescriptorName */
367         OptionalBuffer_Last         /* 14: VendorData */
368         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,10,
369                                         $4,$5,$7,$8,$10,$11,$12,$13,
370                                         TrCreateLeafNode (PARSEOP_DEFAULT_ARG),$14);}
371     | PARSEOP_I2C_SERIALBUS
372         PARSEOP_OPEN_PAREN
373         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
374     ;
375 
376 I2cSerialBusTermV2
377     : PARSEOP_I2C_SERIALBUS_V2
378         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_I2C_SERIALBUS_V2);}
379         WordConstExpr               /* 04: SlaveAddress */
380         OptionalSlaveMode           /* 05: SlaveMode */
381         ',' DWordConstExpr          /* 07: ConnectionSpeed */
382         OptionalAddressingMode      /* 08: AddressingMode */
383         ',' StringData              /* 10: ResourceSource */
384         OptionalByteConstExpr       /* 11: ResourceSourceIndex */
385         OptionalResourceType        /* 12: ResourceType */
386         OptionalNameString          /* 13: DescriptorName */
387         OptionalShareType           /* 14: Share */
388         OptionalBuffer_Last         /* 15: VendorData */
389         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,10,
390                                         $4,$5,$7,$8,$10,$11,$12,$13,$14,$15);}
391     | PARSEOP_I2C_SERIALBUS_V2
392         PARSEOP_OPEN_PAREN
393         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
394     ;
395 
396 InterruptTerm
397     : PARSEOP_INTERRUPT
398         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_INTERRUPT);}
399         OptionalResourceType_First
400         ',' InterruptTypeKeyword
401         ',' InterruptLevel
402         OptionalShareType
403         OptionalByteConstExpr
404         OptionalStringData
405         OptionalNameString_Last
406         PARSEOP_CLOSE_PAREN '{'
407             DWordList '}'           {$$ = TrLinkChildren ($<n>3,8,
408                                         $4,$6,$8,$9,$10,$11,$12,$15);}
409     | PARSEOP_INTERRUPT
410         PARSEOP_OPEN_PAREN
411         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
412     ;
413 
414 IOTerm
415     : PARSEOP_IO
416         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_IO);}
417         IODecodeKeyword
418         ',' WordConstExpr
419         ',' WordConstExpr
420         ',' ByteConstExpr
421         ',' ByteConstExpr
422         OptionalNameString_Last
423         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$13);}
424     | PARSEOP_IO
425         PARSEOP_OPEN_PAREN
426         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
427     ;
428 
429 IRQNoFlagsTerm
430     : PARSEOP_IRQNOFLAGS
431         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_IRQNOFLAGS);}
432         OptionalNameString_First
433         PARSEOP_CLOSE_PAREN '{'
434             ByteList '}'            {$$ = TrLinkChildren ($<n>3,2,$4,$7);}
435     | PARSEOP_IRQNOFLAGS
436         PARSEOP_OPEN_PAREN
437         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
438     ;
439 
440 IRQTerm
441     : PARSEOP_IRQ
442         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_IRQ);}
443         InterruptTypeKeyword
444         ',' InterruptLevel
445         OptionalShareType
446         OptionalNameString_Last
447         PARSEOP_CLOSE_PAREN '{'
448             ByteList '}'            {$$ = TrLinkChildren ($<n>3,5,$4,$6,$7,$8,$11);}
449     | PARSEOP_IRQ
450         PARSEOP_OPEN_PAREN
451         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
452     ;
453 
454 Memory24Term
455     : PARSEOP_MEMORY24
456         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_MEMORY24);}
457         OptionalReadWriteKeyword
458         ',' WordConstExpr
459         ',' WordConstExpr
460         ',' WordConstExpr
461         ',' WordConstExpr
462         OptionalNameString_Last
463         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$13);}
464     | PARSEOP_MEMORY24
465         PARSEOP_OPEN_PAREN
466         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
467     ;
468 
469 Memory32FixedTerm
470     : PARSEOP_MEMORY32FIXED
471         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_MEMORY32FIXED);}
472         OptionalReadWriteKeyword
473         ',' DWordConstExpr
474         ',' DWordConstExpr
475         OptionalNameString_Last
476         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,4,$4,$6,$8,$9);}
477     | PARSEOP_MEMORY32FIXED
478         PARSEOP_OPEN_PAREN
479         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
480     ;
481 
482 Memory32Term
483     : PARSEOP_MEMORY32
484         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_MEMORY32);}
485         OptionalReadWriteKeyword
486         ',' DWordConstExpr
487         ',' DWordConstExpr
488         ',' DWordConstExpr
489         ',' DWordConstExpr
490         OptionalNameString_Last
491         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$13);}
492     | PARSEOP_MEMORY32
493         PARSEOP_OPEN_PAREN
494         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
495     ;
496 
497 QWordIOTerm
498     : PARSEOP_QWORDIO
499         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_QWORDIO);}
500         OptionalResourceType_First
501         OptionalMinType
502         OptionalMaxType
503         OptionalDecodeType
504         OptionalRangeType
505         ',' QWordConstExpr
506         ',' QWordConstExpr
507         ',' QWordConstExpr
508         ',' QWordConstExpr
509         ',' QWordConstExpr
510         OptionalByteConstExpr
511         OptionalStringData
512         OptionalNameString
513         OptionalType
514         OptionalTranslationType_Last
515         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,15,
516                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22,$23);}
517     | PARSEOP_QWORDIO
518         PARSEOP_OPEN_PAREN
519         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
520     ;
521 
522 QWordMemoryTerm
523     : PARSEOP_QWORDMEMORY
524         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_QWORDMEMORY);}
525         OptionalResourceType_First
526         OptionalDecodeType
527         OptionalMinType
528         OptionalMaxType
529         OptionalMemType
530         ',' OptionalReadWriteKeyword
531         ',' QWordConstExpr
532         ',' QWordConstExpr
533         ',' QWordConstExpr
534         ',' QWordConstExpr
535         ',' QWordConstExpr
536         OptionalByteConstExpr
537         OptionalStringData
538         OptionalNameString
539         OptionalAddressRange
540         OptionalType_Last
541         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,16,
542                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$20,$21,$22,$23,$24,$25);}
543     | PARSEOP_QWORDMEMORY
544         PARSEOP_OPEN_PAREN
545         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
546     ;
547 
548 QWordSpaceTerm
549     : PARSEOP_QWORDSPACE
550         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_QWORDSPACE);}
551         ByteConstExpr               {UtCheckIntegerRange ($4, 0xC0, 0xFF);}
552         OptionalResourceType
553         OptionalDecodeType
554         OptionalMinType
555         OptionalMaxType
556         ',' ByteConstExpr
557         ',' QWordConstExpr
558         ',' QWordConstExpr
559         ',' QWordConstExpr
560         ',' QWordConstExpr
561         ',' QWordConstExpr
562         OptionalByteConstExpr
563         OptionalStringData
564         OptionalNameString_Last
565         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,14,
566                                         $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23,$24);}
567     | PARSEOP_QWORDSPACE
568         PARSEOP_OPEN_PAREN
569         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
570     ;
571 
572 RegisterTerm
573     : PARSEOP_REGISTER
574         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_REGISTER);}
575         AddressSpaceKeyword
576         ',' ByteConstExpr
577         ',' ByteConstExpr
578         ',' QWordConstExpr
579         OptionalAccessSize
580         OptionalNameString_Last
581         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,6,$4,$6,$8,$10,$11,$12);}
582     | PARSEOP_REGISTER
583         PARSEOP_OPEN_PAREN
584         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
585     ;
586 
587 SpiSerialBusTerm
588     : PARSEOP_SPI_SERIALBUS
589         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_SPI_SERIALBUS);}
590         WordConstExpr               /* 04: DeviceSelection */
591         OptionalDevicePolarity      /* 05: DevicePolarity */
592         OptionalWireMode            /* 06: WireMode */
593         ',' ByteConstExpr           /* 08: DataBitLength */
594         OptionalSlaveMode           /* 09: SlaveMode */
595         ',' DWordConstExpr          /* 11: ConnectionSpeed */
596         ',' ClockPolarityKeyword    /* 13: ClockPolarity */
597         ',' ClockPhaseKeyword       /* 15: ClockPhase */
598         ',' StringData              /* 17: ResourceSource */
599         OptionalByteConstExpr       /* 18: ResourceSourceIndex */
600         OptionalResourceType        /* 19: ResourceType */
601         OptionalNameString          /* 20: DescriptorName */
602         OptionalBuffer_Last         /* 21: VendorData */
603         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,14,
604                                         $4,$5,$6,$8,$9,$11,$13,$15,$17,$18,$19,$20,
605                                         TrCreateLeafNode (PARSEOP_DEFAULT_ARG),$21);}
606     | PARSEOP_SPI_SERIALBUS
607         PARSEOP_OPEN_PAREN
608         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
609     ;
610 
611 SpiSerialBusTermV2
612     : PARSEOP_SPI_SERIALBUS_V2
613         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_SPI_SERIALBUS_V2);}
614         WordConstExpr               /* 04: DeviceSelection */
615         OptionalDevicePolarity      /* 05: DevicePolarity */
616         OptionalWireMode            /* 06: WireMode */
617         ',' ByteConstExpr           /* 08: DataBitLength */
618         OptionalSlaveMode           /* 09: SlaveMode */
619         ',' DWordConstExpr          /* 11: ConnectionSpeed */
620         ',' ClockPolarityKeyword    /* 13: ClockPolarity */
621         ',' ClockPhaseKeyword       /* 15: ClockPhase */
622         ',' StringData              /* 17: ResourceSource */
623         OptionalByteConstExpr       /* 18: ResourceSourceIndex */
624         OptionalResourceType        /* 19: ResourceType */
625         OptionalNameString          /* 20: DescriptorName */
626         OptionalShareType           /* 21: Share */
627         OptionalBuffer_Last         /* 22: VendorData */
628         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,14,
629                                         $4,$5,$6,$8,$9,$11,$13,$15,$17,$18,$19,$20,$21,$22);}
630     | PARSEOP_SPI_SERIALBUS_V2
631         PARSEOP_OPEN_PAREN
632         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
633     ;
634 
635 StartDependentFnNoPriTerm
636     : PARSEOP_STARTDEPENDENTFN_NOPRI
637         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_STARTDEPENDENTFN_NOPRI);}
638         PARSEOP_CLOSE_PAREN '{'
639         ResourceMacroList '}'       {$$ = TrLinkChildren ($<n>3,1,$6);}
640     | PARSEOP_STARTDEPENDENTFN_NOPRI
641         PARSEOP_OPEN_PAREN
642         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
643     ;
644 
645 StartDependentFnTerm
646     : PARSEOP_STARTDEPENDENTFN
647         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_STARTDEPENDENTFN);}
648         ByteConstExpr
649         ',' ByteConstExpr
650         PARSEOP_CLOSE_PAREN '{'
651         ResourceMacroList '}'       {$$ = TrLinkChildren ($<n>3,3,$4,$6,$9);}
652     | PARSEOP_STARTDEPENDENTFN
653         PARSEOP_OPEN_PAREN
654         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
655     ;
656 
657 UartSerialBusTerm
658     : PARSEOP_UART_SERIALBUS
659         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_UART_SERIALBUS);}
660         DWordConstExpr              /* 04: ConnectionSpeed */
661         OptionalBitsPerByte         /* 05: BitsPerByte */
662         OptionalStopBits            /* 06: StopBits */
663         ',' ByteConstExpr           /* 08: LinesInUse */
664         OptionalEndian              /* 09: Endianess */
665         OptionalParityType          /* 10: Parity */
666         OptionalFlowControl         /* 11: FlowControl */
667         ',' WordConstExpr           /* 13: Rx BufferSize */
668         ',' WordConstExpr           /* 15: Tx BufferSize */
669         ',' StringData              /* 17: ResourceSource */
670         OptionalByteConstExpr       /* 18: ResourceSourceIndex */
671         OptionalResourceType        /* 19: ResourceType */
672         OptionalNameString          /* 20: DescriptorName */
673         OptionalBuffer_Last         /* 21: VendorData */
674         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,15,
675                                         $4,$5,$6,$8,$9,$10,$11,$13,$15,$17,$18,$19,$20,
676                                         TrCreateLeafNode (PARSEOP_DEFAULT_ARG),$21);}
677     | PARSEOP_UART_SERIALBUS
678         PARSEOP_OPEN_PAREN
679         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
680     ;
681 
682 UartSerialBusTermV2
683     : PARSEOP_UART_SERIALBUS_V2
684         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_UART_SERIALBUS_V2);}
685         DWordConstExpr              /* 04: ConnectionSpeed */
686         OptionalBitsPerByte         /* 05: BitsPerByte */
687         OptionalStopBits            /* 06: StopBits */
688         ',' ByteConstExpr           /* 08: LinesInUse */
689         OptionalEndian              /* 09: Endianess */
690         OptionalParityType          /* 10: Parity */
691         OptionalFlowControl         /* 11: FlowControl */
692         ',' WordConstExpr           /* 13: Rx BufferSize */
693         ',' WordConstExpr           /* 15: Tx BufferSize */
694         ',' StringData              /* 17: ResourceSource */
695         OptionalByteConstExpr       /* 18: ResourceSourceIndex */
696         OptionalResourceType        /* 19: ResourceType */
697         OptionalNameString          /* 20: DescriptorName */
698         OptionalShareType           /* 21: Share */
699         OptionalBuffer_Last         /* 22: VendorData */
700         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,15,
701                                         $4,$5,$6,$8,$9,$10,$11,$13,$15,$17,$18,$19,$20,$21,$22);}
702     | PARSEOP_UART_SERIALBUS_V2
703         PARSEOP_OPEN_PAREN
704         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
705     ;
706 
707 VendorLongTerm
708     : PARSEOP_VENDORLONG
709         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_VENDORLONG);}
710         OptionalNameString_First
711         PARSEOP_CLOSE_PAREN '{'
712             ByteList '}'            {$$ = TrLinkChildren ($<n>3,2,$4,$7);}
713     | PARSEOP_VENDORLONG
714         PARSEOP_OPEN_PAREN
715         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
716     ;
717 
718 VendorShortTerm
719     : PARSEOP_VENDORSHORT
720         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_VENDORSHORT);}
721         OptionalNameString_First
722         PARSEOP_CLOSE_PAREN '{'
723             ByteList '}'            {$$ = TrLinkChildren ($<n>3,2,$4,$7);}
724     | PARSEOP_VENDORSHORT
725         PARSEOP_OPEN_PAREN
726         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
727     ;
728 
729 WordBusNumberTerm
730     : PARSEOP_WORDBUSNUMBER
731         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_WORDBUSNUMBER);}
732         OptionalResourceType_First
733         OptionalMinType
734         OptionalMaxType
735         OptionalDecodeType
736         ',' WordConstExpr
737         ',' WordConstExpr
738         ',' WordConstExpr
739         ',' WordConstExpr
740         ',' WordConstExpr
741         OptionalByteConstExpr
742         OptionalStringData
743         OptionalNameString_Last
744         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,12,
745                                         $4,$5,$6,$7,$9,$11,$13,$15,$17,$18,$19,$20);}
746     | PARSEOP_WORDBUSNUMBER
747         PARSEOP_OPEN_PAREN
748         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
749     ;
750 
751 WordIOTerm
752     : PARSEOP_WORDIO
753         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_WORDIO);}
754         OptionalResourceType_First
755         OptionalMinType
756         OptionalMaxType
757         OptionalDecodeType
758         OptionalRangeType
759         ',' WordConstExpr
760         ',' WordConstExpr
761         ',' WordConstExpr
762         ',' WordConstExpr
763         ',' WordConstExpr
764         OptionalByteConstExpr
765         OptionalStringData
766         OptionalNameString
767         OptionalType
768         OptionalTranslationType_Last
769         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,15,
770                                         $4,$5,$6,$7,$8,$10,$12,$14,$16,$18,$19,$20,$21,$22,$23);}
771     | PARSEOP_WORDIO
772         PARSEOP_OPEN_PAREN
773         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
774     ;
775 
776 WordSpaceTerm
777     : PARSEOP_WORDSPACE
778         PARSEOP_OPEN_PAREN          {$<n>$ = TrCreateLeafNode (PARSEOP_WORDSPACE);}
779         ByteConstExpr               {UtCheckIntegerRange ($4, 0xC0, 0xFF);}
780         OptionalResourceType
781         OptionalDecodeType
782         OptionalMinType
783         OptionalMaxType
784         ',' ByteConstExpr
785         ',' WordConstExpr
786         ',' WordConstExpr
787         ',' WordConstExpr
788         ',' WordConstExpr
789         ',' WordConstExpr
790         OptionalByteConstExpr
791         OptionalStringData
792         OptionalNameString_Last
793         PARSEOP_CLOSE_PAREN         {$$ = TrLinkChildren ($<n>3,14,
794                                         $4,$6,$7,$8,$9,$11,$13,$15,$17,$19,$21,$22,$23,$24);}
795     | PARSEOP_WORDSPACE
796         PARSEOP_OPEN_PAREN
797         error PARSEOP_CLOSE_PAREN   {$$ = AslDoError(); yyclearin;}
798     ;
799