1984 lines
		
	
	
	
		
			52 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
		
		
			
		
	
	
			1984 lines
		
	
	
	
		
			52 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
|   | /* A Bison parser, made by GNU Bison 2.3.  */ | |||
|  | 
 | |||
|  | /* Skeleton implementation for Bison's Yacc-like parsers in C | |||
|  | 
 | |||
|  |    Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 | |||
|  |    Free Software Foundation, Inc. | |||
|  | 
 | |||
|  |    This program is free software; you can redistribute it and/or modify | |||
|  |    it under the terms of the GNU General Public License as published by | |||
|  |    the Free Software Foundation; either version 2, or (at your option) | |||
|  |    any later version. | |||
|  | 
 | |||
|  |    This program is distributed in the hope that it will be useful, | |||
|  |    but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
|  |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |||
|  |    GNU General Public License for more details. | |||
|  | 
 | |||
|  |    You should have received a copy of the GNU General Public License | |||
|  |    along with this program; if not, write to the Free Software | |||
|  |    Foundation, Inc., 51 Franklin Street, Fifth Floor, | |||
|  |    Boston, MA 02110-1301, USA.  */ | |||
|  | 
 | |||
|  | /* As a special exception, you may create a larger work that contains | |||
|  |    part or all of the Bison parser skeleton and distribute that work | |||
|  |    under terms of your choice, so long as that work isn't itself a | |||
|  |    parser generator using the skeleton or a modified version thereof | |||
|  |    as a parser skeleton.  Alternatively, if you modify or redistribute | |||
|  |    the parser skeleton itself, you may (at your option) remove this | |||
|  |    special exception, which will cause the skeleton and the resulting | |||
|  |    Bison output files to be licensed under the GNU General Public | |||
|  |    License without this special exception. | |||
|  | 
 | |||
|  |    This special exception was added by the Free Software Foundation in | |||
|  |    version 2.2 of Bison.  */ | |||
|  | 
 | |||
|  | /* C LALR(1) parser skeleton written by Richard Stallman, by | |||
|  |    simplifying the original so-called "semantic" parser.  */ | |||
|  | 
 | |||
|  | /* All symbols defined below should begin with yy or YY, to avoid | |||
|  |    infringing on user name space.  This should be done even for local | |||
|  |    variables, as they might otherwise be expanded by user macros. | |||
|  |    There are some unavoidable exceptions within include files to | |||
|  |    define necessary library symbols; they are noted "INFRINGES ON | |||
|  |    USER NAME SPACE" below.  */ | |||
|  | 
 | |||
|  | /* Identify Bison output.  */ | |||
|  | #define YYBISON 1 | |||
|  | 
 | |||
|  | /* Bison version.  */ | |||
|  | #define YYBISON_VERSION "2.3" | |||
|  | 
 | |||
|  | /* Skeleton name.  */ | |||
|  | #define YYSKELETON_NAME "yacc.c" | |||
|  | 
 | |||
|  | /* Pure parsers.  */ | |||
|  | #define YYPURE 0 | |||
|  | 
 | |||
|  | /* Using locations.  */ | |||
|  | #define YYLSP_NEEDED 1 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Tokens.  */ | |||
|  | #ifndef YYTOKENTYPE | |||
|  | # define YYTOKENTYPE | |||
|  |    /* Put the tokens into the symbol table, so that GDB and other debuggers | |||
|  |       know about them.  */ | |||
|  |    enum yytokentype { | |||
|  |      DT_V1 = 258, | |||
|  |      DT_MEMRESERVE = 259, | |||
|  |      DT_PROPNODENAME = 260, | |||
|  |      DT_LITERAL = 261, | |||
|  |      DT_LEGACYLITERAL = 262, | |||
|  |      DT_BASE = 263, | |||
|  |      DT_BYTE = 264, | |||
|  |      DT_STRING = 265, | |||
|  |      DT_LABEL = 266, | |||
|  |      DT_REF = 267 | |||
|  |    }; | |||
|  | #endif | |||
|  | /* Tokens.  */ | |||
|  | #define DT_V1 258 | |||
|  | #define DT_MEMRESERVE 259 | |||
|  | #define DT_PROPNODENAME 260 | |||
|  | #define DT_LITERAL 261 | |||
|  | #define DT_LEGACYLITERAL 262 | |||
|  | #define DT_BASE 263 | |||
|  | #define DT_BYTE 264 | |||
|  | #define DT_STRING 265 | |||
|  | #define DT_LABEL 266 | |||
|  | #define DT_REF 267 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Copy the first part of user declarations.  */ | |||
|  | #line 23 "dtc-parser.y" | |||
|  | 
 | |||
|  | #include "dtc.h" | |||
|  | #include "srcpos.h" | |||
|  | 
 | |||
|  | int yylex(void); | |||
|  | unsigned long long eval_literal(const char *s, int base, int bits); | |||
|  | 
 | |||
|  | extern struct boot_info *the_boot_info; | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Enabling traces.  */ | |||
|  | #ifndef YYDEBUG | |||
|  | # define YYDEBUG 0 | |||
|  | #endif | |||
|  | 
 | |||
|  | /* Enabling verbose error messages.  */ | |||
|  | #ifdef YYERROR_VERBOSE | |||
|  | # undef YYERROR_VERBOSE | |||
|  | # define YYERROR_VERBOSE 1 | |||
|  | #else | |||
|  | # define YYERROR_VERBOSE 0 | |||
|  | #endif | |||
|  | 
 | |||
|  | /* Enabling the token table.  */ | |||
|  | #ifndef YYTOKEN_TABLE | |||
|  | # define YYTOKEN_TABLE 0 | |||
|  | #endif | |||
|  | 
 | |||
|  | #if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED | |||
|  | typedef union YYSTYPE | |||
|  | #line 34 "dtc-parser.y" | |||
|  | { | |||
|  | 	char *propnodename; | |||
|  | 	char *literal; | |||
|  | 	char *labelref; | |||
|  | 	unsigned int cbase; | |||
|  | 	u8 byte; | |||
|  | 	struct data data; | |||
|  | 
 | |||
|  | 	u64 addr; | |||
|  | 	cell_t cell; | |||
|  | 	struct property *prop; | |||
|  | 	struct property *proplist; | |||
|  | 	struct node *node; | |||
|  | 	struct node *nodelist; | |||
|  | 	struct reserve_info *re; | |||
|  | } | |||
|  | /* Line 187 of yacc.c.  */ | |||
|  | #line 148 "dtc-parser.tab.c" | |||
|  | 	YYSTYPE; | |||
|  | # define yystype YYSTYPE /* obsolescent; will be withdrawn */ | |||
|  | # define YYSTYPE_IS_DECLARED 1 | |||
|  | # define YYSTYPE_IS_TRIVIAL 1 | |||
|  | #endif | |||
|  | 
 | |||
|  | #if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED | |||
|  | typedef struct YYLTYPE | |||
|  | { | |||
|  |   int first_line; | |||
|  |   int first_column; | |||
|  |   int last_line; | |||
|  |   int last_column; | |||
|  | } YYLTYPE; | |||
|  | # define yyltype YYLTYPE /* obsolescent; will be withdrawn */ | |||
|  | # define YYLTYPE_IS_DECLARED 1 | |||
|  | # define YYLTYPE_IS_TRIVIAL 1 | |||
|  | #endif | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Copy the second part of user declarations.  */ | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Line 216 of yacc.c.  */ | |||
|  | #line 173 "dtc-parser.tab.c" | |||
|  | 
 | |||
|  | #ifdef short | |||
|  | # undef short | |||
|  | #endif | |||
|  | 
 | |||
|  | #ifdef YYTYPE_UINT8 | |||
|  | typedef YYTYPE_UINT8 yytype_uint8; | |||
|  | #else | |||
|  | typedef unsigned char yytype_uint8; | |||
|  | #endif | |||
|  | 
 | |||
|  | #ifdef YYTYPE_INT8 | |||
|  | typedef YYTYPE_INT8 yytype_int8; | |||
|  | #elif (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | typedef signed char yytype_int8; | |||
|  | #else | |||
|  | typedef short int yytype_int8; | |||
|  | #endif | |||
|  | 
 | |||
|  | #ifdef YYTYPE_UINT16 | |||
|  | typedef YYTYPE_UINT16 yytype_uint16; | |||
|  | #else | |||
|  | typedef unsigned short int yytype_uint16; | |||
|  | #endif | |||
|  | 
 | |||
|  | #ifdef YYTYPE_INT16 | |||
|  | typedef YYTYPE_INT16 yytype_int16; | |||
|  | #else | |||
|  | typedef short int yytype_int16; | |||
|  | #endif | |||
|  | 
 | |||
|  | #ifndef YYSIZE_T | |||
|  | # ifdef __SIZE_TYPE__ | |||
|  | #  define YYSIZE_T __SIZE_TYPE__ | |||
|  | # elif defined size_t | |||
|  | #  define YYSIZE_T size_t | |||
|  | # elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | #  include <stddef.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #  define YYSIZE_T size_t | |||
|  | # else | |||
|  | #  define YYSIZE_T unsigned int | |||
|  | # endif | |||
|  | #endif | |||
|  | 
 | |||
|  | #define YYSIZE_MAXIMUM ((YYSIZE_T) -1) | |||
|  | 
 | |||
|  | #ifndef YY_ | |||
|  | # if YYENABLE_NLS | |||
|  | #  if ENABLE_NLS | |||
|  | #   include <libintl.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #   define YY_(msgid) dgettext ("bison-runtime", msgid) | |||
|  | #  endif | |||
|  | # endif | |||
|  | # ifndef YY_ | |||
|  | #  define YY_(msgid) msgid | |||
|  | # endif | |||
|  | #endif | |||
|  | 
 | |||
|  | /* Suppress unused-variable warnings by "using" E.  */ | |||
|  | #if ! defined lint || defined __GNUC__ | |||
|  | # define YYUSE(e) ((void) (e)) | |||
|  | #else | |||
|  | # define YYUSE(e) /* empty */ | |||
|  | #endif | |||
|  | 
 | |||
