XHInqDev works now
This commit is contained in:
@@ -6,7 +6,7 @@
|
|||||||
TOOLCHAIN_PREFIX=m68k-atari-mint-
|
TOOLCHAIN_PREFIX=m68k-atari-mint-
|
||||||
CC=$(TOOLCHAIN_PREFIX)gcc
|
CC=$(TOOLCHAIN_PREFIX)gcc
|
||||||
|
|
||||||
CFLAGS=-mcpu=547x \
|
CFLAGS=-mcpu=68030 \
|
||||||
-Os \
|
-Os \
|
||||||
-fomit-frame-pointer \
|
-fomit-frame-pointer \
|
||||||
-g \
|
-g \
|
||||||
@@ -27,7 +27,7 @@ $(APP): $(OBJECTS)
|
|||||||
$(CC) $(CFLAGS) $(OBJECTS) -o $(APP)
|
$(CC) $(CFLAGS) $(OBJECTS) -o $(APP)
|
||||||
|
|
||||||
test: xhdi_test.c
|
test: xhdi_test.c
|
||||||
$(CC) $(CFLAGS) -Wl,-traditional-format xhdi_test.c -o xhdi_test.prg
|
$(CC) $(CFLAGS) -Wl,-traditional-format xhdi_test.c -o xhditest.prg
|
||||||
|
|
||||||
.PHONY clean:
|
.PHONY clean:
|
||||||
- rm -rf *.o $(APP)
|
- rm -rf *.o $(APP)
|
||||||
@@ -58,7 +58,8 @@
|
|||||||
|
|
||||||
extern long xhdi_entrypoint;
|
extern long xhdi_entrypoint;
|
||||||
|
|
||||||
#define CLOBBER_REGISTERS __CLOBBER_RETURN("d0") "d1", "d2", "d3", "d4", "d5", "d6", "a0", "a1", "a2", "a3", "a4", "a5", "a6"
|
#define CLOBBER_REGISTERS "memory" /* */
|
||||||
|
|
||||||
/* XHDI #0 */
|
/* XHDI #0 */
|
||||||
#define XHGetVersion(xhdi_entry) \
|
#define XHGetVersion(xhdi_entry) \
|
||||||
__extension__ \
|
__extension__ \
|
||||||
@@ -71,9 +72,8 @@ __extension__ \
|
|||||||
"jsr (a0)\n\t" \
|
"jsr (a0)\n\t" \
|
||||||
"addq.l #2,sp\n\t" \
|
"addq.l #2,sp\n\t" \
|
||||||
: [retvalue]"=r"(retvalue) /* outputs */ \
|
: [retvalue]"=r"(retvalue) /* outputs */ \
|
||||||
: [entry] "m" (xhdi_entry) /* inputs */ \
|
: [entry] "g" (xhdi_entry) /* inputs */ \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
AND_MEMORY \
|
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
})
|
})
|
||||||
@@ -157,7 +157,6 @@ __extension__ \
|
|||||||
[do_lock]"g"(do_lock), \
|
[do_lock]"g"(do_lock), \
|
||||||
[key]"g"(key), \
|
[key]"g"(key), \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
AND_MEMORY \
|
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
});
|
});
|
||||||
@@ -230,7 +229,6 @@ __extension__ \
|
|||||||
: [retvalue] "=r" (retvalue)/* outputs */ \
|
: [retvalue] "=r" (retvalue)/* outputs */ \
|
||||||
: [entry] "m" (xhdi_entry) /* inputs */ \
|
: [entry] "m" (xhdi_entry) /* inputs */ \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
AND_MEMORY \
|
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
})
|
})
|
||||||
@@ -243,12 +241,12 @@ __extension__ \
|
|||||||
register long retvalue __asm__("d0"); \
|
register long retvalue __asm__("d0"); \
|
||||||
\
|
\
|
||||||
__asm__ volatile( \
|
__asm__ volatile( \
|
||||||
"move.w #7,-(sp)\n\t" \
|
|
||||||
"move.w %[a_bios_device],-(sp)\n\t" \
|
|
||||||
"move.l %[a_major],-(sp)\n\t" \
|
|
||||||
"move.l %[a_minor],-(sp)\n\t" \
|
|
||||||
"move.l %[a_start_sector],-(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_minor],-(sp)\n\t" \
|
||||||
|
"move.l %[a_major],-(sp)\n\t" \
|
||||||
|
"move.w %[a_bios_device],-(sp)\n\t" \
|
||||||
|
"move.w #7,-(sp)\n\t" \
|
||||||
"move.l %[a_entry],a0\n\t" \
|
"move.l %[a_entry],a0\n\t" \
|
||||||
"jsr (a0)\n\t" \
|
"jsr (a0)\n\t" \
|
||||||
"lea 20(sp),sp\n\t" \
|
"lea 20(sp),sp\n\t" \
|
||||||
@@ -260,7 +258,6 @@ __extension__ \
|
|||||||
[a_start_sector]"g"(start_sector), \
|
[a_start_sector]"g"(start_sector), \
|
||||||
[a_bpb]"g"(bpb) \
|
[a_bpb]"g"(bpb) \
|
||||||
: CLOBBER_REGISTERS /* clobbered regs */ \
|
: CLOBBER_REGISTERS /* clobbered regs */ \
|
||||||
AND_MEMORY \
|
|
||||||
); \
|
); \
|
||||||
retvalue; \
|
retvalue; \
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -38,6 +38,18 @@ int getcookie(uint32_t cookie, uint32_t *p_value)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_bpb(_BPB *bpb)
|
||||||
|
{
|
||||||
|
printf("\t\trecsiz = %d\r\n", bpb->recsiz);
|
||||||
|
printf("\t\tclsiz = %d\r\n", bpb->clsiz);
|
||||||
|
printf("\t\tclsizb = %d\r\n", bpb->clsizb);
|
||||||
|
printf("\t\trdlen = %d\r\n", bpb->rdlen);
|
||||||
|
printf("\t\tfsiz = %d\r\n", bpb->fsiz);
|
||||||
|
printf("\t\tfatrec = %d\r\n", bpb->fatrec);
|
||||||
|
printf("\t\tdatrec = %d\r\n", bpb->datrec);
|
||||||
|
printf("\t\tnumcl = %d\r\n", bpb->numcl);
|
||||||
|
printf("\t\tbflags = %x\r\n", bpb->bflags);
|
||||||
|
}
|
||||||
void xhdi_test(void)
|
void xhdi_test(void)
|
||||||
{
|
{
|
||||||
long drvmap;
|
long drvmap;
|
||||||
@@ -56,15 +68,17 @@ void xhdi_test(void)
|
|||||||
uint16_t minor = 0;
|
uint16_t minor = 0;
|
||||||
long start_sector = 0L;
|
long start_sector = 0L;
|
||||||
uint32_t ret;
|
uint32_t ret;
|
||||||
_BPB *bpb = NULL;
|
_BPB *bpb;
|
||||||
|
|
||||||
if ((drvmap >> i) & 1)
|
if ((drvmap >> i) & 1)
|
||||||
{
|
{
|
||||||
ret = XHInqDev(xhdi, i, &major, &minor, &start_sector, &bpb);
|
ret = XHInqDev(xhdi, i, &major, &minor, &start_sector, &bpb);
|
||||||
//if (ret == E_OK)
|
if (ret == E_OK || ret == EDRVNR)
|
||||||
{
|
{
|
||||||
printf("drive %d returned %d:\r\n", i, ret);
|
printf("drive %d returned %d:\r\n", i, ret);
|
||||||
printf("\tmajor = %d, minor = %d, start_sector = %lx, bpb = %p\r\n", major & 0xff, minor & 0xff, start_sector, bpb);
|
printf("\tmajor = %d, minor = %d, start_sector = %lx, bpb = %p\r\n", major & 0xff, minor & 0xff, start_sector, bpb);
|
||||||
|
if (bpb != NULL)
|
||||||
|
print_bpb(bpb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user