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