|  | /* Identity function, used to suppress warnings about constant conditions.  */ | |||
|  | #ifndef lint | |||
|  | # define YYID(n) (n) | |||
|  | #else | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static int | |||
|  | YYID (int i) | |||
|  | #else | |||
|  | static int | |||
|  | YYID (i) | |||
|  |     int i; | |||
|  | #endif | |||
|  | { | |||
|  |   return i; | |||
|  | } | |||
|  | #endif | |||
|  | 
 | |||
|  | #if ! defined yyoverflow || YYERROR_VERBOSE | |||
|  | 
 | |||
|  | /* The parser invokes alloca or malloc; define the necessary symbols.  */ | |||
|  | 
 | |||
|  | # ifdef YYSTACK_USE_ALLOCA | |||
|  | #  if YYSTACK_USE_ALLOCA | |||
|  | #   ifdef __GNUC__ | |||
|  | #    define YYSTACK_ALLOC __builtin_alloca | |||
|  | #   elif defined __BUILTIN_VA_ARG_INCR | |||
|  | #    include <alloca.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #   elif defined _AIX | |||
|  | #    define YYSTACK_ALLOC __alloca | |||
|  | #   elif defined _MSC_VER | |||
|  | #    include <malloc.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #    define alloca _alloca | |||
|  | #   else | |||
|  | #    define YYSTACK_ALLOC alloca | |||
|  | #    if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | #     include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #     ifndef _STDLIB_H | |||
|  | #      define _STDLIB_H 1 | |||
|  | #     endif | |||
|  | #    endif | |||
|  | #   endif | |||
|  | #  endif | |||
|  | # endif | |||
|  | 
 | |||
|  | # ifdef YYSTACK_ALLOC | |||
|  |    /* Pacify GCC's `empty if-body' warning.  */ | |||
|  | #  define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0)) | |||
|  | #  ifndef YYSTACK_ALLOC_MAXIMUM | |||
|  |     /* The OS might guarantee only one guard page at the bottom of the stack, | |||
|  |        and a page size can be as small as 4096 bytes.  So we cannot safely | |||
|  |        invoke alloca (N) if N exceeds 4096.  Use a slightly smaller number | |||
|  |        to allow for a few compiler-allocated temporary stack slots.  */ | |||
|  | #   define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */ | |||
|  | #  endif | |||
|  | # else | |||
|  | #  define YYSTACK_ALLOC YYMALLOC | |||
|  | #  define YYSTACK_FREE YYFREE | |||
|  | #  ifndef YYSTACK_ALLOC_MAXIMUM | |||
|  | #   define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM | |||
|  | #  endif | |||
|  | #  if (defined __cplusplus && ! defined _STDLIB_H \ | |||
|  |        && ! ((defined YYMALLOC || defined malloc) \ | |||
|  | 	     && (defined YYFREE || defined free))) | |||
|  | #   include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #   ifndef _STDLIB_H | |||
|  | #    define _STDLIB_H 1 | |||
|  | #   endif | |||
|  | #  endif | |||
|  | #  ifndef YYMALLOC | |||
|  | #   define YYMALLOC malloc | |||
|  | #   if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ | |||
|  | #   endif | |||
|  | #  endif | |||
|  | #  ifndef YYFREE | |||
|  | #   define YYFREE free | |||
|  | #   if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | void free (void *); /* INFRINGES ON USER NAME SPACE */ | |||
|  | #   endif | |||
|  | #  endif | |||
|  | # endif | |||
|  | #endif /* ! defined yyoverflow || YYERROR_VERBOSE */ | |||
|  | 
 | |||
|  | 
 | |||
|  | #if (! defined yyoverflow \ | |||
|  |      && (! defined __cplusplus \ | |||
|  | 	 || (defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL \ | |||
|  | 	     && defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL))) | |||
|  | 
 | |||
|  | /* A type that is properly aligned for any stack member.  */ | |||
|  | union yyalloc | |||
|  | { | |||
|  |   yytype_int16 yyss; | |||
|  |   YYSTYPE yyvs; | |||
|  |     YYLTYPE yyls; | |||
|  | }; | |||
|  | 
 | |||
|  | /* The size of the maximum gap between one aligned stack and the next.  */ | |||
|  | # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1) | |||
|  | 
 | |||
|  | /* The size of an array large to enough to hold all stacks, each with | |||
|  |    N elements.  */ | |||
|  | # define YYSTACK_BYTES(N) \ | |||
|  |      ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \ | |||
|  |       + 2 * YYSTACK_GAP_MAXIMUM) | |||
|  | 
 | |||
|  | /* Copy COUNT objects from FROM to TO.  The source and destination do | |||
|  |    not overlap.  */ | |||
|  | # ifndef YYCOPY | |||
|  | #  if defined __GNUC__ && 1 < __GNUC__ | |||
|  | #   define YYCOPY(To, From, Count) \ | |||
|  |       __builtin_memcpy (To, From, (Count) * sizeof (*(From))) | |||
|  | #  else | |||
|  | #   define YYCOPY(To, From, Count)		\ | |||
|  |       do					\ | |||
|  | 	{					\ | |||
|  | 	  YYSIZE_T yyi;				\ | |||
|  | 	  for (yyi = 0; yyi < (Count); yyi++)	\ | |||
|  | 	    (To)[yyi] = (From)[yyi];		\ | |||
|  | 	}					\ | |||
|  |       while (YYID (0)) | |||
|  | #  endif | |||
|  | # endif | |||
|  | 
 | |||
|  | /* Relocate STACK from its old location to the new one.  The | |||
|  |    local variables YYSIZE and YYSTACKSIZE give the old and new number of | |||
|  |    elements in the stack, and YYPTR gives the new location of the | |||
|  |    stack.  Advance YYPTR to a properly aligned location for the next | |||
|  |    stack.  */ | |||
|  | # define YYSTACK_RELOCATE(Stack)					\ | |||
|  |     do									\ | |||
|  |       {									\ | |||
|  | 	YYSIZE_T yynewbytes;						\ | |||
|  | 	YYCOPY (&yyptr->Stack, Stack, yysize);				\ | |||
|  | 	Stack = &yyptr->Stack;						\ | |||
|  | 	yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \ | |||
|  | 	yyptr += yynewbytes / sizeof (*yyptr);				\ | |||
|  |       }									\ | |||
|  |     while (YYID (0)) | |||
|  | 
 | |||
|  | #endif | |||
|  | 
 | |||
|  | /* YYFINAL -- State number of the termination state.  */ | |||
|  | #define YYFINAL  9 | |||
|  | /* YYLAST -- Last index in YYTABLE.  */ | |||
|  | #define YYLAST   60 | |||
|  | 
 | |||
|  | /* YYNTOKENS -- Number of terminals.  */ | |||
|  | #define YYNTOKENS  24 | |||
|  | /* YYNNTS -- Number of nonterminals.  */ | |||
|  | #define YYNNTS  20 | |||
|  | /* YYNRULES -- Number of rules.  */ | |||
|  | #define YYNRULES  43 | |||
|  | /* YYNRULES -- Number of states.  */ | |||
|  | #define YYNSTATES  67 | |||
|  | 
 | |||
|  | /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX.  */ | |||
|  | #define YYUNDEFTOK  2 | |||
|  | #define YYMAXUTOK   267 | |||
|  | 
 | |||
|  | #define YYTRANSLATE(YYX)						\ | |||
|  |   ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK) | |||
|  | 
 | |||
|  | /* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX.  */ | |||
|  | static const yytype_uint8 yytranslate[] = | |||
|  | { | |||
|  |        0,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,    23,    14,     2,    15,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,    13, | |||
|  |       19,    18,    20,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,    21,     2,    22,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,    16,     2,    17,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | |||
|  |        2,     2,     2,     2,     2,     2,     1,     2,     3,     4, | |||
|  |        5,     6,     7,     8,     9,    10,    11,    12 | |||
|  | }; | |||
|  | 
 | |||
