xenocara/driver/xf86-video-chips/util/mRegs.c

130 lines
3.0 KiB
C
Raw Normal View History

2006-11-26 13:01:26 -07:00
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
2012-08-11 03:40:47 -06:00
#include "iopl.h"
2006-11-26 13:01:26 -07:00
int hex2int(char* str);
int main(int argc, char** argv)
{
int i, value, index = 0;
char c, cport;
char* str;
unsigned int port, port1 = 0;
int query = 0;
if(argc < 2) {
printf("usage: %s [Cvvxx [Cvvxx]] [Dxx]\n",argv[0]);
printf(" where C = A|a write vv to ARxx\n");
printf(" = C|c write vv to CRxx\n");
printf(" = F|f write vv to FRxx (6555x only)\n");
printf(" = G|g write vv to GRxx\n");
printf(" = M|m write vv to MRxx (6555x only)\n");
printf(" = S|s write vv to SRxx\n");
printf(" = X|x write vv to XRxx\n");
printf(" where D = Y|y write xx to FCR\n");
printf(" = Z|z write vv to MSR\n");
printf(" xx is in hexadecimal\n");
printf(" vv is in hexadecimal or '?' for query\n");
}
SET_IOPL();
for(i = 1; i < argc; i++){
value = 0;
str = argv[i];
c = *str++;
switch (c) {
case 'f':
case 'F':
cport = 'F';
port = 0x3D0;
break;
case 'c':
case 'C':
cport = 'C';
port = 0x3D4;
break;
case 'x':
case 'X':
cport = 'X';
port = 0x3D6;
break;
case 'g':
case 'G':
cport = 'G';
port = 0x3CE;
break;
case 'a':
case 'A':
cport = 'A';
port = 0x3C0;
break;
case 's':
case 'S':
cport = 'S';
port = 0x3C4;
break;
case 'm':
case 'M':
cport = 'M';
port = 0x3D2;
break;
case 'y':
case 'Y':
cport = 'Y';
port = 0x3DA;
port1 = 0x3CA;
break;
case 'z':
case 'Z':
cport = 'Z';
port = 0x3C2;
port1 = 0x3CC;
break;
default:
continue;
break;
}
if ((cport != 'Z') && (cport != 'Y')) index = inb(port);
while ((c = *str++)) {
if (c == '?') {
query = 1;
}
if(c >= '0' && c <= '9')
value = (value << 4) | (c - '0'); /*ASCII assumed*/
else if(c >= 'A' && c < 'G')
value = (value << 4) | (c - 'A'+10); /*ASCII assumed*/
else if(c >= 'a' && c < 'g')
value = (value << 4) | (c - 'a'+10); /*ASCII assumed*/
}
if ((cport != 'Z') && (cport != 'Y')) outb(port,value&0xFF);
if (query) {
if ((cport != 'Z') && (cport != 'Y'))
printf("%cR%X: 0x%X\n", cport, value & 0xFF,
inb(port+1)&0xFF);
else
if (cport == 'Z')
printf("MSR: 0x%X\n", inb(port1)&0xFF);
else
printf("FCR: 0x%X\n", inb(port1)&0xFF);
} else {
if ((cport != 'Z') && (cport != 'Y')) {
printf("%cR%X: 0x%X -> 0x%X\n", cport, value & 0xFF,
inb(port+1)&0xFF, (value&0xFF00)>>8);
outw(port, value);
outb(port, index &0xFF);
} else {
if (cport == 'Z')
printf("MSR: 0x%X -> 0x%X\n", inb(port1)&0xFF, value&0xFF);
else
printf("FCR: 0x%X -> 0x%X\n", inb(port1)&0xFF, value&0xFF);
outb(port, value & 0xFF);
}
}
}
RESET_IOPL();
return 0;
}