1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright © 2021 Intel Corporation
3*61046927SAndroid Build Coastguard Worker *
4*61046927SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker *
11*61046927SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker * Software.
14*61046927SAndroid Build Coastguard Worker *
15*61046927SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*61046927SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*61046927SAndroid Build Coastguard Worker * IN THE SOFTWARE.
22*61046927SAndroid Build Coastguard Worker */
23*61046927SAndroid Build Coastguard Worker
24*61046927SAndroid Build Coastguard Worker #include <stdio.h>
25*61046927SAndroid Build Coastguard Worker #include <stdlib.h>
26*61046927SAndroid Build Coastguard Worker
27*61046927SAndroid Build Coastguard Worker #include "intel_device_info.h"
28*61046927SAndroid Build Coastguard Worker #include "intel_hwconfig.h"
29*61046927SAndroid Build Coastguard Worker #include "intel_hwconfig_types.h"
30*61046927SAndroid Build Coastguard Worker #include "intel/common/intel_gem.h"
31*61046927SAndroid Build Coastguard Worker #include "i915/intel_device_info.h"
32*61046927SAndroid Build Coastguard Worker #include "xe/intel_device_info.h"
33*61046927SAndroid Build Coastguard Worker
34*61046927SAndroid Build Coastguard Worker #include "util/log.h"
35*61046927SAndroid Build Coastguard Worker
36*61046927SAndroid Build Coastguard Worker #ifdef NDEBUG
37*61046927SAndroid Build Coastguard Worker #define DEBUG_BUILD false
38*61046927SAndroid Build Coastguard Worker #else
39*61046927SAndroid Build Coastguard Worker #define DEBUG_BUILD true
40*61046927SAndroid Build Coastguard Worker #endif
41*61046927SAndroid Build Coastguard Worker
42*61046927SAndroid Build Coastguard Worker struct hwconfig {
43*61046927SAndroid Build Coastguard Worker uint32_t key;
44*61046927SAndroid Build Coastguard Worker uint32_t len;
45*61046927SAndroid Build Coastguard Worker uint32_t val[];
46*61046927SAndroid Build Coastguard Worker };
47*61046927SAndroid Build Coastguard Worker
48*61046927SAndroid Build Coastguard Worker static char *
key_to_name(uint32_t key)49*61046927SAndroid Build Coastguard Worker key_to_name(uint32_t key)
50*61046927SAndroid Build Coastguard Worker {
51*61046927SAndroid Build Coastguard Worker #define HANDLE(key_name) case key_name: return #key_name
52*61046927SAndroid Build Coastguard Worker switch (key) {
53*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_SLICES_SUPPORTED);
54*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_DUAL_SUBSLICES_SUPPORTED);
55*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_NUM_EU_PER_DSS);
56*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_NUM_PIXEL_PIPES);
57*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DEPRECATED_MAX_NUM_GEOMETRY_PIPES);
58*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DEPRECATED_L3_CACHE_SIZE_IN_KB);
59*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DEPRECATED_L3_BANK_COUNT);
60*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_CACHE_WAYS_SIZE_IN_BYTES);
61*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_CACHE_WAYS_PER_SECTOR);
62*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_MEMORY_CHANNELS);
63*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MEMORY_TYPE);
64*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_CACHE_TYPES);
65*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_LOCAL_MEMORY_PAGE_SIZES_SUPPORTED);
66*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DEPRECATED_SLM_SIZE_IN_KB);
67*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_NUM_THREADS_PER_EU);
68*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_TOTAL_VS_THREADS);
69*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_TOTAL_GS_THREADS);
70*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_TOTAL_HS_THREADS);
71*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_TOTAL_DS_THREADS);
72*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_TOTAL_VS_THREADS_POCS);
73*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_TOTAL_PS_THREADS);
74*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DEPRECATED_MAX_FILL_RATE);
75*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_RCS);
76*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_CCS);
77*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_VCS);
78*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_VECS);
79*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_COPY_CS);
80*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DEPRECATED_URB_SIZE_IN_KB);
81*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MIN_VS_URB_ENTRIES);
82*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_VS_URB_ENTRIES);
83*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MIN_PCS_URB_ENTRIES);
84*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_PCS_URB_ENTRIES);
85*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MIN_HS_URB_ENTRIES);
86*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_HS_URB_ENTRIES);
87*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MIN_GS_URB_ENTRIES);
88*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_GS_URB_ENTRIES);
89*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MIN_DS_URB_ENTRIES);
90*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_DS_URB_ENTRIES);
91*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_PUSH_CONSTANT_URB_RESERVED_SIZE);
92*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_POCS_PUSH_CONSTANT_URB_RESERVED_SIZE);
93*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_URB_REGION_ALIGNMENT_SIZE_IN_BYTES);
94*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_URB_ALLOCATION_SIZE_UNITS_IN_BYTES);
95*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_URB_SIZE_CCS_IN_BYTES);
96*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_VS_MIN_DEREF_BLOCK_SIZE_HANDLE_COUNT);
97*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_DS_MIN_DEREF_BLOCK_SIZE_HANDLE_COUNT);
98*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_NUM_RT_STACKS_PER_DSS);
99*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_URB_STARTING_ADDRESS);
100*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MIN_CS_URB_ENTRIES);
101*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_CS_URB_ENTRIES);
102*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_URB);
103*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_REST);
104*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_DC);
105*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_RO);
106*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_Z);
107*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_COLOR);
108*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_UNIFIED_TILE_CACHE);
109*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_COMMAND_BUFFER);
110*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_ALLOC_PER_BANK_RW);
111*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_NUM_L3_CONFIGS);
112*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_BINDLESS_SURFACE_OFFSET_BIT_COUNT);
113*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_RESERVED_CCS_WAYS);
114*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_CSR_SIZE_IN_MB);
115*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_GEOMETRY_PIPES_PER_SLICE);
116*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_L3_BANK_SIZE_IN_KB);
117*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_SLM_SIZE_PER_DSS);
118*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_PIXEL_FILL_RATE_PER_SLICE);
119*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_PIXEL_FILL_RATE_PER_DSS);
120*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_URB_SIZE_PER_SLICE_IN_KB);
121*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_URB_SIZE_PER_L3_BANK_COUNT_IN_KB);
122*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_SUBSLICE);
123*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_MAX_EU_PER_SUBSLICE);
124*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_RAMBO_L3_BANK_SIZE_IN_KB);
125*61046927SAndroid Build Coastguard Worker HANDLE(INTEL_HWCONFIG_SLM_SIZE_PER_SS_IN_KB);
126*61046927SAndroid Build Coastguard Worker #undef HANDLE
127*61046927SAndroid Build Coastguard Worker }
128*61046927SAndroid Build Coastguard Worker return "UNKNOWN_INTEL_HWCONFIG";
129*61046927SAndroid Build Coastguard Worker }
130*61046927SAndroid Build Coastguard Worker
131*61046927SAndroid Build Coastguard Worker typedef void (*hwconfig_item_cb)(struct intel_device_info *devinfo,
132*61046927SAndroid Build Coastguard Worker const struct hwconfig *item);
133*61046927SAndroid Build Coastguard Worker
134*61046927SAndroid Build Coastguard Worker static void
process_hwconfig_table(struct intel_device_info * devinfo,const struct hwconfig * hwconfig,int32_t hwconfig_len,hwconfig_item_cb item_callback_func)135*61046927SAndroid Build Coastguard Worker process_hwconfig_table(struct intel_device_info *devinfo,
136*61046927SAndroid Build Coastguard Worker const struct hwconfig *hwconfig,
137*61046927SAndroid Build Coastguard Worker int32_t hwconfig_len,
138*61046927SAndroid Build Coastguard Worker hwconfig_item_cb item_callback_func)
139*61046927SAndroid Build Coastguard Worker {
140*61046927SAndroid Build Coastguard Worker assert(hwconfig);
141*61046927SAndroid Build Coastguard Worker assert(hwconfig_len % 4 == 0);
142*61046927SAndroid Build Coastguard Worker const struct hwconfig *current = hwconfig;
143*61046927SAndroid Build Coastguard Worker const struct hwconfig *end =
144*61046927SAndroid Build Coastguard Worker (struct hwconfig*)(((uint32_t*)hwconfig) + (hwconfig_len / 4));
145*61046927SAndroid Build Coastguard Worker while (current < end) {
146*61046927SAndroid Build Coastguard Worker assert(current + 1 < end);
147*61046927SAndroid Build Coastguard Worker struct hwconfig *next =
148*61046927SAndroid Build Coastguard Worker (struct hwconfig*)((uint32_t*)current + 2 + current->len);
149*61046927SAndroid Build Coastguard Worker assert(next <= end);
150*61046927SAndroid Build Coastguard Worker item_callback_func(devinfo, current);
151*61046927SAndroid Build Coastguard Worker current = next;
152*61046927SAndroid Build Coastguard Worker }
153*61046927SAndroid Build Coastguard Worker assert(current == end);
154*61046927SAndroid Build Coastguard Worker }
155*61046927SAndroid Build Coastguard Worker
156*61046927SAndroid Build Coastguard Worker static inline bool
apply_hwconfig(const struct intel_device_info * devinfo)157*61046927SAndroid Build Coastguard Worker apply_hwconfig(const struct intel_device_info *devinfo)
158*61046927SAndroid Build Coastguard Worker {
159*61046927SAndroid Build Coastguard Worker /* returns is true when the platform should apply hwconfig values */
160*61046927SAndroid Build Coastguard Worker return devinfo->verx10 >= 125;
161*61046927SAndroid Build Coastguard Worker }
162*61046927SAndroid Build Coastguard Worker
163*61046927SAndroid Build Coastguard Worker /* If apply_hwconfig(devinfo) is true, then we apply the
164*61046927SAndroid Build Coastguard Worker * hwconfig value.
165*61046927SAndroid Build Coastguard Worker *
166*61046927SAndroid Build Coastguard Worker * For debug builds, if apply_hwconfig() is false, we will compare the
167*61046927SAndroid Build Coastguard Worker * hwconfig value with the current value in the devinfo and log a warning
168*61046927SAndroid Build Coastguard Worker * message if they differ. This should help to make sure the values in our
169*61046927SAndroid Build Coastguard Worker * devinfo structures match what hwconfig is specified.
170*61046927SAndroid Build Coastguard Worker */
171*61046927SAndroid Build Coastguard Worker #define DEVINFO_HWCONFIG(F, V) \
172*61046927SAndroid Build Coastguard Worker do { \
173*61046927SAndroid Build Coastguard Worker if (apply_hwconfig(devinfo)) \
174*61046927SAndroid Build Coastguard Worker devinfo->F = V; \
175*61046927SAndroid Build Coastguard Worker else if (DEBUG_BUILD && devinfo->F != (V)) \
176*61046927SAndroid Build Coastguard Worker mesa_logw("%s (%u) != devinfo->%s (%u)", \
177*61046927SAndroid Build Coastguard Worker key_to_name(item->key), (V), #F, \
178*61046927SAndroid Build Coastguard Worker devinfo->F); \
179*61046927SAndroid Build Coastguard Worker } while (0)
180*61046927SAndroid Build Coastguard Worker
181*61046927SAndroid Build Coastguard Worker static void
apply_hwconfig_item(struct intel_device_info * devinfo,const struct hwconfig * item)182*61046927SAndroid Build Coastguard Worker apply_hwconfig_item(struct intel_device_info *devinfo,
183*61046927SAndroid Build Coastguard Worker const struct hwconfig *item)
184*61046927SAndroid Build Coastguard Worker {
185*61046927SAndroid Build Coastguard Worker switch (item->key) {
186*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_SLICES_SUPPORTED:
187*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_DUAL_SUBSLICES_SUPPORTED:
188*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_NUM_PIXEL_PIPES:
189*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DEPRECATED_MAX_NUM_GEOMETRY_PIPES:
190*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DEPRECATED_L3_CACHE_SIZE_IN_KB:
191*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DEPRECATED_L3_BANK_COUNT:
192*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_CACHE_WAYS_SIZE_IN_BYTES:
193*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_CACHE_WAYS_PER_SECTOR:
194*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_MEMORY_CHANNELS:
195*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MEMORY_TYPE:
196*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_CACHE_TYPES:
197*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_LOCAL_MEMORY_PAGE_SIZES_SUPPORTED:
198*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DEPRECATED_SLM_SIZE_IN_KB:
199*61046927SAndroid Build Coastguard Worker break; /* ignore */
200*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_NUM_EU_PER_DSS:
201*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(max_eus_per_subslice, item->val[0]);
202*61046927SAndroid Build Coastguard Worker break;
203*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_NUM_THREADS_PER_EU:
204*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(num_thread_per_eu, item->val[0]);
205*61046927SAndroid Build Coastguard Worker break;
206*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_TOTAL_VS_THREADS:
207*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(max_vs_threads, item->val[0]);
208*61046927SAndroid Build Coastguard Worker break;
209*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_TOTAL_GS_THREADS:
210*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(max_gs_threads, item->val[0]);
211*61046927SAndroid Build Coastguard Worker break;
212*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_TOTAL_HS_THREADS:
213*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(max_tcs_threads, item->val[0]);
214*61046927SAndroid Build Coastguard Worker break;
215*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_TOTAL_DS_THREADS:
216*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(max_tes_threads, item->val[0]);
217*61046927SAndroid Build Coastguard Worker break;
218*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_TOTAL_VS_THREADS_POCS:
219*61046927SAndroid Build Coastguard Worker break; /* ignore */
220*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_TOTAL_PS_THREADS: {
221*61046927SAndroid Build Coastguard Worker unsigned threads = item->val[0];
222*61046927SAndroid Build Coastguard Worker if (devinfo->ver == 12)
223*61046927SAndroid Build Coastguard Worker threads /= 2;
224*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(max_threads_per_psd, threads);
225*61046927SAndroid Build Coastguard Worker break;
226*61046927SAndroid Build Coastguard Worker }
227*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_URB_SIZE_PER_SLICE_IN_KB:
228*61046927SAndroid Build Coastguard Worker DEVINFO_HWCONFIG(urb.size, item->val[0]);
229*61046927SAndroid Build Coastguard Worker break;
230*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DEPRECATED_MAX_FILL_RATE:
231*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_RCS:
232*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_CCS:
233*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_VCS:
234*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_VECS:
235*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_COPY_CS:
236*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DEPRECATED_URB_SIZE_IN_KB:
237*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MIN_VS_URB_ENTRIES:
238*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_VS_URB_ENTRIES:
239*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MIN_PCS_URB_ENTRIES:
240*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_PCS_URB_ENTRIES:
241*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MIN_HS_URB_ENTRIES:
242*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_HS_URB_ENTRIES:
243*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MIN_GS_URB_ENTRIES:
244*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_GS_URB_ENTRIES:
245*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MIN_DS_URB_ENTRIES:
246*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_DS_URB_ENTRIES:
247*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_PUSH_CONSTANT_URB_RESERVED_SIZE:
248*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_POCS_PUSH_CONSTANT_URB_RESERVED_SIZE:
249*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_URB_REGION_ALIGNMENT_SIZE_IN_BYTES:
250*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_URB_ALLOCATION_SIZE_UNITS_IN_BYTES:
251*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_URB_SIZE_CCS_IN_BYTES:
252*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_VS_MIN_DEREF_BLOCK_SIZE_HANDLE_COUNT:
253*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_DS_MIN_DEREF_BLOCK_SIZE_HANDLE_COUNT:
254*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_NUM_RT_STACKS_PER_DSS:
255*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_URB_STARTING_ADDRESS:
256*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MIN_CS_URB_ENTRIES:
257*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_CS_URB_ENTRIES:
258*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_URB:
259*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_REST:
260*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_DC:
261*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_RO:
262*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_Z:
263*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_COLOR:
264*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_UNIFIED_TILE_CACHE:
265*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_COMMAND_BUFFER:
266*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_ALLOC_PER_BANK_RW:
267*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_NUM_L3_CONFIGS:
268*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_BINDLESS_SURFACE_OFFSET_BIT_COUNT:
269*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_RESERVED_CCS_WAYS:
270*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_CSR_SIZE_IN_MB:
271*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_GEOMETRY_PIPES_PER_SLICE:
272*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_L3_BANK_SIZE_IN_KB:
273*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_SLM_SIZE_PER_DSS:
274*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_PIXEL_FILL_RATE_PER_SLICE:
275*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_PIXEL_FILL_RATE_PER_DSS:
276*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_URB_SIZE_PER_L3_BANK_COUNT_IN_KB:
277*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_SUBSLICE:
278*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_MAX_EU_PER_SUBSLICE:
279*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_RAMBO_L3_BANK_SIZE_IN_KB:
280*61046927SAndroid Build Coastguard Worker case INTEL_HWCONFIG_SLM_SIZE_PER_SS_IN_KB:
281*61046927SAndroid Build Coastguard Worker default:
282*61046927SAndroid Build Coastguard Worker break; /* ignore */
283*61046927SAndroid Build Coastguard Worker }
284*61046927SAndroid Build Coastguard Worker }
285*61046927SAndroid Build Coastguard Worker
286*61046927SAndroid Build Coastguard Worker bool
intel_hwconfig_process_table(struct intel_device_info * devinfo,void * data,int32_t len)287*61046927SAndroid Build Coastguard Worker intel_hwconfig_process_table(struct intel_device_info *devinfo,
288*61046927SAndroid Build Coastguard Worker void *data, int32_t len)
289*61046927SAndroid Build Coastguard Worker {
290*61046927SAndroid Build Coastguard Worker process_hwconfig_table(devinfo, data, len, apply_hwconfig_item);
291*61046927SAndroid Build Coastguard Worker
292*61046927SAndroid Build Coastguard Worker return apply_hwconfig(devinfo);
293*61046927SAndroid Build Coastguard Worker }
294*61046927SAndroid Build Coastguard Worker
295*61046927SAndroid Build Coastguard Worker static void
print_hwconfig_item(struct intel_device_info * devinfo,const struct hwconfig * item)296*61046927SAndroid Build Coastguard Worker print_hwconfig_item(struct intel_device_info *devinfo,
297*61046927SAndroid Build Coastguard Worker const struct hwconfig *item)
298*61046927SAndroid Build Coastguard Worker {
299*61046927SAndroid Build Coastguard Worker printf("%s: ", key_to_name(item->key));
300*61046927SAndroid Build Coastguard Worker for (int i = 0; i < item->len; i++)
301*61046927SAndroid Build Coastguard Worker printf(i ? ", 0x%x (%d)" : "0x%x (%d)", item->val[i],
302*61046927SAndroid Build Coastguard Worker item->val[i]);
303*61046927SAndroid Build Coastguard Worker printf("\n");
304*61046927SAndroid Build Coastguard Worker }
305*61046927SAndroid Build Coastguard Worker
306*61046927SAndroid Build Coastguard Worker static void
intel_print_hwconfig_table(const struct hwconfig * hwconfig,int32_t hwconfig_len)307*61046927SAndroid Build Coastguard Worker intel_print_hwconfig_table(const struct hwconfig *hwconfig,
308*61046927SAndroid Build Coastguard Worker int32_t hwconfig_len)
309*61046927SAndroid Build Coastguard Worker {
310*61046927SAndroid Build Coastguard Worker process_hwconfig_table(NULL, hwconfig, hwconfig_len, print_hwconfig_item);
311*61046927SAndroid Build Coastguard Worker }
312*61046927SAndroid Build Coastguard Worker
313*61046927SAndroid Build Coastguard Worker void
intel_get_and_print_hwconfig_table(int fd,struct intel_device_info * devinfo)314*61046927SAndroid Build Coastguard Worker intel_get_and_print_hwconfig_table(int fd, struct intel_device_info *devinfo)
315*61046927SAndroid Build Coastguard Worker {
316*61046927SAndroid Build Coastguard Worker struct hwconfig *hwconfig;
317*61046927SAndroid Build Coastguard Worker int32_t hwconfig_len = 0;
318*61046927SAndroid Build Coastguard Worker
319*61046927SAndroid Build Coastguard Worker switch (devinfo->kmd_type) {
320*61046927SAndroid Build Coastguard Worker case INTEL_KMD_TYPE_I915:
321*61046927SAndroid Build Coastguard Worker hwconfig = intel_device_info_i915_query_hwconfig(fd, &hwconfig_len);
322*61046927SAndroid Build Coastguard Worker break;
323*61046927SAndroid Build Coastguard Worker case INTEL_KMD_TYPE_XE:
324*61046927SAndroid Build Coastguard Worker hwconfig = intel_device_info_xe_query_hwconfig(fd, &hwconfig_len);
325*61046927SAndroid Build Coastguard Worker break;
326*61046927SAndroid Build Coastguard Worker default:
327*61046927SAndroid Build Coastguard Worker unreachable("unknown kmd type");
328*61046927SAndroid Build Coastguard Worker break;
329*61046927SAndroid Build Coastguard Worker }
330*61046927SAndroid Build Coastguard Worker
331*61046927SAndroid Build Coastguard Worker if (hwconfig) {
332*61046927SAndroid Build Coastguard Worker intel_print_hwconfig_table(hwconfig, hwconfig_len);
333*61046927SAndroid Build Coastguard Worker free(hwconfig);
334*61046927SAndroid Build Coastguard Worker }
335*61046927SAndroid Build Coastguard Worker }
336