- printf("\n");
- if (id->tPIO <= 5)
- {
- strcat(pmodes, "pio0 ");
- if_strcat((id->tPIO >= 1), pmodes, "pio1 ");
- if_strcat((id->tPIO >= 2), pmodes, "pio2 ");
-
- }
- if_printf((!(id->field_valid&1))," (maybe):");
- if (BB_BIG_ENDIAN) capacity = (id->cur_capacity0 << 16) | id->cur_capacity1;
- else capacity = (id->cur_capacity1 << 16) | id->cur_capacity0;
- printf(" CurCHS=%u/%u/%u, CurSects=%lu, LBA=%s",id->cur_cyls, id->cur_heads,
- id->cur_sectors, capacity ,
- ((id->capability&2)==0)?"no":"yes");
-
- if_printf((id->capability&2),", LBAsects=%u", id->lba_capacity);
-
- if (id->capability&1)
- {
- if (id->dma_1word | id->dma_mword)
- {
- if_strcat((id->dma_1word & 0x100), dmodes, "*");
- if_strcat((id->dma_1word & 1), dmodes, "sdma0 ");
- if_strcat((id->dma_1word & 0x200), dmodes, "*");
- if_strcat((id->dma_1word & 2), dmodes, "sdma1 ");
- if_strcat((id->dma_1word & 0x400), dmodes, "*");
- if_strcat((id->dma_1word & 4), dmodes, "sdma2 ");
- if_strcat((id->dma_1word & 0xf800), dmodes, "*");
- if_strcat((id->dma_1word & 0xf8), dmodes, "sdma? ");
- if_strcat((id->dma_mword & 0x100), dmodes, "*");
- if_strcat((id->dma_mword & 1), dmodes, "mdma0 ");
- if_strcat((id->dma_mword & 0x200), dmodes, "*");
- if_strcat((id->dma_mword & 2), dmodes, "mdma1 ");
- if_strcat((id->dma_mword & 0x400), dmodes, "*");
- if_strcat((id->dma_mword & 4), dmodes, "mdma2 ");
- if_strcat((id->dma_mword & 0xf800), dmodes, "*");
- if_strcat((id->dma_mword & 0xf8), dmodes, "mdma? ");
- }
- }
- printf("\n IORDY=");
- if (id->capability&8)
- printf((id->capability&4) ? "on/off" : "yes");
- else
- printf("no");
-
- if ((id->capability&8) || (id->field_valid&2))
- {
- if (id->field_valid&2)
- {
- printf(", tPIO={min:%u,w/IORDY:%u}", id->eide_pio, id->eide_pio_iordy);
- if_strcat((id->eide_pio_modes & 1), pmodes, "pio3 ");
- if_strcat((id->eide_pio_modes & 2), pmodes, "pio4 ");
- if_strcat((id->eide_pio_modes &~3), pmodes, "pio? ");
- }
- if (id->field_valid&4)
- {
- if_strcat((id->dma_ultra & 0x100),umodes,"*");
- if_strcat((id->dma_ultra & 0x001),umodes,"udma0 ");
- if_strcat((id->dma_ultra & 0x200),umodes,"*");
- if_strcat((id->dma_ultra & 0x002),umodes,"udma1 ");
- if_strcat((id->dma_ultra & 0x400),umodes,"*");
- if_strcat((id->dma_ultra & 0x004),umodes,"udma2 ");
+ puts("");
+
+ if (!(id->field_valid & 1))
+ printf(" (maybe):");
+
+ printf(" CurCHS=%u/%u/%u, CurSects=%lu, LBA=%s", id->cur_cyls, id->cur_heads,
+ id->cur_sectors,
+ (BB_BIG_ENDIAN) ?
+ (unsigned long)(id->cur_capacity0 << 16) | id->cur_capacity1 :
+ (unsigned long)(id->cur_capacity1 << 16) | id->cur_capacity0,
+ ((id->capability&2) == 0) ? "no" : "yes");
+
+ if (id->capability & 2)
+ printf(", LBAsects=%u", id->lba_capacity);
+
+ printf("\n IORDY=%s", (id->capability & 8) ? (id->capability & 4) ? "on/off" : "yes" : "no");
+
+ if (((id->capability & 8) || (id->field_valid & 2)) && (id->field_valid & 2))
+ printf(", tPIO={min:%u,w/IORDY:%u}", id->eide_pio, id->eide_pio_iordy);
+
+ if ((id->capability & 1) && (id->field_valid & 2))
+ printf(", tDMA={min:%u,rec:%u}", id->eide_dma_min, id->eide_dma_time);
+
+ printf("\n PIO modes: ");
+ if (id->tPIO <= 5) {
+ printf("pio0 ");
+ if (id->tPIO >= 1) printf("pio1 ");
+ if (id->tPIO >= 2) printf("pio2 ");
+ }
+ if (id->field_valid & 2) {
+ if (id->eide_pio_modes & 1) printf("pio3 ");
+ if (id->eide_pio_modes & 2) printf("pio4 ");
+ if (id->eide_pio_modes &~3) printf("pio? ");
+ }
+ if (id->capability & 1) {
+ if (id->dma_1word | id->dma_mword) {
+ printf("\n DMA modes: ");
+ if (id->dma_1word & 0x100) printf("*");
+ if (id->dma_1word & 1) printf("sdma0 ");
+ if (id->dma_1word & 0x200) printf("*");
+ if (id->dma_1word & 2) printf("sdma1 ");
+ if (id->dma_1word & 0x400) printf("*");
+ if (id->dma_1word & 4) printf("sdma2 ");
+ if (id->dma_1word & 0xf800) printf("*");
+ if (id->dma_1word & 0xf8) printf("sdma? ");
+ if (id->dma_mword & 0x100) printf("*");
+ if (id->dma_mword & 1) printf("mdma0 ");
+ if (id->dma_mword & 0x200) printf("*");
+ if (id->dma_mword & 2) printf("mdma1 ");
+ if (id->dma_mword & 0x400) printf("*");
+ if (id->dma_mword & 4) printf("mdma2 ");
+ if (id->dma_mword & 0xf800) printf("*");
+ if (id->dma_mword & 0xf8) printf("mdma? ");
+ }
+ }
+ if (((id->capability & 8) || (id->field_valid & 2)) && id->field_valid & 4) {
+ printf("\n UDMA modes: ");
+ if (id->dma_ultra & 0x100) printf("*");
+ if (id->dma_ultra & 0x001) printf("udma0 ");
+ if (id->dma_ultra & 0x200) printf("*");
+ if (id->dma_ultra & 0x002) printf("udma1 ");
+ if (id->dma_ultra & 0x400) printf("*");
+ if (id->dma_ultra & 0x004) printf("udma2 ");