revive pandora and win32 builds, rm gp2x dep for linux, lots of refactoring
[picodrive.git] / platform / gp2x / plat.c
CommitLineData
42171343 1#include <stdio.h>
2#include <stdlib.h>
1fb0dd88 3#include <string.h>
42171343 4#include <stdarg.h>
1fb0dd88 5
0d9bf4fc 6#include "plat_gp2x.h"
42171343 7#include "soc.h"
0d9bf4fc 8#include "warm.h"
1fb0dd88 9#include "../common/plat.h"
10#include "../common/readpng.h"
11#include "../common/menu.h"
e2de9939 12#include "../common/emu.h"
42171343 13#include "../linux/sndout_oss.h"
1fb0dd88 14
ee2a3bdf 15#include <pico/pico.h>
16
42171343 17/* GP2X local */
0d9bf4fc 18int default_cpu_clock;
42171343 19void *gp2x_screens[4];
20
21void gp2x_video_changemode(int bpp)
22{
23 gp2x_video_changemode_ll(bpp);
24
25 gp2x_memset_all_buffers(0, 0, 320*240*2);
26 gp2x_video_flip();
27}
28
29static void gp2x_memcpy_buffers(int buffers, void *data, int offset, int len)
30{
31 char *dst;
32 if (buffers & (1<<0)) { dst = (char *)gp2x_screens[0] + offset; if (dst != data) memcpy(dst, data, len); }
33 if (buffers & (1<<1)) { dst = (char *)gp2x_screens[1] + offset; if (dst != data) memcpy(dst, data, len); }
34 if (buffers & (1<<2)) { dst = (char *)gp2x_screens[2] + offset; if (dst != data) memcpy(dst, data, len); }
35 if (buffers & (1<<3)) { dst = (char *)gp2x_screens[3] + offset; if (dst != data) memcpy(dst, data, len); }
36}
37
38void gp2x_memcpy_all_buffers(void *data, int offset, int len)
39{
40 gp2x_memcpy_buffers(0xf, data, offset, len);
41}
42
43void gp2x_memset_all_buffers(int offset, int byte, int len)
44{
45 memset((char *)gp2x_screens[0] + offset, byte, len);
46 memset((char *)gp2x_screens[1] + offset, byte, len);
47 memset((char *)gp2x_screens[2] + offset, byte, len);
48 memset((char *)gp2x_screens[3] + offset, byte, len);
49}
50
0d9bf4fc 51void gp2x_make_fb_bufferable(int yes)
52{
53 int ret = 0;
54
55 yes = yes ? 1 : 0;
56 ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[0], 320*240*2);
57 ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[1], 320*240*2);
58 ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[2], 320*240*2);
59 ret |= warm_change_cb_range(WCB_B_BIT, yes, gp2x_screens[3], 320*240*2);
60
61 if (ret)
62 fprintf(stderr, "could not make fb buferable.\n");
63 else
64 printf("made fb buferable.\n");
65}
66
42171343 67/* common */
68char cpu_clk_name[16] = "GP2X CPU clocks";
1fb0dd88 69
70void plat_video_menu_enter(int is_rom_loaded)
71{
cc41eb4f 72 /* try to switch nicely avoiding tearing on Wiz */
73 gp2x_video_wait_vsync();
74 memset(gp2x_screens[0], 0, 320*240*2);
75 memset(gp2x_screens[1], 0, 320*240*2);
76 gp2x_video_flip2();
77 gp2x_video_wait_vsync();
78 gp2x_video_wait_vsync();
79
1fb0dd88 80 // switch to 16bpp
42171343 81 gp2x_video_changemode_ll(16);
1fb0dd88 82 gp2x_video_RGB_setscaling(0, 320, 240);
1fb0dd88 83}
84
85void plat_video_menu_begin(void)
86{
42171343 87 memcpy(g_screen_ptr, gp2x_screens[2], 320*240*2);
1fb0dd88 88}
89
90void plat_video_menu_end(void)
91{
42171343 92 // FIXME
93 // gp2x_video_flush_cache();
1fb0dd88 94 gp2x_video_flip2();
95}
96
ee2a3bdf 97void plat_early_init(void)
42171343 98{
99 gp2x_soc_t soc;
100
101 soc = soc_detect();
102 switch (soc)
103 {
104 case SOCID_MMSP2:
0d9bf4fc 105 default_cpu_clock = 200;
42171343 106 break;
107 case SOCID_POLLUX:
42171343 108 strcpy(cpu_clk_name, "Wiz CPU clock");
0d9bf4fc 109 default_cpu_clock = 533;
42171343 110 break;
111 default:
274f95a9 112 printf("could not recognize SoC, running in dummy mode.\n");
113 break;
42171343 114 }
ee2a3bdf 115}
116
117void plat_init(void)
118{
119 gp2x_soc_t soc;
120
121 soc = soc_detect();
122 switch (soc)
123 {
124 case SOCID_MMSP2:
125 mmsp2_init();
54646a39 126 menu_plat_setup(0);
ee2a3bdf 127 break;
128 case SOCID_POLLUX:
129 pollux_init();
130 menu_plat_setup(1);
131 break;
132 default:
274f95a9 133 dummy_init();
ee2a3bdf 134 break;
135 }
42171343 136
0d9bf4fc 137 warm_init();
138
42171343 139 gp2x_memset_all_buffers(0, 0, 320*240*2);
140
697746df 141 // use buffer2 for menubg (using only buffers 0, 1 in menu)
142 g_menubg_ptr = gp2x_screens[2];
143
42171343 144 // snd
145 sndout_oss_init();
146}
147
148void plat_finish(void)
149{
0d9bf4fc 150 gp2x_soc_t soc;
151
152 warm_finish();
153
154 soc = soc_detect();
155 switch (soc)
42171343 156 {
157 case SOCID_MMSP2:
158 mmsp2_finish();
159 break;
160 case SOCID_POLLUX:
161 pollux_finish();
162 break;
274f95a9 163 default:
164 dummy_finish();
165 break;
42171343 166 }
167
42171343 168 sndout_oss_exit();
169}
170
171void lprintf(const char *fmt, ...)
172{
173 va_list vl;
174
175 va_start(vl, fmt);
176 vprintf(fmt, vl);
177 va_end(vl);
178}
179