|  | #if YYDEBUG | |||
|  | /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in | |||
|  |    YYRHS.  */ | |||
|  | static const yytype_uint8 yyprhs[] = | |||
|  | { | |||
|  |        0,     0,     3,     8,    11,    12,    15,    21,    22,    25, | |||
|  |       27,    34,    36,    38,    41,    47,    48,    51,    57,    61, | |||
|  |       64,    69,    74,    77,    80,    81,    84,    87,    88,    91, | |||
|  |       94,    97,    98,   100,   102,   105,   106,   109,   112,   113, | |||
|  |      116,   119,   123,   124 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYRHS -- A `-1'-separated list of the rules' RHS.  */ | |||
|  | static const yytype_int8 yyrhs[] = | |||
|  | { | |||
|  |       25,     0,    -1,     3,    13,    26,    31,    -1,    28,    31, | |||
|  |       -1,    -1,    27,    26,    -1,    43,     4,    30,    30,    13, | |||
|  |       -1,    -1,    29,    28,    -1,    27,    -1,    43,     4,    30, | |||
|  |       14,    30,    13,    -1,     6,    -1,     7,    -1,    15,    32, | |||
|  |       -1,    16,    33,    41,    17,    13,    -1,    -1,    33,    34, | |||
|  |       -1,    43,     5,    18,    35,    13,    -1,    43,     5,    13, | |||
|  |       -1,    36,    10,    -1,    36,    19,    37,    20,    -1,    36, | |||
|  |       21,    40,    22,    -1,    36,    12,    -1,    35,    11,    -1, | |||
|  |       -1,    35,    23,    -1,    36,    11,    -1,    -1,    37,    39, | |||
|  |       -1,    37,    12,    -1,    37,    11,    -1,    -1,     8,    -1, | |||
|  |        6,    -1,    38,     7,    -1,    -1,    40,     9,    -1,    40, | |||
|  |       11,    -1,    -1,    42,    41,    -1,    42,    34,    -1,    43, | |||
|  |        5,    32,    -1,    -1,    11,    -1 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYRLINE[YYN] -- source line where rule number YYN was defined.  */ | |||
|  | static const yytype_uint16 yyrline[] = | |||
|  | { | |||
|  |        0,    85,    85,    89,    97,   100,   107,   115,   118,   125, | |||
|  |      129,   136,   140,   147,   154,   162,   165,   172,   176,   183, | |||
|  |      187,   191,   195,   199,   207,   210,   214,   222,   225,   229, | |||
|  |      234,   242,   245,   249,   253,   261,   264,   268,   276,   279, | |||
|  |      283,   291,   299,   302 | |||
|  | }; | |||
|  | #endif | |||
|  | 
 | |||
|  | #if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE | |||
|  | /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM. | |||
|  |    First, the terminals, then, starting at YYNTOKENS, nonterminals.  */ | |||
|  | static const char *const yytname[] = | |||
|  | { | |||
|  |   "$end", "error", "$undefined", "DT_V1", "DT_MEMRESERVE", | |||
|  |   "DT_PROPNODENAME", "DT_LITERAL", "DT_LEGACYLITERAL", "DT_BASE", | |||
|  |   "DT_BYTE", "DT_STRING", "DT_LABEL", "DT_REF", "';'", "'-'", "'/'", "'{'", | |||
|  |   "'}'", "'='", "'<'", "'>'", "'['", "']'", "','", "$accept", "sourcefile", | |||
|  |   "memreserves", "memreserve", "v0_memreserves", "v0_memreserve", "addr", | |||
|  |   "devicetree", "nodedef", "proplist", "propdef", "propdata", | |||
|  |   "propdataprefix", "celllist", "cellbase", "cellval", "bytestring", | |||
|  |   "subnodes", "subnode", "label", 0 | |||
|  | }; | |||
|  | #endif | |||
|  | 
 | |||
|  | # ifdef YYPRINT | |||
|  | /* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to | |||
|  |    token YYLEX-NUM.  */ | |||
|  | static const yytype_uint16 yytoknum[] = | |||
|  | { | |||
|  |        0,   256,   257,   258,   259,   260,   261,   262,   263,   264, | |||
|  |      265,   266,   267,    59,    45,    47,   123,   125,    61,    60, | |||
|  |       62,    91,    93,    44 | |||
|  | }; | |||
|  | # endif | |||
|  | 
 | |||
|  | /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives.  */ | |||
|  | static const yytype_uint8 yyr1[] = | |||
|  | { | |||
|  |        0,    24,    25,    25,    26,    26,    27,    28,    28,    29, | |||
|  |       29,    30,    30,    31,    32,    33,    33,    34,    34,    35, | |||
|  |       35,    35,    35,    35,    36,    36,    36,    37,    37,    37, | |||
|  |       37,    38,    38,    39,    39,    40,    40,    40,    41,    41, | |||
|  |       41,    42,    43,    43 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN.  */ | |||
|  | static const yytype_uint8 yyr2[] = | |||
|  | { | |||
|  |        0,     2,     4,     2,     0,     2,     5,     0,     2,     1, | |||
|  |        6,     1,     1,     2,     5,     0,     2,     5,     3,     2, | |||
|  |        4,     4,     2,     2,     0,     2,     2,     0,     2,     2, | |||
|  |        2,     0,     1,     1,     2,     0,     2,     2,     0,     2, | |||
|  |        2,     3,     0,     1 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state | |||
|  |    STATE-NUM when YYTABLE doesn't specify something else to do.  Zero | |||
|  |    means the default is an error.  */ | |||
|  | static const yytype_uint8 yydefact[] = | |||
|  | { | |||
|  |        7,     0,    43,     0,     9,     0,     7,     0,     4,     1, | |||
|  |        0,     3,     8,     0,     0,     4,     0,    15,    13,    11, | |||
|  |       12,     0,     2,     5,     0,    38,     0,     0,     0,    16, | |||
|  |        0,    38,     0,     0,     6,     0,    40,    39,     0,    10, | |||
|  |       14,    18,    24,    41,     0,     0,    23,    17,    25,    19, | |||
|  |       26,    22,    27,    35,    31,     0,    33,    32,    30,    29, | |||
|  |       20,     0,    28,    36,    37,    21,    34 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYDEFGOTO[NTERM-NUM].  */ | |||
|  | static const yytype_int8 yydefgoto[] = | |||
|  | { | |||
|  |       -1,     3,    14,     4,     5,     6,    27,    11,    18,    25, | |||
|  |       29,    44,    45,    54,    61,    62,    55,    30,    31,     7 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing | |||
|  |    STATE-NUM.  */ | |||
|  | #define YYPACT_NINF -13 | |||
|  | static const yytype_int8 yypact[] = | |||
|  | { | |||
|  |       23,    11,   -13,    37,   -13,    -4,    18,    39,    18,   -13, | |||
|  |       28,   -13,   -13,    34,    -4,    18,    41,   -13,   -13,   -13, | |||
|  |      -13,    25,   -13,   -13,    34,    -3,    34,    33,    34,   -13, | |||
|  |       30,    -3,    43,    36,   -13,    38,   -13,   -13,    20,   -13, | |||
|  |      -13,   -13,   -13,   -13,     2,     9,   -13,   -13,   -13,   -13, | |||
|  |      -13,   -13,   -13,   -13,    -2,    -6,   -13,   -13,   -13,   -13, | |||
|  |      -13,    45,   -13,   -13,   -13,   -13,   -13 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYPGOTO[NTERM-NUM].  */ | |||
|  | static const yytype_int8 yypgoto[] = | |||
|  | { | |||
|  |      -13,   -13,    35,    27,    47,   -13,   -12,    40,    17,   -13, | |||
|  |       26,   -13,   -13,   -13,   -13,   -13,   -13,    29,   -13,    -8 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYTABLE[YYPACT[STATE-NUM]].  What to do in state STATE-NUM.  If | |||
|  |    positive, shift that token.  If negative, reduce the rule which | |||
|  |    number is the opposite.  If zero, do what YYDEFACT says. | |||
|  |    If YYTABLE_NINF, syntax error.  */ | |||
|  | #define YYTABLE_NINF -43 | |||
|  | static const yytype_int8 yytable[] = | |||
|  | { | |||
|  |       16,    21,   -42,    63,    56,    64,    57,    16,     2,    58, | |||
|  |       59,    10,    28,    46,    33,    47,    65,    32,    60,    49, | |||
|  |       50,    51,   -42,    32,     8,    48,     1,   -42,    52,     2, | |||
|  |       53,    19,    20,    41,     2,    15,    17,     9,    42,    26, | |||
|  |       19,    20,    15,    13,    17,    24,    34,    35,    38,    39, | |||
|  |       23,    40,    66,    12,    22,    43,     0,    36,     0,     0, | |||
|  |       37 | |||
|  | }; | |||
|  | 
 | |||
|  | static const yytype_int8 yycheck[] = | |||
|  | { | |||
|  |        8,    13,     5,     9,     6,    11,     8,    15,    11,    11, | |||
|  |       12,    15,    24,    11,    26,    13,    22,    25,    20,    10, | |||
|  |       11,    12,     4,    31,    13,    23,     3,     4,    19,    11, | |||
|  |       21,     6,     7,    13,    11,     8,    16,     0,    18,    14, | |||
|  |        6,     7,    15,     4,    16,     4,    13,    17,     5,    13, | |||
|  |       15,    13,     7,     6,    14,    38,    -1,    31,    -1,    -1, | |||
|  |       31 | |||
|  | }; | |||
|  | 
 | |||
|  | /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing | |||
|  |    symbol of state STATE-NUM.  */ | |||
|  | static const yytype_uint8 yystos[] = | |||
|  | { | |||
|  |        0,     3,    11,    25,    27,    28,    29,    43,    13,     0, | |||
|  |       15,    31,    28,     4,    26,    27,    43,    16,    32,     6, | |||
|  |        7,    30,    31,    26,     4,    33,    14,    30,    30,    34, | |||
|  |       41,    42,    43,    30,    13,    17,    34,    41,     5,    13, | |||
|  |       13,    13,    18,    32,    35,    36,    11,    13,    23,    10, | |||
|  |       11,    12,    19,    21,    37,    40,     6,     8,    11,    12, | |||
|  |       20,    38,    39,     9,    11,    22,     7 | |||
|  | }; | |||
|  | 
 | |||
|  | #define yyerrok		(yyerrstatus = 0) | |||
|  | #define yyclearin	(yychar = YYEMPTY) | |||
|  | #define YYEMPTY		(-2) | |||
|  | #define YYEOF		0 | |||
|  | 
 | |||
|  | #define YYACCEPT	goto yyacceptlab | |||
|  | #define YYABORT		goto yyabortlab | |||
|  | #define YYERROR		goto yyerrorlab | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Like YYERROR except do call yyerror.  This remains here temporarily | |||
|  |    to ease the transition to the new meaning of YYERROR, for GCC. | |||
|  |    Once GCC version 2 has supplanted version 1, this can go.  */ | |||
|  | 
 | |||
|  | #define YYFAIL		goto yyerrlab | |||
|  | 
 | |||
|  | #define YYRECOVERING()  (!!yyerrstatus) | |||
|  | 
 | |||
|  | #define YYBACKUP(Token, Value)					\ | |||
|  | do								\ | |||
|  |   if (yychar == YYEMPTY && yylen == 1)				\ | |||
|  |     {								\ | |||
|  |       yychar = (Token);						\ | |||
|  |       yylval = (Value);						\ | |||
|  |       yytoken = YYTRANSLATE (yychar);				\ | |||
|  |       YYPOPSTACK (1);						\ | |||
|  |       goto yybackup;						\ | |||
|  |     }								\ | |||
|  |   else								\ | |||
|  |     {								\ | |||
|  |       yyerror (YY_("syntax error: cannot back up")); \ | |||
|  |       YYERROR;							\ | |||
|  |     }								\ | |||
|  | while (YYID (0)) | |||
|  | 
 | |||
|  | 
 | |||
|  | #define YYTERROR	1 | |||
|  | #define YYERRCODE	256 | |||
|  | 
 | |||
|  | 
 | |||
|  | /* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N]. | |||
|  |    If N is 0, then set CURRENT to the empty location which ends | |||
|  |    the previous symbol: RHS[0] (always defined).  */ | |||
|  | 
 | |||
|  | #define YYRHSLOC(Rhs, K) ((Rhs)[K]) | |||
|  | #ifndef YYLLOC_DEFAULT | |||
|  | # define YYLLOC_DEFAULT(Current, Rhs, N)				\ | |||
|  |     do									\ | |||
|  |       if (YYID (N))                                                    \ | |||
|  | 	{								\ | |||
|  | 	  (Current).first_line   = YYRHSLOC (Rhs, 1).first_line;	\ | |||
|  | 	  (Current).first_column = YYRHSLOC (Rhs, 1).first_column;	\ | |||
|  | 	  (Current).last_line    = YYRHSLOC (Rhs, N).last_line;		\ | |||
|  | 	  (Current).last_column  = YYRHSLOC (Rhs, N).last_column;	\ | |||
|  | 	}								\ | |||
|  |       else								\ | |||
|  | 	{								\ | |||
|  | 	  (Current).first_line   = (Current).last_line   =		\ | |||
|  | 	    YYRHSLOC (Rhs, 0).last_line;				\ | |||
|  | 	  (Current).first_column = (Current).last_column =		\ | |||
|  | 	    YYRHSLOC (Rhs, 0).last_column;				\ | |||
|  | 	}								\ | |||
|  |     while (YYID (0)) | |||
|  | #endif | |||
|  | 
 | |||
|  | 
 | |||
|  | /* YY_LOCATION_PRINT -- Print the location on the stream. | |||
|  |    This macro was not mandated originally: define only if we know | |||
|  |    we won't break user code: when these are the locations we know.  */ | |||
|  | 
 | |||
|  | #ifndef YY_LOCATION_PRINT | |||
|  | # if YYLTYPE_IS_TRIVIAL | |||
|  | #  define YY_LOCATION_PRINT(File, Loc)			\ | |||
|  |      fprintf (File, "%d.%d-%d.%d",			\ | |||
|  | 	      (Loc).first_line, (Loc).first_column,	\ | |||
|  | 	      (Loc).last_line,  (Loc).last_column) | |||
|  | # else | |||
|  | #  define YY_LOCATION_PRINT(File, Loc) ((void) 0) | |||
|  | # endif | |||
|  | #endif | |||
|  | 
 | |||
|  | 
 | |||
|  | /* YYLEX -- calling `yylex' with the right arguments.  */ | |||
|  | 
 | |||
|  | #ifdef YYLEX_PARAM | |||
|  | # define YYLEX yylex (YYLEX_PARAM) | |||
|  | #else | |||
|  | # define YYLEX yylex () | |||
|  | #endif | |||
|  | 
 | |||
|  | /* Enable debugging if requested.  */ | |||
|  | #if YYDEBUG | |||
|  | 
 | |||
|  | # ifndef YYFPRINTF | |||
|  | #  include <stdio.h> /* INFRINGES ON USER NAME SPACE */ | |||
|  | #  define YYFPRINTF fprintf | |||
|  | # endif | |||
|  | 
 | |||
|  | # define YYDPRINTF(Args)			\ | |||
|  | do {						\ | |||
|  |   if (yydebug)					\ | |||
|  |     YYFPRINTF Args;				\ | |||
|  | } while (YYID (0)) | |||
|  | 
 | |||
|  | # define YY_SYMBOL_PRINT(Title, Type, Value, Location)			  \ | |||
|  | do {									  \ | |||
|  |   if (yydebug)								  \ | |||
|  |     {									  \ | |||
|  |       YYFPRINTF (stderr, "%s ", Title);					  \ | |||
|  |       yy_symbol_print (stderr,						  \ | |||
|  | 		  Type, Value, Location); \ | |||
|  |       YYFPRINTF (stderr, "\n");						  \ | |||
|  |     }									  \ | |||
|  | } while (YYID (0)) | |||
|  | 
 | |||
|  | 
 | |||
|  | /*--------------------------------. | |||
|  | | Print this symbol on YYOUTPUT.  | | |||
|  | `--------------------------------*/ | |||
|  | 
 | |||
|  | /*ARGSUSED*/ | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static void | |||
|  | yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep, YYLTYPE const * const yylocationp) | |||
|  | #else | |||
|  | static void | |||
|  | yy_symbol_value_print (yyoutput, yytype, yyvaluep, yylocationp) | |||
|  |     FILE *yyoutput; | |||
|  |     int yytype; | |||
|  |     YYSTYPE const * const yyvaluep; | |||
|  |     YYLTYPE const * const yylocationp; | |||
|  | #endif | |||
|  | { | |||
|  |   if (!yyvaluep) | |||
|  |     return; | |||
|  |   YYUSE (yylocationp); | |||
|  | # ifdef YYPRINT | |||
|  |   if (yytype < YYNTOKENS) | |||
|  |     YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep); | |||
|  | # else | |||
|  |   YYUSE (yyoutput); | |||
|  | # endif | |||
|  |   switch (yytype) | |||
|  |     { | |||
|  |       default: | |||
|  | 	break; | |||
|  |     } | |||
|  | } | |||
|  | 
 | |||
