2770b94384c4565fbe9b5db79f3eb7759ef20a37
[libpicofe.git] / win32 / plat.c
1 #include <windows.h>
2 #include <stdio.h>
3
4 #include "../common/lprintf.h"
5 #include "../common/plat.h"
6 #include "../common/emu.h"
7 #include "../../pico/pico.h"
8 #include "version.h"
9 #include "direct.h"
10 #include "dsnd.h"
11 #include "main.h"
12
13 static unsigned short screen_buff[320 * 240];
14 static unsigned char PicoDraw2FB_[(8+320) * (8+240+8)];
15 unsigned char *PicoDraw2FB = PicoDraw2FB_;
16
17 char cpu_clk_name[] = "unused";
18
19 void plat_init(void)
20 {
21         g_screen_ptr = (void *)screen_buff;
22 }
23
24 int plat_is_dir(const char *path)
25 {
26         return (GetFileAttributes(path) & FILE_ATTRIBUTE_DIRECTORY) ? 1 : 0;
27 }
28
29 unsigned int plat_get_ticks_ms(void)
30 {
31         return GetTickCount();
32 }
33
34 unsigned int plat_get_ticks_us(void)
35 {
36         // XXX: maybe performance counters?
37         return GetTickCount() * 1000;
38 }
39
40 void plat_wait_till_us(unsigned int us)
41 {
42         int msdiff = (int)(us - plat_get_ticks_us()) / 1000;
43         if (msdiff > 6)
44                 Sleep(msdiff - 6);
45         while (plat_get_ticks_us() < us)
46                 ;
47 }
48
49 void plat_sleep_ms(int ms)
50 {
51         Sleep(ms);
52 }
53
54 int plat_wait_event(int *fds_hnds, int count, int timeout_ms)
55 {
56         return -1;
57 }
58
59 void pemu_prep_defconfig(void)
60 {
61         memset(&defaultConfig, 0, sizeof(defaultConfig));
62         defaultConfig.s_PicoOpt|= POPT_6BTN_PAD; // for xmen proto
63         defaultConfig.s_PicoCDBuffers = 0;
64         defaultConfig.Frameskip = 0;
65 }
66
67 void pemu_validate_config(void)
68 {
69 }
70
71 static int EmuScanBegin16(unsigned int num)
72 {
73         DrawLineDest = (unsigned short *) g_screen_ptr + g_screen_width * num;
74
75         return 0;
76 }
77
78 void pemu_loop_prep(void)
79 {
80         PicoDrawSetColorFormat(1);
81         PicoScanBegin = EmuScanBegin16;
82         pemu_sound_start();
83 }
84
85 void pemu_loop_end(void)
86 {
87         pemu_sound_stop();
88 }
89
90 void pemu_forced_frame(int opts)
91 {
92 }
93
94 void pemu_update_display(const char *fps, const char *notice_msg)
95 {
96         DirectScreen(g_screen_ptr);
97         DirectPresent();
98 }
99
100 void plat_video_wait_vsync(void)
101 {
102 }
103
104 void plat_video_toggle_renderer(int is_next, int force_16bpp, int is_menu)
105 {
106         // this will auto-select SMS/32X renderers
107         PicoDrawSetColorFormat(1);
108 }
109
110 void emu_video_mode_change(int start_line, int line_count, int is_32cols)
111 {
112         EmuScreenRect.left = is_32cols ? 32 : 0;
113         EmuScreenRect.right = is_32cols ? 256+32 : 320;
114         EmuScreenRect.top = start_line;
115         EmuScreenRect.bottom = start_line + line_count;
116
117         PostMessage(FrameWnd, WM_COMMAND, 0x20000 | 2000, 0);
118 }
119
120 static int sndbuff[2*44100/50/2 + 4];
121
122 static void update_sound(int len)
123 {
124         /* avoid writing audio when lagging behind to prevent audio lag */
125         if (PicoSkipFrame != 2)
126                 DSoundUpdate(sndbuff, (currentConfig.EmuOpt & EOPT_NO_FRMLIMIT) ? 0 : 1);
127 }
128
129 void pemu_sound_start(void)
130 {
131         int ret;
132
133         PsndOut = NULL;
134         currentConfig.EmuOpt &= ~EOPT_EXT_FRMLIMIT;
135
136         // prepare sound stuff
137         if (currentConfig.EmuOpt & EOPT_EN_SOUND)
138         {
139                 PsndRerate(0);
140
141                 ret = DSoundInit(FrameWnd, PsndRate, (PicoOpt & POPT_EN_STEREO) ? 1 : 0, PsndLen);
142                 if (ret != 0) {
143                         lprintf("dsound init failed\n");
144                         return;
145                 }
146
147                 PsndOut = (void *)sndbuff;
148                 PicoWriteSound = update_sound;
149                 currentConfig.EmuOpt |= EOPT_EXT_FRMLIMIT;
150         }
151 }
152
153 void pemu_sound_stop(void)
154 {
155         DSoundExit();
156 }
157
158 void pemu_sound_wait(void)
159 {
160 }
161
162 int plat_get_root_dir(char *dst, int len)
163 {
164         int ml;
165
166         ml = GetModuleFileName(NULL, dst, len);
167         while (ml > 0 && dst[ml] != '\\')
168                 ml--;
169         if (ml != 0)
170                 ml++;
171
172         dst[ml] = 0;
173         return ml;
174 }
175
176 void plat_status_msg_busy_first(const char *msg)
177 {
178 }
179
180 void plat_status_msg_busy_next(const char *msg)
181 {
182 }
183
184 void plat_status_msg_clear(void)
185 {
186 }
187
188 void plat_video_menu_enter(int is_rom_loaded)
189 {
190 }
191
192 void plat_video_menu_begin(void)
193 {
194 }
195
196 void plat_video_menu_end(void)
197 {
198 }
199
200 void plat_update_volume(int has_changed, int is_up)
201 {
202 }
203
204 const char *plat_get_credits(void)
205 {
206         return "PicoDrive v" VERSION " minibeta (c) notaz, 2006-2009\n\n"
207                 "Credits:\n"
208                 "fDave: base code of PicoDrive\n"
209                 "Chui: Fame/C\n"
210                 "NJ: CZ80\n"
211                 "MAME devs: YM2612, SN76496 and SH2 cores\n"
212                 "Stéphane Dallongeville: base of Fame/C (C68K), CZ80\n\n"
213                 "Special thanks (ideas, valuable information and stuff):\n"
214                 "Charles MacDonald, Eke, Exophase, Haze, Lordus, Nemesis,\n"
215                 "Pierpaolo Prazzoli, Rokas, Steve Snake, Tasco Deluxe.\n";
216 }
217
218 void plat_debug_cat(char *str)
219 {
220 }
221
222 // required by pico
223 int mp3_get_bitrate(FILE *f, int size)
224 {
225         return 128;
226 }
227
228 void mp3_start_play(FILE *f, int pos)
229 {
230 }
231
232 void mp3_update(int *buffer, int length, int stereo)
233 {
234 }
235
236 // other
237 void lprintf(const char *fmt, ...)
238 {
239   char buf[512];
240   va_list val;
241
242   va_start(val, fmt);
243   vsnprintf(buf, sizeof(buf), fmt, val);
244   va_end(val);
245   OutputDebugString(buf);
246   printf("%s", buf);
247 }
248
249 // fake
250 int alphasort() { return 0; }
251 int scandir() { return 0; }
252