blank dos build
[retrobench] / src / rbench.c
1 #include <stdio.h>
2 #include <stdlib.h>
3 #include <math.h>
4 #include "rbench.h"
5 #include "treestor.h"
6 #include "util.h"
7
8 #define DEF_WIDTH       640
9 #define DEF_HEIGHT      480
10 #define DEF_BPP         24
11
12 struct options opt = {
13         DEF_WIDTH, DEF_HEIGHT, DEF_BPP
14 };
15
16 int fb_width, fb_height, fb_bpp, fb_pitch;
17 int fb_rshift, fb_gshift, fb_bshift;
18 unsigned int fb_rmask, fb_gmask, fb_bmask;
19 void *framebuf;
20 unsigned int time_msec;
21
22 int init(void)
23 {
24         printf("initialized graphics %dx%d %dbpp\n", fb_width, fb_height, fb_bpp);
25         printf("  rgb mask: %x %x %x\n", fb_rmask, fb_gmask, fb_bmask);
26         printf("  rgb shift: %d %d %d\n", fb_rshift, fb_gshift, fb_bshift);
27         return 0;
28 }
29
30 void cleanup(void)
31 {
32 }
33
34 #define XORRGB(x, y, zoom, r, g, b) \
35         do { \
36                 int xor = (((x) - fb_width/2) * (zoom) >> 10) ^ (((y) - fb_height/2) * (zoom) >> 10); \
37                 (r) = xor >> 2; \
38                 (g) = xor >> 1; \
39                 (b) = xor; \
40         } while(0)
41
42 void redraw(void)
43 {
44         int i, j, r, g, b, xoffs, yoffs, zoom;
45         unsigned char *fbptr;
46         uint16_t *fbptr16;
47         uint32_t *fbptr32;
48
49         xoffs = COS(time_msec >> 5) * fb_width >> 7;
50         yoffs = SIN(time_msec >> 4) * fb_height >> 8;
51         zoom = ((SIN(time_msec >> 4) + 256) << 1) + 512;
52
53         switch(fb_bpp) {
54         case 15:
55         case 16:
56                 fbptr16 = framebuf;
57                 for(i=0; i<fb_height; i++) {
58                         for(j=0; j<fb_width; j++) {
59                                 XORRGB(j + xoffs, i + yoffs, zoom, r, g, b);
60                                 *fbptr16++ = (((r >> 3) << fb_rshift) & fb_rmask) |
61                                         (((g >> 2) << fb_gshift) & fb_gmask) |
62                                         (((b >> 3) << fb_bshift) & fb_bmask);
63                         }
64                         fbptr16 += (fb_pitch >> 1) - fb_width;
65                 }
66                 break;
67
68         case 24:
69                 fbptr = framebuf;
70                 for(i=0; i<fb_height; i++) {
71                         for(j=0; j<fb_width; j++) {
72                                 XORRGB(j + xoffs, i + yoffs, zoom, r, g, b);
73                                 *fbptr++ = r;
74                                 *fbptr++ = g;
75                                 *fbptr++ = b;
76                         }
77                         fbptr += fb_pitch - fb_width * 3;
78                 }
79                 break;
80
81         case 32:
82                 fbptr32 = framebuf;
83                 for(i=0; i<fb_height; i++) {
84                         for(j=0; j<fb_width; j++) {
85                                 XORRGB(j + xoffs, i + yoffs, zoom, r, g, b);
86                                 *fbptr32++ = (((r) << fb_rshift) & fb_rmask) |
87                                         (((g) << fb_gshift) & fb_gmask) |
88                                         (((b) << fb_bshift) & fb_bmask);
89                         }
90                         fbptr32 += (fb_pitch >> 2) - fb_width;
91                 }
92                 break;
93         }
94 }
95
96 void key_event(int key, int press)
97 {
98 }
99
100 int read_config(const char *fname)
101 {
102         FILE *fp;
103         struct ts_node *ts;
104
105         if(!(fp = fopen(fname, "rb"))) {
106                 return -1;
107         }
108         fclose(fp);
109
110         if(!(ts = ts_load(fname))) {
111                 return -1;
112         }
113
114         opt.width = ts_lookup_int(ts, "rbench.width", DEF_WIDTH);
115         opt.height = ts_lookup_int(ts, "rbench.height", DEF_HEIGHT);
116         opt.bpp = ts_lookup_int(ts, "rbench.bpp", DEF_BPP);
117
118         ts_free_tree(ts);
119         return 0;
120 }