|  | 
 | |||
|  | /*--------------------------------. | |||
|  | | Print this symbol on YYOUTPUT.  | | |||
|  | `--------------------------------*/ | |||
|  | 
 | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static void | |||
|  | yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep, YYLTYPE const * const yylocationp) | |||
|  | #else | |||
|  | static void | |||
|  | yy_symbol_print (yyoutput, yytype, yyvaluep, yylocationp) | |||
|  |     FILE *yyoutput; | |||
|  |     int yytype; | |||
|  |     YYSTYPE const * const yyvaluep; | |||
|  |     YYLTYPE const * const yylocationp; | |||
|  | #endif | |||
|  | { | |||
|  |   if (yytype < YYNTOKENS) | |||
|  |     YYFPRINTF (yyoutput, "token %s (", yytname[yytype]); | |||
|  |   else | |||
|  |     YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]); | |||
|  | 
 | |||
|  |   YY_LOCATION_PRINT (yyoutput, *yylocationp); | |||
|  |   YYFPRINTF (yyoutput, ": "); | |||
|  |   yy_symbol_value_print (yyoutput, yytype, yyvaluep, yylocationp); | |||
|  |   YYFPRINTF (yyoutput, ")"); | |||
|  | } | |||
|  | 
 | |||
|  | /*------------------------------------------------------------------. | |||
|  | | yy_stack_print -- Print the state stack from its BOTTOM up to its | | |||
|  | | TOP (included).                                                   | | |||
|  | `------------------------------------------------------------------*/ | |||
|  | 
 | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static void | |||
|  | yy_stack_print (yytype_int16 *bottom, yytype_int16 *top) | |||
|  | #else | |||
|  | static void | |||
|  | yy_stack_print (bottom, top) | |||
|  |     yytype_int16 *bottom; | |||
|  |     yytype_int16 *top; | |||
|  | #endif | |||
|  | { | |||
|  |   YYFPRINTF (stderr, "Stack now"); | |||
|  |   for (; bottom <= top; ++bottom) | |||
|  |     YYFPRINTF (stderr, " %d", *bottom); | |||
|  |   YYFPRINTF (stderr, "\n"); | |||
|  | } | |||
|  | 
 | |||
|  | # define YY_STACK_PRINT(Bottom, Top)				\ | |||
|  | do {								\ | |||
|  |   if (yydebug)							\ | |||
|  |     yy_stack_print ((Bottom), (Top));				\ | |||
|  | } while (YYID (0)) | |||
|  | 
 | |||
|  | 
 | |||
|  | /*------------------------------------------------. | |||
|  | | Report that the YYRULE is going to be reduced.  | | |||
|  | `------------------------------------------------*/ | |||
|  | 
 | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static void | |||
|  | yy_reduce_print (YYSTYPE *yyvsp, YYLTYPE *yylsp, int yyrule) | |||
|  | #else | |||
|  | static void | |||
|  | yy_reduce_print (yyvsp, yylsp, yyrule) | |||
|  |     YYSTYPE *yyvsp; | |||
|  |     YYLTYPE *yylsp; | |||
|  |     int yyrule; | |||
|  | #endif | |||
|  | { | |||
|  |   int yynrhs = yyr2[yyrule]; | |||
|  |   int yyi; | |||
|  |   unsigned long int yylno = yyrline[yyrule]; | |||
|  |   YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n", | |||
|  | 	     yyrule - 1, yylno); | |||
|  |   /* The symbols being reduced.  */ | |||
|  |   for (yyi = 0; yyi < yynrhs; yyi++) | |||
|  |     { | |||
|  |       fprintf (stderr, "   $%d = ", yyi + 1); | |||
|  |       yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi], | |||
|  | 		       &(yyvsp[(yyi + 1) - (yynrhs)]) | |||
|  | 		       , &(yylsp[(yyi + 1) - (yynrhs)])		       ); | |||
|  |       fprintf (stderr, "\n"); | |||
|  |     } | |||
|  | } | |||
|  | 
 | |||
|  | # define YY_REDUCE_PRINT(Rule)		\ | |||
|  | do {					\ | |||
|  |   if (yydebug)				\ | |||
|  |     yy_reduce_print (yyvsp, yylsp, Rule); \ | |||
|  | } while (YYID (0)) | |||
|  | 
 | |||
|  | /* Nonzero means print parse trace.  It is left uninitialized so that | |||
|  |    multiple parsers can coexist.  */ | |||
|  | int yydebug; | |||
|  | #else /* !YYDEBUG */ | |||
|  | # define YYDPRINTF(Args) | |||
|  | # define YY_SYMBOL_PRINT(Title, Type, Value, Location) | |||
|  | # define YY_STACK_PRINT(Bottom, Top) | |||
|  | # define YY_REDUCE_PRINT(Rule) | |||
|  | #endif /* !YYDEBUG */ | |||
|  | 
 | |||
|  | 
 | |||
|  | /* YYINITDEPTH -- initial size of the parser's stacks.  */ | |||
|  | #ifndef	YYINITDEPTH | |||
|  | # define YYINITDEPTH 200 | |||
|  | #endif | |||
|  | 
 | |||
|  | /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only | |||
|  |    if the built-in stack extension method is used). | |||
|  | 
 | |||
|  |    Do not make this value too large; the results are undefined if | |||
|  |    YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH) | |||
|  |    evaluated with infinite-precision integer arithmetic.  */ | |||
|  | 
 | |||
|  | #ifndef YYMAXDEPTH | |||
|  | # define YYMAXDEPTH 10000 | |||
|  | #endif | |||
|  | 
 | |||
|  |  | |||
|  | 
 | |||
|  | #if YYERROR_VERBOSE | |||
|  | 
 | |||
