X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2F16_sd.c;h=610f7ed0d2e867c555acd7d2f9bc61fcbeeae143;hb=adb425e17c32e33e71670dd69c909717f1d65acb;hp=3e4cfc00e6acfd4468e5484a729a9c6a937cde29;hpb=c0799cb75d07f627246ab2b00d869bcb1f6da71d;p=16.git diff --git a/src/lib/16_sd.c b/src/lib/16_sd.c index 3e4cfc00..610f7ed0 100755 --- a/src/lib/16_sd.c +++ b/src/lib/16_sd.c @@ -23,7 +23,7 @@ #include "src/lib/16_sd.h" //static void (interrupt *old_irq0)(); -extern struct glob_game_vars *ggvv; +void interrupt (*old_irq0)(void); void opl2out(word reg, word data) { @@ -196,7 +196,6 @@ void FMSetVoice(int voiceNum, FMInstrument *ins){ opl2out(opCellNum, ins->Feedback); } /* End of FMSetVoice */ - void SD_Initimf(global_game_variables_t *gvar) { if (!init_adlib()) { @@ -226,8 +225,8 @@ void SD_Initimf(global_game_variables_t *gvar) void SD_imf_free_music(global_game_variables_t *gvar) { - if (gvar->ca.sd.imf_music) free(gvar->ca.sd.imf_music); - MM_FreePtr(MEMPTR gvar->ca.audiosegs[0], gvar); //TODO make behave like id engine +// if (gvar->ca.sd.imf_music) free(gvar->ca.sd.imf_music); + MM_FreePtr(MEMPTRCONV gvar->ca.audiosegs[0], gvar); //TODO make behave like id engine gvar->ca.sd.imf_music = gvar->ca.sd.imf_play_ptr = gvar->ca.sd.imf_music_end = NULL; gvar->ca.sd.imf_delay_countdown = 0; } @@ -257,7 +256,7 @@ int SD_imf_load_music(const char *path, global_game_variables_t *gvar) } len -= len & 3; - MM_GetPtr(MEMPTR gvar->ca.audiosegs[0],len, gvar); + MM_GetPtr(MEMPTRCONV gvar->ca.audiosegs[0],len, gvar); gvar->ca.sd.imf_music = (struct imf_entry *)gvar->ca.audiosegs[0]; if (gvar->ca.sd.imf_music == NULL) { close(fd); @@ -271,8 +270,9 @@ int SD_imf_load_music(const char *path, global_game_variables_t *gvar) return 1; } +struct glob_game_vars *ggvv; // WARNING: subroutine call in interrupt handler. make sure you compile with -zu flag for large/compact memory models -/*void interrupt irq0() +void interrupt irq0() { ggvv->ca.sd.irq0_ticks++; if ((ggvv->ca.sd.irq0_cnt += ggvv->ca.sd.irq0_add) >= ggvv->ca.sd.irq0_max) { @@ -282,7 +282,7 @@ int SD_imf_load_music(const char *path, global_game_variables_t *gvar) else { p8259_OCW2(0,P8259_OCW2_NON_SPECIFIC_EOI); } -}*/ +} void SD_imf_tick(global_game_variables_t *gvar) {