b358433ce2342974a33a1d78175a2fda8db357fe
2 * Mesa 3-D graphics library
4 * Copyright (C) 2014 LunarG, Inc.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
28 #include "pipe/p_compiler.h"
29 #include "util/u_debug.h"
31 #include "intel_reg.h"
32 #include "brw_defines.h"
34 #include "gen_regs.xml.h"
35 #include "gen_mi.xml.h"
36 #include "gen_blitter.xml.h"
37 #include "gen_render_surface.xml.h"
38 #include "gen_render_dynamic.xml.h"
39 #include "gen_render_3d.xml.h"
40 #include "gen_eu_isa.xml.h"
41 #include "gen_eu_message.xml.h"
43 #define GEN_MI_CMD(op) (GEN6_MI_TYPE_MI | GEN6_MI_OPCODE_ ## op)
45 #define GEN_BLITTER_CMD(op) \
46 (GEN6_BLITTER_TYPE_BLITTER | GEN6_BLITTER_OPCODE_ ## op)
48 #define GEN_RENDER_CMD(subtype, op) \
49 (GEN6_RENDER_TYPE_RENDER | \
50 GEN6_RENDER_SUBTYPE_ ## subtype | \
51 GEN6_RENDER_OPCODE_ ## op)
56 return (devid
== 0x0102 || /* GT1 desktop */
57 devid
== 0x0112 || /* GT2 desktop */
58 devid
== 0x0122 || /* GT2_PLUS desktop */
59 devid
== 0x0106 || /* GT1 mobile */
60 devid
== 0x0116 || /* GT2 mobile */
61 devid
== 0x0126 || /* GT2_PLUS mobile */
62 devid
== 0x010a); /* GT1 server */
66 gen_get_snb_gt(int devid
)
68 assert(gen_is_snb(devid
));
69 return (devid
& 0x30) ? 2 : 1;
75 return (devid
== 0x0152 || /* GT1 desktop */
76 devid
== 0x0162 || /* GT2 desktop */
77 devid
== 0x0156 || /* GT1 mobile */
78 devid
== 0x0166 || /* GT2 mobile */
79 devid
== 0x015a || /* GT1 server */
80 devid
== 0x016a); /* GT2 server */
84 gen_get_ivb_gt(int devid
)
86 assert(gen_is_ivb(devid
));
87 return (devid
& 0x30) >> 4;
93 return (devid
== 0x0402 || /* GT1 desktop */
94 devid
== 0x0412 || /* GT2 desktop */
95 devid
== 0x0422 || /* GT3 desktop */
96 devid
== 0x0406 || /* GT1 mobile */
97 devid
== 0x0416 || /* GT2 mobile */
98 devid
== 0x0426 || /* GT2 mobile */
99 devid
== 0x040a || /* GT1 server */
100 devid
== 0x041a || /* GT2 server */
101 devid
== 0x042a || /* GT3 server */
102 devid
== 0x040b || /* GT1 reserved */
103 devid
== 0x041b || /* GT2 reserved */
104 devid
== 0x042b || /* GT3 reserved */
105 devid
== 0x040e || /* GT1 reserved */
106 devid
== 0x041e || /* GT2 reserved */
107 devid
== 0x042e || /* GT3 reserved */
108 devid
== 0x0c02 || /* SDV */
123 devid
== 0x0a02 || /* ULT */
138 devid
== 0x0d02 || /* CRW */
156 gen_get_hsw_gt(int devid
)
158 assert(gen_is_hsw(devid
));
159 return ((devid
& 0x30) >> 4) + 1;
163 gen_is_vlv(int devid
)
165 return (devid
== 0x0f30 ||
174 gen_is_atom(int devid
)
176 return gen_is_vlv(devid
);
180 gen_is_desktop(int devid
)
182 assert(!gen_is_atom(devid
));
183 return ((devid
& 0xf) == 0x2);
187 gen_is_mobile(int devid
)
189 assert(!gen_is_atom(devid
));
190 return ((devid
& 0xf) == 0x6);
194 gen_is_server(int devid
)
196 assert(!gen_is_atom(devid
));
197 return ((devid
& 0xf) == 0xa);