|  | # ifndef yystrlen | |||
|  | #  if defined __GLIBC__ && defined _STRING_H | |||
|  | #   define yystrlen strlen | |||
|  | #  else | |||
|  | /* Return the length of YYSTR.  */ | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static YYSIZE_T | |||
|  | yystrlen (const char *yystr) | |||
|  | #else | |||
|  | static YYSIZE_T | |||
|  | yystrlen (yystr) | |||
|  |     const char *yystr; | |||
|  | #endif | |||
|  | { | |||
|  |   YYSIZE_T yylen; | |||
|  |   for (yylen = 0; yystr[yylen]; yylen++) | |||
|  |     continue; | |||
|  |   return yylen; | |||
|  | } | |||
|  | #  endif | |||
|  | # endif | |||
|  | 
 | |||
|  | # ifndef yystpcpy | |||
|  | #  if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE | |||
|  | #   define yystpcpy stpcpy | |||
|  | #  else | |||
|  | /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in | |||
|  |    YYDEST.  */ | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static char * | |||
|  | yystpcpy (char *yydest, const char *yysrc) | |||
|  | #else | |||
|  | static char * | |||
|  | yystpcpy (yydest, yysrc) | |||
|  |     char *yydest; | |||
|  |     const char *yysrc; | |||
|  | #endif | |||
|  | { | |||
|  |   char *yyd = yydest; | |||
|  |   const char *yys = yysrc; | |||
|  | 
 | |||
|  |   while ((*yyd++ = *yys++) != '\0') | |||
|  |     continue; | |||
|  | 
 | |||
|  |   return yyd - 1; | |||
|  | } | |||
|  | #  endif | |||
|  | # endif | |||
|  | 
 | |||
|  | # ifndef yytnamerr | |||
|  | /* Copy to YYRES the contents of YYSTR after stripping away unnecessary | |||
|  |    quotes and backslashes, so that it's suitable for yyerror.  The | |||
|  |    heuristic is that double-quoting is unnecessary unless the string | |||
|  |    contains an apostrophe, a comma, or backslash (other than | |||
|  |    backslash-backslash).  YYSTR is taken from yytname.  If YYRES is | |||
|  |    null, do not copy; instead, return the length of what the result | |||
|  |    would have been.  */ | |||
|  | static YYSIZE_T | |||
|  | yytnamerr (char *yyres, const char *yystr) | |||
|  | { | |||
|  |   if (*yystr == '"') | |||
|  |     { | |||
|  |       YYSIZE_T yyn = 0; | |||
|  |       char const *yyp = yystr; | |||
|  | 
 | |||
|  |       for (;;) | |||
|  | 	switch (*++yyp) | |||
|  | 	  { | |||
|  | 	  case '\'': | |||
|  | 	  case ',': | |||
|  | 	    goto do_not_strip_quotes; | |||
|  | 
 | |||
|  | 	  case '\\': | |||
|  | 	    if (*++yyp != '\\') | |||
|  | 	      goto do_not_strip_quotes; | |||
|  | 	    /* Fall through.  */ | |||
|  | 	  default: | |||
|  | 	    if (yyres) | |||
|  | 	      yyres[yyn] = *yyp; | |||
|  | 	    yyn++; | |||
|  | 	    break; | |||
|  | 
 | |||
|  | 	  case '"': | |||
|  | 	    if (yyres) | |||
|  | 	      yyres[yyn] = '\0'; | |||
|  | 	    return yyn; | |||
|  | 	  } | |||
|  |     do_not_strip_quotes: ; | |||
|  |     } | |||
|  | 
 | |||
|  |   if (! yyres) | |||
|  |     return yystrlen (yystr); | |||
|  | 
 | |||
|  |   return yystpcpy (yyres, yystr) - yyres; | |||
|  | } | |||
|  | # endif | |||
|  | 
 | |||
|  | /* Copy into YYRESULT an error message about the unexpected token | |||
|  |    YYCHAR while in state YYSTATE.  Return the number of bytes copied, | |||
|  |    including the terminating null byte.  If YYRESULT is null, do not | |||
|  |    copy anything; just return the number of bytes that would be | |||
|  |    copied.  As a special case, return 0 if an ordinary "syntax error" | |||
|  |    message will do.  Return YYSIZE_MAXIMUM if overflow occurs during | |||
|  |    size calculation.  */ | |||
|  | static YYSIZE_T | |||
|  | yysyntax_error (char *yyresult, int yystate, int yychar) | |||
|  | { | |||
|  |   int yyn = yypact[yystate]; | |||
|  | 
 | |||
|  |   if (! (YYPACT_NINF < yyn && yyn <= YYLAST)) | |||
|  |     return 0; | |||
|  |   else | |||
|  |     { | |||
|  |       int yytype = YYTRANSLATE (yychar); | |||
|  |       YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]); | |||
|  |       YYSIZE_T yysize = yysize0; | |||
|  |       YYSIZE_T yysize1; | |||
|  |       int yysize_overflow = 0; | |||
|  |       enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 }; | |||
|  |       char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM]; | |||
|  |       int yyx; | |||
|  | 
 | |||
|  | # if 0 | |||
|  |       /* This is so xgettext sees the translatable formats that are | |||
|  | 	 constructed on the fly.  */ | |||
|  |       YY_("syntax error, unexpected %s"); | |||
|  |       YY_("syntax error, unexpected %s, expecting %s"); | |||
|  |       YY_("syntax error, unexpected %s, expecting %s or %s"); | |||
|  |       YY_("syntax error, unexpected %s, expecting %s or %s or %s"); | |||
|  |       YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"); | |||
|  | # endif | |||
|  |       char *yyfmt; | |||
|  |       char const *yyf; | |||
|  |       static char const yyunexpected[] = "syntax error, unexpected %s"; | |||
|  |       static char const yyexpecting[] = ", expecting %s"; | |||
|  |       static char const yyor[] = " or %s"; | |||
|  |       char yyformat[sizeof yyunexpected | |||
|  | 		    + sizeof yyexpecting - 1 | |||
|  | 		    + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2) | |||
|  | 		       * (sizeof yyor - 1))]; | |||
|  |       char const *yyprefix = yyexpecting; | |||
|  | 
 | |||
|  |       /* Start YYX at -YYN if negative to avoid negative indexes in | |||
|  | 	 YYCHECK.  */ | |||
|  |       int yyxbegin = yyn < 0 ? -yyn : 0; | |||
|  | 
 | |||
|  |       /* Stay within bounds of both yycheck and yytname.  */ | |||
|  |       int yychecklim = YYLAST - yyn + 1; | |||
|  |       int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; | |||
|  |       int yycount = 1; | |||
|  | 
 | |||
|  |       yyarg[0] = yytname[yytype]; | |||
|  |       yyfmt = yystpcpy (yyformat, yyunexpected); | |||
|  | 
 | |||
|  |       for (yyx = yyxbegin; yyx < yyxend; ++yyx) | |||
|  | 	if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR) | |||
|  | 	  { | |||
|  | 	    if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) | |||
|  | 	      { | |||
|  | 		yycount = 1; | |||
|  | 		yysize = yysize0; | |||
|  | 		yyformat[sizeof yyunexpected - 1] = '\0'; | |||
|  | 		break; | |||
|  | 	      } | |||
|  | 	    yyarg[yycount++] = yytname[yyx]; | |||
|  | 	    yysize1 = yysize + yytnamerr (0, yytname[yyx]); | |||
|  | 	    yysize_overflow |= (yysize1 < yysize); | |||
|  | 	    yysize = yysize1; | |||
|  | 	    yyfmt = yystpcpy (yyfmt, yyprefix); | |||
|  | 	    yyprefix = yyor; | |||
|  | 	  } | |||
|  | 
 | |||
|  |       yyf = YY_(yyformat); | |||
|  |       yysize1 = yysize + yystrlen (yyf); | |||
|  |       yysize_overflow |= (yysize1 < yysize); | |||
|  |       yysize = yysize1; | |||
|  | 
 | |||
|  |       if (yysize_overflow) | |||
|  | 	return YYSIZE_MAXIMUM; | |||
|  | 
 | |||
|  |       if (yyresult) | |||
|  | 	{ | |||
|  | 	  /* Avoid sprintf, as that infringes on the user's name space. | |||
|  | 	     Don't have undefined behavior even if the translation | |||
|  | 	     produced a string with the wrong number of "%s"s.  */ | |||
|  | 	  char *yyp = yyresult; | |||
|  | 	  int yyi = 0; | |||
|  | 	  while ((*yyp = *yyf) != '\0') | |||
|  | 	    { | |||
|  | 	      if (*yyp == '%' && yyf[1] == 's' && yyi < yycount) | |||
|  | 		{ | |||
|  | 		  yyp += yytnamerr (yyp, yyarg[yyi++]); | |||
|  | 		  yyf += 2; | |||
|  | 		} | |||
|  | 	      else | |||
|  | 		{ | |||
|  | 		  yyp++; | |||
|  | 		  yyf++; | |||
|  | 		} | |||
|  | 	    } | |||
|  | 	} | |||
|  |       return yysize; | |||
|  |     } | |||
|  | } | |||
|  | #endif /* YYERROR_VERBOSE */ | |||
|  |  | |||
|  | 
 | |||
|  | /*-----------------------------------------------. | |||
|  | | Release the memory associated to this symbol.  | | |||
|  | `-----------------------------------------------*/ | |||
|  | 
 | |||
|  | /*ARGSUSED*/ | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | static void | |||
|  | yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep, YYLTYPE *yylocationp) | |||
|  | #else | |||
|  | static void | |||
|  | yydestruct (yymsg, yytype, yyvaluep, yylocationp) | |||
|  |     const char *yymsg; | |||
|  |     int yytype; | |||
|  |     YYSTYPE *yyvaluep; | |||
|  |     YYLTYPE *yylocationp; | |||
|  | #endif | |||
|  | { | |||
|  |   YYUSE (yyvaluep); | |||
|  |   YYUSE (yylocationp); | |||
|  | 
 | |||
|  |   if (!yymsg) | |||
|  |     yymsg = "Deleting"; | |||
|  |   YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp); | |||
|  | 
 | |||
