Mercurial > repos > blastem
diff lc8951.h @ 2062:07ed42bd7b4c segacd
Some progress on CDC and CDD emulation. Now passes first 3 "CDC INIT" tests in mcd-verificator
author | Michael Pavone <pavone@retrodev.com> |
---|---|
date | Fri, 28 Jan 2022 00:50:17 -0800 |
parents | 70260f6051dd |
children | 02a9846668d1 |
line wrap: on
line diff
--- a/lc8951.h Thu Jan 27 00:33:41 2022 -0800 +++ b/lc8951.h Fri Jan 28 00:50:17 2022 -0800 @@ -4,7 +4,10 @@ #include <stdint.h> typedef struct { - uint32_t cycles; + uint32_t cycle; + uint32_t clock_step; + uint32_t decode_end; + uint32_t transfer_end; uint8_t buffer[0x4000]; @@ -19,12 +22,16 @@ uint8_t ctrl1; uint8_t ar; uint8_t ar_mask; + uint8_t decoding; + uint16_t ptl_internal; } lc8951; void lc8951_init(lc8951 *context); -//void lc8951_run(lc8951 *context, uint32_t cycle); +void lc8951_run(lc8951 *context, uint32_t cycle); void lc8951_reg_write(lc8951 *context, uint8_t value); uint8_t lc8951_reg_read(lc8951 *context); void lc8951_ar_write(lc8951 *context, uint8_t value); +void lc8951_write_byte(lc8951 *context, uint32_t cycle, int sector_offset, uint8_t byte); +uint32_t lc8951_next_interrupt(lc8951 *context); #endif //LC8951_H_