major menu unification, minor reorganization
[libpicofe.git] / pandora / pandora.c
CommitLineData
fe017393 1\r
2#include <stdio.h>\r
3#include <stdlib.h>\r
4#include <stdarg.h>\r
5#include <string.h>\r
6#include <unistd.h>\r
7#include <sys/mman.h>\r
8#include <sys/types.h>\r
9#include <sys/stat.h>\r
f7c40368 10#include <linux/fb.h>\r
fe017393 11#include <fcntl.h>\r
12#include <errno.h>\r
13\r
14#include "../gp2x/gp2x.h"\r
b3972d82 15#include "../linux/sndout_oss.h"\r
095a240b 16#include "../common/arm_linux.h"\r
fe017393 17\r
f7c40368 18static volatile unsigned int *memregs = MAP_FAILED;\r
fe017393 19//static\r
20int memdev = 0;\r
b3972d82 21static int fbdev = -1;\r
fe017393 22\r
de9b1274 23#define SCREEN_MAP_SIZE (800*480*2)\r
f7c40368 24static void *screen = MAP_FAILED;\r
fe017393 25void *gp2x_screen;\r
26\r
fe017393 27\r
28/* video stuff */\r
29void gp2x_video_flip(void)\r
30{\r
fe017393 31}\r
32\r
33/* doulblebuffered flip */\r
34void gp2x_video_flip2(void)\r
35{\r
fe017393 36}\r
37\r
38\r
39void gp2x_video_changemode2(int bpp)\r
40{\r
fe017393 41}\r
42\r
43\r
44void gp2x_video_changemode(int bpp)\r
45{\r
fe017393 46}\r
47\r
48\r
49void gp2x_video_setpalette(int *pal, int len)\r
50{\r
fe017393 51}\r
52\r
53\r
fe017393 54void gp2x_video_RGB_setscaling(int ln_offs, int W, int H)\r
55{\r
fe017393 56}\r
57\r
58\r
59void gp2x_video_wait_vsync(void)\r
60{\r
fe017393 61}\r
62\r
fe017393 63void gp2x_video_flush_cache(void)\r
64{\r
095a240b 65// cache_flush_d_inval_i(gp2x_screen, (char *)gp2x_screen + 320*240*2, 0);\r
fe017393 66}\r
67\r
fe017393 68void gp2x_memcpy_buffers(int buffers, void *data, int offset, int len)\r
69{\r
fe017393 70}\r
71\r
72\r
73void gp2x_memcpy_all_buffers(void *data, int offset, int len)\r
74{\r
fe017393 75}\r
76\r
77\r
78void gp2x_memset_all_buffers(int offset, int byte, int len)\r
79{\r
492d353a 80 memset((char *)gp2x_screen + offset, byte, len);\r
fe017393 81}\r
82\r
83\r
84void gp2x_pd_clone_buffer2(void)\r
85{\r
095a240b 86 memset(gp2x_screen, 0, 800*480*2);\r
fe017393 87}\r
88\r
b3972d82 89// FIXME\r
90#if 0\r
91static int touchcal[7] = { 6203, 0, -1501397, 0, -4200, 16132680, 65536 };\r
92\r
fe017393 93typedef struct ucb1x00_ts_event\r
94{\r
95 unsigned short pressure;\r
96 unsigned short x;\r
97 unsigned short y;\r
98 unsigned short pad;\r
99 struct timeval stamp;\r
100} UCB1X00_TS_EVENT;\r
101\r
102int gp2x_touchpad_read(int *x, int *y)\r
103{\r
104 UCB1X00_TS_EVENT event;\r
105 static int zero_seen = 0;\r
106 int retval;\r
107\r
108 if (touchdev < 0) return -1;\r
109\r
110 retval = read(touchdev, &event, sizeof(event));\r
111 if (retval <= 0) {\r
112 printf("touch read failed %i %i\n", retval, errno);\r
113 return -1;\r
114 }\r
115 // this is to ignore the messed-up 4.1.x driver\r
116 if (event.pressure == 0) zero_seen = 1;\r
117\r
118 if (x) *x = (event.x * touchcal[0] + touchcal[2]) >> 16;\r
119 if (y) *y = (event.y * touchcal[4] + touchcal[5]) >> 16;\r
120 // printf("read %i %i %i\n", event.pressure, *x, *y);\r
121\r
122 return zero_seen ? event.pressure : 0;\r
123}\r
b3972d82 124#else\r
125int gp2x_touchpad_read(int *x, int *y) { return -1; }\r
492d353a 126#endif\r
fe017393 127\r
128/* common */\r
129void gp2x_init(void)\r
130{\r
131 printf("entering init()\n"); fflush(stdout);\r
132\r
133 memdev = open("/dev/mem", O_RDWR);\r
134 if (memdev == -1)\r
135 {\r
b3972d82 136 perror("open(\"/dev/mem\")");\r
fe017393 137 exit(1);\r
138 }\r
f7c40368 139/*\r
492d353a 140 memregs = mmap(0, 0x01000000, PROT_READ|PROT_WRITE, MAP_SHARED, memdev, 0x48000000);\r
141 if (memregs == MAP_FAILED)\r
fe017393 142 {\r
143 printf("mmap(memregs) failed with %i\n", errno);\r
144 exit(1);\r
145 }\r
f7c40368 146*/\r
8add01a3 147 fbdev = open("/dev/fb0", O_RDWR);\r
148 if (fbdev == -1)\r
149 {\r
b3972d82 150 perror("open(\"/dev/fb0\")");\r
f7c40368 151 exit(1);\r
152 }\r
153\r
492d353a 154 screen = mmap(0, SCREEN_MAP_SIZE, PROT_WRITE|PROT_READ, MAP_SHARED, fbdev, 0);\r
155 if (screen == MAP_FAILED)\r
156 {\r
b3972d82 157 perror("mmap(fbptr)");\r
492d353a 158 exit(1);\r
159 }\r
160 printf("fbptr %p\n", screen);\r
de9b1274 161 gp2x_screen = screen;\r
fe017393 162\r
fe017393 163 // snd\r
b3972d82 164 sndout_oss_init();\r
fe017393 165\r
fe017393 166 printf("exitting init()\n"); fflush(stdout);\r
167}\r
168\r
fe017393 169void gp2x_deinit(void)\r
170{\r
f7c40368 171 if (screen != MAP_FAILED)\r
172 munmap(screen, SCREEN_MAP_SIZE);\r
173 if (memregs != MAP_FAILED)\r
174 munmap((void *)memregs, 0x10000);\r
fe017393 175 close(memdev);\r
f7c40368 176 if (fbdev >= 0) close(fbdev);\r
fe017393 177\r
b3972d82 178 sndout_oss_exit();\r
fe017393 179\r
492d353a 180 printf("all done");\r
fe017393 181}\r
182\r
183/* lprintf */\r
184void lprintf(const char *fmt, ...)\r
185{\r
186 va_list vl;\r
187\r
188 va_start(vl, fmt);\r
189 vprintf(fmt, vl);\r
190 va_end(vl);\r
191}\r
192\r
193\r
194/* fake GP2X */\r
195int crashed_940 = 0;\r
196\r
fe017393 197void set_gamma(int g100, int A_SNs_curve) {}\r
198void set_FCLK(unsigned MHZ) {}\r
199void set_LCD_custom_rate(int rate) {}\r
200void unset_LCD_custom_rate(void) {}\r
492d353a 201void Pause940(int yes) {}\r
202void Reset940(int yes, int bank) {}\r
fe017393 203\r