|  |   switch (yytype) | |||
|  |     { | |||
|  | 
 | |||
|  |       default: | |||
|  | 	break; | |||
|  |     } | |||
|  | } | |||
|  |  | |||
|  | 
 | |||
|  | /* Prevent warnings from -Wmissing-prototypes.  */ | |||
|  | 
 | |||
|  | #ifdef YYPARSE_PARAM | |||
|  | #if defined __STDC__ || defined __cplusplus | |||
|  | int yyparse (void *YYPARSE_PARAM); | |||
|  | #else | |||
|  | int yyparse (); | |||
|  | #endif | |||
|  | #else /* ! YYPARSE_PARAM */ | |||
|  | #if defined __STDC__ || defined __cplusplus | |||
|  | int yyparse (void); | |||
|  | #else | |||
|  | int yyparse (); | |||
|  | #endif | |||
|  | #endif /* ! YYPARSE_PARAM */ | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | /* The look-ahead symbol.  */ | |||
|  | int yychar; | |||
|  | 
 | |||
|  | /* The semantic value of the look-ahead symbol.  */ | |||
|  | YYSTYPE yylval; | |||
|  | 
 | |||
|  | /* Number of syntax errors so far.  */ | |||
|  | int yynerrs; | |||
|  | /* Location data for the look-ahead symbol.  */ | |||
|  | YYLTYPE yylloc; | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  | /*----------. | |||
|  | | yyparse.  | | |||
|  | `----------*/ | |||
|  | 
 | |||
|  | #ifdef YYPARSE_PARAM | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | int | |||
|  | yyparse (void *YYPARSE_PARAM) | |||
|  | #else | |||
|  | int | |||
|  | yyparse (YYPARSE_PARAM) | |||
|  |     void *YYPARSE_PARAM; | |||
|  | #endif | |||
|  | #else /* ! YYPARSE_PARAM */ | |||
|  | #if (defined __STDC__ || defined __C99__FUNC__ \ | |||
|  |      || defined __cplusplus || defined _MSC_VER) | |||
|  | int | |||
|  | yyparse (void) | |||
|  | #else | |||
|  | int | |||
|  | yyparse () | |||
|  | 
 | |||
|  | #endif | |||
|  | #endif | |||
|  | { | |||
|  |    | |||
|  |   int yystate; | |||
|  |   int yyn; | |||
|  |   int yyresult; | |||
|  |   /* Number of tokens to shift before error messages enabled.  */ | |||
|  |   int yyerrstatus; | |||
|  |   /* Look-ahead token as an internal (translated) token number.  */ | |||
|  |   int yytoken = 0; | |||
|  | #if YYERROR_VERBOSE | |||
|  |   /* Buffer for error messages, and its allocated size.  */ | |||
|  |   char yymsgbuf[128]; | |||
|  |   char *yymsg = yymsgbuf; | |||
|  |   YYSIZE_T yymsg_alloc = sizeof yymsgbuf; | |||
|  | #endif | |||
|  | 
 | |||
|  |   /* Three stacks and their tools: | |||
|  |      `yyss': related to states, | |||
|  |      `yyvs': related to semantic values, | |||
|  |      `yyls': related to locations. | |||
|  | 
 | |||
|  |      Refer to the stacks thru separate pointers, to allow yyoverflow | |||
|  |      to reallocate them elsewhere.  */ | |||
|  | 
 | |||
|  |   /* The state stack.  */ | |||
|  |   yytype_int16 yyssa[YYINITDEPTH]; | |||
|  |   yytype_int16 *yyss = yyssa; | |||
|  |   yytype_int16 *yyssp; | |||
|  | 
 | |||
|  |   /* The semantic value stack.  */ | |||
|  |   YYSTYPE yyvsa[YYINITDEPTH]; | |||
|  |   YYSTYPE *yyvs = yyvsa; | |||
|  |   YYSTYPE *yyvsp; | |||
|  | 
 | |||
|  |   /* The location stack.  */ | |||
|  |   YYLTYPE yylsa[YYINITDEPTH]; | |||
|  |   YYLTYPE *yyls = yylsa; | |||
|  |   YYLTYPE *yylsp; | |||
|  |   /* The locations where the error started and ended.  */ | |||
|  |   YYLTYPE yyerror_range[2]; | |||
|  | 
 | |||
|  | #define YYPOPSTACK(N)   (yyvsp -= (N), yyssp -= (N), yylsp -= (N)) | |||
|  | 
 | |||
|  |   YYSIZE_T yystacksize = YYINITDEPTH; | |||
|  | 
 | |||
|  |   /* The variables used to return semantic value and location from the | |||
|  |      action routines.  */ | |||
|  |   YYSTYPE yyval; | |||
|  |   YYLTYPE yyloc; | |||
|  | 
 | |||
|  |   /* The number of symbols on the RHS of the reduced rule. | |||
|  |      Keep to zero when no symbol should be popped.  */ | |||
|  |   int yylen = 0; | |||
|  | 
 | |||
|  |   YYDPRINTF ((stderr, "Starting parse\n")); | |||
|  | 
 | |||
|  |   yystate = 0; | |||
|  |   yyerrstatus = 0; | |||
|  |   yynerrs = 0; | |||
|  |   yychar = YYEMPTY;		/* Cause a token to be read.  */ | |||
|  | 
 | |||
|  |   /* Initialize stack pointers. | |||
|  |      Waste one element of value and location stack | |||
|  |      so that they stay on the same level as the state stack. | |||
|  |      The wasted elements are never initialized.  */ | |||
|  | 
 | |||
|  |   yyssp = yyss; | |||
|  |   yyvsp = yyvs; | |||
|  |   yylsp = yyls; | |||
|  | #if YYLTYPE_IS_TRIVIAL | |||
|  |   /* Initialize the default location before parsing starts.  */ | |||
|  |   yylloc.first_line   = yylloc.last_line   = 1; | |||
|  |   yylloc.first_column = yylloc.last_column = 0; | |||
|  | #endif | |||
|  | 
 | |||
|  |   goto yysetstate; | |||
|  | 
 | |||
|  | /*------------------------------------------------------------. | |||
|  | | yynewstate -- Push a new state, which is found in yystate.  | | |||
|  | `------------------------------------------------------------*/ | |||
|  |  yynewstate: | |||
|  |   /* In all cases, when you get here, the value and location stacks | |||
|  |      have just been pushed.  So pushing a state here evens the stacks.  */ | |||
|  |   yyssp++; | |||
|  | 
 | |||
|  |  yysetstate: | |||
|  |   *yyssp = yystate; | |||
|  | 
 | |||
|  |   if (yyss + yystacksize - 1 <= yyssp) | |||
|  |     { | |||
|  |       /* Get the current used size of the three stacks, in elements.  */ | |||
|  |       YYSIZE_T yysize = yyssp - yyss + 1; | |||
|  | 
 | |||
|  | #ifdef yyoverflow | |||
|  |       { | |||
|  | 	/* Give user a chance to reallocate the stack.  Use copies of | |||
|  | 	   these so that the &'s don't force the real ones into | |||
|  | 	   memory.  */ | |||
|  | 	YYSTYPE *yyvs1 = yyvs; | |||
|  | 	yytype_int16 *yyss1 = yyss; | |||
|  | 	YYLTYPE *yyls1 = yyls; | |||
|  | 
 | |||
|  | 	/* Each stack pointer address is followed by the size of the | |||
|  | 	   data in use in that stack, in bytes.  This used to be a | |||
|  | 	   conditional around just the two extra args, but that might | |||
|  | 	   be undefined if yyoverflow is a macro.  */ | |||
|  | 	yyoverflow (YY_("memory exhausted"), | |||
|  | 		    &yyss1, yysize * sizeof (*yyssp), | |||
|  | 		    &yyvs1, yysize * sizeof (*yyvsp), | |||
|  | 		    &yyls1, yysize * sizeof (*yylsp), | |||
|  | 		    &yystacksize); | |||
|  | 	yyls = yyls1; | |||
|  | 	yyss = yyss1; | |||
|  | 	yyvs = yyvs1; | |||
|  |       } | |||
|  | #else /* no yyoverflow */ | |||
|  | # ifndef YYSTACK_RELOCATE | |||
|  |       goto yyexhaustedlab; | |||
|  | # else | |||
|  |       /* Extend the stack our own way.  */ | |||
|  |       if (YYMAXDEPTH <= yystacksize) | |||
|  | 	goto yyexhaustedlab; | |||
|  |       yystacksize *= 2; | |||
|  |       if (YYMAXDEPTH < yystacksize) | |||
|  | 	yystacksize = YYMAXDEPTH; | |||
|  | 
 | |||
|  |       { | |||
|  | 	yytype_int16 *yyss1 = yyss; | |||
|  | 	union yyalloc *yyptr = | |||
|  | 	  (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize)); | |||
|  | 	if (! yyptr) | |||
|  | 	  goto yyexhaustedlab; | |||
|  | 	YYSTACK_RELOCATE (yyss); | |||
|  | 	YYSTACK_RELOCATE (yyvs); | |||
|  | 	YYSTACK_RELOCATE (yyls); | |||
|  | #  undef YYSTACK_RELOCATE | |||
|  | 	if (yyss1 != yyssa) | |||
|  | 	  YYSTACK_FREE (yyss1); | |||
|  |       } | |||
|  | # endif | |||
|  | #endif /* no yyoverflow */ | |||
|  | 
 | |||
|  |       yyssp = yyss + yysize - 1; | |||
|  |       yyvsp = yyvs + yysize - 1; | |||
|  |       yylsp = yyls + yysize - 1; | |||
|  | 
 | |||
|  |       YYDPRINTF ((stderr, "Stack size increased to %lu\n", | |||
|  | 		  (unsigned long int) yystacksize)); | |||
|  | 
 | |||
|  |       if (yyss + yystacksize - 1 <= yyssp) | |||
|  | 	YYABORT; | |||
|  |     } | |||
|  | 
 | |||
|  |   YYDPRINTF ((stderr, "Entering state %d\n", yystate)); | |||
|  | 
 | |||
|  |   goto yybackup; | |||
|  | 
 | |||
|  | /*-----------. | |||
|  | | yybackup.  | | |||
|  | `-----------*/ | |||
|  | yybackup: | |||
|  | 
 | |||
