VirtualBox

source: vbox/trunk/src/VBox/Devices/Graphics/testcase/dump-vmwgfx.c@ 98103

Last change on this file since 98103 was 98103, checked in by vboxsync, 2 years ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 21.8 KB
Line 
1/* $Id: dump-vmwgfx.c 98103 2023-01-17 14:15:46Z vboxsync $ */
2/** @file
3 * dump-vmwgfx.c - Dumps parameters and capabilities of vmwgfx.ko.
4 */
5
6/*
7 * Copyright (C) 2013-2023 Oracle and/or its affiliates.
8 *
9 * This file is part of VirtualBox base platform packages, as
10 * available from https://www.virtualbox.org.
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation, in version 3 of the
15 * License.
16 *
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, see <https://www.gnu.org/licenses>.
24 *
25 * SPDX-License-Identifier: GPL-3.0-only
26 */
27
28
29/*********************************************************************************************************************************
30* Header Files *
31*********************************************************************************************************************************/
32#include <assert.h>
33#include <dirent.h>
34#include <errno.h>
35#include <fcntl.h>
36#include <stdio.h>
37#include <stdint.h>
38#include <stdlib.h>
39#include <string.h>
40#include <sys/ioctl.h>
41#include <sys/mman.h>
42#include <sys/stat.h>
43#include <unistd.h>
44
45
46/*********************************************************************************************************************************
47* Defined Constants And Macros *
48*********************************************************************************************************************************/
49#define DRM_IOCTL_BASE 'd'
50#define DRM_COMMAND_BASE 0x40
51#define DRM_VMW_GET_PARAM 0
52#define DRM_VMW_GET_3D_CAP 13
53#define DRM_IOCTL_VMW_GET_PARAM _IOWR(DRM_IOCTL_BASE, DRM_COMMAND_BASE + DRM_VMW_GET_PARAM, struct drm_vmw_getparam_arg)
54#define DRM_IOCTL_VMW_GET_3D_CAP _IOW(DRM_IOCTL_BASE, DRM_COMMAND_BASE + DRM_VMW_GET_3D_CAP, struct drm_vmw_get_3d_cap_arg)
55
56#define SVGA3DCAPS_RECORD_DEVCAPS 0x100
57
58#define DRM_VMW_PARAM_NUM_STREAMS 0
59#define DRM_VMW_PARAM_FREE_STREAMS 1
60#define DRM_VMW_PARAM_3D 2
61#define DRM_VMW_PARAM_HW_CAPS 3
62#define DRM_VMW_PARAM_FIFO_CAPS 4
63#define DRM_VMW_PARAM_MAX_FB_SIZE 5
64#define DRM_VMW_PARAM_FIFO_HW_VERSION 6
65#define DRM_VMW_PARAM_MAX_SURF_MEMORY 7
66#define DRM_VMW_PARAM_3D_CAP_SIZE 8
67#define DRM_VMW_PARAM_MAX_MOB_MEMORY 9
68#define DRM_VMW_PARAM_MAX_MOB_SIZE 10
69
70
71/*********************************************************************************************************************************
72* Structures and Typedefs *
73*********************************************************************************************************************************/
74struct drm_vmw_get_3d_cap_arg
75{
76 uint64_t buffer;
77 uint32_t max_size;
78 uint32_t pad64;
79};
80
81
82struct SVGA3dCapsRecordHeader
83{
84 uint32_t length;
85 uint32_t type;
86};
87
88struct SVGA3dCapsRecord
89{
90 /* Skipped if DRM_VMW_PARAM_MAX_MOB_MEMORY is read. */
91 struct SVGA3dCapsRecordHeader header;
92 uint32_t data[1];
93};
94
95struct drm_vmw_getparam_arg
96{
97 uint64_t value;
98 uint32_t param;
99 uint32_t pad64;
100};
101
102
103typedef struct FLAGDESC
104{
105 uint32_t fMask;
106 const char *pszName;
107} FLAGDESC;
108typedef FLAGDESC const *PCFLAGDESC;
109
110
111/*********************************************************************************************************************************
112* Global Variables *
113*********************************************************************************************************************************/
114/** The size of the 3D capabilities. */
115static uint32_t g_cb3dCaps;
116/** Set if the driver will return the new 3D capability format. */
117static int g_fNew3dCapFormat = 0;
118/** The SVGA_CAP_XXX mask for the card. */
119static uint64_t g_fHwCaps = 0;
120
121/** Names for the vmsvga 3d capabilities, prefixed with format type hint char. (Copied from DevSVGA.cpp.) */
122static const char * const g_apszVmSvgaDevCapNames[] =
123{
124 "x3D", /* = 0 */
125 "xMAX_LIGHTS",
126 "xMAX_TEXTURES",
127 "xMAX_CLIP_PLANES",
128 "xVERTEX_SHADER_VERSION",
129 "xVERTEX_SHADER",
130 "xFRAGMENT_SHADER_VERSION",
131 "xFRAGMENT_SHADER",
132 "xMAX_RENDER_TARGETS",
133 "xS23E8_TEXTURES",
134 "xS10E5_TEXTURES",
135 "xMAX_FIXED_VERTEXBLEND",
136 "xD16_BUFFER_FORMAT",
137 "xD24S8_BUFFER_FORMAT",
138 "xD24X8_BUFFER_FORMAT",
139 "xQUERY_TYPES",
140 "xTEXTURE_GRADIENT_SAMPLING",
141 "rMAX_POINT_SIZE",
142 "xMAX_SHADER_TEXTURES",
143 "xMAX_TEXTURE_WIDTH",
144 "xMAX_TEXTURE_HEIGHT",
145 "xMAX_VOLUME_EXTENT",
146 "xMAX_TEXTURE_REPEAT",
147 "xMAX_TEXTURE_ASPECT_RATIO",
148 "xMAX_TEXTURE_ANISOTROPY",
149 "xMAX_PRIMITIVE_COUNT",
150 "xMAX_VERTEX_INDEX",
151 "xMAX_VERTEX_SHADER_INSTRUCTIONS",
152 "xMAX_FRAGMENT_SHADER_INSTRUCTIONS",
153 "xMAX_VERTEX_SHADER_TEMPS",
154 "xMAX_FRAGMENT_SHADER_TEMPS",
155 "xTEXTURE_OPS",
156 "xSURFACEFMT_X8R8G8B8",
157 "xSURFACEFMT_A8R8G8B8",
158 "xSURFACEFMT_A2R10G10B10",
159 "xSURFACEFMT_X1R5G5B5",
160 "xSURFACEFMT_A1R5G5B5",
161 "xSURFACEFMT_A4R4G4B4",
162 "xSURFACEFMT_R5G6B5",
163 "xSURFACEFMT_LUMINANCE16",
164 "xSURFACEFMT_LUMINANCE8_ALPHA8",
165 "xSURFACEFMT_ALPHA8",
166 "xSURFACEFMT_LUMINANCE8",
167 "xSURFACEFMT_Z_D16",
168 "xSURFACEFMT_Z_D24S8",
169 "xSURFACEFMT_Z_D24X8",
170 "xSURFACEFMT_DXT1",
171 "xSURFACEFMT_DXT2",
172 "xSURFACEFMT_DXT3",
173 "xSURFACEFMT_DXT4",
174 "xSURFACEFMT_DXT5",
175 "xSURFACEFMT_BUMPX8L8V8U8",
176 "xSURFACEFMT_A2W10V10U10",
177 "xSURFACEFMT_BUMPU8V8",
178 "xSURFACEFMT_Q8W8V8U8",
179 "xSURFACEFMT_CxV8U8",
180 "xSURFACEFMT_R_S10E5",
181 "xSURFACEFMT_R_S23E8",
182 "xSURFACEFMT_RG_S10E5",
183 "xSURFACEFMT_RG_S23E8",
184 "xSURFACEFMT_ARGB_S10E5",
185 "xSURFACEFMT_ARGB_S23E8",
186 "xMISSING62",
187 "xMAX_VERTEX_SHADER_TEXTURES",
188 "xMAX_SIMULTANEOUS_RENDER_TARGETS",
189 "xSURFACEFMT_V16U16",
190 "xSURFACEFMT_G16R16",
191 "xSURFACEFMT_A16B16G16R16",
192 "xSURFACEFMT_UYVY",
193 "xSURFACEFMT_YUY2",
194 "xMULTISAMPLE_NONMASKABLESAMPLES",
195 "xMULTISAMPLE_MASKABLESAMPLES",
196 "xALPHATOCOVERAGE",
197 "xSUPERSAMPLE",
198 "xAUTOGENMIPMAPS",
199 "xSURFACEFMT_NV12",
200 "xSURFACEFMT_AYUV",
201 "xMAX_CONTEXT_IDS",
202 "xMAX_SURFACE_IDS",
203 "xSURFACEFMT_Z_DF16",
204 "xSURFACEFMT_Z_DF24",
205 "xSURFACEFMT_Z_D24S8_INT",
206 "xSURFACEFMT_BC4_UNORM",
207 "xSURFACEFMT_BC5_UNORM", /* 83 */
208 "xVGPU10",
209 "xVIDEO_DECODE",
210 "xVIDEO_PROCESS",
211 "xLINE_AA",
212 "xLINE_STRIPPLE",
213 "fMAX_LINE_WIDTH",
214 "fMAX_AA_LINE_WIDTH", /* 90 */
215 "xSURFACEFMT_YV12",
216 "xLOGICOPS",
217 "xSCREENTARGETS",
218 "xTS_COLOR_KEY",
219 "xDX", /* 95 */
220};
221
222/** SVGA_CAP flag descriptors. */
223static FLAGDESC const g_aVmSvgaCapFlags[] =
224{
225 { UINT32_C(0x00000001), "unknown-bit-0" },
226 { UINT32_C(0x00000002), "SVGA_CAP_RECT_COPY" },
227 { UINT32_C(0x00000004), "unknown-bit-2" },
228 { UINT32_C(0x00000008), "unknown-bit-3" },
229 { UINT32_C(0x00000010), "unknown-bit-4" },
230 { UINT32_C(0x00000020), "SVGA_CAP_CURSOR" },
231 { UINT32_C(0x00000040), "SVGA_CAP_CURSOR_BYPASS" },
232 { UINT32_C(0x00000080), "SVGA_CAP_CURSOR_BYPASS_2" },
233 { UINT32_C(0x00000100), "SVGA_CAP_8BIT_EMULATION" },
234 { UINT32_C(0x00000200), "SVGA_CAP_ALPHA_CURSOR" },
235 { UINT32_C(0x00000400), "unknown-bit-10" },
236 { UINT32_C(0x00000800), "unknown-bit-11" },
237 { UINT32_C(0x00001000), "unknown-bit-12" },
238 { UINT32_C(0x00002000), "unknown-bit-13" },
239 { UINT32_C(0x00004000), "SVGA_CAP_3D" },
240 { UINT32_C(0x00008000), "SVGA_CAP_EXTENDED_FIFO" },
241 { UINT32_C(0x00010000), "SVGA_CAP_MULTIMON" },
242 { UINT32_C(0x00020000), "SVGA_CAP_PITCHLOCK" },
243 { UINT32_C(0x00040000), "SVGA_CAP_IRQMASK" },
244 { UINT32_C(0x00080000), "SVGA_CAP_DISPLAY_TOPOLOGY" },
245 { UINT32_C(0x00100000), "SVGA_CAP_GMR" },
246 { UINT32_C(0x00200000), "SVGA_CAP_TRACES" },
247 { UINT32_C(0x00400000), "SVGA_CAP_GMR2" },
248 { UINT32_C(0x00800000), "SVGA_CAP_SCREEN_OBJECT_2" },
249 { UINT32_C(0x01000000), "SVGA_CAP_COMMAND_BUFFERS" },
250 { UINT32_C(0x02000000), "SVGA_CAP_DEAD1" },
251 { UINT32_C(0x04000000), "SVGA_CAP_CMD_BUFFERS_2" },
252 { UINT32_C(0x08000000), "SVGA_CAP_GBOBJECTS" },
253 { UINT32_C(0x10000000), "unknown-bit-28" },
254 { UINT32_C(0x20000000), "unknown-bit-29" },
255 { UINT32_C(0x40000000), "unknown-bit-30" },
256 { UINT32_C(0x80000000), "unknown-bit-31" },
257};
258
259/** SVGA_FIFO_CAP flag descriptors. */
260static FLAGDESC const g_aVmSvgaFifoCapFlags[] =
261{
262 { UINT32_C(0x00000001), "SVGA_FIFO_CAP_FENCE" },
263 { UINT32_C(0x00000002), "SVGA_FIFO_CAP_ACCELFRONT" },
264 { UINT32_C(0x00000004), "SVGA_FIFO_CAP_PITCHLOCK" },
265 { UINT32_C(0x00000008), "SVGA_FIFO_CAP_VIDEO" },
266 { UINT32_C(0x00000010), "SVGA_FIFO_CAP_CURSOR_BYPASS_3" },
267 { UINT32_C(0x00000020), "SVGA_FIFO_CAP_ESCAPE" },
268 { UINT32_C(0x00000040), "SVGA_FIFO_CAP_RESERVE" },
269 { UINT32_C(0x00000080), "SVGA_FIFO_CAP_SCREEN_OBJECT" },
270 { UINT32_C(0x00000100), "SVGA_FIFO_CAP_GMR2/SVGA_FIFO_CAP_3D_HWVERSION_REVISED" },
271 { UINT32_C(0x00000200), "SVGA_FIFO_CAP_SCREEN_OBJECT_2" },
272 { UINT32_C(0x00000400), "SVGA_FIFO_CAP_DEAD" },
273 { UINT32_C(0x00000800), "unknown-bit-11" },
274 { UINT32_C(0x00001000), "unknown-bit-12" },
275 { UINT32_C(0x00002000), "unknown-bit-13" },
276 { UINT32_C(0x00004000), "unknown-bit-14" },
277 { UINT32_C(0x00008000), "unknown-bit-15" },
278 { UINT32_C(0x00010000), "unknown-bit-16" },
279 { UINT32_C(0x00020000), "unknown-bit-17" },
280 { UINT32_C(0x00040000), "unknown-bit-18" },
281 { UINT32_C(0x00080000), "unknown-bit-19" },
282 { UINT32_C(0x00100000), "unknown-bit-20" },
283 { UINT32_C(0x00200000), "unknown-bit-21" },
284 { UINT32_C(0x00400000), "unknown-bit-22" },
285 { UINT32_C(0x00800000), "unknown-bit-23" },
286 { UINT32_C(0x01000000), "unknown-bit-24" },
287 { UINT32_C(0x02000000), "unknown-bit-25" },
288 { UINT32_C(0x04000000), "unknown-bit-26" },
289 { UINT32_C(0x08000000), "unknown-bit-27" },
290 { UINT32_C(0x10000000), "unknown-bit-28" },
291 { UINT32_C(0x20000000), "unknown-bit-29" },
292 { UINT32_C(0x40000000), "unknown-bit-30" },
293 { UINT32_C(0x80000000), "unknown-bit-31" },
294};
295
296
297static void DisplayFlags(PCFLAGDESC paFlagDescs, uint32_t fFlags, unsigned cchIndent)
298{
299 uint32_t i;
300 for (i = 0; i < 32; i++)
301 {
302 assert(paFlagDescs[i].fMask == (UINT32_C(1) << i));
303 if (paFlagDescs[i].fMask & fFlags)
304 printf("%*s%s\n", cchIndent, "", paFlagDescs[i].pszName);
305 }
306}
307
308
309static int QueryParam(int fd, uint32_t uParam, const char *pszParam)
310{
311 struct drm_vmw_getparam_arg Arg;
312 int rc;
313
314 Arg.value = 0;
315 Arg.param = uParam;
316 Arg.pad64 = 0;
317 rc = ioctl(fd, DRM_IOCTL_VMW_GET_PARAM, &Arg);
318 if (rc >= 0)
319 {
320 switch (uParam)
321 {
322 case DRM_VMW_PARAM_3D:
323 printf("%30s: %#llx -- enabled: %s\n", pszParam, Arg.value,
324 Arg.value == 0 ? "no" : Arg.value == 1 ? "yes" : "huh?");
325 break;
326
327 case DRM_VMW_PARAM_FIFO_HW_VERSION:
328 printf("%30s: %#llx -- major=%llu minor=%llu\n", pszParam, Arg.value, Arg.value >> 16, Arg.value & 0xffff);
329 break;
330
331 case DRM_VMW_PARAM_HW_CAPS:
332 printf("%30s: %#llx\n", pszParam, Arg.value);
333 DisplayFlags(g_aVmSvgaCapFlags, (uint32_t)Arg.value, 32);
334 g_fHwCaps = Arg.value;
335 break;
336
337 case DRM_VMW_PARAM_FIFO_CAPS:
338 printf("%30s: %#llx\n", pszParam, Arg.value);
339 DisplayFlags(g_aVmSvgaFifoCapFlags, (uint32_t)Arg.value, 32);
340 break;
341
342 case DRM_VMW_PARAM_3D_CAP_SIZE:
343 printf("%30s: %#llx (%lld) [bytes]\n", pszParam, Arg.value, Arg.value);
344 g_cb3dCaps = (uint32_t)Arg.value;
345 break;
346
347 default:
348 printf("%30s: %#llx (%lld)\n", pszParam, Arg.value, Arg.value);
349 break;
350 }
351 }
352 else
353 printf("%32s: failed: rc=%d errno=%d (%s)\n", pszParam, rc, errno, strerror(errno));
354 return rc;
355}
356
357
358static int Dump3DParameters(int fd, int rcExit)
359{
360 int rc;
361 printf("\n**** vmwgfx parameters *****\n");
362#define QUERY_PARAM(nm) QueryParam(fd, nm, #nm)
363 rc = QUERY_PARAM(DRM_VMW_PARAM_HW_CAPS);
364 if (rc < 0)
365 rcExit = 1;
366 QUERY_PARAM(DRM_VMW_PARAM_FIFO_CAPS);
367 QUERY_PARAM(DRM_VMW_PARAM_FIFO_HW_VERSION);
368 QUERY_PARAM(DRM_VMW_PARAM_3D);
369 QUERY_PARAM(DRM_VMW_PARAM_NUM_STREAMS);
370 QUERY_PARAM(DRM_VMW_PARAM_FREE_STREAMS);
371 QUERY_PARAM(DRM_VMW_PARAM_MAX_FB_SIZE);
372 QUERY_PARAM(DRM_VMW_PARAM_MAX_SURF_MEMORY);
373 QUERY_PARAM(DRM_VMW_PARAM_3D_CAP_SIZE);
374 rc = QUERY_PARAM(DRM_VMW_PARAM_MAX_MOB_MEMORY);
375 if (rc >= 0)
376 g_fNew3dCapFormat = g_fHwCaps & UINT32_C(0x08000000) /*SVGA_CAP_GBOBJECTS */;
377 QUERY_PARAM(DRM_VMW_PARAM_MAX_MOB_SIZE);
378 return rcExit;
379}
380
381
382static void PrintOne3DCapability(uint32_t iCap, uint32_t uValue)
383{
384 union
385 {
386 float rValue;
387 uint32_t u32Value;
388 } u;
389 u.u32Value = uValue;
390 if (iCap < sizeof(g_apszVmSvgaDevCapNames) / sizeof(g_apszVmSvgaDevCapNames[0]))
391 {
392 const char *pszName = g_apszVmSvgaDevCapNames[iCap];
393 if (pszName[0] == 'x')
394 printf(" cap[%u]=%#010x {%s}\n", iCap, u.u32Value, pszName + 1);
395 else
396 printf(" cap[%u]=%d.%04u {%s}\n", iCap, (int)u.rValue, (unsigned)(u.rValue * 1000) % 10000, pszName + 1);
397 }
398 else
399 printf(" cap[%u]=%#010x\n", iCap, u.u32Value);
400}
401
402
403static void DumpOld3dCapabilityRecords(struct SVGA3dCapsRecord *pCur)
404{
405 for (;;)
406 {
407 printf(" SVGA3dCapsRecordHeader: length=%#x (%d) type=%d\n",
408 pCur->header.length, pCur->header.length, pCur->header.type);
409 if (pCur->header.length == 0)
410 break;
411
412 uint32_t i;
413 for (i = 0; i < pCur->header.length - 2; i += 2)
414 PrintOne3DCapability(pCur->data[i], pCur->data[i + 1]);
415 pCur = (struct SVGA3dCapsRecord *)((uint32_t *)pCur + pCur->header.length);
416 }
417}
418
419
420static int Dump3DCapabilities(int fd, int rcExit)
421{
422 struct SVGA3dCapsRecord *pBuf;
423 struct drm_vmw_get_3d_cap_arg Caps3D;
424 int rc;
425
426
427 printf("\n**** 3D capabilities *****\n");
428 Caps3D.pad64 = 0;
429 Caps3D.max_size = 1024 * sizeof(uint32_t);
430 pBuf = (struct SVGA3dCapsRecord *)calloc(Caps3D.max_size, 1);
431 Caps3D.buffer = (uintptr_t)pBuf;
432
433 errno = 0;
434 rc = ioctl(fd, DRM_IOCTL_VMW_GET_3D_CAP, &Caps3D);
435 if (rc >= 0)
436 {
437 printf("DRM_IOCTL_VMW_GET_3D_CAP: rc=%d\n", rc);
438 if (!g_fNew3dCapFormat)
439 DumpOld3dCapabilityRecords(pBuf);
440 else
441 {
442 uint32_t const *pau32Data = (uint32_t const *)pBuf;
443 uint32_t cCaps = g_cb3dCaps / sizeof(uint32_t);
444 uint32_t iCap;
445 for (iCap = 0; iCap < cCaps; iCap++)
446 PrintOne3DCapability(iCap, pau32Data[iCap]);
447 }
448 }
449 else
450 {
451 fprintf(stderr, "DRM_IOCTL_VMW_GET_3D_CAP failed: %d - %s\n", errno, strerror(errno));
452 rcExit = 1;
453 }
454
455 free(pBuf);
456 return rcExit;
457}
458
459
460static int FindAndMapFifo(uint32_t const **ppau32Fifo, uint32_t *pcbFifo, int rcExit)
461{
462 const char g_szDir[] = "/sys/bus/pci/devices";
463 DIR *pDir = opendir(g_szDir);
464 if (pDir)
465 {
466 struct dirent *pEntry;
467 char szPath[4096];
468 size_t offPath = sizeof(g_szDir);
469 memcpy(szPath, g_szDir, sizeof(g_szDir));
470 szPath[offPath - 1] = '/';
471
472 while ((pEntry = readdir(pDir)) != NULL)
473 {
474 struct stat st;
475 size_t cchName = strlen(pEntry->d_name);
476 memcpy(&szPath[offPath], pEntry->d_name, cchName);
477 strcpy(&szPath[offPath + cchName], "/boot_vga");
478 if (stat(szPath, &st) >= 0)
479 {
480 /* Found something that looks like the VGA device. Try map resource2. */
481 strcpy(&szPath[offPath + cchName], "/resource2");
482 if (stat(szPath, &st) >= 0)
483 {
484 int fdFifo = open(szPath, O_RDONLY);
485 if (fdFifo >= 0)
486 {
487 *pcbFifo = (uint32_t)st.st_size;
488 *ppau32Fifo = (uint32_t *)mmap(NULL, *pcbFifo, PROT_READ, MAP_SHARED | MAP_FILE, fdFifo, 0);
489 if (*ppau32Fifo != MAP_FAILED)
490 {
491 printf("info: Mapped %s at %p LB %#x\n", szPath, *ppau32Fifo, *pcbFifo);
492 close(fdFifo);
493 closedir(pDir);
494 return rcExit;
495 }
496
497 fprintf(stderr, "error: failed to mmap '%s': %d (%s)\n", szPath, errno, strerror(errno));
498 close(fdFifo);
499 }
500 else
501 fprintf(stderr, "error: failed to open '%s': %d (%s)\n", g_szDir, errno, strerror(errno));
502 }
503 else
504 fprintf(stderr, "error: boot_vga devices doesn't have '%s'. (%d [%s])\n", szPath, errno, strerror(errno));
505 }
506 } /* for each directory entry */
507
508 closedir(pDir);
509 }
510 else
511 fprintf(stderr, "error: failed to open '%s': %d (%s)\n", g_szDir, errno, strerror(errno));
512 return 1;
513}
514
515
516static int DumpFifoStuff(uint32_t const *pau32Fifo, uint32_t cbFifo, int rcExit)
517{
518 uint32_t cMax = cbFifo / sizeof(uint32_t);
519 uint32_t i, iMin, iMax;
520
521 printf("\n***** FIFO - %u bytes (%#x) *****\n", cbFifo, cbFifo);
522 if (cMax >= 4)
523 {
524 iMin = pau32Fifo[0] / sizeof(uint32_t);
525 printf(" FIFO_MIN: %#09x -- iMin=%#08x\n", pau32Fifo[0], iMin);
526 iMax = pau32Fifo[1] / sizeof(uint32_t);
527 printf(" FIFO_MAX: %#09x -- iMax=%#08x\n", pau32Fifo[1], iMax);
528 printf(" FIFO_NEXT_CMD: %#09x -- iNextCmd=%#08x\n", pau32Fifo[2], (uint32_t)(pau32Fifo[2] / sizeof(uint32_t)));
529 printf(" FIFO_STOP: %#09x -- iStop=%#08x\n", pau32Fifo[3], (uint32_t)(pau32Fifo[3] / sizeof(uint32_t)));
530 }
531 else
532 {
533 fprintf(stderr, "error: cbFifo=%#x is too small\n", cbFifo);
534 return 1;
535 }
536 if (iMin > 4)
537 {
538 printf(" FIFO_CAPABILITIES: %#x (%d)\n", pau32Fifo[4], pau32Fifo[4]);
539 DisplayFlags(g_aVmSvgaFifoCapFlags, pau32Fifo[4], 28);
540 }
541 if (iMin > 5)
542 printf(" FIFO_FLAGS: %#x (%d)\n", pau32Fifo[5], pau32Fifo[5]);
543 if (iMin > 6)
544 printf(" FIFO_FENCE: %#x (%d)\n", pau32Fifo[6], pau32Fifo[6]);
545 if (iMin > 7)
546 printf(" FIFO_3D_VERSION: %#x -- %u.%u\n", pau32Fifo[7], pau32Fifo[7] >> 16, pau32Fifo[7] & 0xffff);
547 if (iMin > 8)
548 printf(" FIFO_PITCH_LOCK: %#x (%d)\n", pau32Fifo[8], pau32Fifo[8]);
549 if (iMin > 9)
550 printf(" FIFO_CURSOR_ON: %#x (%d)\n", pau32Fifo[9], pau32Fifo[9]);
551 if (iMin > 10)
552 printf(" FIFO_CURSOR_X: %#x (%d)\n", pau32Fifo[10], pau32Fifo[10]);
553 if (iMin > 11)
554 printf(" FIFO_CURSOR_Y: %#x (%d)\n", pau32Fifo[11], pau32Fifo[11]);
555 if (iMin > 12)
556 printf(" FIFO_CURSOR_COUNT: %#x (%d)\n", pau32Fifo[12], pau32Fifo[12]);
557 if (iMin > 13)
558 printf(" FIFO_CURSOR_LAST_UPDATED: %#x (%d)\n", pau32Fifo[13], pau32Fifo[13]);
559 if (iMin > 14)
560 printf(" FIFO_RESERVED: %#x (%d)\n", pau32Fifo[14], pau32Fifo[14]);
561 if (iMin > 15)
562 printf(" FIFO_CURSOR_SCREEN_ID: %#x (%d)\n", pau32Fifo[15], pau32Fifo[15]);
563 if (iMin > 16)
564 printf(" FIFO_DEAD: %#x (%d)\n", pau32Fifo[16], pau32Fifo[16]);
565 if (iMin > 17)
566 printf("FIFO_3D_HWVERSION_REVISED: %#x -- %u.%u\n", pau32Fifo[17], pau32Fifo[17] >> 16, pau32Fifo[7] & 0xffff);
567
568 for (i = 18; i < 32 && i < iMin; i++)
569 if (pau32Fifo[i] != 0)
570 printf("FIFO_UNKNOWN_%u: %#x (%d)\n", i, pau32Fifo[i], pau32Fifo[i]);
571
572 if (iMin >= 32+64)
573 {
574 if (pau32Fifo[32])
575 {
576 printf(" FIFO_3D_CAPS:\n");
577 DumpOld3dCapabilityRecords((struct SVGA3dCapsRecord *)&pau32Fifo[32]);
578 }
579 else
580 printf("warning: 3D capabilities not present?\n");
581 }
582
583
584 if (iMin > 288)
585 printf(" FIFO_GUEST_3D_HWVERSION: %#x -- %u.%u\n", pau32Fifo[288], pau32Fifo[288] >> 16, pau32Fifo[288] & 0xffff);
586 if (iMin > 289)
587 printf(" FIFO_FENCE_GOAL: %#x (%d)\n", pau32Fifo[289], pau32Fifo[289]);
588 if (iMin > 290)
589 printf(" FIFO_BUSY: %#x (%d)\n", pau32Fifo[290], pau32Fifo[290]);
590
591 for (i = 291; i < iMin; i++)
592 if (pau32Fifo[i] != 0)
593 printf("FIFO_UNKNOWN_%u: %#x (%d)\n", i, pau32Fifo[i], pau32Fifo[i]);
594
595 return rcExit;
596}
597
598
599
600
601
602int main(int argc, char **argv)
603{
604 int rcExit = 0;
605 const char *pszDev = "/dev/dri/card0";
606 if (argc == 2)
607 pszDev = argv[1];
608
609 int fd = open(pszDev, O_RDWR);
610 if (fd != -1)
611 {
612 uint32_t const *pau32Fifo = NULL;
613 uint32_t cbFifo = 0;
614
615 /*
616 * Parameters.
617 */
618 rcExit = Dump3DParameters(fd, rcExit);
619
620 /*
621 * 3D capabilities.
622 */
623 rcExit = Dump3DCapabilities(fd, rcExit);
624
625 /*
626 * Map and dump the FIFO registers.
627 */
628 rcExit = FindAndMapFifo(&pau32Fifo, &cbFifo, rcExit);
629 if (pau32Fifo && cbFifo)
630 rcExit = DumpFifoStuff(pau32Fifo, cbFifo, rcExit);
631 }
632 else
633 {
634 fprintf(stderr, "error opening '%s': %d\n", pszDev, errno);
635 rcExit = 1;
636 }
637
638 return rcExit;
639}
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette