diff --git a/src/86box.h b/src/86box.h index d9d9d2bb9..312dd5500 100644 --- a/src/86box.h +++ b/src/86box.h @@ -1 +1,4 @@ +/* Copyright holders: Tenshi + see COPYING for more details +*/ #define emulator_version "1.00" diff --git a/src/Makefile_AMD.mingw b/src/Makefile_AMD.mingw index 969ad3f6e..436b11d5f 100644 --- a/src/Makefile_AMD.mingw +++ b/src/Makefile_AMD.mingw @@ -1,49 +1,2 @@ -VPATH = . dosbox resid-fp slirp -CPP = g++.exe -CC = gcc.exe -WINDRES = windres.exe -CFLAGS = -O3 -march=amdfam10 -mtune=amdfam10 -fbranch-probabilities -fvpt -funroll-loops -fpeel-loops -ftracer -fomit-frame-pointer -ffast-math -msse -msse2 -msse3 -mfpmath=sse -mstackrealign -OBJ = 386.o 386_dynarec.o 386_dynarec_ops.o 808x.o acer386sx.o acerm3a.o ali1429.o amstrad.o cdrom-ioctl.o cdrom-iso.o \ - cdrom-null.o codegen.o codegen_ops.o codegen_timing_486.o codegen_timing_686.o codegen_timing_pentium.o codegen_timing_winchip.o codegen_x86.o compaq.o config.o cpu.o dac.o \ - device.o disc.o disc_fdi.o disc_img.o disc_sector.o dma.o fdc.o fdc37c665.o fdc37c932fr.o fdd.o fdi2raw.o gameport.o headland.o i430hx.o i430lx.o i430fx.o \ - i430nx.o i430vx.o i440fx.o ide.o intel.o intel_flash.o io.o jim.o joystick_ch_flightstick_pro.o joystick_standard.o joystick_sw_pad.o joystick_tm_fcs.o keyboard.o keyboard_amstrad.o keyboard_at.o \ - keyboard_olim24.o keyboard_pcjr.o keyboard_xt.o lpt.o mcr.o mem.o memregs.o model.o mouse.o mouse_ps2.o \ - mouse_serial.o ne2000.o neat.o nethandler.o nmi.o nvr.o olivetti_m24.o opti.o pc.o pc87306.o pci.o pic.o piix.o pit.o ppi.o ps1.o rom.o rtc.o \ - scat.o serial.o sis496.o sis85c471.o sio.o sound.o sound_ad1848.o sound_adlib.o sound_adlibgold.o sound_cms.o \ - sound_dbopl.o sound_emu8k.o sound_gus.o sound_mpu401_uart.o sound_opl.o sound_pas16.o sound_ps1.o sound_pssj.o sound_resid.o \ - sound_sb.o sound_sb_dsp.o sound_sn76489.o sound_speaker.o sound_ssi2001.o sound_wss.o sound_ym7128.o \ - soundopenal.o tandy_eeprom.o tandy_rom.o timer.o um8669f.o vid_ati_eeprom.o vid_ati_mach64.o vid_ati18800.o \ - vid_ati28800.o vid_ati68860_ramdac.o vid_bt485_ramdac.o vid_cga.o vid_cl5429.o vid_ega.o vid_et4000.o \ - vid_et4000w32.o vid_hercules.o vid_icd2061.o vid_ics2595.o vid_incolor.o vid_mda.o \ - vid_olivetti_m24.o vid_oti067.o vid_paradise.o vid_pc1512.o vid_pc1640.o vid_pc200.o \ - vid_pcjr.o vid_ps1_svga.o vid_s3.o vid_s3_virge.o vid_sdac_ramdac.o vid_stg_ramdac.o vid_svga.o \ - vid_svga_render.o vid_tandy.o vid_tandysl.o vid_tgui9440.o vid_tkd8001_ramdac.o vid_tvga.o vid_unk_ramdac.o \ - vid_vga.o vid_voodoo.o video.o w83877f.o wd76c10.o win.o win-config.o win-d3d.o win-d3d-fs.o win-ddraw.o \ - win-ddraw-fs.o win-ddraw-screenshot.o win-deviceconfig.o win-hdconf.o win-joystick.o win-joystickconfig.o win-keyboard.o win-midi.o win-mouse.o \ - win-status.o win-video.o x86seg.o x87.o xtide.o pc.res -DBOBJ = dbopl.o vid_cga_comp.o -SIDOBJ = convolve.o convolve-sse.o envelope.o extfilt.o filter.o pot.o sid.o voice.o wave6581__ST.o wave6581_P_T.o wave6581_PS_.o wave6581_PST.o wave8580__ST.o wave8580_P_T.o wave8580_PS_.o wave8580_PST.o wave.o -SLIRPOBJ = bootp.o ip_icmp.o misc.o socket.o tcp_timer.o cksum.o ip_input.o queue.o tcp_input.o tftp.o debug.o ip_output.o sbuf.o tcp_output.o udp.o if.o mbuf.o slirp.o tcp_subr.o - - -LIBS = -mwindows -lwinmm -lopenal.dll -lopenal -lddraw -ldinput8 -ldxguid -ld3d9 -ld3dx9 -lwsock32 -liphlpapi -lstdc++ -static-libstdc++ -static-libgcc -static - -PCem.exe: $(OBJ) $(DBOBJ) $(SIDOBJ) $(SLIRPOBJ) - $(CC) $(OBJ) $(DBOBJ) $(SIDOBJ) $(SLIRPOBJ) -o "PCem.exe" $(LIBS) - strip "PCem.exe" - -all : PCem.exe - -clean : - rm *.o - rm *.exe - rm *.res - -%.o : %.c - $(CC) $(CFLAGS) -c $< - -%.o : %.cc - $(CPP) $(CFLAGS) -c $< - -pc.res: pc.rc - $(WINDRES) -i pc.rc --input-format=rc -o pc.res -O coff +include Makefile.mingw +CFLAGS = -O3 -march=amdfam10 -mtune=amdfam10 -fbranch-probabilities -fvpt -funroll-loops -fpeel-loops -ftracer -fomit-frame-pointer -ffast-math -msse -msse2 -msse3 -mfpmath=sse -mstackrealign \ No newline at end of file diff --git a/src/disc_fdi.c b/src/disc_fdi.c index 64d197483..663bf7976 100644 --- a/src/disc_fdi.c +++ b/src/disc_fdi.c @@ -1,4 +1,4 @@ -/* Copyright holders: Sarah Walker +/* Copyright holders: Sarah Walker, Tenshi see COPYING for more details */ #include diff --git a/src/disc_img.c b/src/disc_img.c index 7fcc985c0..ee6d63e78 100644 --- a/src/disc_img.c +++ b/src/disc_img.c @@ -1,4 +1,4 @@ -/* Copyright holders: Sarah Walker +/* Copyright holders: Sarah Walker, Tenshi see COPYING for more details */ #include "ibm.h" diff --git a/src/disc_sector_86box.c b/src/disc_sector_86box.c index f1c21b8af..883e5dcce 100644 --- a/src/disc_sector_86box.c +++ b/src/disc_sector_86box.c @@ -1,3 +1,6 @@ +/* Copyright holders: Tenshi + see COPYING for more details +*/ #include "ibm.h" #include "disc.h" #include "disc_sector.h" diff --git a/src/ne2000.c b/src/ne2000.c index 0e7bfe827..f12230aa6 100644 --- a/src/ne2000.c +++ b/src/ne2000.c @@ -1,4 +1,4 @@ -/* Copyright holders: Peter Grehan, SA1988 +/* Copyright holders: Peter Grehan, SA1988, Tenshi see COPYING for more details */ ///////////////////////////////////////////////////////////////////////// diff --git a/src/sound_mameopl.c b/src/sound_mameopl.c deleted file mode 100644 index ed8c9b1dd..000000000 --- a/src/sound_mameopl.c +++ /dev/null @@ -1,203 +0,0 @@ -/* Copyright holders: Sarah Walker - see COPYING for more details -*/ -#include -#include -#include "ibm.h" -#include "io.h" -#include "sound.h" -#include "mame/fmopl.h" -#include "mame/ymf262.h" -#include "sound_opl.h" -#include "sound_dbopl.h" - -/*Interfaces between PCem and the actual OPL emulator*/ - - -uint8_t opl2_read(uint16_t a, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - cycles -= (int)(isa_timing * 8); - opl2_update2(opl); - return ym3812_read(opl->YM3812[0], a); -} -void opl2_write(uint16_t a, uint8_t v, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - opl2_update2(opl); - ym3812_write(opl->YM3812[0],a,v); - ym3812_write(opl->YM3812[1],a,v); -} - -uint8_t opl2_l_read(uint16_t a, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - cycles -= (int)(isa_timing * 8); - opl2_update2(opl); - return ym3812_read(opl->YM3812[0], a); -} -void opl2_l_write(uint16_t a, uint8_t v, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - opl2_update2(opl); - ym3812_write(opl->YM3812[0],a,v); -} - -uint8_t opl2_r_read(uint16_t a, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - cycles -= (int)(isa_timing * 8); - opl2_update2(opl); - return ym3812_read(opl->YM3812[1], a); -} -void opl2_r_write(uint16_t a, uint8_t v, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - opl2_update2(opl); - ym3812_write(opl->YM3812[1],a,v); -} - -uint8_t opl3_read(uint16_t a, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - cycles -= (int)(isa_timing * 8); - opl3_update2(opl); - return ymf262_read(opl->YMF262, a); -} -void opl3_write(uint16_t a, uint8_t v, void *priv) -{ - opl_t *opl = (opl_t *)priv; - - opl3_update2(opl); - ymf262_write(opl->YMF262, a, v); -} - - -void opl2_update2(opl_t *opl) -{ - if (opl->pos < sound_pos_global) - { - ym3812_update_one(opl->YM3812[0], &opl->buffer[opl->pos*2], sound_pos_global - opl->pos); - ym3812_update_one(opl->YM3812[1], &opl->buffer[opl->pos*2 + 1], sound_pos_global - opl->pos); - for (; opl->pos < sound_pos_global; opl->pos++) - { - opl->filtbuf[0] = opl->buffer[opl->pos*2] = (opl->buffer[opl->pos*2] / 4) + ((opl->filtbuf[0] * 11) / 16); - opl->filtbuf[1] = opl->buffer[opl->pos*2+1] = (opl->buffer[opl->pos*2+1] / 4) + ((opl->filtbuf[1] * 11) / 16); - } - } -} - -void opl3_update2(opl_t *opl) -{ - if (opl->pos < sound_pos_global) - { - ymf262_update_one(opl->YMF262, &opl->buffer[opl->pos*2], sound_pos_global - opl->pos); - for (; opl->pos < sound_pos_global; opl->pos++) - { - opl->filtbuf[0] = opl->buffer[opl->pos*2] = (opl->buffer[opl->pos*2] / 4) + ((opl->filtbuf[0] * 11) / 16); - opl->filtbuf[1] = opl->buffer[opl->pos*2+1] = (opl->buffer[opl->pos*2+1] / 4) + ((opl->filtbuf[1] * 11) / 16); - } - } -} - -void ym3812_timer_set_0(void *param, int timer, int64_t period) -{ - opl_t *opl = (opl_t *)param; - - opl->timers[0][timer] = period * TIMER_USEC * 20; - if (!opl->timers[0][timer]) opl->timers[0][timer] = 1; - opl->timers_enable[0][timer] = period ? 1 : 0; -} -void ym3812_timer_set_1(void *param, int timer, int64_t period) -{ - opl_t *opl = (opl_t *)param; - - opl->timers[1][timer] = period * TIMER_USEC * 20; - if (!opl->timers[1][timer]) opl->timers[1][timer] = 1; - opl->timers_enable[1][timer] = period ? 1 : 0; -} - -void ymf262_timer_set(void *param, int timer, int64_t period) -{ - opl_t *opl = (opl_t *)param; - - opl->timers[0][timer] = period * TIMER_USEC * 20; - if (!opl->timers[0][timer]) opl->timers[0][timer] = 1; - opl->timers_enable[0][timer] = period ? 1 : 0; -} - -static void opl_timer_callback00(void *p) -{ - opl_t *opl = (opl_t *)p; - - opl->timers_enable[0][0] = 0; - ym3812_timer_over(opl->YM3812[0], 0); -} -static void opl_timer_callback01(void *p) -{ - opl_t *opl = (opl_t *)p; - - opl->timers_enable[0][1] = 0; - ym3812_timer_over(opl->YM3812[0], 1); -} -static void opl_timer_callback10(void *p) -{ - opl_t *opl = (opl_t *)p; - - opl->timers_enable[1][0] = 0; - ym3812_timer_over(opl->YM3812[1], 0); -} -static void opl_timer_callback11(void *p) -{ - opl_t *opl = (opl_t *)p; - - opl->timers_enable[1][1] = 0; - ym3812_timer_over(opl->YM3812[1], 1); -} -static void opl3_timer_callback00(void *p) -{ - opl_t *opl = (opl_t *)p; - - opl->timers_enable[0][0] = 0; - ymf262_timer_over(opl->YMF262, 0); -} -static void opl3_timer_callback01(void *p) -{ - opl_t *opl = (opl_t *)p; - - opl->timers_enable[0][1] = 0; - ymf262_timer_over(opl->YMF262, 1); -} - -void opl2_init(opl_t *opl) -{ - opl->YM3812[0] = ym3812_init(NULL, 3579545, 48000); - ym3812_reset_chip(opl->YM3812[0]); - ym3812_set_timer_handler(opl->YM3812[0], ym3812_timer_set_0, opl); - - opl->YM3812[1] = ym3812_init(NULL, 3579545, 48000); - ym3812_reset_chip(opl->YM3812[1]); - ym3812_set_timer_handler(opl->YM3812[1], ym3812_timer_set_1, opl); - - timer_add(opl_timer_callback00, &opl->timers[0][0], &opl->timers_enable[0][0], (void *)opl); - timer_add(opl_timer_callback01, &opl->timers[0][1], &opl->timers_enable[0][1], (void *)opl); - timer_add(opl_timer_callback10, &opl->timers[1][0], &opl->timers_enable[1][0], (void *)opl); - timer_add(opl_timer_callback11, &opl->timers[1][1], &opl->timers_enable[1][1], (void *)opl); -} - -void opl3_init(opl_t *opl) -{ - opl->YMF262 = ymf262_init(NULL, 3579545 * 4, 48000); - ymf262_reset_chip(opl->YMF262); - ymf262_set_timer_handler(opl->YMF262, ymf262_timer_set, opl); - timer_add(opl3_timer_callback00, &opl->timers[0][0], &opl->timers_enable[0][0], (void *)opl); - timer_add(opl3_timer_callback01, &opl->timers[0][1], &opl->timers_enable[0][1], (void *)opl); -} -