1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <sys/mman.h>
#include <unistd.h>
#include <fcntl.h>
#include <errno.h>
#include <stdarg.h>
#include "vbe.h"
#include "vesamode.h"
#include "xbox.h"
#ifdef HAVE_VBE
#include "int10/vbios.h"
#else
#define InitInt10(PCI_CONFIG) 0
#define FreeInt10() /**/
#endif
#ident "$Id$"
#define SQR(x) ((x) * (x))
void log_err(char *format, ...)
{
va_list args;
va_start(args, format);
vfprintf(stderr, format, args);
va_end(args);
}
int main(void)
{
int i, j;
unsigned char hmin, hmax, vmin, vmax;
struct vbe_info vbe_info_static;
struct vbe_info *vbe_info = &vbe_info_static;
struct vbe_edid1_info edid_static;
struct vbe_edid1_info *edid = &edid_static;
struct vbe_modeline *modelines;
int pci_config_type = 0;
/* Determine PCI configuration type */
pci_config_type = 1;
/* Get VBE information */
#ifdef HAVE_VBE
if (box_is_xbox() == 1) {
if (get_fb_info(vbe_info) == 0)
return 1;
} else {
#endif
/* Initialize Int10 */
if (InitInt10(pci_config_type)) return 1;
if (vbe_get_vbe_info(vbe_info) == 0) {
FreeInt10();
return 1;
}
#ifdef HAVE_VBE
}
#endif
printf("%dKB of video ram\n", vbe_info->memory_size / 1024);
/* List supported standard modes */
#ifdef HAVE_VBE
for (j = 0; j < vbe_info->modes; j++)
for (i = 0; known_vesa_modes[i].x; i++)
if (known_vesa_modes[i].number == vbe_info->mode_list[j])
printf("%d %d %d\n",
known_vesa_modes[i].colors,
known_vesa_modes[i].x,
known_vesa_modes[i].y
);
/* optimal on a TV, just return canned values */
if (box_is_xbox() == 1)
printf("%d %d %d\n", 16777216, 640, 480);
#endif
printf("\n");
/* Get EDID information */
if (vbe_get_edid_info(edid) == 0) {
FreeInt10();
return 0;
}
FreeInt10();
if (edid->manufacturer_name.p == 0 || edid->product_code == 0) return 0;
if (edid->version == 255 && edid->revision == 255) return 0;
vbe_get_edid_ranges(edid, &hmin, &hmax, &vmin, &vmax);
modelines = vbe_get_edid_modelines(edid);
if (hmin > hmax || vmin > vmax) return 0;
printf(hmin ? "%d-%d kHz HorizSync\n" : "\n", hmin, hmax);
printf(vmin ? "%d-%d Hz VertRefresh\n" : "\n", vmin, vmax);
if (edid->max_size_horizontal != 127 && edid->max_size_vertical != 127) {
char manufacturer[4];
double size = sqrt(SQR(edid->max_size_horizontal) +
SQR(edid->max_size_vertical)) / 2.54;
manufacturer[0] = edid->manufacturer_name.u.char1 + 'A' - 1;
manufacturer[1] = edid->manufacturer_name.u.char2 + 'A' - 1;
manufacturer[2] = edid->manufacturer_name.u.char3 + 'A' - 1;
manufacturer[3] = '\0';
printf(size ? "%3.2f inches monitor (truly %3.2f') EISA ID=%s%04x\n" : "\n", size * 1.08, size, manufacturer, edid->product_code);
}
for(j=0; modelines && (modelines[j].refresh != 0); j++){
printf("# %dx%d, %1.1f%sHz",
modelines[j].width,
modelines[j].height,
modelines[j].refresh,
modelines[j].interlaced?"i":""
);
if(modelines[j].modeline) {
printf("; hfreq=%f, vfreq=%f\n%s\n",
modelines[j].hfreq,
modelines[j].vfreq,
modelines[j].modeline);
} else printf("\n");
}
return 0;
}
|