|  |   /* Do appropriate processing given the current state.  Read a | |||
|  |      look-ahead token if we need one and don't already have one.  */ | |||
|  | 
 | |||
|  |   /* First try to decide what to do without reference to look-ahead token.  */ | |||
|  |   yyn = yypact[yystate]; | |||
|  |   if (yyn == YYPACT_NINF) | |||
|  |     goto yydefault; | |||
|  | 
 | |||
|  |   /* Not known => get a look-ahead token if don't already have one.  */ | |||
|  | 
 | |||
|  |   /* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol.  */ | |||
|  |   if (yychar == YYEMPTY) | |||
|  |     { | |||
|  |       YYDPRINTF ((stderr, "Reading a token: ")); | |||
|  |       yychar = YYLEX; | |||
|  |     } | |||
|  | 
 | |||
|  |   if (yychar <= YYEOF) | |||
|  |     { | |||
|  |       yychar = yytoken = YYEOF; | |||
|  |       YYDPRINTF ((stderr, "Now at end of input.\n")); | |||
|  |     } | |||
|  |   else | |||
|  |     { | |||
|  |       yytoken = YYTRANSLATE (yychar); | |||
|  |       YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc); | |||
|  |     } | |||
|  | 
 | |||
|  |   /* If the proper action on seeing token YYTOKEN is to reduce or to | |||
|  |      detect an error, take that action.  */ | |||
|  |   yyn += yytoken; | |||
|  |   if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken) | |||
|  |     goto yydefault; | |||
|  |   yyn = yytable[yyn]; | |||
|  |   if (yyn <= 0) | |||
|  |     { | |||
|  |       if (yyn == 0 || yyn == YYTABLE_NINF) | |||
|  | 	goto yyerrlab; | |||
|  |       yyn = -yyn; | |||
|  |       goto yyreduce; | |||
|  |     } | |||
|  | 
 | |||
|  |   if (yyn == YYFINAL) | |||
|  |     YYACCEPT; | |||
|  | 
 | |||
|  |   /* Count tokens shifted since error; after three, turn off error | |||
|  |      status.  */ | |||
|  |   if (yyerrstatus) | |||
|  |     yyerrstatus--; | |||
|  | 
 | |||
|  |   /* Shift the look-ahead token.  */ | |||
|  |   YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc); | |||
|  | 
 | |||
|  |   /* Discard the shifted token unless it is eof.  */ | |||
|  |   if (yychar != YYEOF) | |||
|  |     yychar = YYEMPTY; | |||
|  | 
 | |||
|  |   yystate = yyn; | |||
|  |   *++yyvsp = yylval; | |||
|  |   *++yylsp = yylloc; | |||
|  |   goto yynewstate; | |||
|  | 
 | |||
|  | 
 | |||
|  | /*-----------------------------------------------------------. | |||
|  | | yydefault -- do the default action for the current state.  | | |||
|  | `-----------------------------------------------------------*/ | |||
|  | yydefault: | |||
|  |   yyn = yydefact[yystate]; | |||
|  |   if (yyn == 0) | |||
|  |     goto yyerrlab; | |||
|  |   goto yyreduce; | |||
|  | 
 | |||
|  | 
 | |||
|  | /*-----------------------------. | |||
|  | | yyreduce -- Do a reduction.  | | |||
|  | `-----------------------------*/ | |||
|  | yyreduce: | |||
|  |   /* yyn is the number of a rule to reduce with.  */ | |||
|  |   yylen = yyr2[yyn]; | |||
|  | 
 | |||
|  |   /* If YYLEN is nonzero, implement the default value of the action: | |||
|  |      `$$ = $1'. | |||
|  | 
 | |||
|  |      Otherwise, the following line sets YYVAL to garbage. | |||
|  |      This behavior is undocumented and Bison | |||
|  |      users should not rely upon it.  Assigning to YYVAL | |||
|  |      unconditionally makes the parser a bit smaller, and it avoids a | |||
|  |      GCC warning that YYVAL may be used uninitialized.  */ | |||
|  |   yyval = yyvsp[1-yylen]; | |||
|  | 
 | |||
|  |   /* Default location.  */ | |||
|  |   YYLLOC_DEFAULT (yyloc, (yylsp - yylen), yylen); | |||
|  |   YY_REDUCE_PRINT (yyn); | |||
|  |   switch (yyn) | |||
|  |     { | |||
|  |         case 2: | |||
|  | #line 86 "dtc-parser.y" | |||
|  |     { | |||
|  | 			the_boot_info = build_boot_info((yyvsp[(3) - (4)].re), (yyvsp[(4) - (4)].node)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 3: | |||
|  | #line 90 "dtc-parser.y" | |||
|  |     { | |||
|  | 			the_boot_info = build_boot_info((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].node)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 4: | |||
|  | #line 97 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = NULL; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 5: | |||
|  | #line 101 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = chain_reserve_entry((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].re)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 6: | |||
|  | #line 108 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = build_reserve_entry((yyvsp[(3) - (5)].addr), (yyvsp[(4) - (5)].addr), (yyvsp[(1) - (5)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 7: | |||
|  | #line 115 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = NULL; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 8: | |||
|  | #line 119 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = chain_reserve_entry((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].re)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 9: | |||
|  | #line 126 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = (yyvsp[(1) - (1)].re); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 10: | |||
|  | #line 130 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.re) = build_reserve_entry((yyvsp[(3) - (6)].addr), (yyvsp[(5) - (6)].addr) - (yyvsp[(3) - (6)].addr) + 1, (yyvsp[(1) - (6)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 11: | |||
|  | #line 137 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.addr) = eval_literal((yyvsp[(1) - (1)].literal), 0, 64); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 12: | |||
|  | #line 141 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.addr) = eval_literal((yyvsp[(1) - (1)].literal), 16, 64); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 13: | |||
|  | #line 148 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.node) = name_node((yyvsp[(2) - (2)].node), "", NULL); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 14: | |||
|  | #line 155 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.node) = build_node((yyvsp[(2) - (5)].proplist), (yyvsp[(3) - (5)].nodelist)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 15: | |||
|  | #line 162 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.proplist) = NULL; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 16: | |||
|  | #line 166 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.proplist) = chain_property((yyvsp[(2) - (2)].prop), (yyvsp[(1) - (2)].proplist)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 17: | |||
|  | #line 173 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.prop) = build_property((yyvsp[(2) - (5)].propnodename), (yyvsp[(4) - (5)].data), (yyvsp[(1) - (5)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 18: | |||
|  | #line 177 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.prop) = build_property((yyvsp[(2) - (3)].propnodename), empty_data, (yyvsp[(1) - (3)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 19: | |||
|  | #line 184 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_merge((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].data)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 20: | |||
|  | #line 188 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_merge((yyvsp[(1) - (4)].data), (yyvsp[(3) - (4)].data)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 21: | |||
|  | #line 192 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_merge((yyvsp[(1) - (4)].data), (yyvsp[(3) - (4)].data)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 22: | |||
|  | #line 196 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), REF_PATH, (yyvsp[(2) - (2)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 23: | |||
|  | #line 200 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 24: | |||
|  | #line 207 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = empty_data; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 25: | |||
|  | #line 211 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = (yyvsp[(1) - (2)].data); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 26: | |||
|  | #line 215 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 27: | |||
|  | #line 222 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = empty_data; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 28: | |||
|  | #line 226 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_append_cell((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].cell)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 29: | |||
|  | #line 230 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_append_cell(data_add_marker((yyvsp[(1) - (2)].data), REF_PHANDLE, | |||
|  | 							      (yyvsp[(2) - (2)].labelref)), -1); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 30: | |||
|  | #line 235 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 31: | |||
|  | #line 242 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.cbase) = 16; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 33: | |||
|  | #line 250 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.cell) = eval_literal((yyvsp[(1) - (1)].literal), 0, 32); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 34: | |||
|  | #line 254 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.cell) = eval_literal((yyvsp[(2) - (2)].literal), (yyvsp[(1) - (2)].cbase), 32); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 35: | |||
|  | #line 261 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = empty_data; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 36: | |||
|  | #line 265 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_append_byte((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].byte)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 37: | |||
|  | #line 269 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 38: | |||
|  | #line 276 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.nodelist) = NULL; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 39: | |||
|  | #line 280 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.nodelist) = chain_node((yyvsp[(1) - (2)].node), (yyvsp[(2) - (2)].nodelist)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 40: | |||
|  | #line 284 "dtc-parser.y" | |||
|  |     { | |||
|  | 			yyerror("syntax error: properties must precede subnodes\n"); | |||
|  | 			YYERROR; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 41: | |||
|  | #line 292 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.node) = name_node((yyvsp[(3) - (3)].node), (yyvsp[(2) - (3)].propnodename), (yyvsp[(1) - (3)].labelref)); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 42: | |||
|  | #line 299 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.labelref) = NULL; | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  |   case 43: | |||
|  | #line 303 "dtc-parser.y" | |||
|  |     { | |||
|  | 			(yyval.labelref) = (yyvsp[(1) - (1)].labelref); | |||
|  | 		;} | |||
|  |     break; | |||
|  | 
 | |||
|  | 
 | |||
|  | /* Line 1267 of yacc.c.  */ | |||
|  | #line 1734 "dtc-parser.tab.c" | |||
|  |       default: break; | |||
|  |     } | |||
|  |   YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc); | |||
|  | 
 | |||
|  |   YYPOPSTACK (yylen); | |||
|  |   yylen = 0; | |||
|  |   YY_STACK_PRINT (yyss, yyssp); | |||
|  | 
 | |||
|  |   *++yyvsp = yyval; | |||
|  |   *++yylsp = yyloc; | |||
|  | 
 | |||
|  |   /* Now `shift' the result of the reduction.  Determine what state | |||
|  |      that goes to, based on the state we popped back to and the rule | |||
|  |      number reduced by.  */ | |||
|  | 
 | |||
|  |   yyn = yyr1[yyn]; | |||
|  | 
 | |||
|  |   yystate = yypgoto[yyn - YYNTOKENS] + *yyssp; | |||
|  |   if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp) | |||
|  |     yystate = yytable[yystate]; | |||
|  |   else | |||
|  |     yystate = yydefgoto[yyn - YYNTOKENS]; | |||
|  | 
 | |||
