sconfig: Allow to specify device operations

Currently we only have runtime mechanisms to assign device operations to
a node in our devicetree (with one exception: the root device). The most
common method is to map PCI IDs to the device operations with a `struct
pci_driver`. Another accustomed way is to let a chip driver assign them.

For very common drivers, e.g. those in soc/intel/common/blocks/, the PCI
ID lists grew very large and are incredibly error-prone. Often, IDs are
missing and sometimes IDs are added almost mechanically without checking
the code for compatibility. Maintaining these lists in a central place
also reduces flexibility.

Now, for onboard devices it is actually unnecessary to assign the device
operations at runtime. We already know exactly what operations should be
assigned. And since we are using chipset devicetrees, we have a perfect
place to put that information.

This patch adds a simple mechanism to `sconfig`. It allows us to speci-
fy operations per device, e.g.

  device pci 00.0 alias system_agent on
          ops system_agent_ops
  end

The operations are given as a C identifier. In this example, we simply
assume that a global `struct device_operations system_agent_ops` exists.

Change-Id: I2833d2f2450fde3206c33393f58b86fd4280b566
Signed-off-by: Nico Huber <nico.h@gmx.de>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/66483
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
Reviewed-by: Felix Held <felix-coreboot@felixheld.de>
This commit is contained in:
Nico Huber
2022-08-06 19:02:59 +02:00
committed by Felix Held
parent f1ba7d6c8f
commit c0fc38eed8
7 changed files with 401 additions and 332 deletions

View File

