2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
%{
|
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* Module Name: aslcompiler.y - Bison input file (ASL grammar and actions)
|
2005-06-29 19:39:54 +04:00
|
|
|
* $Revision: 1.16 $
|
2005-06-29 19:37:15 +04:00
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
*
|
|
|
|
* 1. Copyright Notice
|
|
|
|
*
|
2005-06-29 19:39:47 +04:00
|
|
|
* Some or all of this work - Copyright (c) 1999, Intel Corp. All rights
|
|
|
|
* reserved.
|
2005-06-29 19:37:15 +04:00
|
|
|
*
|
|
|
|
* 2. License
|
|
|
|
*
|
|
|
|
* 2.1. This is your license from Intel Corp. under its intellectual property
|
|
|
|
* rights. You may have additional license terms from the party that provided
|
|
|
|
* you this software, covering your right to use that party's intellectual
|
|
|
|
* property rights.
|
|
|
|
*
|
|
|
|
* 2.2. Intel grants, free of charge, to any person ("Licensee") obtaining a
|
|
|
|
* copy of the source code appearing in this file ("Covered Code") an
|
|
|
|
* irrevocable, perpetual, worldwide license under Intel's copyrights in the
|
|
|
|
* base code distributed originally by Intel ("Original Intel Code") to copy,
|
|
|
|
* make derivatives, distribute, use and display any portion of the Covered
|
|
|
|
* Code in any form, with the right to sublicense such rights; and
|
|
|
|
*
|
|
|
|
* 2.3. Intel grants Licensee a non-exclusive and non-transferable patent
|
|
|
|
* license (with the right to sublicense), under only those claims of Intel
|
|
|
|
* patents that are infringed by the Original Intel Code, to make, use, sell,
|
|
|
|
* offer to sell, and import the Covered Code and derivative works thereof
|
|
|
|
* solely to the minimum extent necessary to exercise the above copyright
|
|
|
|
* license, and in no event shall the patent license extend to any additions
|
|
|
|
* to or modifications of the Original Intel Code. No other license or right
|
|
|
|
* is granted directly or by implication, estoppel or otherwise;
|
|
|
|
*
|
|
|
|
* The above copyright and patent license is granted only if the following
|
|
|
|
* conditions are met:
|
|
|
|
*
|
|
|
|
* 3. Conditions
|
|
|
|
*
|
|
|
|
* 3.1. Redistribution of Source with Rights to Further Distribute Source.
|
|
|
|
* Redistribution of source code of any substantial portion of the Covered
|
|
|
|
* Code or modification with rights to further distribute source must include
|
|
|
|
* the above Copyright Notice, the above License, this list of Conditions,
|
|
|
|
* and the following Disclaimer and Export Compliance provision. In addition,
|
|
|
|
* Licensee must cause all Covered Code to which Licensee contributes to
|
|
|
|
* contain a file documenting the changes Licensee made to create that Covered
|
|
|
|
* Code and the date of any change. Licensee must include in that file the
|
|
|
|
* documentation of any changes made by any predecessor Licensee. Licensee
|
|
|
|
* must include a prominent statement that the modification is derived,
|
|
|
|
* directly or indirectly, from Original Intel Code.
|
|
|
|
*
|
|
|
|
* 3.2. Redistribution of Source with no Rights to Further Distribute Source.
|
|
|
|
* Redistribution of source code of any substantial portion of the Covered
|
|
|
|
* Code or modification without rights to further distribute source must
|
|
|
|
* include the following Disclaimer and Export Compliance provision in the
|
|
|
|
* documentation and/or other materials provided with distribution. In
|
|
|
|
* addition, Licensee may not authorize further sublicense of source of any
|
|
|
|
* portion of the Covered Code, and must include terms to the effect that the
|
|
|
|
* license from Licensee to its licensee is limited to the intellectual
|
|
|
|
* property embodied in the software Licensee provides to its licensee, and
|
|
|
|
* not to intellectual property embodied in modifications its licensee may
|
|
|
|
* make.
|
|
|
|
*
|
|
|
|
* 3.3. Redistribution of Executable. Redistribution in executable form of any
|
|
|
|
* substantial portion of the Covered Code or modification must reproduce the
|
|
|
|
* above Copyright Notice, and the following Disclaimer and Export Compliance
|
|
|
|
* provision in the documentation and/or other materials provided with the
|
|
|
|
* distribution.
|
|
|
|
*
|
|
|
|
* 3.4. Intel retains all right, title, and interest in and to the Original
|
|
|
|
* Intel Code.
|
|
|
|
*
|
|
|
|
* 3.5. Neither the name Intel nor any other trademark owned or controlled by
|
|
|
|
* Intel shall be used in advertising or otherwise to promote the sale, use or
|
|
|
|
* other dealings in products derived from or relating to the Covered Code
|
|
|
|
* without prior written authorization from Intel.
|
|
|
|
*
|
|
|
|
* 4. Disclaimer and Export Compliance
|
|
|
|
*
|
|
|
|
* 4.1. INTEL MAKES NO WARRANTY OF ANY KIND REGARDING ANY SOFTWARE PROVIDED
|
|
|
|
* HERE. ANY SOFTWARE ORIGINATING FROM INTEL OR DERIVED FROM INTEL SOFTWARE
|
|
|
|
* IS PROVIDED "AS IS," AND INTEL WILL NOT PROVIDE ANY SUPPORT, ASSISTANCE,
|
|
|
|
* INSTALLATION, TRAINING OR OTHER SERVICES. INTEL WILL NOT PROVIDE ANY
|
|
|
|
* UPDATES, ENHANCEMENTS OR EXTENSIONS. INTEL SPECIFICALLY DISCLAIMS ANY
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY, NONINFRINGEMENT AND FITNESS FOR A
|
|
|
|
* PARTICULAR PURPOSE.
|
|
|
|
*
|
|
|
|
* 4.2. IN NO EVENT SHALL INTEL HAVE ANY LIABILITY TO LICENSEE, ITS LICENSEES
|
|
|
|
* OR ANY OTHER THIRD PARTY, FOR ANY LOST PROFITS, LOST DATA, LOSS OF USE OR
|
|
|
|
* COSTS OF PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, OR FOR ANY INDIRECT,
|
|
|
|
* SPECIAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THIS AGREEMENT, UNDER ANY
|
|
|
|
* CAUSE OF ACTION OR THEORY OF LIABILITY, AND IRRESPECTIVE OF WHETHER INTEL
|
|
|
|
* HAS ADVANCE NOTICE OF THE POSSIBILITY OF SUCH DAMAGES. THESE LIMITATIONS
|
|
|
|
* SHALL APPLY NOTWITHSTANDING THE FAILURE OF THE ESSENTIAL PURPOSE OF ANY
|
|
|
|
* LIMITED REMEDY.
|
|
|
|
*
|
|
|
|
* 4.3. Licensee shall not export, either directly or indirectly, any of this
|
|
|
|
* software or system incorporating such software without first obtaining any
|
|
|
|
* required license or other approval from the U. S. Department of Commerce or
|
|
|
|
* any other agency or department of the United States Government. In the
|
|
|
|
* event Licensee exports any such software from the United States or
|
|
|
|
* re-exports any such software from a foreign destination, Licensee shall
|
|
|
|
* ensure that the distribution and export/re-export of the software is in
|
|
|
|
* compliance with all laws, regulations, orders, or other restrictions of the
|
|
|
|
* U.S. Export Administration Regulations. Licensee agrees that neither it nor
|
|
|
|
* any of its subsidiaries will export/re-export any technical data, process,
|
|
|
|
* software, or service, directly or indirectly, to any country for which the
|
|
|
|
* United States government or any agency thereof requires an export license,
|
|
|
|
* other governmental approval, or letter of assurance, without first obtaining
|
|
|
|
* such license, approval or letter.
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
#define YYDEBUG 1
|
2005-06-29 19:39:54 +04:00
|
|
|
#define YYERROR_VERBOSE 1
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
/*
|
|
|
|
* State stack - compiler will fault if it overflows. (Default was 200)
|
|
|
|
*/
|
|
|
|
#define YYINITDEPTH 600
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
#include "AslCompiler.h"
|
2005-06-29 19:37:15 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "acpi.h"
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
extern int AslCompilererror(char* s);
|
|
|
|
extern int AslCompilerlex();
|
|
|
|
extern char *AslCompilertext;
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
/*
|
2005-06-29 19:39:47 +04:00
|
|
|
* Next statement is important - this makes everything public so that
|
2005-06-29 19:37:15 +04:00
|
|
|
* we can access some of the parser tables from other modules
|
|
|
|
*/
|
|
|
|
#define static
|
2005-06-29 19:39:54 +04:00
|
|
|
#undef alloca
|
|
|
|
#define alloca AslLocalAllocate
|
|
|
|
#define YYERROR_VERBOSE 1
|
|
|
|
|
|
|
|
void *
|
|
|
|
AslLocalAllocate (unsigned int Size);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The windows version of bison defines this incorrectly as "32768" (Not negative).
|
|
|
|
* Using a custom (edited binary) version of bison that defines YYFLAG as YYFBAD
|
|
|
|
* instead (#define YYFBAD 32768), so we can define it correctly here.
|
|
|
|
*
|
|
|
|
* The problem is that if YYFLAG is positive, the extended syntax error messages
|
|
|
|
* are disabled.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define YYFLAG 0
|
|
|
|
|
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
%}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Declare the type of values in the grammar
|
|
|
|
*/
|
|
|
|
|
|
|
|
%union {
|
2005-06-29 19:39:47 +04:00
|
|
|
int i;
|
|
|
|
long l;
|
|
|
|
char *s;
|
2005-06-29 19:39:54 +04:00
|
|
|
ASL_PARSE_NODE *n;
|
2005-06-29 19:37:15 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Token types: These are returned by the lexer
|
|
|
|
*/
|
|
|
|
|
|
|
|
%token <i> ACCESSAS
|
|
|
|
%token <i> ACCESSATTRIB_BLOCK
|
|
|
|
%token <i> ACCESSATTRIB_BYTE
|
|
|
|
%token <i> ACCESSATTRIB_CALL
|
|
|
|
%token <i> ACCESSATTRIB_QUICK
|
|
|
|
%token <i> ACCESSATTRIB_SND_RCV
|
|
|
|
%token <i> ACCESSATTRIB_WORD
|
|
|
|
%token <i> ACCESSTYPE_ANY
|
|
|
|
%token <i> ACCESSTYPE_BUF
|
|
|
|
%token <i> ACCESSTYPE_BYTE
|
|
|
|
%token <i> ACCESSTYPE_DWORD
|
|
|
|
%token <i> ACCESSTYPE_QWORD
|
|
|
|
%token <i> ACCESSTYPE_WORD
|
|
|
|
%token <i> ACQUIRE
|
|
|
|
%token <i> ADD
|
|
|
|
%token <i> ADDRESSSPACE_FFIXEDHW
|
|
|
|
%token <i> ADDRESSTYPE_ACPI
|
|
|
|
%token <i> ADDRESSTYPE_MEMORY
|
|
|
|
%token <i> ADDRESSTYPE_NVS
|
|
|
|
%token <i> ADDRESSTYPE_RESERVED
|
|
|
|
%token <i> ALIAS
|
|
|
|
%token <i> AND
|
|
|
|
%token <i> ARG0
|
|
|
|
%token <i> ARG1
|
|
|
|
%token <i> ARG2
|
|
|
|
%token <i> ARG3
|
|
|
|
%token <i> ARG4
|
|
|
|
%token <i> ARG5
|
|
|
|
%token <i> ARG6
|
|
|
|
%token <i> BANKFIELD
|
|
|
|
%token <i> BREAK
|
|
|
|
%token <i> BREAKPOINT
|
|
|
|
%token <i> BUFFER
|
|
|
|
%token <i> BUSMASTERTYPE_MASTER
|
|
|
|
%token <i> BUSMASTERTYPE_NOTMASTER
|
|
|
|
%token <i> BYTECONST
|
|
|
|
%token <i> CASE
|
|
|
|
%token <i> CONCATENATE
|
|
|
|
%token <i> CONCATENATERESTEMPLATE
|
|
|
|
%token <i> CONDREFOF
|
|
|
|
%token <i> CONTINUE
|
2005-06-29 19:39:47 +04:00
|
|
|
%token <i> COPY
|
2005-06-29 19:37:15 +04:00
|
|
|
%token <i> CREATEBITFIELD
|
|
|
|
%token <i> CREATEBYTEFIELD
|
|
|
|
%token <i> CREATEDWORDFIELD
|
|
|
|
%token <i> CREATEFIELD
|
|
|
|
%token <i> CREATEQWORDFIELD
|
|
|
|
%token <i> CREATEWORDFIELD
|
|
|
|
%token <i> DATATABLEREGION
|
|
|
|
%token <i> DEBUG
|
|
|
|
%token <i> DECODETYPE_POS
|
|
|
|
%token <i> DECODETYPE_SUB
|
|
|
|
%token <i> DECREMENT
|
|
|
|
%token <i> DEFAULT
|
|
|
|
%token <i> DEFAULT_ARG
|
|
|
|
%token <i> DEFINITIONBLOCK
|
|
|
|
%token <i> DEREFOF
|
|
|
|
%token <i> DEVICE
|
|
|
|
%token <i> DIVIDE
|
|
|
|
%token <i> DMA
|
|
|
|
%token <i> DMATYPE_A
|
|
|
|
%token <i> DMATYPE_COMPATIBILITY
|
|
|
|
%token <i> DMATYPE_B
|
|
|
|
%token <i> DMATYPE_F
|
|
|
|
%token <i> DWORDCONST
|
|
|
|
%token <i> DWORDIO
|
|
|
|
%token <i> DWORDMEMORY
|
|
|
|
%token <i> EISAID
|
|
|
|
%token <i> ELSE
|
|
|
|
%token <i> ELSEIF
|
|
|
|
%token <i> ENDDEPENDENTFN
|
|
|
|
%token <i> EVENT
|
|
|
|
%token <i> EXTERNAL
|
|
|
|
%token <i> FATAL
|
|
|
|
%token <i> FIELD
|
|
|
|
%token <i> FINDSETLEFTBIT
|
|
|
|
%token <i> FINDSETRIGHTBIT
|
|
|
|
%token <i> FIXEDIO
|
|
|
|
%token <i> FROMBCD
|
|
|
|
%token <i> IF
|
|
|
|
%token <i> INCLUDE
|
2005-06-29 19:39:54 +04:00
|
|
|
%token <i> INCLUDE_CSTYLE
|
2005-06-29 19:37:15 +04:00
|
|
|
%token <i> INCREMENT
|
|
|
|
%token <i> INDEX
|
|
|
|
%token <i> INDEXFIELD
|
|
|
|
%token <i> INTEGER
|
|
|
|
%token <i> INTERRUPT
|
|
|
|
%token <i> INTLEVEL_ACTIVEHIGH
|
|
|
|
%token <i> INTLEVEL_ACTIVELOW
|
|
|
|
%token <i> INTTYPE_EDGE
|
|
|
|
%token <i> INTTYPE_LEVEL
|
|
|
|
%token <i> IO
|
|
|
|
%token <i> IODECODETYPE_10
|
|
|
|
%token <i> IODECODETYPE_16
|
|
|
|
%token <i> IRQ
|
|
|
|
%token <i> IRQNOFLAGS
|
|
|
|
%token <i> LAND
|
|
|
|
%token <i> LEQUAL
|
|
|
|
%token <i> LGREATER
|
|
|
|
%token <i> LGREATEREQUAL
|
|
|
|
%token <i> LLESS
|
|
|
|
%token <i> LLESSEQUAL
|
|
|
|
%token <i> LNOT
|
|
|
|
%token <i> LNOTEQUAL
|
|
|
|
%token <i> LOAD
|
|
|
|
%token <i> LOADTABLE
|
|
|
|
%token <i> LOCAL0
|
|
|
|
%token <i> LOCAL1
|
|
|
|
%token <i> LOCAL2
|
|
|
|
%token <i> LOCAL3
|
|
|
|
%token <i> LOCAL4
|
|
|
|
%token <i> LOCAL5
|
|
|
|
%token <i> LOCAL6
|
|
|
|
%token <i> LOCAL7
|
|
|
|
%token <i> LOCKRULE_LOCK
|
|
|
|
%token <i> LOCKRULE_NOLOCK
|
|
|
|
%token <i> LOR
|
|
|
|
%token <i> MATCH
|
|
|
|
%token <i> MATCHTYPE_MEQ
|
|
|
|
%token <i> MATCHTYPE_MGE
|
|
|
|
%token <i> MATCHTYPE_MGT
|
|
|
|
%token <i> MATCHTYPE_MLE
|
|
|
|
%token <i> MATCHTYPE_MLT
|
|
|
|
%token <i> MATCHTYPE_MTR
|
|
|
|
%token <i> MAXTYPE_FIXED
|
|
|
|
%token <i> MAXTYPE_NOTFIXED
|
|
|
|
%token <i> MEMORY24
|
|
|
|
%token <i> MEMORY32
|
|
|
|
%token <i> MEMORY32FIXED
|
|
|
|
%token <i> MEMTYPE_CACHEABLE
|
|
|
|
%token <i> MEMTYPE_NONCACHEABLE
|
|
|
|
%token <i> MEMTYPE_PREFETCHABLE
|
|
|
|
%token <i> MEMTYPE_WRITECOMBINING
|
|
|
|
%token <i> METHOD
|
|
|
|
%token <i> MID
|
|
|
|
%token <i> MINTYPE_FIXED
|
|
|
|
%token <i> MINTYPE_NOTFIXED
|
|
|
|
%token <i> MOD
|
|
|
|
%token <i> MULTIPLY
|
|
|
|
%token <i> MUTEX
|
|
|
|
%token <i> NAME
|
|
|
|
%token <s> NAMESEG
|
|
|
|
%token <s> NAMESTRING
|
|
|
|
%token <i> NAND
|
|
|
|
%token <i> NOOP
|
|
|
|
%token <i> NOR
|
|
|
|
%token <i> NOT
|
|
|
|
%token <i> NOTIFY
|
|
|
|
%token <i> OBJECTTYPE
|
|
|
|
%token <i> OBJECTTYPE_BFF
|
|
|
|
%token <i> OBJECTTYPE_BUF
|
|
|
|
%token <i> OBJECTTYPE_DDB
|
|
|
|
%token <i> OBJECTTYPE_DEV
|
|
|
|
%token <i> OBJECTTYPE_EVT
|
|
|
|
%token <i> OBJECTTYPE_FLD
|
|
|
|
%token <i> OBJECTTYPE_INT
|
|
|
|
%token <i> OBJECTTYPE_MTH
|
|
|
|
%token <i> OBJECTTYPE_MTX
|
|
|
|
%token <i> OBJECTTYPE_OPR
|
|
|
|
%token <i> OBJECTTYPE_PKG
|
|
|
|
%token <i> OBJECTTYPE_POW
|
|
|
|
%token <i> OBJECTTYPE_STR
|
|
|
|
%token <i> OBJECTTYPE_THZ
|
|
|
|
%token <i> OBJECTTYPE_UNK
|
|
|
|
%token <i> OFFSET
|
|
|
|
%token <i> ONE
|
|
|
|
%token <i> ONES
|
|
|
|
%token <i> OPERATIONREGION
|
|
|
|
%token <i> OR
|
|
|
|
%token <i> PACKAGE
|
|
|
|
%token <i> PACKAGE_LENGTH
|
|
|
|
%token <i> POWERRESOURCE
|
|
|
|
%token <i> PROCESSOR
|
|
|
|
%token <i> QWORDCONST
|
|
|
|
%token <i> QWORDIO
|
|
|
|
%token <i> QWORDMEMORY
|
|
|
|
%token <i> RANGETYPE_ENTIRE
|
|
|
|
%token <i> RANGETYPE_ISAONLY
|
|
|
|
%token <i> RANGETYPE_NONISAONLY
|
|
|
|
%token <i> RAW_DATA
|
|
|
|
%token <i> READWRITETYPE_BOTH
|
|
|
|
%token <i> READWRITETYPE_READONLY
|
|
|
|
%token <i> REFOF
|
|
|
|
%token <i> REGIONSPACE_CMOS
|
|
|
|
%token <i> REGIONSPACE_EC
|
|
|
|
%token <i> REGIONSPACE_IO
|
|
|
|
%token <i> REGIONSPACE_MEM
|
|
|
|
%token <i> REGIONSPACE_PCI
|
|
|
|
%token <i> REGIONSPACE_PCIBAR
|
|
|
|
%token <i> REGIONSPACE_SMBUS
|
|
|
|
%token <i> REGISTER
|
|
|
|
%token <i> RELEASE
|
|
|
|
%token <i> RESERVED_BYTES
|
|
|
|
%token <i> RESET
|
|
|
|
%token <i> RESOURCETEMPLATE
|
|
|
|
%token <i> RESOURCETYPE_CONSUMER
|
|
|
|
%token <i> RESOURCETYPE_PRODUCER
|
|
|
|
%token <i> RETURN
|
|
|
|
%token <i> SCOPE
|
|
|
|
%token <i> SERIALIZERULE_NOTSERIAL
|
|
|
|
%token <i> SERIALIZERULE_SERIAL
|
|
|
|
%token <i> SHARETYPE_EXCLUSIVE
|
|
|
|
%token <i> SHARETYPE_SHARED
|
|
|
|
%token <i> SHIFTLEFT
|
|
|
|
%token <i> SHIFTRIGHT
|
|
|
|
%token <i> SIGNAL
|
|
|
|
%token <i> SIZEOF
|
|
|
|
%token <i> SLEEP
|
|
|
|
%token <i> STALL
|
|
|
|
%token <i> STARTDEPENDENTFN
|
|
|
|
%token <i> STARTDEPENDENTFN_NOPRI
|
|
|
|
%token <i> STORE
|
2005-06-29 19:39:47 +04:00
|
|
|
%token <i> STRING
|
2005-06-29 19:37:15 +04:00
|
|
|
%token <s> STRING_LITERAL
|
|
|
|
%token <i> SUBTRACT
|
|
|
|
%token <i> SWITCH
|
|
|
|
%token <i> THERMALZONE
|
|
|
|
%token <i> TOBCD
|
2005-06-29 19:39:54 +04:00
|
|
|
%token <i> TOBUFFER
|
|
|
|
%token <i> TODECIMALSTRING
|
|
|
|
%token <i> TOHEXSTRING
|
|
|
|
%token <i> TOINTEGER
|
2005-06-29 19:37:15 +04:00
|
|
|
%token <i> TRANSLATIONTYPE_DENSE
|
|
|
|
%token <i> TRANSLATIONTYPE_SPARSE
|
|
|
|
%token <i> TYPE_STATIC
|
|
|
|
%token <i> TYPE_TRANSLATION
|
|
|
|
%token <i> UNICODE
|
|
|
|
%token <i> UNLOAD
|
|
|
|
%token <i> UPDATERULE_ONES
|
|
|
|
%token <i> UPDATERULE_PRESERVE
|
|
|
|
%token <i> UPDATERULE_ZEROS
|
|
|
|
%token <i> VENDORLONG
|
|
|
|
%token <i> VENDORSHORT
|
|
|
|
%token <i> WAIT
|
|
|
|
%token <i> WHILE
|
|
|
|
%token <i> WORDBUSNUMBER
|
|
|
|
%token <i> WORDCONST
|
|
|
|
%token <i> WORDIO
|
|
|
|
%token <i> XFERTYPE_8
|
|
|
|
%token <i> XFERTYPE_8_16
|
|
|
|
%token <i> XFERTYPE_16
|
|
|
|
%token <i> XOR
|
|
|
|
%token <i> ZERO
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Production names
|
|
|
|
*/
|
|
|
|
|
|
|
|
%type <n> ASLCode
|
|
|
|
%type <n> DefinitionBlockTerm
|
|
|
|
%type <n> TermList
|
|
|
|
%type <n> Term
|
|
|
|
%type <n> CompilerDirective
|
|
|
|
%type <n> ObjectList
|
|
|
|
%type <n> Object
|
|
|
|
%type <n> DataObject
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> DataRefObject
|
|
|
|
%type <n> ComputationalData
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> BufferData
|
|
|
|
%type <n> PackageData
|
|
|
|
%type <n> IntegerData
|
2005-06-29 19:39:54 +04:00
|
|
|
%type <n> StringData
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> NamedObject
|
|
|
|
%type <n> NameSpaceModifier
|
|
|
|
%type <n> UserTerm
|
|
|
|
%type <n> ArgList
|
|
|
|
%type <n> ArgListTail
|
|
|
|
%type <n> TermArg
|
|
|
|
%type <n> Target
|
|
|
|
|
|
|
|
%type <n> Type1Opcode
|
|
|
|
%type <n> Type2Opcode
|
|
|
|
%type <n> Type3Opcode
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> Type4Opcode
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> Type5Opcode
|
|
|
|
%type <n> Type6Opcode
|
|
|
|
|
|
|
|
|
|
|
|
%type <n> IncludeTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
%type <n> IncludeCStyleTerm
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> ExternalTerm
|
|
|
|
|
|
|
|
%type <n> FieldUnitList
|
|
|
|
%type <n> FieldUnitListTail
|
|
|
|
%type <n> FieldUnit
|
|
|
|
%type <n> FieldUnitEntry
|
|
|
|
|
|
|
|
%type <n> OffsetTerm
|
|
|
|
%type <n> AccessAsTerm
|
|
|
|
%type <n> OptionalAccessAttribTerm
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/* Named Objects */
|
|
|
|
|
|
|
|
%type <n> BankFieldTerm
|
|
|
|
%type <n> CreateBitFieldTerm
|
|
|
|
%type <n> CreateByteFieldTerm
|
|
|
|
%type <n> CreateDWordFieldTerm
|
|
|
|
%type <n> CreateFieldTerm
|
|
|
|
%type <n> CreateQWordFieldTerm
|
|
|
|
%type <n> CreateWordFieldTerm
|
|
|
|
%type <n> DataRegionTerm
|
|
|
|
%type <n> DeviceTerm
|
|
|
|
%type <n> EventTerm
|
|
|
|
%type <n> FieldTerm
|
|
|
|
%type <n> IndexFieldTerm
|
|
|
|
%type <n> MethodTerm
|
|
|
|
%type <n> MutexTerm
|
|
|
|
%type <n> OpRegionTerm
|
|
|
|
%type <n> OpRegionSpaceIdTerm
|
|
|
|
%type <n> PowerResTerm
|
|
|
|
%type <n> ProcessorTerm
|
|
|
|
%type <n> ThermalZoneTerm
|
|
|
|
|
|
|
|
|
|
|
|
/* Namespace modifiers */
|
|
|
|
|
|
|
|
%type <n> AliasTerm
|
|
|
|
%type <n> NameTerm
|
|
|
|
%type <n> ScopeTerm
|
|
|
|
|
|
|
|
/* Type 1 opcodes */
|
|
|
|
|
|
|
|
%type <n> BreakTerm
|
|
|
|
%type <n> BreakPointTerm
|
|
|
|
%type <n> ContinueTerm
|
|
|
|
%type <n> FatalTerm
|
|
|
|
%type <n> IfElseTerm
|
|
|
|
%type <n> IfTerm
|
|
|
|
%type <n> ElseTerm
|
|
|
|
%type <n> LoadTerm
|
|
|
|
%type <n> NoOpTerm
|
|
|
|
%type <n> NotifyTerm
|
|
|
|
%type <n> ReleaseTerm
|
|
|
|
%type <n> ResetTerm
|
|
|
|
%type <n> ReturnTerm
|
|
|
|
%type <n> SignalTerm
|
|
|
|
%type <n> SleepTerm
|
|
|
|
%type <n> StallTerm
|
|
|
|
%type <n> SwitchTerm
|
|
|
|
%type <n> CaseTermList
|
|
|
|
%type <n> DefaultTermList
|
|
|
|
%type <n> CaseTerm
|
|
|
|
%type <n> DefaultTerm
|
|
|
|
%type <n> UnloadTerm
|
|
|
|
%type <n> WhileTerm
|
|
|
|
|
|
|
|
/* Type 2 opcodes */
|
|
|
|
|
|
|
|
%type <n> AcquireTerm
|
|
|
|
%type <n> AddTerm
|
|
|
|
%type <n> AndTerm
|
|
|
|
%type <n> ConcatTerm
|
|
|
|
%type <n> ConcatResTerm
|
|
|
|
%type <n> CondRefOfTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> CopyTerm
|
|
|
|
%type <n> CopyTarget
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> DecTerm
|
|
|
|
%type <n> DerefOfTerm
|
|
|
|
%type <n> DivideTerm
|
|
|
|
%type <n> FindSetLeftBitTerm
|
|
|
|
%type <n> FindSetRightBitTerm
|
|
|
|
%type <n> FromBCDTerm
|
|
|
|
%type <n> IncTerm
|
|
|
|
%type <n> IndexTerm
|
|
|
|
%type <n> LAndTerm
|
|
|
|
%type <n> LEqualTerm
|
|
|
|
%type <n> LGreaterTerm
|
|
|
|
%type <n> LGreaterEqualTerm
|
|
|
|
%type <n> LLessTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> LLessEqualTerm
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> LNotTerm
|
|
|
|
%type <n> LNotEqualTerm
|
|
|
|
%type <n> LoadTableTerm
|
|
|
|
%type <n> LOrTerm
|
|
|
|
%type <n> MatchTerm
|
|
|
|
%type <n> MidTerm
|
|
|
|
%type <n> ModTerm
|
|
|
|
%type <n> MultiplyTerm
|
|
|
|
%type <n> NAndTerm
|
|
|
|
%type <n> NOrTerm
|
|
|
|
%type <n> NotTerm
|
|
|
|
%type <n> ObjectTypeTerm
|
|
|
|
%type <n> OrTerm
|
|
|
|
%type <n> RefOfTerm
|
|
|
|
%type <n> ShiftLeftTerm
|
|
|
|
%type <n> ShiftRightTerm
|
|
|
|
%type <n> SizeOfTerm
|
|
|
|
%type <n> StoreTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> StringTerm
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> SubtractTerm
|
|
|
|
%type <n> ToBCDTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
%type <n> ToBufferTerm
|
|
|
|
%type <n> ToDecimalStringTerm
|
|
|
|
%type <n> ToHexStringTerm
|
|
|
|
%type <n> ToIntegerTerm
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> WaitTerm
|
|
|
|
%type <n> XOrTerm
|
|
|
|
|
|
|
|
%type <n> OptionalTermArg
|
|
|
|
%type <n> OptionalListTermArg
|
|
|
|
|
|
|
|
|
|
|
|
/* Keywords */
|
|
|
|
|
|
|
|
%type <n> ObjectTypeKeyword
|
|
|
|
%type <n> AccessTypeKeyword
|
|
|
|
%type <n> AccessAttribKeyword
|
|
|
|
%type <n> LockRuleKeyword
|
|
|
|
%type <n> UpdateRuleKeyword
|
|
|
|
%type <n> RegionSpaceKeyword
|
|
|
|
%type <n> AddressSpaceKeyword
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> UserDefRegionSpace
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> MatchOpKeyword
|
|
|
|
%type <n> SerializeRuleKeyword
|
|
|
|
%type <n> DMATypeKeyword
|
|
|
|
%type <n> BusMasterKeyword
|
|
|
|
%type <n> XferTypeKeyword
|
|
|
|
%type <n> ResourceTypeKeyword
|
|
|
|
%type <n> MinKeyword
|
|
|
|
%type <n> MaxKeyword
|
|
|
|
%type <n> DecodeKeyword
|
|
|
|
%type <n> RangeTypeKeyword
|
|
|
|
%type <n> MemTypeKeyword
|
|
|
|
%type <n> ReadWriteKeyword
|
|
|
|
%type <n> InterruptTypeKeyword
|
|
|
|
%type <n> InterruptLevel
|
|
|
|
%type <n> ShareTypeKeyword
|
|
|
|
%type <n> IODecodeKeyword
|
|
|
|
%type <n> TypeKeyword
|
|
|
|
%type <n> TranslationKeyword
|
|
|
|
%type <n> AddressKeyword
|
|
|
|
|
|
|
|
/* Types */
|
|
|
|
|
|
|
|
%type <n> SuperName
|
|
|
|
%type <n> ArgTerm
|
|
|
|
%type <n> LocalTerm
|
|
|
|
%type <n> DebugTerm
|
|
|
|
|
|
|
|
|
|
|
|
%type <n> Integer
|
|
|
|
|
|
|
|
%type <n> ByteConst
|
|
|
|
%type <n> WordConst
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> DwordConst
|
|
|
|
%type <n> QwordConst
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
%type <n> String
|
|
|
|
|
|
|
|
%type <n> ConstTerm
|
|
|
|
%type <n> ByteConstExpr
|
|
|
|
%type <n> WordConstExpr
|
|
|
|
%type <n> DWordConstExpr
|
|
|
|
%type <n> QWordConstExpr
|
|
|
|
%type <n> ConstExprTerm
|
|
|
|
|
|
|
|
%type <n> BufferTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> BufferData
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> ByteList
|
|
|
|
%type <n> ByteListTail
|
|
|
|
%type <n> DWordList
|
|
|
|
%type <n> DWordListTail
|
|
|
|
|
|
|
|
%type <n> PackageTerm
|
|
|
|
%type <n> PackageLengthTerm
|
|
|
|
%type <n> PackageList
|
|
|
|
%type <n> PackageListTail
|
|
|
|
%type <n> PackageElement
|
|
|
|
|
|
|
|
%type <n> EISAIDTerm
|
|
|
|
%type <n> ResourceTemplateTerm
|
|
|
|
%type <n> UnicodeTerm
|
|
|
|
%type <n> ResourceMacroList
|
|
|
|
%type <n> ResourceMacroTerm
|
|
|
|
|
|
|
|
%type <n> DMATerm
|
|
|
|
%type <n> DWordIOTerm
|
|
|
|
%type <n> DWordMemoryTerm
|
|
|
|
%type <n> EndDependentFnTerm
|
|
|
|
%type <n> FixedIOTerm
|
|
|
|
%type <n> InterruptTerm
|
|
|
|
%type <n> IOTerm
|
|
|
|
%type <n> IRQNoFlagsTerm
|
|
|
|
%type <n> IRQTerm
|
|
|
|
%type <n> Memory24Term
|
|
|
|
%type <n> Memory32FixedTerm
|
|
|
|
%type <n> Memory32Term
|
|
|
|
%type <n> QWordIOTerm
|
|
|
|
%type <n> QWordMemoryTerm
|
|
|
|
%type <n> RegisterTerm
|
|
|
|
%type <n> StartDependentFnTerm
|
|
|
|
%type <n> StartDependentFnNoPriTerm
|
|
|
|
%type <n> VendorLongTerm
|
|
|
|
%type <n> VendorShortTerm
|
|
|
|
%type <n> WordBusNumberTerm
|
|
|
|
%type <n> WordIOTerm
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
|
|
|
/* TBD: Could not find in spec */
|
|
|
|
|
|
|
|
%type <n> ObjectReference
|
|
|
|
%type <n> DDBHandle
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:54 +04:00
|
|
|
%type <n> NameString
|
|
|
|
%type <n> NameSeg
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
|
|
|
|
/* Local types that help construct the AML, not in ACPI spec */
|
|
|
|
|
|
|
|
%type <n> AmlPackageLengthTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> OptionalComma
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> OptionalByteConstExpr
|
|
|
|
%type <n> OptionalDWordConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> OptionalAccessAttribKeyword
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> OptionalSerializeRuleKeyword
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> OptionalMinType
|
|
|
|
%type <n> OptionalMaxType
|
|
|
|
%type <n> OptionalMemType
|
|
|
|
%type <n> OptionalDecodeType
|
|
|
|
%type <n> OptionalRangeType
|
|
|
|
%type <n> OptionalShareType
|
|
|
|
%type <n> OptionalType
|
2005-06-29 19:39:47 +04:00
|
|
|
%type <n> OptionalTranslationType
|
|
|
|
%type <n> OptionalStringData
|
|
|
|
%type <n> OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
%type <n> OptionalNameString_First
|
2005-06-29 19:37:15 +04:00
|
|
|
%type <n> OptionalAddressRange
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
*
|
|
|
|
* Production rules start here
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* ASL Names
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/*
|
|
|
|
* Blocks, Data, and Opcodes
|
|
|
|
*/
|
|
|
|
|
|
|
|
ASLCode
|
|
|
|
: DefinitionBlockTerm
|
|
|
|
;
|
|
|
|
|
|
|
|
DefinitionBlockTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DEFINITIONBLOCK '(' {$$ = TgCreateLeafNode (DEFINITIONBLOCK)}
|
2005-06-29 19:37:15 +04:00
|
|
|
String ','
|
|
|
|
String ','
|
|
|
|
ByteConst ','
|
|
|
|
String ','
|
|
|
|
String ','
|
2005-06-29 19:39:47 +04:00
|
|
|
DwordConst
|
|
|
|
')' '{' TermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,7,$4,$6,$8,$10,$12,$14,$17)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
TermList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
2005-06-29 19:39:54 +04:00
|
|
|
| Term TermList {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Term
|
2005-06-29 19:39:47 +04:00
|
|
|
: Object {}
|
|
|
|
| Type1Opcode {}
|
|
|
|
| Type2Opcode {}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CompilerDirective
|
2005-06-29 19:39:47 +04:00
|
|
|
: IncludeTerm {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| IncludeCStyleTerm {$$= NULL}
|
2005-06-29 19:39:47 +04:00
|
|
|
| ExternalTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ObjectList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
2005-06-29 19:39:54 +04:00
|
|
|
| Object ObjectList {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Object
|
2005-06-29 19:39:47 +04:00
|
|
|
: CompilerDirective {}
|
|
|
|
| NamedObject {}
|
|
|
|
| NameSpaceModifier {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DataObject
|
2005-06-29 19:39:47 +04:00
|
|
|
: BufferData {}
|
|
|
|
| PackageData {}
|
|
|
|
| IntegerData {}
|
|
|
|
| StringData {}
|
|
|
|
;
|
|
|
|
|
|
|
|
DataRefObject
|
|
|
|
: DataObject {}
|
|
|
|
| ObjectReference {}
|
|
|
|
| DDBHandle {}
|
|
|
|
;
|
|
|
|
|
|
|
|
ComputationalData
|
|
|
|
: BufferData {}
|
|
|
|
| IntegerData {}
|
|
|
|
| StringData {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
BufferData
|
2005-06-29 19:39:47 +04:00
|
|
|
: Type5Opcode {}
|
|
|
|
| BufferTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PackageData
|
2005-06-29 19:39:47 +04:00
|
|
|
: PackageTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IntegerData
|
2005-06-29 19:39:47 +04:00
|
|
|
: Type3Opcode {}
|
|
|
|
| Integer {}
|
|
|
|
| ConstTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
StringData
|
2005-06-29 19:39:47 +04:00
|
|
|
: Type4Opcode {}
|
|
|
|
| String {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NamedObject
|
2005-06-29 19:39:47 +04:00
|
|
|
: BankFieldTerm {}
|
|
|
|
| CreateBitFieldTerm {}
|
|
|
|
| CreateByteFieldTerm {}
|
|
|
|
| CreateDWordFieldTerm {}
|
|
|
|
| CreateFieldTerm {}
|
|
|
|
| CreateQWordFieldTerm {}
|
|
|
|
| CreateWordFieldTerm {}
|
|
|
|
| DataRegionTerm {}
|
|
|
|
| DeviceTerm {}
|
|
|
|
| EventTerm {}
|
|
|
|
| FieldTerm {}
|
|
|
|
| IndexFieldTerm {}
|
|
|
|
| MethodTerm {}
|
|
|
|
| MutexTerm {}
|
|
|
|
| OpRegionTerm {}
|
|
|
|
| PowerResTerm {}
|
|
|
|
| ProcessorTerm {}
|
|
|
|
| ThermalZoneTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NameSpaceModifier
|
2005-06-29 19:39:47 +04:00
|
|
|
: AliasTerm {}
|
|
|
|
| NameTerm {}
|
|
|
|
| ScopeTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
UserTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: NameString '('
|
2005-06-29 19:39:54 +04:00
|
|
|
ArgList ')' {$$ = TgLinkChildNode ($1,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ArgList
|
2005-06-29 19:39:51 +04:00
|
|
|
: {$$ = NULL}
|
2005-06-29 19:39:54 +04:00
|
|
|
| TermArg ArgListTail {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ArgListTail
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL} /* Allows a trailing comma at list end */
|
2005-06-29 19:39:54 +04:00
|
|
|
| ',' TermArg ArgListTail {$$ = TgLinkPeerNode ($2,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
TermArg
|
2005-06-29 19:39:51 +04:00
|
|
|
: Type2Opcode {}
|
|
|
|
| DataRefObject {}
|
|
|
|
| ArgTerm {}
|
|
|
|
| LocalTerm {}
|
2005-06-29 19:39:47 +04:00
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
: {$$ = TgCreateLeafNode (ZERO)} /* Placeholder is a ZeroOp object */
|
|
|
|
| ',' {$$ = TgCreateLeafNode (ZERO)} /* Placeholder is a ZeroOp object */
|
|
|
|
| ',' SuperName {$$ = TgSetNodeFlags ($2, NODE_IS_TARGET)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
/* Opcode types */
|
|
|
|
|
|
|
|
Type1Opcode
|
2005-06-29 19:39:47 +04:00
|
|
|
: BreakTerm {}
|
|
|
|
| BreakPointTerm {}
|
|
|
|
| ContinueTerm {}
|
|
|
|
| FatalTerm {}
|
|
|
|
| IfElseTerm {}
|
|
|
|
| LoadTerm {}
|
|
|
|
| NoOpTerm {}
|
|
|
|
| NotifyTerm {}
|
|
|
|
| ReleaseTerm {}
|
|
|
|
| ResetTerm {}
|
|
|
|
| ReturnTerm {}
|
|
|
|
| SignalTerm {}
|
|
|
|
| SleepTerm {}
|
|
|
|
| StallTerm {}
|
|
|
|
| SwitchTerm {}
|
|
|
|
| UnloadTerm {}
|
|
|
|
| WhileTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Type2Opcode
|
2005-06-29 19:39:47 +04:00
|
|
|
: AcquireTerm {}
|
|
|
|
| AddTerm {}
|
|
|
|
| AndTerm {}
|
|
|
|
| ConcatTerm {}
|
|
|
|
| ConcatResTerm {}
|
|
|
|
| CondRefOfTerm {}
|
|
|
|
| CopyTerm {}
|
|
|
|
| DecTerm {}
|
|
|
|
| DerefOfTerm {}
|
|
|
|
| DivideTerm {}
|
|
|
|
| FindSetLeftBitTerm {}
|
|
|
|
| FindSetRightBitTerm {}
|
|
|
|
| FromBCDTerm {}
|
|
|
|
| IncTerm {}
|
|
|
|
| IndexTerm {}
|
|
|
|
| LAndTerm {}
|
|
|
|
| LEqualTerm {}
|
|
|
|
| LGreaterTerm {}
|
|
|
|
| LGreaterEqualTerm {}
|
|
|
|
| LLessTerm {}
|
|
|
|
| LLessEqualTerm {}
|
|
|
|
| LNotTerm {}
|
|
|
|
| LNotEqualTerm {}
|
|
|
|
| LoadTableTerm {}
|
|
|
|
| LOrTerm {}
|
|
|
|
| MatchTerm {}
|
|
|
|
| MidTerm {}
|
|
|
|
| ModTerm {}
|
|
|
|
| MultiplyTerm {}
|
|
|
|
| NAndTerm {}
|
|
|
|
| NOrTerm {}
|
|
|
|
| NotTerm {}
|
|
|
|
| ObjectTypeTerm {}
|
|
|
|
| OrTerm {}
|
|
|
|
| RefOfTerm {}
|
|
|
|
| ShiftLeftTerm {}
|
|
|
|
| ShiftRightTerm {}
|
|
|
|
| SizeOfTerm {}
|
|
|
|
| StoreTerm {}
|
|
|
|
| StringTerm {}
|
|
|
|
| SubtractTerm {}
|
|
|
|
| ToBCDTerm {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| ToBufferTerm {}
|
|
|
|
| ToDecimalStringTerm {}
|
|
|
|
| ToHexStringTerm {}
|
|
|
|
| ToIntegerTerm {}
|
2005-06-29 19:39:47 +04:00
|
|
|
| WaitTerm {}
|
|
|
|
| XOrTerm {}
|
|
|
|
| UserTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* A type 3 opcode evaluates to an Integer and cannot have a destination operand
|
|
|
|
*/
|
|
|
|
|
|
|
|
Type3Opcode
|
2005-06-29 19:39:47 +04:00
|
|
|
: AddTerm {}
|
|
|
|
| AndTerm {}
|
|
|
|
| DecTerm {}
|
|
|
|
| DivideTerm {}
|
|
|
|
| EISAIDTerm {}
|
|
|
|
| FindSetLeftBitTerm {}
|
|
|
|
| FindSetRightBitTerm {}
|
|
|
|
| FromBCDTerm {}
|
|
|
|
| IncTerm {}
|
|
|
|
| IndexTerm {}
|
|
|
|
| LAndTerm {}
|
|
|
|
| LEqualTerm {}
|
|
|
|
| LGreaterTerm {}
|
|
|
|
| LGreaterEqualTerm {}
|
|
|
|
| LLessTerm {}
|
|
|
|
| LLessEqualTerm {}
|
|
|
|
| LNotTerm {}
|
|
|
|
| LNotEqualTerm {}
|
|
|
|
| LOrTerm {}
|
|
|
|
| MatchTerm {}
|
|
|
|
| ModTerm {}
|
|
|
|
| MultiplyTerm {}
|
|
|
|
| NAndTerm {}
|
|
|
|
| NOrTerm {}
|
|
|
|
| NotTerm {}
|
|
|
|
| OrTerm {}
|
|
|
|
| ShiftLeftTerm {}
|
|
|
|
| ShiftRightTerm {}
|
|
|
|
| SubtractTerm {}
|
|
|
|
| ToBCDTerm {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| ToIntegerTerm {}
|
2005-06-29 19:39:47 +04:00
|
|
|
| XOrTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Type4Opcode
|
2005-06-29 19:39:47 +04:00
|
|
|
: ConcatTerm {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| ToDecimalStringTerm {}
|
|
|
|
| ToHexStringTerm {}
|
2005-06-29 19:39:47 +04:00
|
|
|
| MidTerm {}
|
|
|
|
| StringTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Type5Opcode
|
2005-06-29 19:39:54 +04:00
|
|
|
: ToBufferTerm {}
|
2005-06-29 19:39:47 +04:00
|
|
|
| ConcatTerm {}
|
|
|
|
| ConcatResTerm {}
|
|
|
|
| MidTerm {}
|
|
|
|
| ResourceTemplateTerm {}
|
|
|
|
| UnicodeTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Type6Opcode
|
2005-06-29 19:39:47 +04:00
|
|
|
: RefOfTerm {}
|
|
|
|
| DerefOfTerm {}
|
|
|
|
| IndexTerm {}
|
|
|
|
| UserTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IncludeTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: INCLUDE '('
|
2005-06-29 19:39:54 +04:00
|
|
|
String {FlOpenIncludeFile ($3)}
|
|
|
|
')'
|
|
|
|
TermList {$$ = $6}
|
|
|
|
;
|
|
|
|
|
|
|
|
IncludeCStyleTerm
|
|
|
|
: INCLUDE_CSTYLE
|
|
|
|
String {FlOpenIncludeFile ($2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ExternalTerm
|
|
|
|
: EXTERNAL '('
|
2005-06-29 19:39:47 +04:00
|
|
|
String ','
|
|
|
|
ObjectTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgCreateNode (EXTERNAL,2,$3,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/******* Named Objects *******************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
BankFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: BANKFIELD '(' {$$ = TgCreateLeafNode (BANKFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
NameString ','
|
|
|
|
TermArg ','
|
|
|
|
AccessTypeKeyword ','
|
|
|
|
LockRuleKeyword ','
|
|
|
|
UpdateRuleKeyword
|
|
|
|
')' '{'
|
|
|
|
FieldUnitList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,7,$4,$6,$8,$10,$12,$14,$17)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FieldUnitList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| FieldUnit
|
2005-06-29 19:39:54 +04:00
|
|
|
FieldUnitListTail {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FieldUnitListTail
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL} /* Allows a trailing comma at list end */
|
|
|
|
| ',' FieldUnit
|
2005-06-29 19:39:54 +04:00
|
|
|
FieldUnitListTail {$$ = TgLinkPeerNode ($2,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FieldUnit
|
2005-06-29 19:39:47 +04:00
|
|
|
: FieldUnitEntry {}
|
|
|
|
| OffsetTerm {}
|
|
|
|
| AccessAsTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FieldUnitEntry
|
2005-06-29 19:39:54 +04:00
|
|
|
: ',' AmlPackageLengthTerm {$$ = TgCreateNode (RESERVED_BYTES,1,$2)}
|
2005-06-29 19:39:47 +04:00
|
|
|
| NameSeg ','
|
2005-06-29 19:39:54 +04:00
|
|
|
AmlPackageLengthTerm {$$ = TgLinkChildNode ($1,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
OffsetTerm
|
|
|
|
: OFFSET '('
|
|
|
|
AmlPackageLengthTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgCreateNode (OFFSET,1,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
AccessAsTerm
|
|
|
|
: ACCESSAS '('
|
|
|
|
AccessTypeKeyword
|
|
|
|
OptionalAccessAttribTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgCreateNode (ACCESSAS,2,$3,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CreateBitFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CREATEBITFIELD '(' {$$ = TgCreateLeafNode (CREATEBITFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CreateByteFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CREATEBYTEFIELD '(' {$$ = TgCreateLeafNode (CREATEBYTEFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CreateDWordFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CREATEDWORDFIELD '(' {$$ = TgCreateLeafNode (CREATEDWORDFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CreateFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CREATEFIELD '(' {$$ = TgCreateLeafNode (CREATEFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$10)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CreateQWordFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CREATEQWORDFIELD '(' {$$ = TgCreateLeafNode (CREATEQWORDFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CreateWordFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CREATEWORDFIELD '(' {$$ = TgCreateLeafNode (CREATEWORDFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DataRegionTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DATATABLEREGION '(' {$$ = TgCreateLeafNode (DATATABLEREGION)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$10)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DeviceTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DEVICE '(' {$$ = TgCreateLeafNode (DEVICE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
NameString
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
|
|
|
ObjectList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
EventTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: EVENT '(' {$$ = TgCreateLeafNode (EVENT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: FIELD '(' {$$ = TgCreateLeafNode (FIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
AccessTypeKeyword ','
|
|
|
|
LockRuleKeyword ','
|
|
|
|
UpdateRuleKeyword
|
|
|
|
')' '{'
|
|
|
|
FieldUnitList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,5,$4,$6,$8,$10,$13)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IndexFieldTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: INDEXFIELD '(' {$$ = TgCreateLeafNode (INDEXFIELD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
NameString ','
|
|
|
|
AccessTypeKeyword ','
|
|
|
|
LockRuleKeyword ','
|
|
|
|
UpdateRuleKeyword
|
|
|
|
')' '{'
|
|
|
|
FieldUnitList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$15)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MethodTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: METHOD '(' {$$ = TgCreateLeafNode (METHOD)}
|
2005-06-29 19:37:15 +04:00
|
|
|
NameString
|
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalSerializeRuleKeyword
|
|
|
|
OptionalByteConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
TermList '}' {$$ = TgLinkChildren ($<n>3,5,$4,$5,$6,$7,$10)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MutexTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: MUTEX '(' {$$ = TgCreateLeafNode (MUTEX)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
ByteConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
OpRegionTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: OPERATIONREGION '(' {$$ = TgCreateLeafNode (OPERATIONREGION)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
OpRegionSpaceIdTerm ','
|
|
|
|
TermArg ','
|
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$10)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
OpRegionSpaceIdTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: RegionSpaceKeyword {}
|
|
|
|
| ByteConst {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PowerResTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: POWERRESOURCE '(' {$$ = TgCreateLeafNode (POWERRESOURCE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
ByteConstExpr ','
|
|
|
|
WordConstExpr
|
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ObjectList '}' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$11)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ProcessorTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: PROCESSOR '(' {$$ = TgCreateLeafNode (PROCESSOR)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
2005-06-29 19:39:51 +04:00
|
|
|
ByteConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalDWordConstExpr
|
|
|
|
OptionalByteConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ObjectList '}' {$$ = TgLinkChildren ($<n>3,5,$4,$6,$7,$8,$11)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ThermalZoneTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: THERMALZONE '(' {$$ = TgCreateLeafNode (THERMALZONE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
NameString
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ObjectList '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/******* Namespace modifiers *************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
AliasTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: ALIAS '(' {$$ = TgCreateLeafNode (ALIAS)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
NameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NameTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: NAME '(' {$$ = TgCreateLeafNode (NAME)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
DataRefObject
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ScopeTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SCOPE '(' {$$ = TgCreateLeafNode (SCOPE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
NameString
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ObjectList '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/******* Type 1 opcodes *******************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
BreakTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: BREAK {$$ = TgCreateNode (BREAK, 0)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
BreakPointTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: BREAKPOINT {$$ = TgCreateNode (BREAKPOINT, 0)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ContinueTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CONTINUE {$$ = TgCreateNode (CONTINUE, 0)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FatalTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: FATAL '(' {$$ = TgCreateLeafNode (FATAL)}
|
2005-06-29 19:39:47 +04:00
|
|
|
ByteConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IfElseTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: IfTerm ElseTerm {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
IfTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: IF '(' {$$ = TgCreateLeafNode (IF)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
|
|
|
TermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ElseTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
2005-06-29 19:39:54 +04:00
|
|
|
| ELSE '{' {$$ = TgCreateLeafNode (ELSE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,1,$4)}
|
|
|
|
|
|
|
|
| ELSEIF '{' {$$ = TgCreateLeafNode (ELSEIF)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermList '}'
|
|
|
|
ElseTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LoadTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LOAD '(' {$$ = TgCreateLeafNode (LOAD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
NameString ','
|
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NoOpTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: NOOP {$$ = TgCreateNode (NOOP, 0)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
NotifyTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: NOTIFY '(' {$$ = TgCreateLeafNode (NOTIFY)}
|
2005-06-29 19:39:47 +04:00
|
|
|
SuperName ','
|
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ReleaseTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: RELEASE '(' {$$ = TgCreateLeafNode (RELEASE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
ResetTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: RESET '(' {$$ = TgCreateLeafNode (RESET)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ReturnTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: RETURN '(' {$$ = TgCreateLeafNode (RETURN)}
|
|
|
|
OptionalTermArg
|
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
SignalTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SIGNAL '(' {$$ = TgCreateLeafNode (SIGNAL)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
SleepTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SLEEP '(' {$$ = TgCreateLeafNode (SLEEP)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
StallTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: STALL '(' {$$ = TgCreateLeafNode (STALL)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
SwitchTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SWITCH '(' {$$ = TgCreateLeafNode (SWITCH)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
|
|
|
CaseTermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CaseTermList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {}
|
|
|
|
| CaseTerm {}
|
|
|
|
| DefaultTerm
|
|
|
|
DefaultTermList {}
|
|
|
|
| CaseTerm
|
|
|
|
CaseTermList {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DefaultTermList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {}
|
|
|
|
| CaseTerm {}
|
|
|
|
| CaseTerm
|
|
|
|
DefaultTermList {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CaseTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CASE '(' {$$ = TgCreateLeafNode (CASE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
DataObject
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
|
|
|
TermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DefaultTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DEFAULT '{' {$$ = TgCreateLeafNode (DEFAULT)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
UnloadTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: UNLOAD '(' {$$ = TgCreateLeafNode (UNLOAD)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
WhileTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: WHILE '(' {$$ = TgCreateLeafNode (WHILE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{' TermList '}'
|
2005-06-29 19:39:54 +04:00
|
|
|
{$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
/******* Type 2 opcodes *******************************************************/
|
|
|
|
|
|
|
|
AcquireTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: ACQUIRE '(' {$$ = TgCreateLeafNode (ACQUIRE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
SuperName ','
|
|
|
|
WordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
AddTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: ADD '(' {$$ = TgCreateLeafNode (ADD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
AndTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: AND '(' {$$ = TgCreateLeafNode (AND)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ConcatTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CONCATENATE '(' {$$ = TgCreateLeafNode (CONCATENATE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ConcatResTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CONCATENATERESTEMPLATE '(' {$$ = TgCreateLeafNode (CONCATENATERESTEMPLATE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CondRefOfTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: CONDREFOF '(' {$$ = TgCreateLeafNode (CONDREFOF)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
CopyTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: COPY '(' {$$ = TgCreateLeafNode (COPY)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
CopyTarget
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:39:47 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
CopyTarget
|
|
|
|
: NameString {}
|
|
|
|
| LocalTerm {}
|
|
|
|
| ArgTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DecTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DECREMENT '(' {$$ = TgCreateLeafNode (DECREMENT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DerefOfTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DEREFOF '(' {$$ = TgCreateLeafNode (DEREFOF)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DivideTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DIVIDE '(' {$$ = TgCreateLeafNode (DIVIDE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$7,$8)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FindSetLeftBitTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: FINDSETLEFTBIT '(' {$$ = TgCreateLeafNode (FINDSETLEFTBIT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FindSetRightBitTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: FINDSETRIGHTBIT '(' {$$ = TgCreateLeafNode (FINDSETRIGHTBIT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FromBCDTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: FROMBCD '(' {$$ = TgCreateLeafNode (FROMBCD)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IncTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: INCREMENT '(' {$$ = TgCreateLeafNode (INCREMENT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IndexTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: INDEX '(' {$$ = TgCreateLeafNode (INDEX)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LAndTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LAND '(' {$$ = TgCreateLeafNode (LAND)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LEqualTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LEQUAL '(' {$$ = TgCreateLeafNode (LEQUAL)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LGreaterTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LGREATER '(' {$$ = TgCreateLeafNode (LGREATER)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LGreaterEqualTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LGREATEREQUAL '(' {$$ = TgCreateLeafNode (LGREATEREQUAL)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LLessTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LLESS '(' {$$ = TgCreateLeafNode (LLESS)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LLessEqualTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LLESSEQUAL '(' {$$ = TgCreateLeafNode (LLESSEQUAL)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LNotTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LNOT '(' {$$ = TgCreateLeafNode (LNOT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LNotEqualTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LNOTEQUAL '(' {$$ = TgCreateLeafNode (LNOTEQUAL)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LoadTableTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LOADTABLE '(' {$$ = TgCreateLeafNode (LOADTABLE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
OptionalListTermArg
|
|
|
|
OptionalListTermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalListTermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,6,$4,$6,$8,$9,$10,$11)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LOrTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LOR '(' {$$ = TgCreateLeafNode (LOR)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MatchTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: MATCH '(' {$$ = TgCreateLeafNode (MATCH)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
MatchOpKeyword ','
|
|
|
|
TermArg ','
|
|
|
|
MatchOpKeyword ','
|
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$14)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MidTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: MID '(' {$$ = TgCreateLeafNode (MID)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$9)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ModTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: MOD '(' {$$ = TgCreateLeafNode (MOD)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MultiplyTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: MULTIPLY '(' {$$ = TgCreateLeafNode (MULTIPLY)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NAndTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: NAND '(' {$$ = TgCreateLeafNode (NAND)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NOrTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: NOR '(' {$$ = TgCreateLeafNode (NOR)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
NotTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: NOT '(' {$$ = TgCreateLeafNode (NOT)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ObjectTypeTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: OBJECTTYPE '(' {$$ = TgCreateLeafNode (OBJECTTYPE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
OrTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: OR '(' {$$ = TgCreateLeafNode (OR)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:54 +04:00
|
|
|
/*
|
|
|
|
* In RefOf, the node isn't really a target, but we can't keep track of it after
|
|
|
|
* we've taken a pointer to it. (hard to tell if a local becomes initialized this way.)
|
|
|
|
*/
|
2005-06-29 19:37:15 +04:00
|
|
|
RefOfTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: REFOF '(' {$$ = TgCreateLeafNode (REFOF)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,TgSetNodeFlags ($4, NODE_IS_TARGET))}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ShiftLeftTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SHIFTLEFT '(' {$$ = TgCreateLeafNode (SHIFTLEFT)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ShiftRightTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SHIFTRIGHT '(' {$$ = TgCreateLeafNode (SHIFTRIGHT)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
SizeOfTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SIZEOF '(' {$$ = TgCreateLeafNode (SIZEOF)}
|
2005-06-29 19:37:15 +04:00
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,1,$4)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
StoreTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: STORE '(' {$$ = TgCreateLeafNode (STORE)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
|
|
|
SuperName
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,TgSetNodeFlags ($6, NODE_IS_TARGET))}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
StringTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: STRING '(' {$$ = TgCreateLeafNode (STRING)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalListTermArg
|
2005-06-29 19:37:15 +04:00
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$5,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
SubtractTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: SUBTRACT '(' {$$ = TgCreateLeafNode (SUBTRACT)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
ToBCDTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: TOBCD '(' {$$ = TgCreateLeafNode (TOBCD)}
|
|
|
|
TermArg
|
|
|
|
Target
|
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
|
|
|
;
|
|
|
|
|
|
|
|
ToBufferTerm
|
|
|
|
: TOBUFFER '(' {$$ = TgCreateLeafNode (TOBUFFER)}
|
|
|
|
TermArg
|
|
|
|
Target
|
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
|
|
|
;
|
|
|
|
|
|
|
|
ToDecimalStringTerm
|
|
|
|
: TODECIMALSTRING '(' {$$ = TgCreateLeafNode (TODECIMALSTRING)}
|
|
|
|
TermArg
|
|
|
|
Target
|
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
|
|
|
;
|
|
|
|
|
|
|
|
ToHexStringTerm
|
|
|
|
: TOHEXSTRING '(' {$$ = TgCreateLeafNode (TOHEXSTRING)}
|
|
|
|
TermArg
|
|
|
|
Target
|
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
|
|
|
;
|
|
|
|
|
|
|
|
ToIntegerTerm
|
|
|
|
: TOINTEGER '(' {$$ = TgCreateLeafNode (TOINTEGER)}
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
WaitTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: WAIT '(' {$$ = TgCreateLeafNode (WAIT)}
|
2005-06-29 19:39:47 +04:00
|
|
|
SuperName ','
|
|
|
|
TermArg
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,2,$4,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
XOrTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: XOR '(' {$$ = TgCreateLeafNode (XOR)}
|
2005-06-29 19:39:47 +04:00
|
|
|
TermArg ','
|
2005-06-29 19:37:15 +04:00
|
|
|
TermArg
|
|
|
|
Target
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/******* Keywords *************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
ObjectTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: OBJECTTYPE_UNK {$$ = TgCreateLeafNode (OBJECTTYPE_UNK)}
|
|
|
|
| OBJECTTYPE_INT {$$ = TgCreateLeafNode (OBJECTTYPE_INT)}
|
|
|
|
| OBJECTTYPE_STR {$$ = TgCreateLeafNode (OBJECTTYPE_STR)}
|
|
|
|
| OBJECTTYPE_BUF {$$ = TgCreateLeafNode (OBJECTTYPE_BUF)}
|
|
|
|
| OBJECTTYPE_PKG {$$ = TgCreateLeafNode (OBJECTTYPE_PKG)}
|
|
|
|
| OBJECTTYPE_FLD {$$ = TgCreateLeafNode (OBJECTTYPE_FLD)}
|
|
|
|
| OBJECTTYPE_DEV {$$ = TgCreateLeafNode (OBJECTTYPE_DEV)}
|
|
|
|
| OBJECTTYPE_EVT {$$ = TgCreateLeafNode (OBJECTTYPE_EVT)}
|
|
|
|
| OBJECTTYPE_MTH {$$ = TgCreateLeafNode (OBJECTTYPE_MTH)}
|
|
|
|
| OBJECTTYPE_MTX {$$ = TgCreateLeafNode (OBJECTTYPE_MTX)}
|
|
|
|
| OBJECTTYPE_OPR {$$ = TgCreateLeafNode (OBJECTTYPE_OPR)}
|
|
|
|
| OBJECTTYPE_POW {$$ = TgCreateLeafNode (OBJECTTYPE_POW)}
|
|
|
|
| OBJECTTYPE_THZ {$$ = TgCreateLeafNode (OBJECTTYPE_THZ)}
|
|
|
|
| OBJECTTYPE_BFF {$$ = TgCreateLeafNode (OBJECTTYPE_BFF)}
|
|
|
|
| OBJECTTYPE_DDB {$$ = TgCreateLeafNode (OBJECTTYPE_DDB)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
AccessTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: ACCESSTYPE_ANY {$$ = TgCreateLeafNode (ACCESSTYPE_ANY)}
|
|
|
|
| ACCESSTYPE_BYTE {$$ = TgCreateLeafNode (ACCESSTYPE_BYTE)}
|
|
|
|
| ACCESSTYPE_WORD {$$ = TgCreateLeafNode (ACCESSTYPE_WORD)}
|
|
|
|
| ACCESSTYPE_DWORD {$$ = TgCreateLeafNode (ACCESSTYPE_DWORD)}
|
|
|
|
| ACCESSTYPE_QWORD {$$ = TgCreateLeafNode (ACCESSTYPE_QWORD)}
|
|
|
|
| ACCESSTYPE_BUF {$$ = TgCreateLeafNode (ACCESSTYPE_BUF)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
AccessAttribKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: ACCESSATTRIB_QUICK {$$ = TgCreateLeafNode (ACCESSATTRIB_QUICK )}
|
|
|
|
| ACCESSATTRIB_SND_RCV {$$ = TgCreateLeafNode (ACCESSATTRIB_SND_RCV)}
|
|
|
|
| ACCESSATTRIB_BYTE {$$ = TgCreateLeafNode (ACCESSATTRIB_BYTE)}
|
|
|
|
| ACCESSATTRIB_WORD {$$ = TgCreateLeafNode (ACCESSATTRIB_WORD)}
|
|
|
|
| ACCESSATTRIB_BLOCK {$$ = TgCreateLeafNode (ACCESSATTRIB_BLOCK)}
|
|
|
|
| ACCESSATTRIB_CALL {$$ = TgCreateLeafNode (ACCESSATTRIB_CALL)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LockRuleKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: LOCKRULE_LOCK {$$ = TgCreateLeafNode (LOCKRULE_LOCK)}
|
|
|
|
| LOCKRULE_NOLOCK {$$ = TgCreateLeafNode (LOCKRULE_NOLOCK)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
UpdateRuleKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: UPDATERULE_PRESERVE {$$ = TgCreateLeafNode (UPDATERULE_PRESERVE)}
|
|
|
|
| UPDATERULE_ONES {$$ = TgCreateLeafNode (UPDATERULE_ONES)}
|
|
|
|
| UPDATERULE_ZEROS {$$ = TgCreateLeafNode (UPDATERULE_ZEROS)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
RegionSpaceKeyword
|
2005-06-29 19:39:47 +04:00
|
|
|
: UserDefRegionSpace {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| REGIONSPACE_IO {$$ = TgCreateLeafNode (REGIONSPACE_IO)}
|
|
|
|
| REGIONSPACE_MEM {$$ = TgCreateLeafNode (REGIONSPACE_MEM)}
|
|
|
|
| REGIONSPACE_PCI {$$ = TgCreateLeafNode (REGIONSPACE_PCI)}
|
|
|
|
| REGIONSPACE_EC {$$ = TgCreateLeafNode (REGIONSPACE_EC)}
|
|
|
|
| REGIONSPACE_SMBUS {$$ = TgCreateLeafNode (REGIONSPACE_SMBUS)}
|
|
|
|
| REGIONSPACE_CMOS {$$ = TgCreateLeafNode (REGIONSPACE_CMOS)}
|
|
|
|
| REGIONSPACE_PCIBAR {$$ = TgCreateLeafNode (REGIONSPACE_PCIBAR)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
AddressSpaceKeyword
|
2005-06-29 19:39:47 +04:00
|
|
|
: RegionSpaceKeyword {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| ADDRESSSPACE_FFIXEDHW {$$ = TgCreateLeafNode (ADDRESSSPACE_FFIXEDHW)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
UserDefRegionSpace
|
|
|
|
: ByteConst {}
|
|
|
|
;
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
SerializeRuleKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: SERIALIZERULE_SERIAL {$$ = TgCreateLeafNode (SERIALIZERULE_SERIAL)}
|
|
|
|
| SERIALIZERULE_NOTSERIAL {$$ = TgCreateLeafNode (SERIALIZERULE_NOTSERIAL)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MatchOpKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: MATCHTYPE_MTR {$$ = TgCreateLeafNode (MATCHTYPE_MTR)}
|
|
|
|
| MATCHTYPE_MEQ {$$ = TgCreateLeafNode (MATCHTYPE_MEQ)}
|
|
|
|
| MATCHTYPE_MLE {$$ = TgCreateLeafNode (MATCHTYPE_MLE)}
|
|
|
|
| MATCHTYPE_MLT {$$ = TgCreateLeafNode (MATCHTYPE_MLT)}
|
|
|
|
| MATCHTYPE_MGE {$$ = TgCreateLeafNode (MATCHTYPE_MGE)}
|
|
|
|
| MATCHTYPE_MGT {$$ = TgCreateLeafNode (MATCHTYPE_MGT)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DMATypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: DMATYPE_A {$$ = TgCreateLeafNode (DMATYPE_A)}
|
|
|
|
| DMATYPE_COMPATIBILITY {$$ = TgCreateLeafNode (DMATYPE_COMPATIBILITY)}
|
|
|
|
| DMATYPE_B {$$ = TgCreateLeafNode (DMATYPE_B)}
|
|
|
|
| DMATYPE_F {$$ = TgCreateLeafNode (DMATYPE_F)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
BusMasterKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: BUSMASTERTYPE_MASTER {$$ = TgCreateLeafNode (BUSMASTERTYPE_MASTER)}
|
|
|
|
| BUSMASTERTYPE_NOTMASTER {$$ = TgCreateLeafNode (BUSMASTERTYPE_NOTMASTER)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
XferTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: XFERTYPE_8 {$$ = TgCreateLeafNode (XFERTYPE_8)}
|
|
|
|
| XFERTYPE_8_16 {$$ = TgCreateLeafNode (XFERTYPE_8_16)}
|
|
|
|
| XFERTYPE_16 {$$ = TgCreateLeafNode (XFERTYPE_16)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ResourceTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: RESOURCETYPE_CONSUMER {$$ = TgCreateLeafNode (RESOURCETYPE_CONSUMER)}
|
|
|
|
| RESOURCETYPE_PRODUCER {$$ = TgCreateLeafNode (RESOURCETYPE_PRODUCER)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MinKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: MINTYPE_FIXED {$$ = TgCreateLeafNode (MINTYPE_FIXED)}
|
|
|
|
| MINTYPE_NOTFIXED {$$ = TgCreateLeafNode (MINTYPE_NOTFIXED)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MaxKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: MAXTYPE_FIXED {$$ = TgCreateLeafNode (MAXTYPE_FIXED)}
|
|
|
|
| MAXTYPE_NOTFIXED {$$ = TgCreateLeafNode (MAXTYPE_NOTFIXED)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DecodeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: DECODETYPE_POS {$$ = TgCreateLeafNode (DECODETYPE_POS)}
|
|
|
|
| DECODETYPE_SUB {$$ = TgCreateLeafNode (DECODETYPE_SUB)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
RangeTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: RANGETYPE_ISAONLY {$$ = TgCreateLeafNode (RANGETYPE_ISAONLY)}
|
|
|
|
| RANGETYPE_NONISAONLY {$$ = TgCreateLeafNode (RANGETYPE_NONISAONLY)}
|
|
|
|
| RANGETYPE_ENTIRE {$$ = TgCreateLeafNode (RANGETYPE_ENTIRE)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
MemTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: MEMTYPE_CACHEABLE {$$ = TgCreateLeafNode (MEMTYPE_CACHEABLE)}
|
|
|
|
| MEMTYPE_WRITECOMBINING {$$ = TgCreateLeafNode (MEMTYPE_WRITECOMBINING)}
|
|
|
|
| MEMTYPE_PREFETCHABLE {$$ = TgCreateLeafNode (MEMTYPE_PREFETCHABLE)}
|
|
|
|
| MEMTYPE_NONCACHEABLE {$$ = TgCreateLeafNode (MEMTYPE_NONCACHEABLE)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ReadWriteKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: READWRITETYPE_BOTH {$$ = TgCreateLeafNode (READWRITETYPE_BOTH)}
|
|
|
|
| READWRITETYPE_READONLY {$$ = TgCreateLeafNode (READWRITETYPE_READONLY)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
InterruptTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: INTTYPE_EDGE {$$ = TgCreateLeafNode (INTTYPE_EDGE)}
|
|
|
|
| INTTYPE_LEVEL {$$ = TgCreateLeafNode (INTTYPE_LEVEL)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
InterruptLevel
|
2005-06-29 19:39:54 +04:00
|
|
|
: INTLEVEL_ACTIVEHIGH {$$ = TgCreateLeafNode (INTLEVEL_ACTIVEHIGH)}
|
|
|
|
| INTLEVEL_ACTIVELOW {$$ = TgCreateLeafNode (INTLEVEL_ACTIVELOW)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ShareTypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: SHARETYPE_SHARED {$$ = TgCreateLeafNode (SHARETYPE_SHARED)}
|
|
|
|
| SHARETYPE_EXCLUSIVE {$$ = TgCreateLeafNode (SHARETYPE_EXCLUSIVE)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IODecodeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: IODECODETYPE_16 {$$ = TgCreateLeafNode (IODECODETYPE_16)}
|
|
|
|
| IODECODETYPE_10 {$$ = TgCreateLeafNode (IODECODETYPE_10)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
TypeKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: TYPE_TRANSLATION {$$ = TgCreateLeafNode (TYPE_TRANSLATION)}
|
|
|
|
| TYPE_STATIC {$$ = TgCreateLeafNode (TYPE_STATIC)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
TranslationKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: TRANSLATIONTYPE_SPARSE {$$ = TgCreateLeafNode (TRANSLATIONTYPE_SPARSE)}
|
|
|
|
| TRANSLATIONTYPE_DENSE {$$ = TgCreateLeafNode (TRANSLATIONTYPE_DENSE)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
AddressKeyword
|
2005-06-29 19:39:54 +04:00
|
|
|
: ADDRESSTYPE_MEMORY {$$ = TgCreateLeafNode (ADDRESSTYPE_MEMORY)}
|
|
|
|
| ADDRESSTYPE_RESERVED {$$ = TgCreateLeafNode (ADDRESSTYPE_RESERVED)}
|
|
|
|
| ADDRESSTYPE_NVS {$$ = TgCreateLeafNode (ADDRESSTYPE_NVS)}
|
|
|
|
| ADDRESSTYPE_ACPI {$$ = TgCreateLeafNode (ADDRESSTYPE_ACPI)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
/******* Miscellaneous Types **************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
SuperName
|
2005-06-29 19:39:47 +04:00
|
|
|
: NameString {}
|
|
|
|
| ArgTerm {}
|
|
|
|
| LocalTerm {}
|
|
|
|
| DebugTerm {}
|
|
|
|
| Type6Opcode {}
|
|
|
|
| UserTerm {}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ArgTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: ARG0 {$$ = TgCreateLeafNode (ARG0)}
|
|
|
|
| ARG1 {$$ = TgCreateLeafNode (ARG1)}
|
|
|
|
| ARG2 {$$ = TgCreateLeafNode (ARG2)}
|
|
|
|
| ARG3 {$$ = TgCreateLeafNode (ARG3)}
|
|
|
|
| ARG4 {$$ = TgCreateLeafNode (ARG4)}
|
|
|
|
| ARG5 {$$ = TgCreateLeafNode (ARG5)}
|
|
|
|
| ARG6 {$$ = TgCreateLeafNode (ARG6)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
LocalTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: LOCAL0 {$$ = TgCreateLeafNode (LOCAL0)}
|
|
|
|
| LOCAL1 {$$ = TgCreateLeafNode (LOCAL1)}
|
|
|
|
| LOCAL2 {$$ = TgCreateLeafNode (LOCAL2)}
|
|
|
|
| LOCAL3 {$$ = TgCreateLeafNode (LOCAL3)}
|
|
|
|
| LOCAL4 {$$ = TgCreateLeafNode (LOCAL4)}
|
|
|
|
| LOCAL5 {$$ = TgCreateLeafNode (LOCAL5)}
|
|
|
|
| LOCAL6 {$$ = TgCreateLeafNode (LOCAL6)}
|
|
|
|
| LOCAL7 {$$ = TgCreateLeafNode (LOCAL7)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DebugTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DEBUG {$$ = TgCreateLeafNode (DEBUG)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
Integer
|
2005-06-29 19:39:54 +04:00
|
|
|
: INTEGER {$$ = TgCreateValuedLeafNode (INTEGER, (void *) AslCompilerlval.i)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:39:47 +04:00
|
|
|
;
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
ByteConst
|
2005-06-29 19:39:54 +04:00
|
|
|
: Integer {$$ = TgUpdateNode (BYTECONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
WordConst
|
2005-06-29 19:39:54 +04:00
|
|
|
: Integer {$$ = TgUpdateNode (WORDCONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
DwordConst
|
2005-06-29 19:39:54 +04:00
|
|
|
: Integer {$$ = TgUpdateNode (DWORDCONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
QwordConst
|
2005-06-29 19:39:54 +04:00
|
|
|
: Integer {$$ = TgUpdateNode (QWORDCONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
String
|
2005-06-29 19:39:54 +04:00
|
|
|
: STRING_LITERAL {$$ = TgCreateValuedLeafNode (STRING_LITERAL, AslCompilerlval.s)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
/*
|
|
|
|
* TBD: Needs | REVISION
|
|
|
|
*/
|
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
ConstTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: ZERO {$$ = TgCreateLeafNode (ZERO)}
|
|
|
|
| ONE {$$ = TgCreateLeafNode (ONE)}
|
|
|
|
| ONES {$$ = TgCreateLeafNode (ONES)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ByteConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
: Type3Opcode {$$ = TgUpdateNode (BYTECONST, $1)}
|
|
|
|
| ConstExprTerm {$$ = TgUpdateNode (BYTECONST, $1)}
|
|
|
|
| Integer {$$ = TgUpdateNode (BYTECONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
WordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
: Type3Opcode {$$ = TgUpdateNode (WORDCONST, $1)}
|
|
|
|
| ConstExprTerm {$$ = TgUpdateNode (WORDCONST, $1)}
|
|
|
|
| Integer {$$ = TgUpdateNode (WORDCONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DWordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
: Type3Opcode {$$ = TgUpdateNode (DWORDCONST, $1)}
|
|
|
|
| ConstExprTerm {$$ = TgUpdateNode (DWORDCONST, $1)}
|
|
|
|
| Integer {$$ = TgUpdateNode (DWORDCONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
QWordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
: Type3Opcode {$$ = TgUpdateNode (QWORDCONST, $1)}
|
|
|
|
| ConstExprTerm {$$ = TgUpdateNode (QWORDCONST, $1)}
|
|
|
|
| Integer {$$ = TgUpdateNode (QWORDCONST, $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ConstExprTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: ZERO {$$ = TgCreateLeafNode (ZERO)}
|
|
|
|
| ONE {$$ = TgCreateLeafNode (ONE)}
|
|
|
|
| ONES {$$ = TgCreateLeafNode (ONES)}
|
|
|
|
| error {$$= NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
BufferTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: BUFFER '(' {$$ = TgCreateLeafNode (BUFFER)}
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalTermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
BufferData '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
BufferData
|
2005-06-29 19:39:54 +04:00
|
|
|
: ByteList {}
|
|
|
|
| StringData {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ByteList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ByteConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteListTail {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ByteListTail
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL} /* Allows a trailing comma at list end */
|
|
|
|
| ',' ByteConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteListTail {$$ = TgLinkPeerNode ($2,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DWordList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| DWordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
DWordListTail {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DWordListTail
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL} /* Allows a trailing comma at list end */
|
|
|
|
| ',' DWordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
DWordListTail {$$ = TgLinkPeerNode ($2,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PackageTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: PACKAGE '(' {$$ = TgCreateLeafNode (PACKAGE)}
|
2005-06-29 19:37:15 +04:00
|
|
|
PackageLengthTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
PackageList '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PackageLengthTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ByteConstExpr {}
|
|
|
|
| TermArg {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PackageList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| PackageElement
|
2005-06-29 19:39:54 +04:00
|
|
|
PackageListTail {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PackageListTail
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL} /* Allows a trailing comma at list end */
|
|
|
|
| ',' PackageElement
|
2005-06-29 19:39:54 +04:00
|
|
|
PackageListTail {$$ = TgLinkPeerNode ($2,$3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
PackageElement
|
2005-06-29 19:39:47 +04:00
|
|
|
: DataObject {}
|
|
|
|
| NameString {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
EISAIDTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: EISAID '('
|
2005-06-29 19:39:54 +04:00
|
|
|
StringData ')' {$$ = TgUpdateNode (EISAID, $3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
/******* Resources and Memory ***********************************************/
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
ResourceTemplateTerm
|
|
|
|
: RESOURCETEMPLATE '(' ')'
|
2005-06-29 19:39:47 +04:00
|
|
|
'{'
|
|
|
|
ResourceMacroList '}' {$$ = TgCreateNode (RESOURCETEMPLATE,3,
|
2005-06-29 19:39:54 +04:00
|
|
|
TgCreateLeafNode (DEFAULT_ARG),
|
|
|
|
TgCreateLeafNode (DEFAULT_ARG),$5)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
UnicodeTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: UNICODE '('
|
2005-06-29 19:37:15 +04:00
|
|
|
StringData
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgUpdateNode (UNICODE, $3)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ResourceMacroList
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ResourceMacroTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
ResourceMacroList {$$ = TgLinkPeerNode ($1,$2)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
ResourceMacroTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: DMATerm {}
|
|
|
|
| DWordIOTerm {}
|
|
|
|
| DWordMemoryTerm {}
|
|
|
|
| EndDependentFnTerm {}
|
|
|
|
| FixedIOTerm {}
|
|
|
|
| InterruptTerm {}
|
|
|
|
| IOTerm {}
|
|
|
|
| IRQNoFlagsTerm {}
|
|
|
|
| IRQTerm {}
|
|
|
|
| Memory24Term {}
|
|
|
|
| Memory32FixedTerm {}
|
|
|
|
| Memory32Term {}
|
|
|
|
| QWordIOTerm {}
|
|
|
|
| QWordMemoryTerm {}
|
|
|
|
| RegisterTerm {}
|
|
|
|
| StartDependentFnTerm {}
|
|
|
|
| StartDependentFnNoPriTerm {}
|
|
|
|
| VendorLongTerm {}
|
|
|
|
| VendorShortTerm {}
|
|
|
|
| WordBusNumberTerm {}
|
|
|
|
| WordIOTerm {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DMATerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DMA '(' {$$ = TgCreateLeafNode (DMA)}
|
2005-06-29 19:39:47 +04:00
|
|
|
DMATypeKeyword ','
|
|
|
|
BusMasterKeyword ','
|
2005-06-29 19:39:51 +04:00
|
|
|
XferTypeKeyword
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
2005-06-29 19:37:15 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteList '}' {$$ = TgLinkChildren ($<n>3,5,$4,$6,$8,$9,$12)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DWordIOTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DWORDIO '(' {$$ = TgCreateLeafNode (DWORDIO)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalMinType
|
|
|
|
OptionalMaxType
|
|
|
|
OptionalDecodeType
|
|
|
|
OptionalRangeType
|
2005-06-29 19:39:47 +04:00
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
|
|
|
OptionalNameString
|
|
|
|
OptionalType
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalTranslationType
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,15,$4,$5,$6,$7,$8,$9,$11,$13,$15,$17,$18,$19,$20,$21,$22)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
DWordMemoryTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: DWORDMEMORY '(' {$$ = TgCreateLeafNode (DWORDMEMORY)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalDecodeType
|
|
|
|
OptionalMinType
|
|
|
|
OptionalMaxType
|
|
|
|
OptionalMemType
|
2005-06-29 19:39:47 +04:00
|
|
|
ReadWriteKeyword ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
|
|
|
OptionalNameString
|
|
|
|
OptionalAddressRange
|
2005-06-29 19:39:51 +04:00
|
|
|
OptionalType
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,16,$4,$5,$6,$7,$8,$9,$11,$13,$15,$17,$19,$20,$21,$22,$23,$24)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
EndDependentFnTerm
|
2005-06-29 19:39:47 +04:00
|
|
|
: ENDDEPENDENTFN '('
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgCreateLeafNode (ENDDEPENDENTFN)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
FixedIOTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: FIXEDIO '(' {$$ = TgCreateLeafNode (FIXEDIO)}
|
2005-06-29 19:39:47 +04:00
|
|
|
WordConstExpr ','
|
|
|
|
ByteConstExpr
|
|
|
|
OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
InterruptTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: INTERRUPT '(' {$$ = TgCreateLeafNode (INTERRUPT)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
|
|
|
InterruptTypeKeyword ','
|
|
|
|
InterruptLevel
|
|
|
|
OptionalShareType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
2005-06-29 19:37:15 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
DWordList '}' {$$ = TgLinkChildren ($<n>3,8,$4,$5,$7,$8,$9,$10,$11,$14)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IOTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: IO '(' {$$ = TgCreateLeafNode (IO)}
|
2005-06-29 19:39:47 +04:00
|
|
|
IODecodeKeyword ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
ByteConstExpr ','
|
|
|
|
ByteConstExpr
|
|
|
|
OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$13)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IRQNoFlagsTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: IRQNOFLAGS '(' {$$ = TgCreateLeafNode (IRQNOFLAGS)}
|
|
|
|
OptionalNameString_First
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteList '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
IRQTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: IRQ '(' {$$ = TgCreateLeafNode (IRQ)}
|
2005-06-29 19:39:47 +04:00
|
|
|
InterruptTypeKeyword ','
|
|
|
|
InterruptLevel
|
|
|
|
OptionalShareType
|
|
|
|
OptionalNameString
|
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteList '}' {$$ = TgLinkChildren ($<n>3,5,$4,$6,$7,$8,$11)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Memory24Term
|
2005-06-29 19:39:54 +04:00
|
|
|
: MEMORY24 '(' {$$ = TgCreateLeafNode (MEMORY24)}
|
2005-06-29 19:39:47 +04:00
|
|
|
ReadWriteKeyword ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
2005-06-29 19:39:51 +04:00
|
|
|
WordConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$13)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Memory32FixedTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: MEMORY32FIXED '(' {$$ = TgCreateLeafNode (MEMORY32FIXED)}
|
2005-06-29 19:39:47 +04:00
|
|
|
ReadWriteKeyword ','
|
|
|
|
DWordConstExpr ','
|
2005-06-29 19:39:51 +04:00
|
|
|
DWordConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$9)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
Memory32Term
|
2005-06-29 19:39:54 +04:00
|
|
|
: MEMORY32 '(' {$$ = TgCreateLeafNode (MEMORY32)}
|
2005-06-29 19:39:47 +04:00
|
|
|
ReadWriteKeyword ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
|
|
|
DWordConstExpr ','
|
2005-06-29 19:39:51 +04:00
|
|
|
DWordConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,6,$4,$6,$8,$10,$12,$13)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
QWordIOTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: QWORDIO '(' {$$ = TgCreateLeafNode (QWORDIO)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalMinType
|
|
|
|
OptionalMaxType
|
|
|
|
OptionalDecodeType
|
|
|
|
OptionalRangeType
|
2005-06-29 19:39:47 +04:00
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
|
|
|
OptionalNameString
|
|
|
|
OptionalType
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalTranslationType
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,15,$4,$5,$6,$7,$8,$9,$11,$13,$15,$17,$18,$19,$20,$21,$22)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
QWordMemoryTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: QWORDMEMORY '(' {$$ = TgCreateLeafNode (QWORDMEMORY)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalDecodeType
|
|
|
|
OptionalMinType
|
|
|
|
OptionalMaxType
|
|
|
|
OptionalMemType
|
2005-06-29 19:39:47 +04:00
|
|
|
ReadWriteKeyword ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr ','
|
|
|
|
QWordConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
|
|
|
OptionalNameString
|
|
|
|
OptionalAddressRange
|
2005-06-29 19:39:51 +04:00
|
|
|
OptionalType
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,16,$4,$5,$6,$7,$8,$9,$11,$13,$15,$17,$19,$20,$21,$22,$23,$24)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
RegisterTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: REGISTER '(' {$$ = TgCreateLeafNode (REGISTER)}
|
2005-06-29 19:39:47 +04:00
|
|
|
AddressKeyword ','
|
|
|
|
ByteConstExpr ','
|
|
|
|
ByteConstExpr ','
|
|
|
|
QWordConstExpr
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,4,$4,$6,$8,$10)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
StartDependentFnTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: STARTDEPENDENTFN '(' {$$ = TgCreateLeafNode (STARTDEPENDENTFN)}
|
2005-06-29 19:39:47 +04:00
|
|
|
ByteConstExpr ','
|
2005-06-29 19:39:51 +04:00
|
|
|
ByteConstExpr
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ResourceMacroList '}' {$$ = TgLinkChildren ($<n>3,3,$4,$6,$9)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
StartDependentFnNoPriTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: STARTDEPENDENTFN_NOPRI '(' {$$ = TgCreateLeafNode (STARTDEPENDENTFN_NOPRI)}
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ResourceMacroList '}' {$$ = TgLinkChildren ($<n>3,1,$6)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
VendorLongTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: VENDORLONG '(' {$$ = TgCreateLeafNode (VENDORLONG)}
|
|
|
|
OptionalNameString_First
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteList '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
VendorShortTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: VENDORSHORT '(' {$$ = TgCreateLeafNode (VENDORSHORT)}
|
|
|
|
OptionalNameString_First
|
2005-06-29 19:39:47 +04:00
|
|
|
')' '{'
|
2005-06-29 19:39:54 +04:00
|
|
|
ByteList '}' {$$ = TgLinkChildren ($<n>3,2,$4,$7)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
WordBusNumberTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: WORDBUSNUMBER '(' {$$ = TgCreateLeafNode (WORDBUSNUMBER)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalMinType
|
|
|
|
OptionalMaxType
|
|
|
|
OptionalDecodeType
|
2005-06-29 19:39:47 +04:00
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,12,$4,$5,$6,$7,$8,$10,$12,$14,$16,$17,$18,$19)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
WordIOTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: WORDIO '(' {$$ = TgCreateLeafNode (WORDIO)}
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalMinType
|
|
|
|
OptionalMaxType
|
|
|
|
OptionalDecodeType
|
|
|
|
OptionalRangeType
|
2005-06-29 19:39:47 +04:00
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr ','
|
|
|
|
WordConstExpr
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalByteConstExpr
|
|
|
|
OptionalStringData
|
|
|
|
OptionalNameString
|
|
|
|
OptionalType
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalTranslationType
|
2005-06-29 19:39:54 +04:00
|
|
|
')' {$$ = TgLinkChildren ($<n>3,15,$4,$5,$6,$7,$8,$9,$11,$13,$15,$17,$18,$19,$20,$21,$22)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
/******* Object References ***********************************************/
|
|
|
|
|
|
|
|
|
|
|
|
NameString
|
2005-06-29 19:39:47 +04:00
|
|
|
: NameSeg {}
|
2005-06-29 19:39:54 +04:00
|
|
|
| NAMESTRING {$$ = TgCreateValuedLeafNode (NAMESTRING, AslCompilerlval.s)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
NameSeg
|
2005-06-29 19:39:54 +04:00
|
|
|
: NAMESEG {$$ = TgCreateValuedLeafNode (NAMESEG, AslCompilerlval.s)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
/* TBD: Could not find in spec */
|
2005-06-29 19:37:15 +04:00
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
ObjectReference
|
2005-06-29 19:39:51 +04:00
|
|
|
: NameString {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
DDBHandle
|
2005-06-29 19:39:51 +04:00
|
|
|
: String {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
/******* Helper rules ****************************************************/
|
2005-06-29 19:37:15 +04:00
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
|
|
|
AmlPackageLengthTerm
|
2005-06-29 19:39:54 +04:00
|
|
|
: Integer {$$ = TgUpdateNode (PACKAGE_LENGTH,(ASL_PARSE_NODE *) $1)}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
OptionalListTermArg
|
2005-06-29 19:39:47 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' TermArg {$$ = $2}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalTermArg
|
|
|
|
: {$$ = NULL}
|
|
|
|
| TermArg {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalComma
|
|
|
|
: {}
|
|
|
|
| ',' {}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalAccessAttribTerm
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' ByteConstExpr {$$ = $2}
|
|
|
|
| ',' AccessAttribKeyword {$$ = $2}
|
|
|
|
| ',' {$$ = NULL}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalAccessAttribKeyword
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' AccessAttribKeyword {$$ = $2}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalSerializeRuleKeyword
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' SerializeRuleKeyword {$$ = $2}
|
|
|
|
|
|
|
|
|
|
|
|
OptionalByteConstExpr
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' ByteConstExpr {$$ = $2}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalDWordConstExpr
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' DWordConstExpr {$$ = $2}
|
|
|
|
;
|
2005-06-29 19:37:15 +04:00
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalStringData
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' StringData {$$ = $2}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalNameString
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' NameString {$$ = $2}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:54 +04:00
|
|
|
OptionalNameString_First
|
|
|
|
: {$$ = NULL}
|
|
|
|
| NameString {$$ = $1}
|
|
|
|
;
|
|
|
|
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalAddressRange
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' AddressKeyword {$$ = $2}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalResourceType
|
|
|
|
: ',' {$$ = NULL}
|
|
|
|
| ResourceTypeKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalMinType
|
|
|
|
: ',' {$$ = NULL}
|
|
|
|
| MinKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalMaxType
|
|
|
|
: ',' {$$ = NULL}
|
|
|
|
| MaxKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalMemType
|
|
|
|
: ',' {$$ = NULL}
|
|
|
|
| MemTypeKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalDecodeType
|
|
|
|
: ',' {$$ = NULL}
|
|
|
|
| DecodeKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalRangeType
|
|
|
|
: ',' {$$ = NULL}
|
|
|
|
| RangeTypeKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalShareType
|
2005-06-29 19:39:54 +04:00
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| ',' ShareTypeKeyword {$$ = $2}
|
2005-06-29 19:39:47 +04:00
|
|
|
;
|
2005-06-29 19:37:15 +04:00
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalType
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| TypeKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
OptionalTranslationType
|
|
|
|
: {$$ = NULL}
|
|
|
|
| ',' {$$ = NULL}
|
|
|
|
| TranslationKeyword ',' {$$ = $1}
|
2005-06-29 19:37:15 +04:00
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
%%
|
|
|
|
|
|
|
|
/* programs */
|
|
|
|
|
2005-06-29 19:39:47 +04:00
|
|
|
/*
|
|
|
|
* ???
|
|
|
|
*/
|
2005-06-29 19:37:15 +04:00
|
|
|
int
|
2005-06-29 19:39:47 +04:00
|
|
|
AslCompilerwrap()
|
2005-06-29 19:37:15 +04:00
|
|
|
{
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2005-06-29 19:39:54 +04:00
|
|
|
void *
|
|
|
|
AslLocalAllocate (unsigned int Size)
|
|
|
|
{
|
|
|
|
void *Mem;
|
|
|
|
|
|
|
|
|
|
|
|
DbgPrint ("\nAslLocalAllocate: Expanding Stack to %d\n\n", Size);
|
|
|
|
|
|
|
|
Mem = _CmCallocate (Size, 0, "", 0);
|
|
|
|
if (!Mem)
|
|
|
|
{
|
|
|
|
AslCommonError (ASL_ERROR, ASL_MSG_MEMORY_ALLOCATION, Gbl_CurrentLineNumber,
|
|
|
|
Gbl_LogicalLineNumber, NULL);
|
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (Mem);
|
|
|
|
}
|
|
|
|
|
2005-06-29 19:37:15 +04:00
|
|
|
|
|
|
|
|
|
|
|
|