|  |   goto yynewstate; | |||
|  | 
 | |||
|  | 
 | |||
|  | /*------------------------------------. | |||
|  | | yyerrlab -- here on detecting error | | |||
|  | `------------------------------------*/ | |||
|  | yyerrlab: | |||
|  |   /* If not already recovering from an error, report this error.  */ | |||
|  |   if (!yyerrstatus) | |||
|  |     { | |||
|  |       ++yynerrs; | |||
|  | #if ! YYERROR_VERBOSE | |||
|  |       yyerror (YY_("syntax error")); | |||
|  | #else | |||
|  |       { | |||
|  | 	YYSIZE_T yysize = yysyntax_error (0, yystate, yychar); | |||
|  | 	if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM) | |||
|  | 	  { | |||
|  | 	    YYSIZE_T yyalloc = 2 * yysize; | |||
|  | 	    if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM)) | |||
|  | 	      yyalloc = YYSTACK_ALLOC_MAXIMUM; | |||
|  | 	    if (yymsg != yymsgbuf) | |||
|  | 	      YYSTACK_FREE (yymsg); | |||
|  | 	    yymsg = (char *) YYSTACK_ALLOC (yyalloc); | |||
|  | 	    if (yymsg) | |||
|  | 	      yymsg_alloc = yyalloc; | |||
|  | 	    else | |||
|  | 	      { | |||
|  | 		yymsg = yymsgbuf; | |||
|  | 		yymsg_alloc = sizeof yymsgbuf; | |||
|  | 	      } | |||
|  | 	  } | |||
|  | 
 | |||
|  | 	if (0 < yysize && yysize <= yymsg_alloc) | |||
|  | 	  { | |||
|  | 	    (void) yysyntax_error (yymsg, yystate, yychar); | |||
|  | 	    yyerror (yymsg); | |||
|  | 	  } | |||
|  | 	else | |||
|  | 	  { | |||
|  | 	    yyerror (YY_("syntax error")); | |||
|  | 	    if (yysize != 0) | |||
|  | 	      goto yyexhaustedlab; | |||
|  | 	  } | |||
|  |       } | |||
|  | #endif | |||
|  |     } | |||
|  | 
 | |||
|  |   yyerror_range[0] = yylloc; | |||
|  | 
 | |||
|  |   if (yyerrstatus == 3) | |||
|  |     { | |||
|  |       /* If just tried and failed to reuse look-ahead token after an | |||
|  | 	 error, discard it.  */ | |||
|  | 
 | |||
|  |       if (yychar <= YYEOF) | |||
|  | 	{ | |||
|  | 	  /* Return failure if at end of input.  */ | |||
|  | 	  if (yychar == YYEOF) | |||
|  | 	    YYABORT; | |||
|  | 	} | |||
|  |       else | |||
|  | 	{ | |||
|  | 	  yydestruct ("Error: discarding", | |||
|  | 		      yytoken, &yylval, &yylloc); | |||
|  | 	  yychar = YYEMPTY; | |||
|  | 	} | |||
|  |     } | |||
|  | 
 | |||
|  |   /* Else will try to reuse look-ahead token after shifting the error | |||
|  |      token.  */ | |||
|  |   goto yyerrlab1; | |||
|  | 
 | |||
|  | 
 | |||
|  | /*---------------------------------------------------. | |||
|  | | yyerrorlab -- error raised explicitly by YYERROR.  | | |||
|  | `---------------------------------------------------*/ | |||
|  | yyerrorlab: | |||
|  | 
 | |||
|  |   /* Pacify compilers like GCC when the user code never invokes | |||
|  |      YYERROR and the label yyerrorlab therefore never appears in user | |||
|  |      code.  */ | |||
|  |   if (/*CONSTCOND*/ 0) | |||
|  |      goto yyerrorlab; | |||
|  | 
 | |||
|  |   yyerror_range[0] = yylsp[1-yylen]; | |||
|  |   /* Do not reclaim the symbols of the rule which action triggered | |||
|  |      this YYERROR.  */ | |||
|  |   YYPOPSTACK (yylen); | |||
|  |   yylen = 0; | |||
|  |   YY_STACK_PRINT (yyss, yyssp); | |||
|  |   yystate = *yyssp; | |||
|  |   goto yyerrlab1; | |||
|  | 
 | |||
|  | 
 | |||
|  | /*-------------------------------------------------------------. | |||
|  | | yyerrlab1 -- common code for both syntax error and YYERROR.  | | |||
|  | `-------------------------------------------------------------*/ | |||
|  | yyerrlab1: | |||
|  |   yyerrstatus = 3;	/* Each real token shifted decrements this.  */ | |||
|  | 
 | |||
|  |   for (;;) | |||
|  |     { | |||
|  |       yyn = yypact[yystate]; | |||
|  |       if (yyn != YYPACT_NINF) | |||
|  | 	{ | |||
|  | 	  yyn += YYTERROR; | |||
|  | 	  if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR) | |||
|  | 	    { | |||
|  | 	      yyn = yytable[yyn]; | |||
|  | 	      if (0 < yyn) | |||
|  | 		break; | |||
|  | 	    } | |||
|  | 	} | |||
|  | 
 | |||
|  |       /* Pop the current state because it cannot handle the error token.  */ | |||
|  |       if (yyssp == yyss) | |||
|  | 	YYABORT; | |||
|  | 
 | |||
|  |       yyerror_range[0] = *yylsp; | |||
|  |       yydestruct ("Error: popping", | |||
|  | 		  yystos[yystate], yyvsp, yylsp); | |||
|  |       YYPOPSTACK (1); | |||
|  |       yystate = *yyssp; | |||
|  |       YY_STACK_PRINT (yyss, yyssp); | |||
|  |     } | |||
|  | 
 | |||
|  |   if (yyn == YYFINAL) | |||
|  |     YYACCEPT; | |||
|  | 
 | |||
|  |   *++yyvsp = yylval; | |||
|  | 
 | |||
|  |   yyerror_range[1] = yylloc; | |||
|  |   /* Using YYLLOC is tempting, but would change the location of | |||
|  |      the look-ahead.  YYLOC is available though.  */ | |||
|  |   YYLLOC_DEFAULT (yyloc, (yyerror_range - 1), 2); | |||
|  |   *++yylsp = yyloc; | |||
|  | 
 | |||
|  |   /* Shift the error token.  */ | |||
|  |   YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp); | |||
|  | 
 | |||
|  |   yystate = yyn; | |||
|  |   goto yynewstate; | |||
|  | 
 | |||
|  | 
 | |||
|  | /*-------------------------------------. | |||
|  | | yyacceptlab -- YYACCEPT comes here.  | | |||
|  | `-------------------------------------*/ | |||
|  | yyacceptlab: | |||
|  |   yyresult = 0; | |||
|  |   goto yyreturn; | |||
|  | 
 | |||
|  | /*-----------------------------------. | |||
|  | | yyabortlab -- YYABORT comes here.  | | |||
|  | `-----------------------------------*/ | |||
|  | yyabortlab: | |||
|  |   yyresult = 1; | |||
|  |   goto yyreturn; | |||
|  | 
 | |||
|  | #ifndef yyoverflow | |||
|  | /*-------------------------------------------------. | |||
|  | | yyexhaustedlab -- memory exhaustion comes here.  | | |||
|  | `-------------------------------------------------*/ | |||
|  | yyexhaustedlab: | |||
|  |   yyerror (YY_("memory exhausted")); | |||
|  |   yyresult = 2; | |||
|  |   /* Fall through.  */ | |||
|  | #endif | |||
|  | 
 | |||
|  | yyreturn: | |||
|  |   if (yychar != YYEOF && yychar != YYEMPTY) | |||
|  |      yydestruct ("Cleanup: discarding lookahead", | |||
|  | 		 yytoken, &yylval, &yylloc); | |||
|  |   /* Do not reclaim the symbols of the rule which action triggered | |||
|  |      this YYABORT or YYACCEPT.  */ | |||
|  |   YYPOPSTACK (yylen); | |||
|  |   YY_STACK_PRINT (yyss, yyssp); | |||
|  |   while (yyssp != yyss) | |||
|  |     { | |||
|  |       yydestruct ("Cleanup: popping", | |||
|  | 		  yystos[*yyssp], yyvsp, yylsp); | |||
|  |       YYPOPSTACK (1); | |||
|  |     } | |||
|  | #ifndef yyoverflow | |||
|  |   if (yyss != yyssa) | |||
|  |     YYSTACK_FREE (yyss); | |||
|  | #endif | |||
|  | #if YYERROR_VERBOSE | |||
|  |   if (yymsg != yymsgbuf) | |||
|  |     YYSTACK_FREE (yymsg); | |||
|  | #endif | |||
|  |   /* Make sure YYID is used.  */ | |||
|  |   return YYID (yyresult); | |||
|  | } | |||
|  | 
 | |||
|  | 
 | |||
|  | #line 308 "dtc-parser.y" | |||
|  | 
 | |||
|  | 
 | |||
|  | void yyerror (char const *s) | |||
|  | { | |||
|  | 	const char *fname = srcpos_filename_for_num(yylloc.filenum); | |||
|  | 
 | |||
|  | 	if (strcmp(fname, "-") == 0) | |||
|  | 		fname = "stdin"; | |||
|  | 
 | |||
|  | 	fprintf(stderr, "%s:%d %s\n", | |||
|  | 		fname, yylloc.first_line, s); | |||
|  | } | |||
|  | 
 | |||
|  | unsigned long long eval_literal(const char *s, int base, int bits) | |||
|  | { | |||
|  | 	unsigned long long val; | |||
|  | 	char *e; | |||
|  | 
 | |||
|  | 	errno = 0; | |||
|  | 	val = strtoull(s, &e, base); | |||
|  | 	if (*e) | |||
|  | 		yyerror("bad characters in literal"); | |||
|  | 	else if ((errno == ERANGE) | |||
|  | 		 || ((bits < 64) && (val >= (1ULL << bits)))) | |||
|  | 		yyerror("literal out of range"); | |||
|  | 	else if (errno != 0) | |||
|  | 		yyerror("bad literal"); | |||
|  | 	return val; | |||
|  | } | |||
|  | 
 |