@@ -349,8 +349,8 @@ static void yynoreturn yy_fatal_error ( const char* msg );
(yy_hold_char) = *yy_cp; \
*yy_cp = '\0'; \
(yy_c_buf_p) = yy_cp;
#define YY_NUM_RULES 50
#define YY_END_OF_BUFFER 51
#define YY_NUM_RULES 51
#define YY_END_OF_BUFFER 52
/* This struct is not used in this scanner,
but its presence is necessary. */
struct yy_trans_info
@@ -358,31 +358,31 @@ struct yy_trans_info
flex_int32_t yy_verify;
flex_int32_t yy_nxt;
};
static const flex_int16_t yy_accept[210] =
static const flex_int16_t yy_accept[211] =
{ 0,
0, 0, 51, 49, 1, 3, 49, 49, 49, 44,
44, 41, 45, 49, 45, 45, 45, 45, 45, 49,
49, 49, 49, 49, 49, 49, 49, 49, 49, 42,
49, 1, 3, 49, 0, 49, 49, 0, 2, 44,
45, 49, 49, 49, 9, 49, 49, 45, 49, 49,
49, 49, 49, 49, 49, 49, 49, 49, 34, 49,
49, 49, 49, 49, 15, 49, 49, 49, 49, 49,
49, 49, 49, 49, 48, 48, 49, 0, 43, 49,
49, 49, 25, 49, 49, 33, 38, 49, 49, 49,
49, 49, 22, 49, 49, 32, 49, 49, 49, 16,
0, 0, 52, 50, 1, 3, 50, 50, 50, 45,
45, 42, 46, 50, 46, 46, 46, 46, 46, 50,
50, 50, 50, 50, 50, 50, 50, 50, 50, 43,
50, 1, 3, 50, 0, 50, 50, 0, 2, 45,
46, 50, 50, 50, 10, 50, 50, 46, 50, 50,
50, 50, 50, 50, 50, 50, 50, 50, 35, 50,
50, 50, 50, 50, 16, 50, 50, 50, 50, 50,
50, 50, 50, 50, 49, 49, 50, 0, 44, 50,
50, 50, 26, 50, 50, 34, 39, 50, 50, 50,
50, 50, 23, 50, 50, 33, 50, 50, 50, 17,
49, 19, 21, 49, 8, 49, 49, 29, 49, 30,
7, 49, 0, 46, 49, 4, 49, 49, 49, 49,
49, 49, 31, 49, 49, 49, 49, 49, 28, 49,
49, 49, 49, 49, 47, 47, 6, 49, 49, 49,
12, 49, 49, 49, 49, 49, 23, 49, 49, 14,
49, 49, 49, 49, 5, 26, 49, 49, 17, 49,
20, 49, 13, 49, 49, 49, 49, 49, 27, 36,
49, 49, 49, 49, 49, 49, 49, 49, 49, 10,
49, 49, 49, 49, 11, 49, 18, 49, 49, 49,
49, 35, 49, 49, 49, 24, 49, 49, 37, 49,
7, 50, 20, 22, 50, 9, 50, 50, 30, 50,
31, 8, 50, 0, 47, 50, 4, 50, 50, 50,
50, 50, 50, 32, 50, 50, 50, 50, 50, 29,
50, 50, 50, 50, 50, 48, 48, 6, 50, 50,
50, 13, 50, 50, 50, 50, 50, 24, 50, 50,
15, 50, 50, 50, 50, 5, 27, 50, 50, 18,
50, 21, 50, 14, 50, 50, 50, 50, 50, 28,
37, 50, 50, 50, 50, 50, 50, 50, 50, 50,
11, 50, 50, 50, 50, 12, 50, 19, 50, 50,
50, 50, 36, 50, 50, 50, 25, 50, 50, 38,
49, 49, 49, 49, 49, 40, 49, 39, 0
50, 50, 50, 50, 50, 50, 41, 50, 40, 0
} ;
static const YY_CHAR yy_ec[256] =
@@ -425,140 +425,140 @@ static const YY_CHAR yy_meta[41] =
1, 1, 1, 1, 1, 1, 1, 1, 1, 1
} ;
static const flex_int16_t yy_base[217] =
static const flex_int16_t yy_base[218] =
{ 0,
0, 0, 282, 0, 279, 283, 277, 39, 43, 40,
241, 0, 46, 264, 56, 60, 64, 67, 72, 56,
252, 74, 259, 39, 70, 59, 254, 77, 241, 0,
0, 271, 283, 108, 267, 112, 116, 268, 283, 0,
113, 116, 255, 244, 0, 243, 232, 122, 239, 234,
244, 242, 246, 233, 235, 239, 239, 233, 239, 224,
224, 225, 227, 229, 0, 216, 224, 218, 218, 117,
228, 220, 226, 87, 0, 283, 139, 238, 0, 231,
224, 210, 223, 213, 220, 0, 0, 210, 216, 213,
204, 212, 0, 210, 200, 0, 204, 208, 198, 0,
0, 0, 283, 0, 280, 284, 278, 39, 43, 40,
242, 0, 46, 265, 56, 60, 64, 67, 72, 56,
253, 74, 260, 39, 70, 59, 255, 77, 242, 0,
0, 272, 284, 108, 268, 112, 116, 269, 284, 0,
113, 116, 256, 245, 0, 244, 233, 122, 240, 235,
245, 243, 247, 234, 236, 240, 240, 234, 240, 225,
225, 226, 228, 230, 0, 106, 226, 220, 220, 119,
230, 222, 228, 87, 0, 284, 141, 240, 0, 233,
226, 212, 225, 215, 222, 0, 0, 212, 218, 215,
206, 214, 0, 212, 202, 0, 206, 210, 200, 0,
201, 0, 0, 207, 0, 199, 198, 0, 189, 0,
0, 216, 215, 0, 186, 0, 199, 198, 191, 195,
185, 181, 0, 191, 179, 185, 190, 191, 0, 178,
185, 172, 175, 164, 0, 283, 0, 176, 180, 172,
0, 171, 173, 169, 171, 176, 0, 160, 165, 0,
158, 158, 157, 154, 0, 0, 166, 168, 0, 152,
169, 155, 0, 162, 166, 147, 147, 154, 0, 0,
153, 145, 144, 68, 154, 140, 150, 140, 132, 0,
136, 130, 128, 133, 0, 122, 0, 116, 122, 125,
117, 0, 132, 113, 126, 0, 120, 127, 0, 104,
0, 203, 0, 0, 209, 0, 201, 200, 0, 191,
0, 0, 218, 217, 0, 188, 0, 201, 200, 193,
197, 187, 183, 0, 193, 181, 187, 192, 193, 0,
180, 187, 174, 177, 166, 0, 284, 0, 178, 182,
174, 0, 173, 175, 171, 173, 178, 0, 162, 167,
0, 160, 160, 159, 156, 0, 0, 168, 170, 0,
154, 171, 157, 0, 164, 168, 149, 149, 156, 0,
0, 155, 147, 146, 68, 156, 142, 152, 142, 134,
0, 151, 145, 130, 135, 0, 124, 0, 118, 124,
127, 119, 0, 134, 115, 128, 0, 122, 129, 0,
106, 94, 78, 65, 37, 0, 31, 0, 283, 42,
158, 160, 162, 164, 166, 168
104, 106, 94, 78, 65, 37, 0, 31, 0, 284,
42, 158, 160, 162, 164, 166, 168
} ;
static const flex_int16_t yy_def[217] =
static const flex_int16_t yy_def[218] =
{ 0,
209, 1, 209, 210, 209, 209, 210, 211, 212, 210,
10, 210, 10, 210, 10, 10, 10, 10, 10, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 209, 209, 211, 213, 214, 212, 215, 209, 10,
10, 10, 210, 210, 210, 210, 210, 10, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 209, 214, 216, 42, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 1, 210, 211, 210, 210, 211, 212, 213, 211,
10, 211, 10, 211, 10, 10, 10, 10, 10, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 210, 210, 212, 214, 215, 213, 216, 210, 10,
10, 10, 211, 211, 211, 211, 211, 10, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 210, 215, 217, 42, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 209, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 209, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 210, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 210, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
210, 210, 210, 210, 210, 210, 210, 210, 0, 209,
209, 209, 209, 209, 209, 209
211, 211, 211, 211, 211, 211, 211, 211, 211, 0,
210, 210, 210, 210, 210, 210, 210
} ;
static const flex_int16_t yy_nxt[324] =
static const flex_int16_t yy_nxt[325] =
{ 0,
4, 5, 6, 7, 8, 9, 10, 11, 10, 12,
13, 13, 14, 4, 4, 4, 15, 13, 16, 17,
18, 19, 20, 21, 22, 23, 24, 4, 25, 26,
4, 27, 28, 4, 29, 4, 4, 4, 4, 30,
35, 35, 31, 36, 38, 39, 40, 40, 40, 208,
35, 35, 31, 36, 38, 39, 40, 40, 40, 209,
41, 41, 41, 41, 41, 62, 41, 41, 41, 41,
41, 41, 41, 41, 41, 63, 41, 41, 41, 207,
41, 41, 41, 41, 41, 63, 41, 41, 41, 208,
41, 41, 41, 41, 41, 41, 54, 67, 41, 41,
41, 44, 57, 46, 48, 55, 68, 181, 45, 47,
69, 64, 49, 206, 51, 50, 52, 65, 205, 66,
41, 44, 57, 46, 48, 55, 68, 182, 45, 47,
69, 64, 49, 207, 51, 50, 52, 65, 206, 66,
182, 58, 59, 71, 110, 60, 72, 111, 53, 35,
35, 73, 75, 78, 78, 204, 31, 38, 39, 41,
41, 41, 79, 79, 79, 203, 79, 79, 41, 41,
41, 202, 79, 79, 79, 79, 79, 79, 105, 106,
78, 78, 201, 112, 200, 199, 198, 197, 196, 195,
194, 193, 192, 191, 190, 189, 188, 84, 34, 34,
183, 58, 59, 71, 111, 60, 72, 112, 53, 35,
35, 73, 75, 78, 78, 205, 31, 38, 39, 41,
41, 41, 79, 79, 79, 204, 79, 79, 41, 41,
41, 203, 79, 79, 79, 79, 79, 79, 101, 102,
106, 107, 78, 78, 202, 113, 201, 200, 199, 198,
197, 196, 195, 194, 193, 192, 191, 84, 34, 34,
37, 37, 35, 35, 77, 77, 38, 38, 78, 78,
187, 186, 185, 184, 183, 180, 179, 178, 177, 176,
175, 174, 173, 172, 171, 170, 169, 168, 167, 166,
165, 164, 163, 162, 161, 160, 159, 158, 157, 156,
190, 189, 188, 187, 186, 185, 184, 181, 180, 179,
178, 177, 176, 175, 174, 173, 172, 171, 170, 169,
168, 167, 166, 165, 164, 163, 162, 161, 160, 159,
155, 154, 153, 152, 151, 150, 149, 148, 147, 146,
145, 144, 143, 142, 141, 140, 139, 138, 137, 136,
135, 134, 133, 132, 131, 130, 129, 128, 127, 126,
125, 124, 123, 122, 121, 120, 119, 118, 117, 116,
115, 114, 113, 109, 108, 107, 104, 103, 102, 101,
100, 99, 98, 97, 96, 95, 94, 93, 92, 91,
90, 89, 88, 87, 86, 85, 83, 82, 81, 80,
39, 76, 32, 74, 70, 61, 56, 43, 42, 33,
32, 209, 3, 209, 209, 209, 209, 209, 209, 209,
209, 209, 209, 209, 209, 209, 209, 209, 209, 209,
158, 157, 156, 155, 154, 153, 152, 151, 150, 149,
148, 147, 146, 145, 144, 143, 142, 141, 140, 139,
138, 137, 136, 135, 134, 133, 132, 131, 130, 129,
128, 127, 126, 125, 124, 123, 122, 121, 120, 119,
118, 117, 116, 115, 114, 110, 109, 108, 105, 104,
103, 100, 99, 98, 97, 96, 95, 94, 93, 92,
91, 90, 89, 88, 87, 86, 85, 83, 82, 81,
80, 39, 76, 32, 74, 70, 61, 56, 43, 42,
33, 32, 210, 3, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
209, 209, 209, 209, 209, 209, 209, 209, 209, 209,
209, 209, 209, 209, 209, 209, 209, 209, 209, 209,
209, 209, 209
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210
} ;
static const flex_int16_t yy_chk[324] =
static const flex_int16_t yy_chk[325] =
{ 0,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
8, 8, 210, 8, 9, 9, 10, 10, 10, 207,
8, 8, 211, 8, 9, 9, 10, 10, 10, 208,
10, 10, 13, 13, 13, 24, 10, 10, 10, 10,
10, 10, 15, 15, 15, 24, 16, 16, 16, 205,
10, 10, 15, 15, 15, 24, 16, 16, 16, 206,
17, 17, 17, 18, 18, 18, 20, 26, 19, 19,
19, 15, 22, 16, 17, 20, 26, 174, 15, 16,
26, 25, 17, 204, 18, 17, 19, 25, 203, 25,
19, 15, 22, 16, 17, 20, 26, 175, 15, 16,
26, 25, 17, 205, 18, 17, 19, 25, 204, 25,
174, 22, 22, 28, 74, 22, 28, 74, 19, 34,
34, 28, 34, 36, 36, 202, 36, 37, 37, 41,
41, 41, 42, 42, 42, 201, 42, 42, 48, 48,
48, 200, 42, 42, 42, 42, 42, 42, 70, 70,
77, 77, 198, 77, 197, 195, 194, 193, 191, 190,
189, 188, 186, 184, 183, 182, 181, 48, 211, 211,
212, 212, 213, 213, 214, 214, 215, 215, 216, 216,
179, 178, 177, 176, 175, 173, 172, 171, 168, 167,
166, 165, 164, 162, 161, 160, 158, 157, 154, 153,
152, 151, 149, 148, 146, 145, 144, 143, 142, 140,
175, 22, 22, 28, 74, 22, 28, 74, 19, 34,
34, 28, 34, 36, 36, 203, 36, 37, 37, 41,
41, 41, 42, 42, 42, 202, 42, 42, 48, 48,
48, 201, 42, 42, 42, 42, 42, 42, 66, 66,
70, 70, 77, 77, 199, 77, 198, 196, 195, 194,
192, 191, 190, 189, 187, 185, 184, 48, 212, 212,
213, 213, 214, 214, 215, 215, 216, 216, 217, 217,
183, 182, 180, 179, 178, 177, 176, 174, 173, 172,
169, 168, 167, 166, 165, 163, 162, 161, 159, 158,
155, 154, 153, 152, 150, 149, 147, 146, 145, 144,
139, 138, 134, 133, 132, 131, 130, 128, 127, 126,
125, 124, 122, 121, 120, 119, 118, 117, 115, 113,
112, 109, 107, 106, 104, 101, 99, 98, 97, 95,
94, 92, 91, 90, 89, 88, 85, 84, 83, 82,
81, 80, 78, 73, 72, 71, 69, 68, 67, 66,
64, 63, 62, 61, 60, 59, 58, 57, 56, 55,
54, 53, 52, 51, 50, 49, 47, 46, 44, 43,
38, 35, 32, 29, 27, 23, 21, 14, 11, 7,
5, 3, 209, 209, 209, 209, 209, 209, 209, 209,
209, 209, 209, 209, 209, 209, 209, 209, 209, 209,
143, 141, 140, 139, 135, 134, 133, 132, 131, 129,
128, 127, 126, 125, 123, 122, 121, 120, 119, 118,
116, 114, 113, 110, 108, 107, 105, 102, 99, 98,
97, 95, 94, 92, 91, 90, 89, 88, 85, 84,
83, 82, 81, 80, 78, 73, 72, 71, 69, 68,
67, 64, 63, 62, 61, 60, 59, 58, 57, 56,
55, 54, 53, 52, 51, 50, 49, 47, 46, 44,
43, 38, 35, 32, 29, 27, 23, 21, 14, 11,
7, 5, 3, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
209, 209, 209, 209, 209, 209, 209, 209, 209, 209,
209, 209, 209, 209, 209, 209, 209, 209, 209, 209,
209, 209, 209
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210, 210, 210, 210, 210, 210, 210,
210, 210, 210, 210
} ;
static yy_state_type yy_last_accepting_state;
@@ -823,13 +823,13 @@ yy_match:
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
{
yy_current_state = (int) yy_def[yy_current_state];
if ( yy_current_state >= 210 )
if ( yy_current_state >= 211 )
yy_c = yy_meta[yy_c];
}
yy_current_state = yy_nxt[yy_base[yy_current_state] + yy_c];
++yy_cp;
}
while ( yy_base[yy_current_state] != 283 );
while ( yy_base[yy_current_state] != 284 );
yy_find_action:
yy_act = yy_accept[yy_current_state];
@@ -881,7 +881,7 @@ YY_RULE_SETUP
YY_BREAK
case 7:
YY_RULE_SETUP
{return(REFERENCE);}
{return(OPS);}
YY_BREAK
case 8:
YY_RULE_SETUP
@@ -889,143 +889,143 @@ YY_RULE_SETUP
YY_BREAK
case 9:
YY_RULE_SETUP
{return(ASSOCIATION);}
{return(REFERENCE);}
YY_BREAK
case 10:
YY_RULE_SETUP
{return(REGISTER);}
{return(ASSOCIATION);}
YY_BREAK
case 11:
YY_RULE_SETUP
{return(FW_CONFIG_TABLE);}
{return(REGISTER);}
YY_BREAK
case 12:
YY_RULE_SETUP
{return(FW_CONFIG_FIELD);}
{return(FW_CONFIG_TABLE);}
YY_BREAK
case 13:
YY_RULE_SETUP
{return(FW_CONFIG_OPTION);}
{return(FW_CONFIG_FIELD);}
YY_BREAK
case 14:
YY_RULE_SETUP
{return(FW_CONFIG_PROBE);}
{return(FW_CONFIG_OPTION);}
YY_BREAK
case 15:
YY_RULE_SETUP
{yylval.number=1; return(BOOL);}
{return(FW_CONFIG_PROBE);}
YY_BREAK
case 16:
YY_RULE_SETUP
{yylval.number=0; return(BOOL);}
{yylval.number=1; return(BOOL);}
YY_BREAK
case 17:
YY_RULE_SETUP
{yylval.number=3; return(STATUS);}
{yylval.number=0; return(BOOL);}
YY_BREAK
case 18:
YY_RULE_SETUP
{yylval.number=5; return(STATUS);}
{yylval.number=3; return(STATUS);}
YY_BREAK
case 19:
YY_RULE_SETUP
{yylval.number=PCI; return(BUS);}
{yylval.number=5; return(STATUS);}
YY_BREAK
case 20:
YY_RULE_SETUP
{yylval.number=IOAPIC; return(BUS);}
{yylval.number=PCI; return(BUS);}
YY_BREAK
case 21:
YY_RULE_SETUP
{yylval.number=PNP; return(BUS);}
{yylval.number=IOAPIC; return(BUS);}
YY_BREAK
case 22:
YY_RULE_SETUP
{yylval.number=I2C; return(BUS);}
{yylval.number=PNP; return(BUS);}
YY_BREAK
case 23:
YY_RULE_SETUP
{yylval.number=APIC; return(BUS);}
{yylval.number=I2C; return(BUS);}
YY_BREAK
case 24:
YY_RULE_SETUP
{yylval.number=CPU_CLUSTER; return(BUS);}
{yylval.number=APIC; return(BUS);}
YY_BREAK
case 25:
YY_RULE_SETUP
{yylval.number=CPU; return(BUS);}
{yylval.number=CPU_CLUSTER; return(BUS);}
YY_BREAK
case 26:
YY_RULE_SETUP
{yylval.number=DOMAIN; return(BUS);}
{yylval.number=CPU; return(BUS);}
YY_BREAK
case 27:
YY_RULE_SETUP
{yylval.number=GENERIC; return(BUS);}
{yylval.number=DOMAIN; return(BUS);}
YY_BREAK
case 28:
YY_RULE_SETUP
{yylval.number=MMIO; return(BUS);}
{yylval.number=GENERIC; return(BUS);}
YY_BREAK
case 29:
YY_RULE_SETUP
{yylval.number=SPI; return(BUS);}
{yylval.number=MMIO; return(BUS);}
YY_BREAK
case 30:
YY_RULE_SETUP
{yylval.number=USB; return(BUS);}
{yylval.number=SPI; return(BUS);}
YY_BREAK
case 31:
YY_RULE_SETUP
{yylval.number=GPIO; return(BUS);}
{yylval.number=USB; return(BUS);}
YY_BREAK
case 32:
YY_RULE_SETUP
{yylval.number=IRQ; return(RESOURCE);}
{yylval.number=GPIO; return(BUS);}
YY_BREAK
case 33:
YY_RULE_SETUP
{yylval.number=DRQ; return(RESOURCE);}
{yylval.number=IRQ; return(RESOURCE);}
YY_BREAK
case 34:
YY_RULE_SETUP
{yylval.number=IO; return(RESOURCE);}
{yylval.number=DRQ; return(RESOURCE);}
YY_BREAK
case 35:
YY_RULE_SETUP
{return(IOAPIC_IRQ);}
{yylval.number=IO; return(RESOURCE);}
YY_BREAK
case 36:
YY_RULE_SETUP
{return(INHERIT);}
{return(IOAPIC_IRQ);}
YY_BREAK
case 37:
YY_RULE_SETUP
{return(SUBSYSTEMID);}
{return(INHERIT);}
YY_BREAK
case 38:
YY_RULE_SETUP
{return(END);}
{return(SUBSYSTEMID);}
YY_BREAK
case 39:
YY_RULE_SETUP
{return(SLOT_DESC);}
{return(END);}
YY_BREAK
case 40:
YY_RULE_SETUP
{return(SMBIOS_DEV_INFO);}
{return(SLOT_DESC);}
YY_BREAK
case 41:
YY_RULE_SETUP
{return(EQUALS);}
{return(SMBIOS_DEV_INFO);}
YY_BREAK
case 42:
YY_RULE_SETUP
{return(PIPE);}
{return(EQUALS);}
YY_BREAK
case 43:
YY_RULE_SETUP
{yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(NUMBER);}
{return(PIPE);}
YY_BREAK
case 44:
YY_RULE_SETUP
@@ -1037,12 +1037,11 @@ YY_RULE_SETUP
YY_BREAK
case 46:
YY_RULE_SETUP
{yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(PCIINT);}
{yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(NUMBER);}
YY_BREAK
case 47:
/* rule 47 can match eol */
YY_RULE_SETUP
{yylval.string = malloc(yyleng-1); strncpy(yylval.string, yytext+1, yyleng-2); yylval.string[yyleng-2]='\0'; return(STRING);}
{yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(PCIINT);}
YY_BREAK
case 48:
/* rule 48 can match eol */
@@ -1050,10 +1049,15 @@ YY_RULE_SETUP
{yylval.string = malloc(yyleng-1); strncpy(yylval.string, yytext+1, yyleng-2); yylval.string[yyleng-2]='\0'; return(STRING);}
YY_BREAK
case 49:
/* rule 49 can match eol */
YY_RULE_SETUP
{yylval.string = malloc(yyleng-1); strncpy(yylval.string, yytext+1, yyleng-2); yylval.string[yyleng-2]='\0'; return(STRING);}
YY_BREAK
case 50:
YY_RULE_SETUP
{yylval.string = malloc(yyleng+1); strncpy(yylval.string, yytext, yyleng); yylval.string[yyleng]='\0'; return(STRING);}
YY_BREAK
case 50:
case 51:
YY_RULE_SETUP
ECHO;
YY_BREAK
@@ -1353,7 +1357,7 @@ static int yy_get_next_buffer (void)
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
{
yy_current_state = (int) yy_def[yy_current_state];
if ( yy_current_state >= 210 )
if ( yy_current_state >= 211 )
yy_c = yy_meta[yy_c];
}
yy_current_state = yy_nxt[yy_base[yy_current_state] + yy_c];
@@ -1381,11 +1385,11 @@ static int yy_get_next_buffer (void)
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
{
yy_current_state = (int) yy_def[yy_current_state];
if ( yy_current_state >= 210 )
if ( yy_current_state >= 211 )
yy_c = yy_meta[yy_c];
}
yy_current_state = yy_nxt[yy_base[yy_current_state] + yy_c];
yy_is_jam = (yy_current_state == 209);
yy_is_jam = (yy_current_state == 210);
return yy_is_jam ? 0 : yy_current_state;
}