Take a shot at getting this to compile under newpnp.

This commit is contained in:
Peter Wemm 1999-09-02 05:20:08 +00:00
parent 64da768b1d
commit 724dcf900f
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=50786

View File

@ -23,7 +23,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $Id: pnpinfo.c,v 1.4 1999/05/04 16:59:42 luoqi Exp $ * $Id: pnpinfo.c,v 1.5 1999/05/22 17:35:43 dfr Exp $
*/ */
#include <sys/time.h> #include <sys/time.h>
@ -36,7 +36,7 @@
#include <machine/cpufunc.h> #include <machine/cpufunc.h>
#include <i386/isa/pnp.h> #include <isa/pnpreg.h>
#ifdef DEBUG #ifdef DEBUG
#define DEB(x) x #define DEB(x) x
@ -112,7 +112,7 @@ send_Initiation_LFSR()
{ {
int cur, i; int cur, i;
pnp_write(CONFIG_CONTROL, 0x2); pnp_write(PNP_CONFIG_CONTROL, 0x2);
/* Reset the LSFR */ /* Reset the LSFR */
outb(_PNP_ADDRESS, 0); outb(_PNP_ADDRESS, 0);
@ -169,7 +169,7 @@ get_resource_info(u_char *buffer, int len)
int i, j; int i, j;
for (i = 0; i < len; i++) { for (i = 0; i < len; i++) {
outb(_PNP_ADDRESS, STATUS); outb(_PNP_ADDRESS, PNP_STATUS);
for (j = 0; j < 100; j++) { for (j = 0; j < 100; j++) {
if ((inb((rd_port << 2) | 0x3)) & 0x1) if ((inb((rd_port << 2) | 0x3)) & 0x1)
break; break;
@ -179,7 +179,7 @@ get_resource_info(u_char *buffer, int len)
printf("PnP device failed to report resource data\n"); printf("PnP device failed to report resource data\n");
return 0; return 0;
} }
outb(_PNP_ADDRESS, RESOURCE_DATA); outb(_PNP_ADDRESS, PNP_RESOURCE_DATA);
buffer[i] = inb((rd_port << 2) | 0x3); buffer[i] = inb((rd_port << 2) | 0x3);
DEB(printf("--- get_resource_info: got 0x%02x\n",(unsigned)buffer[i])); DEB(printf("--- get_resource_info: got 0x%02x\n",(unsigned)buffer[i]));
} }
@ -303,11 +303,11 @@ handle_small_res(u_char *resinfo, int item, int len)
default: default:
printf("*** ITEM 0x%02x detected\n", item); printf("*** ITEM 0x%02x detected\n", item);
break; break;
case PNP_VERSION: case PNP_TAG_VERSION:
printf("PnP Version %d.%d, Vendor Version %d\n", printf("PnP Version %d.%d, Vendor Version %d\n",
resinfo[0] >> 4, resinfo[0] & (0xf), resinfo[1]); resinfo[0] >> 4, resinfo[0] & (0xf), resinfo[1]);
break; break;
case LOG_DEVICE_ID: case PNP_TAG_LOGICAL_DEVICE:
printf("\nLogical Device ID: %c%c%c%02x%02x 0x%08x #%d\n", printf("\nLogical Device ID: %c%c%c%02x%02x 0x%08x #%d\n",
((resinfo[0] & 0x7c) >> 2) + 64, ((resinfo[0] & 0x7c) >> 2) + 64,
(((resinfo[0] & 0x03) << 3) | (((resinfo[0] & 0x03) << 3) |
@ -327,7 +327,7 @@ handle_small_res(u_char *resinfo, int item, int len)
if (len == 6) if (len == 6)
printf("\tVendor register funcs %02x\n", resinfo[5]); printf("\tVendor register funcs %02x\n", resinfo[5]);
break; break;
case COMP_DEVICE_ID: case PNP_TAG_COMPAT_DEVICE:
printf("Compatible Device ID: %c%c%c%02x%02x (%08x)\n", printf("Compatible Device ID: %c%c%c%02x%02x (%08x)\n",
((resinfo[0] & 0x7c) >> 2) + 64, ((resinfo[0] & 0x7c) >> 2) + 64,
(((resinfo[0] & 0x03) << 3) | (((resinfo[0] & 0x03) << 3) |
@ -335,7 +335,7 @@ handle_small_res(u_char *resinfo, int item, int len)
(resinfo[1] & 0x1f) + 64, (resinfo[1] & 0x1f) + 64,
resinfo[2], resinfo[3], *(int *)resinfo); resinfo[2], resinfo[3], *(int *)resinfo);
break; break;
case IRQ_FORMAT: case PNP_TAG_IRQ_FORMAT:
printf(" IRQ: "); printf(" IRQ: ");
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
@ -357,7 +357,7 @@ handle_small_res(u_char *resinfo, int item, int len)
printf(" - only one type (true/edge)\n"); printf(" - only one type (true/edge)\n");
} }
break; break;
case DMA_FORMAT: case PNP_TAG_DMA_FORMAT:
printf(" DMA: channel(s) "); printf(" DMA: channel(s) ");
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
if (resinfo[0] & (1<<i)) if (resinfo[0] & (1<<i))
@ -365,7 +365,7 @@ handle_small_res(u_char *resinfo, int item, int len)
printf ("\n"); printf ("\n");
report_dma_info (resinfo[1]); report_dma_info (resinfo[1]);
break; break;
case START_DEPEND_FUNC: case PNP_TAG_START_DEPENDANT:
printf("TAG Start DF\n"); printf("TAG Start DF\n");
if (len == 1) { if (len == 1) {
switch (resinfo[0]) { switch (resinfo[0]) {
@ -381,10 +381,10 @@ handle_small_res(u_char *resinfo, int item, int len)
} }
} }
break; break;
case END_DEPEND_FUNC: case PNP_TAG_END_DEPENDANT:
printf("TAG End DF\n"); printf("TAG End DF\n");
break; break;
case IO_PORT_DESC: case PNP_TAG_IO_RANGE:
printf(" I/O Range 0x%x .. 0x%x, alignment 0x%x, len 0x%x\n", printf(" I/O Range 0x%x .. 0x%x, alignment 0x%x, len 0x%x\n",
resinfo[1] + (resinfo[2] << 8), resinfo[1] + (resinfo[2] << 8),
resinfo[3] + (resinfo[4] << 8), resinfo[3] + (resinfo[4] << 8),
@ -394,20 +394,20 @@ handle_small_res(u_char *resinfo, int item, int len)
else else
printf("\t[not 16-bit addr]\n"); printf("\t[not 16-bit addr]\n");
break; break;
case FIXED_IO_PORT_DESC: case PNP_TAG_IO_FIXED:
printf (" FIXED I/O base address 0x%x length 0x%x\n", printf (" FIXED I/O base address 0x%x length 0x%x\n",
resinfo[0] + ( (resinfo[1] & 3 ) << 8), /* XXX */ resinfo[0] + ( (resinfo[1] & 3 ) << 8), /* XXX */
resinfo[2]); resinfo[2]);
break; break;
#ifdef DIAGNOSTIC #ifdef DIAGNOSTIC
case SM_RES_RESERVED: case PNP_TAG_RESERVED:
printf("Reserved Tag Detected\n"); printf("Reserved Tag Detected\n");
break; break;
#endif #endif
case SM_VENDOR_DEFINED: case PNP_TAG_VENDOR:
printf("*** Small Vendor Tag Detected\n"); printf("*** Small Vendor Tag Detected\n");
break; break;
case END_TAG: case PNP_TAG_END:
printf("End Tag\n\n"); printf("End Tag\n\n");
/* XXX Record and Verify Checksum */ /* XXX Record and Verify Checksum */
return 1; return 1;
@ -424,7 +424,7 @@ handle_large_res(u_char *resinfo, int item, int len)
DEB(printf("*** Large ITEM %d len %d found\n", item, len)); DEB(printf("*** Large ITEM %d len %d found\n", item, len));
switch (item) { switch (item) {
case MEMORY_RANGE_DESC: case PNP_TAG_MEMORY_RANGE:
report_memory_info(resinfo[0]); report_memory_info(resinfo[0]);
printf("Memory range minimum address: 0x%x\n", printf("Memory range minimum address: 0x%x\n",
(resinfo[1] << 8) + (resinfo[2] << 16)); (resinfo[1] << 8) + (resinfo[2] << 16));
@ -435,7 +435,7 @@ handle_large_res(u_char *resinfo, int item, int len)
printf("Memory range length: 0x%x\n", printf("Memory range length: 0x%x\n",
(resinfo[7] + (resinfo[8] << 8)) * 256); (resinfo[7] + (resinfo[8] << 8)) * 256);
break; break;
case ID_STRING_ANSI: case PNP_TAG_ID_ANSI:
printf("Device Description: "); printf("Device Description: ");
for (i = 0; i < len; i++) { for (i = 0; i < len; i++) {
@ -444,21 +444,23 @@ handle_large_res(u_char *resinfo, int item, int len)
} }
printf("\n"); printf("\n");
break; break;
case ID_STRING_UNICODE: case PNP_TAG_ID_UNICODE:
printf("ID String Unicode Detected (Undefined)\n"); printf("ID String Unicode Detected (Undefined)\n");
break; break;
case LG_VENDOR_DEFINED: case PNP_TAG_LARGE_VENDOR:
printf("Large Vendor Defined Detected\n"); printf("Large Vendor Defined Detected\n");
break; break;
case _32BIT_MEM_RANGE_DESC: case PNP_TAG_MEMORY32_RANGE:
printf("32bit Memory Range Desc Unimplemented\n"); printf("32bit Memory Range Desc Unimplemented\n");
break; break;
case _32BIT_FIXED_LOC_DESC: case PNP_TAG_MEMORY32_FIXED:
printf("32bit Fixed Location Desc Unimplemented\n"); printf("32bit Fixed Location Desc Unimplemented\n");
break; break;
case LG_RES_RESERVED: #ifdef DIAGNOSTIC
case PNP_TAG_LARGE_RESERVED:
printf("Large Reserved Tag Detected\n"); printf("Large Reserved Tag Detected\n");
break; break;
#endif
} }
} }
@ -481,8 +483,8 @@ dump_resdata(u_char *data, int csn)
*(int *)&(data[0]), *(int *)&(data[0]),
*(int *)&(data[4])); *(int *)&(data[4]));
pnp_write(SET_CSN, csn); /* Move this out of this function XXX */ pnp_write(PNP_SET_CSN, csn); /* Move this out of this function XXX */
outb(_PNP_ADDRESS, STATUS); outb(_PNP_ADDRESS, PNP_STATUS);
/* Allows up to 1kb of Resource Info, Should be plenty */ /* Allows up to 1kb of Resource Info, Should be plenty */
for (i = 0; i < 1024; i++) { for (i = 0; i < 1024; i++) {
@ -516,7 +518,7 @@ dump_resdata(u_char *data, int csn)
} }
printf("Successfully got %d resources, %d logical fdevs\n", i, printf("Successfully got %d resources, %d logical fdevs\n", i,
logdevs); logdevs);
printf("-- card select # 0x%04x\n", pnp_read(SET_CSN)); printf("-- card select # 0x%04x\n", pnp_read(PNP_SET_CSN));
printf("\nCSN %c%c%c%02x%02x (0x%08x), Serial Number 0x%08x\n", printf("\nCSN %c%c%c%02x%02x (0x%08x), Serial Number 0x%08x\n",
((data[0] & 0x7c) >> 2) + 64, ((data[0] & 0x7c) >> 2) + 64,
(((data[0] & 0x03) << 3) | ((data[1] & 0xe0) >> 5)) + 64, (((data[0] & 0x03) << 3) | ((data[1] & 0xe0) >> 5)) + 64,
@ -527,18 +529,19 @@ dump_resdata(u_char *data, int csn)
for (i=0; i<logdevs; i++) { for (i=0; i<logdevs; i++) {
int j; int j;
pnp_write(SET_LDN, i); pnp_write(PNP_SET_LDN, i);
printf("\nLogical device #%d\n", pnp_read(SET_LDN) ); printf("\nLogical device #%d\n", pnp_read(PNP_SET_LDN) );
printf("IO: "); printf("IO: ");
for (j=0; j<8; j++) for (j=0; j<8; j++)
printf(" 0x%04x", pnp_readw(IO_CONFIG_BASE + j*2)); printf(" 0x%02x%02x", pnp_read(PNP_IO_BASE_HIGH(i)),
pnp_read(PNP_IO_BASE_LOW(i)));
printf("\nIRQ %d %d\n", printf("\nIRQ %d %d\n",
pnp_read(IRQ_CONFIG), pnp_read(IRQ_CONFIG+2) ); pnp_read(PNP_IRQ_LEVEL(0)), pnp_read(PNP_IRQ_LEVEL(1)) );
printf("DMA %d %d\n", printf("DMA %d %d\n",
pnp_read(DRQ_CONFIG), pnp_read(DRQ_CONFIG+1) ); pnp_read(PNP_DMA_CHANNEL(0)), pnp_read(PNP_DMA_CHANNEL(1)) );
printf("IO range check 0x%02x activate 0x%02x\n", printf("IO range check 0x%02x activate 0x%02x\n",
pnp_read(IO_RANGE_CHECK), pnp_read(ACTIVATE) ); pnp_read(PNP_IO_RANGE_CHECK), pnp_read(PNP_ACTIVATE) );
} }
} }
@ -559,14 +562,14 @@ isolation_protocol()
send_Initiation_LFSR(); send_Initiation_LFSR();
/* Reset CSN for All Cards */ /* Reset CSN for All Cards */
pnp_write(CONFIG_CONTROL, 0x04); pnp_write(PNP_CONFIG_CONTROL, 0x04);
for (csn = 1; (csn < MAX_PNP_CARDS); csn++) { for (csn = 1; (csn < PNP_MAX_CARDS); csn++) {
/* Wake up cards without a CSN */ /* Wake up cards without a CSN */
logdevs = 0 ; logdevs = 0 ;
pnp_write(WAKE, 0); pnp_write(PNP_WAKE, 0);
pnp_write(SET_RD_DATA, rd_port); pnp_write(PNP_SET_RD_DATA, rd_port);
outb(_PNP_ADDRESS, SERIAL_ISOLATION); outb(_PNP_ADDRESS, PNP_SERIAL_ISOLATION);
DELAY(1000); /* Delay 1 msec */ DELAY(1000); /* Delay 1 msec */
if (get_serial(data)) if (get_serial(data))