blob: 78629c07f97727fe8476abb2ff373de4d597042a [file] [log] [blame]
balrog64b40bc2008-11-04 09:04:41 +00001/*
2 * Toshiba TC6393XB I/O Controller.
3 * Found in Sharp Zaurus SL-6000 (tosa) or some
4 * Toshiba e-Series PDAs.
5 *
6 * FB support code. Based on G364 fb emulator
7 *
Stefan Weilbcc4e412011-12-02 10:30:41 +01008 * Copyright (c) 2007 Hervé Poussineau
balrog64b40bc2008-11-04 09:04:41 +00009 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License as
12 * published by the Free Software Foundation; either version 2 of
13 * the License, or (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
aurel32fad6cb12009-01-04 22:05:52 +000020 * You should have received a copy of the GNU General Public License along
Blue Swirl8167ee82009-07-16 20:47:01 +000021 * with this program; if not, see <http://www.gnu.org/licenses/>.
balrog64b40bc2008-11-04 09:04:41 +000022 */
23
24#if BITS == 8
Paolo Bonzini2cdaca92014-01-31 14:47:33 +000025# define SET_PIXEL(addr, color) (*(uint8_t *)addr = color)
balrog64b40bc2008-11-04 09:04:41 +000026#elif BITS == 15 || BITS == 16
Paolo Bonzini2cdaca92014-01-31 14:47:33 +000027# define SET_PIXEL(addr, color) (*(uint16_t *)addr = color)
balrog64b40bc2008-11-04 09:04:41 +000028#elif BITS == 24
Paolo Bonzini2cdaca92014-01-31 14:47:33 +000029# define SET_PIXEL(addr, color) \
30 do { \
31 addr[0] = color; \
32 addr[1] = (color) >> 8; \
33 addr[2] = (color) >> 16; \
34 } while (0)
balrog64b40bc2008-11-04 09:04:41 +000035#elif BITS == 32
Paolo Bonzini2cdaca92014-01-31 14:47:33 +000036# define SET_PIXEL(addr, color) (*(uint32_t *)addr = color)
balrog64b40bc2008-11-04 09:04:41 +000037#else
38# error unknown bit depth
39#endif
40
41
Paul Brookbc24a222009-05-10 01:44:56 +010042static void glue(tc6393xb_draw_graphic, BITS)(TC6393xbState *s)
balrog64b40bc2008-11-04 09:04:41 +000043{
Gerd Hoffmannc78f7132013-03-05 15:24:14 +010044 DisplaySurface *surface = qemu_console_surface(s->con);
balrog64b40bc2008-11-04 09:04:41 +000045 int i;
balrog64b40bc2008-11-04 09:04:41 +000046 uint16_t *data_buffer;
47 uint8_t *data_display;
48
pbrook44654492009-04-10 00:26:15 +000049 data_buffer = s->vram_ptr;
Gerd Hoffmannc78f7132013-03-05 15:24:14 +010050 data_display = surface_data(surface);
balrog64b40bc2008-11-04 09:04:41 +000051 for(i = 0; i < s->scr_height; i++) {
52#if (BITS == 16)
53 memcpy(data_display, data_buffer, s->scr_width * 2);
54 data_buffer += s->scr_width;
Gerd Hoffmannc78f7132013-03-05 15:24:14 +010055 data_display += surface_stride(surface);
balrog64b40bc2008-11-04 09:04:41 +000056#else
57 int j;
58 for (j = 0; j < s->scr_width; j++, data_display += BITS / 8, data_buffer++) {
59 uint16_t color = *data_buffer;
60 uint32_t dest_color = glue(rgb_to_pixel, BITS)(
61 ((color & 0xf800) * 0x108) >> 11,
62 ((color & 0x7e0) * 0x41) >> 9,
63 ((color & 0x1f) * 0x21) >> 2
64 );
65 SET_PIXEL(data_display, dest_color);
66 }
67#endif
68 }
69}
70
71#undef BITS
72#undef SET_PIXEL