test program finished for all XHDI functions
This commit is contained in:
@@ -73,8 +73,8 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
bas_vector = bas_sd_vector(old_vector);
|
bas_vector = bas_sd_vector(old_vector);
|
||||||
printf("got vector from BaS: %p\r\n", bas_vector);
|
printf("got vector from BaS: %p\r\n", bas_vector);
|
||||||
setcookie('XHDI', (uint32_t) bas_vector);
|
//setcookie('XHDI', (uint32_t) bas_vector);
|
||||||
|
XHNewCookie(old_vector, bas_vector);
|
||||||
printf("vector to BaS driver set\r\n");
|
printf("vector to BaS driver set\r\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -51,6 +51,22 @@
|
|||||||
#define XH_TARGET_STOPPED (1 << 30)
|
#define XH_TARGET_STOPPED (1 << 30)
|
||||||
#define XH_TARGET_RESERVED (1 << 31)
|
#define XH_TARGET_RESERVED (1 << 31)
|
||||||
|
|
||||||
|
/* XHDI DOS limits */
|
||||||
|
|
||||||
|
#define XH_DL_SECSIZ (0) /* Maximum sector size (BIOS level) */
|
||||||
|
#define XH_DL_MINFAT (1) /* Minimum number of FATs */
|
||||||
|
#define XH_DL_MAXFAT (2) /* Maximal number of FATs */
|
||||||
|
#define XH_DL_MINSPC (3) /* Minimum sectors per cluster */
|
||||||
|
#define XH_DL_MAXSPC (4) /* Maximum sectors per cluster */
|
||||||
|
#define XH_DL_CLUSTS (5) /* Maximum number of clusters of a 16-bit FAT */
|
||||||
|
#define XH_DL_MAXSEC (6) /* Maximum number of sectors */
|
||||||
|
#define XH_DL_DRIVES (7) /* Maximum number of BIOS drives supported by the DOS */
|
||||||
|
#define XH_DL_CLSIZB (8) /* Maximum cluster size */
|
||||||
|
#define XH_DL_RDLEN (9) /* Max. (bpb->rdlen * bpb->recsiz/32) */
|
||||||
|
#define XH_DL_CLUSTS12 (12) /* Max. number of clusters of a 12-bit FAT */
|
||||||
|
#define XH_DL_CLUSTS32 (13) /* Max. number of clusters of a 32 bit FAT */
|
||||||
|
#define XH_DL_BFLAGS (14) /* Supported bits in bpb->bflags */
|
||||||
|
|
||||||
#ifndef _FEATURES_H
|
#ifndef _FEATURES_H
|
||||||
#include <features.h>
|
#include <features.h>
|
||||||
#endif /* _FEATURES_H */
|
#endif /* _FEATURES_H */
|
||||||
@@ -122,7 +138,7 @@ __extension__ \
|
|||||||
"jsr (a0)\n\t" \
|
"jsr (a0)\n\t" \
|
||||||
"lea 10(sp),sp\n\t" \
|
"lea 10(sp),sp\n\t" \
|
||||||
: "=r"(retvalue) /* outputs */ \
|
: "=r"(retvalue) /* outputs */ \
|
||||||
: [a_xhdi_entry]"g"(xhdi_entry), \
|
: [entry]"g"(xhdi_entry), \
|
||||||
[a_major]"g"(major), \
|
[a_major]"g"(major), \
|
||||||
[a_minor]"g"(minor), \
|
[a_minor]"g"(minor), \
|
||||||
[a_do_reserve]"g"(do_reserve), \
|
[a_do_reserve]"g"(do_reserve), \
|
||||||
@@ -227,7 +243,6 @@ __extension__ \
|
|||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
})
|
})
|
||||||
#define e_xhdi_drivemap xhdi_drivemap(xhdi_entrypoint)
|
|
||||||
|
|
||||||
/* XHDI #7 */
|
/* XHDI #7 */
|
||||||
#define XHInqDev(xhdi_entry, bios_device, major, minor, start_sector, bpb) \
|
#define XHInqDev(xhdi_entry, bios_device, major, minor, start_sector, bpb) \
|
||||||
@@ -281,7 +296,7 @@ __extension__ \
|
|||||||
[a_version]"g"(version), \
|
[a_version]"g"(version), \
|
||||||
[a_company]"g"(company), \
|
[a_company]"g"(company), \
|
||||||
[a_ahdi_version]"g"(ahdi_version), \
|
[a_ahdi_version]"g"(ahdi_version), \
|
||||||
[a_max_ipl]"g"(max_ipl), \
|
[a_max_ipl]"g"(max_ipl) \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
@@ -328,7 +343,7 @@ __extension__ \
|
|||||||
: [entry]"g"(xhdi_entry), \
|
: [entry]"g"(xhdi_entry), \
|
||||||
[a_major]"g"(major), \
|
[a_major]"g"(major), \
|
||||||
[a_minor]"g"(minor), \
|
[a_minor]"g"(minor), \
|
||||||
[a_rwflag]"g"(rwflag) \
|
[a_rwflag]"g"(rwflag), \
|
||||||
[a_recno]"g"(recno), \
|
[a_recno]"g"(recno), \
|
||||||
[a_count]"g"(count), \
|
[a_count]"g"(count), \
|
||||||
[a_buf]"g"(buf) \
|
[a_buf]"g"(buf) \
|
||||||
@@ -347,7 +362,6 @@ __extension__ \
|
|||||||
"move.w %[a_stringlen],-(sp)\n\t" \
|
"move.w %[a_stringlen],-(sp)\n\t" \
|
||||||
"move.l %[a_product_name],-(sp)\n\t" \
|
"move.l %[a_product_name],-(sp)\n\t" \
|
||||||
"move.l %[a_device_flags],-(sp)\n\t" \
|
"move.l %[a_device_flags],-(sp)\n\t" \
|
||||||
"move.l %[a_recno],-(sp)\n\t" \
|
|
||||||
"move.l %[a_block_size],-(sp)\n\t" \
|
"move.l %[a_block_size],-(sp)\n\t" \
|
||||||
"move.w %[a_minor],-(sp)\n\t" \
|
"move.w %[a_minor],-(sp)\n\t" \
|
||||||
"move.w %[a_major],-(sp)\n\t" \
|
"move.w %[a_major],-(sp)\n\t" \
|
||||||
@@ -357,12 +371,12 @@ __extension__ \
|
|||||||
"lea 24(sp),sp\n\t" \
|
"lea 24(sp),sp\n\t" \
|
||||||
: "=r"(retvalue) /* outputs */ \
|
: "=r"(retvalue) /* outputs */ \
|
||||||
: [entry]"g"(xhdi_entry), \
|
: [entry]"g"(xhdi_entry), \
|
||||||
[major]"g"(major), \
|
[a_major]"g"(major), \
|
||||||
[minor]"g"(minor), \
|
[a_minor]"g"(minor), \
|
||||||
[blocksize]"g"(blocksize) \
|
[a_block_size]"g"(block_size), \
|
||||||
[device_flags]"g"(device_flags), \
|
[a_device_flags]"g"(device_flags), \
|
||||||
[product_name]"g"(product_name), \
|
[a_product_name]"g"(product_name), \
|
||||||
[stringlen]"g"(stringlen) \
|
[a_stringlen]"g"(stringlen) \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
@@ -375,7 +389,7 @@ __extension__ \
|
|||||||
register long retvalue __asm__("d0"); \
|
register long retvalue __asm__("d0"); \
|
||||||
\
|
\
|
||||||
__asm__ volatile( \
|
__asm__ volatile( \
|
||||||
"move.l %[a_part_id],-(sp)\n\t" \
|
"move.l %[a_partid],-(sp)\n\t" \
|
||||||
"move.l %[a_blocks],-(sp)\n\t" \
|
"move.l %[a_blocks],-(sp)\n\t" \
|
||||||
"move.l %[a_bpb],-(sp)\n\t" \
|
"move.l %[a_bpb],-(sp)\n\t" \
|
||||||
"move.l %[a_start_sector],-(sp)\n\t" \
|
"move.l %[a_start_sector],-(sp)\n\t" \
|
||||||
@@ -391,7 +405,7 @@ __extension__ \
|
|||||||
[a_bios_device]"g"(bios_device), \
|
[a_bios_device]"g"(bios_device), \
|
||||||
[a_major]"g"(major), \
|
[a_major]"g"(major), \
|
||||||
[a_minor]"g"(minor), \
|
[a_minor]"g"(minor), \
|
||||||
[a_start_sector]"g"(start_sector) \
|
[a_start_sector]"g"(start_sector), \
|
||||||
[a_bpb]"g"(bpb), \
|
[a_bpb]"g"(bpb), \
|
||||||
[a_blocks]"g"(blocks), \
|
[a_blocks]"g"(blocks), \
|
||||||
[a_partid]"g"(partid) \
|
[a_partid]"g"(partid) \
|
||||||
@@ -468,7 +482,7 @@ __extension__ \
|
|||||||
: "=r"(retvalue) /* outputs */ \
|
: "=r"(retvalue) /* outputs */ \
|
||||||
: [entry]"g"(xhdi_entry), \
|
: [entry]"g"(xhdi_entry), \
|
||||||
[a_major]"g"(major), \
|
[a_major]"g"(major), \
|
||||||
[a_minor]"g"(minor), \
|
[a_minor]"g"(minor) \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
@@ -490,14 +504,14 @@ __extension__ \
|
|||||||
: "=r"(retvalue) /* outputs */ \
|
: "=r"(retvalue) /* outputs */ \
|
||||||
: [entry]"g"(xhdi_entry), \
|
: [entry]"g"(xhdi_entry), \
|
||||||
[a_opcode]"g"(opcode), \
|
[a_opcode]"g"(opcode), \
|
||||||
[a_data]"g"(data), \
|
[a_data]"g"(data) \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
})
|
})
|
||||||
|
|
||||||
/* XHDI #17 */
|
/* XHDI #17 */
|
||||||
#define XHDosLimits(xhdi_entry, which, limit) \
|
#define XHDOSLimits(xhdi_entry, which, limit) \
|
||||||
__extension__ \
|
__extension__ \
|
||||||
({ \
|
({ \
|
||||||
register long retvalue __asm__("d0"); \
|
register long retvalue __asm__("d0"); \
|
||||||
@@ -543,7 +557,7 @@ __extension__ \
|
|||||||
})
|
})
|
||||||
|
|
||||||
/* XHDI #19 */
|
/* XHDI #19 */
|
||||||
#define xhdi_last_reaccess(xhdi_entry, major, minor) \
|
#define XHReaccess(xhdi_entry, major, minor) \
|
||||||
__extension__ \
|
__extension__ \
|
||||||
({ \
|
({ \
|
||||||
register long retvalue __asm__("d0"); \
|
register long retvalue __asm__("d0"); \
|
||||||
|
|||||||
@@ -50,6 +50,12 @@ void print_bpb(_BPB *bpb)
|
|||||||
printf("\t\tnumcl = %u\r\n", bpb->numcl);
|
printf("\t\tnumcl = %u\r\n", bpb->numcl);
|
||||||
printf("\t\tbflags = %x\r\n", bpb->bflags);
|
printf("\t\tbflags = %x\r\n", bpb->bflags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* XHDI test routine
|
||||||
|
*
|
||||||
|
* XHDI functions must be called in supervisor mode - pack everything in a function that can be called by Supexec()
|
||||||
|
*/
|
||||||
void xhdi_test(void)
|
void xhdi_test(void)
|
||||||
{
|
{
|
||||||
long drvmap;
|
long drvmap;
|
||||||
@@ -61,43 +67,117 @@ void xhdi_test(void)
|
|||||||
drvmap = XHDrvMap(xhdi);
|
drvmap = XHDrvMap(xhdi);
|
||||||
printf("XHDrvmap = %lx\r\n", drvmap);
|
printf("XHDrvmap = %lx\r\n", drvmap);
|
||||||
|
|
||||||
printf("XHInqDev for all XHDI devices\r\n");
|
printf("XHInqDev and XHInqDriver for all XHDI devices\r\n");
|
||||||
for (i = 0; i < 32; i++)
|
for (i = 0; i < 32; i++)
|
||||||
{
|
{
|
||||||
|
char driver_name[17];
|
||||||
|
char driver_version[7];
|
||||||
|
char driver_company[17];
|
||||||
|
uint16_t ahdi_version;
|
||||||
|
uint16_t max_ipl;
|
||||||
|
|
||||||
uint16_t major = 0;
|
uint16_t major = 0;
|
||||||
uint16_t minor = 0;
|
uint16_t minor = 0;
|
||||||
long start_sector = 0L;
|
long start_sector = 0L;
|
||||||
uint32_t ret;
|
uint32_t ret;
|
||||||
_BPB *bpb;
|
_BPB *bpb = NULL;
|
||||||
|
long blocks;
|
||||||
|
char part_id[20];
|
||||||
|
|
||||||
if ((drvmap >> i) & 1)
|
if ((drvmap >> i) & 1)
|
||||||
{
|
{
|
||||||
|
printf("XHInqDev(%d):\r\n", i);
|
||||||
ret = XHInqDev(xhdi, i, &major, &minor, &start_sector, &bpb);
|
ret = XHInqDev(xhdi, i, &major, &minor, &start_sector, &bpb);
|
||||||
if (ret == E_OK || ret == EDRVNR)
|
if (ret == E_OK || ret == EDRVNR)
|
||||||
{
|
{
|
||||||
long block_size;
|
long block_size;
|
||||||
long flags;
|
long flags;
|
||||||
char *product_name;
|
char product_name[33];
|
||||||
|
char buff[512];
|
||||||
|
unsigned long blocks;
|
||||||
|
unsigned long blocksize;
|
||||||
|
unsigned long ms;
|
||||||
|
|
||||||
printf("drive %d returned %d:\r\n", i, ret);
|
printf("drive %d returned %d:\r\n", i, ret);
|
||||||
printf("\tmajor = %x, minor = %x, start_sector = %lx, bpb = %p\r\n", major, minor, start_sector, bpb);
|
printf("\tmajor = %x, minor = %x, start_sector = %lx, bpb = %p\r\n", major, minor, start_sector, bpb);
|
||||||
if (bpb != NULL)
|
if (bpb != NULL)
|
||||||
print_bpb(bpb);
|
print_bpb(bpb);
|
||||||
|
|
||||||
printf("trying to eject device major = %u, minor = %u. result = %ld\r\n",
|
printf("XHInqTarget() major = %x, minor = %x. result = %ld\r\n", major, minor,
|
||||||
|
XHInqTarget(xhdi, major, minor, &block_size, &flags, &product_name));
|
||||||
|
printf("block_size = %ld, flags = %lx, product_name = \"%s\"\r\n", block_size, flags, product_name);
|
||||||
|
|
||||||
|
printf("XHInqTarget2() major = %x, minor = %x. result = %ld\r\n", major, minor,
|
||||||
|
XHInqTarget2(xhdi, major, minor, &block_size, &flags, &buff, 512));
|
||||||
|
printf("block_size = %ld, flags = %lx, product_name = \"%s\"\r\n", block_size, flags, product_name);
|
||||||
|
|
||||||
|
printf("try to read sector 1 from device major = %x, minor = %x. Result: %ld\r\n",
|
||||||
|
major, minor, XHReadWrite(xhdi, major, minor, 0, 1, 1, &buff));
|
||||||
|
|
||||||
|
(void) Cconws("\r\n<press any key>\r\n");
|
||||||
|
(void) Cconin();
|
||||||
|
|
||||||
|
printf("XHEject() on device major = %x, minor = %x. result = %ld\r\n",
|
||||||
major, minor, XHEject(xhdi, major, minor, 1, 1));
|
major, minor, XHEject(xhdi, major, minor, 1, 1));
|
||||||
printf("trying to lock device major = %u, minor = %u. result = %ld\r\n",
|
|
||||||
|
printf("XHLock() on device major = %x, minor = %x. result = %ld\r\n",
|
||||||
major, minor, XHLock(xhdi, major, minor, 1, 1));
|
major, minor, XHLock(xhdi, major, minor, 1, 1));
|
||||||
|
|
||||||
printf("inquire target major = %u, minor = %u. result = %ld\r\n", major, minor,
|
printf("XHReserve() on device major = %x, minor = %x. result = %ld\r\n",
|
||||||
XHInqTarget(xhdi, major, minor, &block_size, &flags, &product_name));
|
major, minor, XHReserve(xhdi, major, minor, 1, 1));
|
||||||
printf("block_size = %ld, flags = %ld, product_name = \"%s\"", block_size, flags, product_name);
|
|
||||||
|
|
||||||
|
printf("XHStop() on device major = %x, minor = %x. result = %ld\r\n",
|
||||||
|
major, minor, XHStop(xhdi, major, minor, 1, 1));
|
||||||
|
|
||||||
|
printf("XHDriverSpecial() on device major = %x, minor = %x. result = %ld\r\n",
|
||||||
|
major, minor, XHDriverSpecial(xhdi, 'EMUT', 0x12345678, 0, NULL));
|
||||||
|
|
||||||
|
printf("XHGetCapacity() on device major = %x, minor = %x. result = %ld\r\n",
|
||||||
|
major, minor, XHGetCapacity(xhdi, major, minor, &blocks, &blocksize));
|
||||||
|
printf("blocks = %ld, blocksize = %ld\r\n", blocks, blocksize);
|
||||||
|
|
||||||
|
printf("XHMediumChanged() on device major = %x, minor = %x. Result = %ld\r\n",
|
||||||
|
major, minor, XHMediumChanged(xhdi, major, minor));
|
||||||
|
|
||||||
|
printf("XHMintInfo() on driver. Result = %ld\r\n",
|
||||||
|
XHMintInfo(xhdi, 1, &buff));
|
||||||
|
|
||||||
|
(void) Cconws("\r\n<press any key>\r\n");
|
||||||
|
(void) Cconin();
|
||||||
|
|
||||||
|
printf("XHDOSLimits(XH_DL_SECSIZ); on driver. Result = %ld\r\n",
|
||||||
|
XHDOSLimits(xhdi, XH_DL_SECSIZ, 0));
|
||||||
|
|
||||||
|
ms = 0L;
|
||||||
|
printf("XHLastAccess() on device major = %x, minor = %x. Result = %ld\r\n",
|
||||||
|
major, minor, XHLastAccess(xhdi, major, minor, &ms));
|
||||||
|
printf("ms = %ld\r\n", ms);
|
||||||
|
|
||||||
|
printf("XHReaccess() on device major = %x, minor = %x. Result = %ld\r\n",
|
||||||
|
major, minor, XHReaccess(xhdi, major, minor));
|
||||||
|
}
|
||||||
|
printf("XHInqDriver(%d):", i);
|
||||||
|
ret = XHInqDriver(xhdi, i, &driver_name, &driver_version, &driver_company, &ahdi_version, &max_ipl);
|
||||||
|
printf("%d\r\n", ret);
|
||||||
|
if (ret == E_OK || ret == EDRVNR)
|
||||||
|
{
|
||||||
|
printf("driver_name = %s, driver_version = %s, driver_company = %s, ahdi_version = %d, max_ipl = %d\r\n",
|
||||||
|
driver_name, driver_version, driver_company, ahdi_version, max_ipl);
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("XHInqDev2(%d):\r\n", i);
|
||||||
|
ret = XHInqDev2(xhdi, i, &major, &minor, &start_sector, &bpb, &blocks, &part_id);
|
||||||
|
if (ret == E_OK || ret == EDRVNR)
|
||||||
|
{
|
||||||
|
printf("drive %d returned %d:\r\n", i, ret);
|
||||||
|
printf("\tmajor = %x, minor = %x, start_sector = %lx, bpb = %p, blocks = %ld, part_id = %s\r\n",
|
||||||
|
major, minor, start_sector, bpb, blocks, part_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
bpb = NULL;
|
bpb = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
(void) Cconws("\033EGCC XHDI Test Program\r\n=====================\r\n\r\n");
|
(void) Cconws("\033EGCC XHDI Test Program\r\n=====================\r\n\r\n");
|
||||||
|
|||||||
Reference in New Issue
Block a user