1360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes/* dristat.c --
2360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * Created: Mon Jan 15 05:05:07 2001 by faith@acm.org
3360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes *
4360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * Copyright 2000 VA Linux Systems, Inc., Fremont, California.
5360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * All Rights Reserved.
6360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes *
7360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * Permission is hereby granted, free of charge, to any person obtaining a
8360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * copy of this software and associated documentation files (the "Software"),
9360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * to deal in the Software without restriction, including without limitation
10360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * and/or sell copies of the Software, and to permit persons to whom the
12360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * Software is furnished to do so, subject to the following conditions:
13360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes *
14360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * The above copyright notice and this permission notice (including the next
15360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * paragraph) shall be included in all copies or substantial portions of the
16360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * Software.
17360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes *
18360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
21360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
22360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
23360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
24360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * DEALINGS IN THE SOFTWARE.
25360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes *
26360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes * Authors: Rickard E. (Rik) Faith <faith@valinux.com>
27360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes *
28360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes */
29360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
300599f2fd6aea0421a91d9297dcd454aa416dfbaaRob Clark#ifdef HAVE_CONFIG_H
310599f2fd6aea0421a91d9297dcd454aa416dfbaaRob Clark# include <config.h>
320599f2fd6aea0421a91d9297dcd454aa416dfbaaRob Clark#endif
330599f2fd6aea0421a91d9297dcd454aa416dfbaaRob Clark
34360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#include <stdio.h>
35360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#include <stdlib.h>
36360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#include <unistd.h>
37b5e02f8eb3b9c178014e510e5999fab671031a6cJon Smirl#include "xf86drm.h"
38b5e02f8eb3b9c178014e510e5999fab671031a6cJon Smirl#include "xf86drmRandom.c"
39b5e02f8eb3b9c178014e510e5999fab671031a6cJon Smirl#include "xf86drmHash.c"
40b5e02f8eb3b9c178014e510e5999fab671031a6cJon Smirl#include "xf86drm.c"
41360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
42360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#define DRM_VERSION 0x00000001
43360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#define DRM_MEMORY  0x00000002
44360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#define DRM_CLIENTS 0x00000004
45360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes#define DRM_STATS   0x00000008
4688dbee54ed400a3fd5594fab506518c171167805Rik Faith#define DRM_BUSID   0x00000010
47360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
48360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughesstatic void getversion(int fd)
49360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes{
50360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    drmVersionPtr version;
51360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
52360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    version = drmGetVersion(fd);
53360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (version) {
54360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("  Version information:\n");
55360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("    Name: %s\n", version->name ? version->name : "?");
56360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("    Version: %d.%d.%d\n",
57360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	       version->version_major,
58360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	       version->version_minor,
59360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	       version->version_patchlevel);
60360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("    Date: %s\n", version->date ? version->date : "?");
61360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("    Desc: %s\n", version->desc ? version->desc : "?");
62360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	drmFreeVersion(version);
63360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    } else {
64360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("  No version information available\n");
65360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
66360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes}
67360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
6888dbee54ed400a3fd5594fab506518c171167805Rik Faithstatic void getbusid(int fd)
6988dbee54ed400a3fd5594fab506518c171167805Rik Faith{
7088dbee54ed400a3fd5594fab506518c171167805Rik Faith    const char *busid = drmGetBusid(fd);
7188dbee54ed400a3fd5594fab506518c171167805Rik Faith
7288dbee54ed400a3fd5594fab506518c171167805Rik Faith    printf("  Busid: %s\n", *busid ? busid : "(not set)");
7388dbee54ed400a3fd5594fab506518c171167805Rik Faith    drmFreeBusid(busid);
7488dbee54ed400a3fd5594fab506518c171167805Rik Faith}
7588dbee54ed400a3fd5594fab506518c171167805Rik Faith
76360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
77360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughesstatic void getvm(int fd)
78360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes{
79360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int             i;
80360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    const char      *typename;
81360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    char            flagname[33];
82244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie    drm_handle_t    offset;
83360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    drmSize         size;
84360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    drmMapType      type;
85360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    drmMapFlags     flags;
86244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie    drm_handle_t    handle;
87360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int             mtrr;
88360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
892dc672a7908817f43391703a8341cb873fbb1543Leif Delgass    printf("  VM map information:\n");
902dc672a7908817f43391703a8341cb873fbb1543Leif Delgass    printf("  flags: (R)estricted (r)ead/(w)rite (l)ocked (k)ernel (W)rite-combine (L)ock:\n");
91360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    printf("    slot     offset       size type flags    address mtrr\n");
92360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
93360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    for (i = 0;
94360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	 !drmGetMap(fd, i, &offset, &size, &type, &flags, &handle, &mtrr);
95360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	 i++) {
96360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
97360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	switch (type) {
982dc672a7908817f43391703a8341cb873fbb1543Leif Delgass	case DRM_FRAME_BUFFER:   typename = "FB";  break;
992dc672a7908817f43391703a8341cb873fbb1543Leif Delgass	case DRM_REGISTERS:      typename = "REG"; break;
1002dc672a7908817f43391703a8341cb873fbb1543Leif Delgass	case DRM_SHM:            typename = "SHM"; break;
1012dc672a7908817f43391703a8341cb873fbb1543Leif Delgass	case DRM_AGP:            typename = "AGP"; break;
1022dc672a7908817f43391703a8341cb873fbb1543Leif Delgass	case DRM_SCATTER_GATHER: typename = "SG";  break;
10313e34308b70a9e0e7682ae7ced29a4aa0c3ad281Jan Vesely	case DRM_CONSISTENT:     typename = "CON"; break;
1042dc672a7908817f43391703a8341cb873fbb1543Leif Delgass	default:                 typename = "???"; break;
105360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
106360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
107360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[0] = (flags & DRM_RESTRICTED)      ? 'R' : ' ';
108360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[1] = (flags & DRM_READ_ONLY)       ? 'r' : 'w';
109360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[2] = (flags & DRM_LOCKED)          ? 'l' : ' ';
110360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[3] = (flags & DRM_KERNEL)          ? 'k' : ' ';
111360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[4] = (flags & DRM_WRITE_COMBINING) ? 'W' : ' ';
112360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[5] = (flags & DRM_CONTAINS_LOCK)   ? 'L' : ' ';
113360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	flagname[6] = '\0';
114360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
115360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("    %4d 0x%08lx 0x%08lx %3.3s %6.6s 0x%08lx ",
116e4a519635f75bde38aeb5b09f2ff4efbf73453e9Matthew W. S. Bell	       i, (unsigned long)offset, (unsigned long)size,
117e4a519635f75bde38aeb5b09f2ff4efbf73453e9Matthew W. S. Bell	       typename, flagname, (unsigned long)handle);
118360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	if (mtrr < 0) printf("none\n");
119360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	else          printf("%4d\n", mtrr);
120360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
121360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes}
122360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
123360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughesstatic void getclients(int fd)
124360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes{
125360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int           i;
126360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int           auth;
127360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int           pid;
128360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int           uid;
129360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    unsigned long magic;
130360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    unsigned long iocs;
131360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    char          buf[64];
132360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    char          cmd[40];
133360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int           procfd;
134360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
135360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    printf("  DRI client information:\n");
13688dbee54ed400a3fd5594fab506518c171167805Rik Faith    printf("    a   pid   uid      magic     ioctls   prog\n");
137360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
138360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    for (i = 0; !drmGetClient(fd, i, &auth, &pid, &uid, &magic, &iocs); i++) {
139360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	sprintf(buf, "/proc/%d/cmdline", pid);
140b646515d6124b906f5a0c2cf76f8fda590884ef0Adam Jackson	memset(cmd, 0, sizeof(cmd));
141360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	if ((procfd = open(buf, O_RDONLY, 0)) >= 0) {
142360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    read(procfd, cmd, sizeof(cmd)-1);
143360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    close(procfd);
144360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
14588dbee54ed400a3fd5594fab506518c171167805Rik Faith	if (*cmd) {
14688dbee54ed400a3fd5594fab506518c171167805Rik Faith	    char *pt;
14788dbee54ed400a3fd5594fab506518c171167805Rik Faith
14888dbee54ed400a3fd5594fab506518c171167805Rik Faith	    for (pt = cmd; *pt; pt++) if (!isprint(*pt)) *pt = ' ';
149360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf("    %c %5d %5d %10lu %10lu   %s\n",
150360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes		   auth ? 'y' : 'n', pid, uid, magic, iocs, cmd);
15188dbee54ed400a3fd5594fab506518c171167805Rik Faith	} else {
152360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf("    %c %5d %5d %10lu %10lu\n",
153360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes		   auth ? 'y' : 'n', pid, uid, magic, iocs);
15488dbee54ed400a3fd5594fab506518c171167805Rik Faith	}
155360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
156360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes}
157360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
158360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughesstatic void printhuman(unsigned long value, const char *name, int mult)
159360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes{
160360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    const char *p;
161360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    double     f;
162360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes				/* Print width 5 number in width 6 space */
163360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (value < 100000) {
164360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf(" %5lu", value);
165360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	return;
166360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
167360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
168360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    p = name;
169360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    f = (double)value / (double)mult;
170360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (f < 10.0) {
171360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf(" %4.2f%c", f, *p);
172360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	return;
173360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
174360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
175360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    p++;
176360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    f = (double)value / (double)mult;
177360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (f < 10.0) {
178360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf(" %4.2f%c", f, *p);
179360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	return;
180360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
181360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
182360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    p++;
183360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    f = (double)value / (double)mult;
184360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (f < 10.0) {
185360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf(" %4.2f%c", f, *p);
186360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	return;
187360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
188360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes}
189360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
190360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughesstatic void getstats(int fd, int i)
191360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes{
192360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    drmStatsT prev, curr;
19365041c4a19bc6d1cc86f768259b9e0888af0bd5fJan Vesely    unsigned  j;
194360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    double    rate;
19565041c4a19bc6d1cc86f768259b9e0888af0bd5fJan Vesely
196360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    printf("  System statistics:\n");
197360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
198360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (drmGetStats(fd, &prev)) return;
199360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    if (!i) {
200360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	for (j = 0; j < prev.count; j++) {
201360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf("    ");
202360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf(prev.data[j].long_format, prev.data[j].long_name);
203360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (prev.data[j].isvalue) printf(" 0x%08lx\n", prev.data[j].value);
204360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    else                      printf(" %10lu\n", prev.data[j].value);
205360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
206360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	return;
207360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
208360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
209360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    printf("    ");
210360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    for (j = 0; j < prev.count; j++)
211360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	if (!prev.data[j].verbose) {
212360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf(" ");
213360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf(prev.data[j].rate_format, prev.data[j].rate_name);
214360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
215360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    printf("\n");
216360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
217360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    for (;;) {
218360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	sleep(i);
219360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	if (drmGetStats(fd, &curr)) return;
220360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("    ");
221360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	for (j = 0; j < curr.count; j++) {
222360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (curr.data[j].verbose) continue;
223360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (curr.data[j].isvalue) {
224360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes		printf(" %08lx", curr.data[j].value);
225360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    } else {
226360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes		rate = (curr.data[j].value - prev.data[j].value) / (double)i;
227360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes		printhuman(rate, curr.data[j].mult_names, curr.data[j].mult);
228360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    }
229360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
230360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	printf("\n");
231360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	memcpy(&prev, &curr, sizeof(prev));
232360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
233360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
234360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes}
235360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
236360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughesint main(int argc, char **argv)
237360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes{
238360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int  c;
239360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int  mask     = 0;
240360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int  minor    = 0;
241360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int  interval = 0;
242360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int  fd;
243360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    char buf[64];
244360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    int  i;
245360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
24688dbee54ed400a3fd5594fab506518c171167805Rik Faith    while ((c = getopt(argc, argv, "avmcsbM:i:")) != EOF)
247360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	switch (c) {
248360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 'a': mask = ~0;                          break;
249360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 'v': mask |= DRM_VERSION;                break;
250360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 'm': mask |= DRM_MEMORY;                 break;
251360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 'c': mask |= DRM_CLIENTS;                break;
252360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 's': mask |= DRM_STATS;                  break;
25388dbee54ed400a3fd5594fab506518c171167805Rik Faith	case 'b': mask |= DRM_BUSID;                  break;
254360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 'i': interval = strtol(optarg, NULL, 0); break;
255360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	case 'M': minor = strtol(optarg, NULL, 0);    break;
256360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	default:
257244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "Usage: dristat [options]\n\n" );
258244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "Displays DRM information. Use with no arguments to display available cards.\n\n" );
259244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -a            Show all available information\n" );
260244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -b            Show DRM bus ID's\n" );
261244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -c            Display information about DRM clients\n" );
262244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -i [interval] Continuously display statistics every [interval] seconds\n" );
263244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -v            Display DRM module and card version information\n" );
264244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -m            Display memory use information\n" );
265244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -s            Display DRM statistics\n" );
266244b3e6c7cf61d3de56267e5813b0a1821ca0ac0Dave Airlie	    fprintf( stderr, "  -M [minor]    Select card by minor number\n" );
267360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    return 1;
268360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
269360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
270360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    for (i = 0; i < 16; i++) if (!minor || i == minor) {
271360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	sprintf(buf, DRM_DEV_NAME, DRM_DIR_NAME, i);
272ad8bbfd3c74466f088be8088d2d0524bed392b71Frank Binns	fd = drmOpenMinor(i, 1, DRM_NODE_PRIMARY);
273360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	if (fd >= 0) {
274360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    printf("%s\n", buf);
27588dbee54ed400a3fd5594fab506518c171167805Rik Faith	    if (mask & DRM_BUSID)   getbusid(fd);
276360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (mask & DRM_VERSION) getversion(fd);
277360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (mask & DRM_MEMORY)  getvm(fd);
278360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (mask & DRM_CLIENTS) getclients(fd);
279360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    if (mask & DRM_STATS)   getstats(fd, interval);
280360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	    close(fd);
281360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes	}
282360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    }
283360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes
284360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes    return 0;
285360475376c5a597caf4a981c934a6b0d783fa94dGareth Hughes}
286