]> git.proxmox.com Git - qemu.git/blame - console.h
scsi: fix incorrect ?: use
[qemu.git] / console.h
CommitLineData
87ecb68b
PB
1#ifndef CONSOLE_H
2#define CONSOLE_H
3
4#include "qemu-char.h"
d54908a5 5#include "qdict.h"
87ecb68b
PB
6
7/* keyboard/mouse support */
8
9#define MOUSE_EVENT_LBUTTON 0x01
10#define MOUSE_EVENT_RBUTTON 0x02
11#define MOUSE_EVENT_MBUTTON 0x04
12
7ed9eba3
AL
13/* in ms */
14#define GUI_REFRESH_INTERVAL 30
15
87ecb68b
PB
16typedef void QEMUPutKBDEvent(void *opaque, int keycode);
17typedef void QEMUPutMouseEvent(void *opaque, int dx, int dy, int dz, int buttons_state);
18
19typedef struct QEMUPutMouseEntry {
20 QEMUPutMouseEvent *qemu_put_mouse_event;
21 void *qemu_put_mouse_event_opaque;
22 int qemu_put_mouse_event_absolute;
23 char *qemu_put_mouse_event_name;
24
25 /* used internally by qemu for handling mice */
26 struct QEMUPutMouseEntry *next;
27} QEMUPutMouseEntry;
28
29void qemu_add_kbd_event_handler(QEMUPutKBDEvent *func, void *opaque);
30QEMUPutMouseEntry *qemu_add_mouse_event_handler(QEMUPutMouseEvent *func,
31 void *opaque, int absolute,
32 const char *name);
33void qemu_remove_mouse_event_handler(QEMUPutMouseEntry *entry);
34
35void kbd_put_keycode(int keycode);
36void kbd_mouse_event(int dx, int dy, int dz, int buttons_state);
37int kbd_mouse_is_absolute(void);
38
bc24a225 39struct MouseTransformInfo {
a5d7eb65
AZ
40 /* Touchscreen resolution */
41 int x;
42 int y;
43 /* Calibration values as used/generated by tslib */
44 int a[7];
45};
46
376253ec 47void do_info_mice(Monitor *mon);
d54908a5 48void do_mouse_set(Monitor *mon, const QDict *qdict);
87ecb68b
PB
49
50/* keysym is a unicode code except for special keys (see QEMU_KEY_xxx
51 constants) */
52#define QEMU_KEY_ESC1(c) ((c) | 0xe100)
53#define QEMU_KEY_BACKSPACE 0x007f
54#define QEMU_KEY_UP QEMU_KEY_ESC1('A')
55#define QEMU_KEY_DOWN QEMU_KEY_ESC1('B')
56#define QEMU_KEY_RIGHT QEMU_KEY_ESC1('C')
57#define QEMU_KEY_LEFT QEMU_KEY_ESC1('D')
58#define QEMU_KEY_HOME QEMU_KEY_ESC1(1)
59#define QEMU_KEY_END QEMU_KEY_ESC1(4)
60#define QEMU_KEY_PAGEUP QEMU_KEY_ESC1(5)
61#define QEMU_KEY_PAGEDOWN QEMU_KEY_ESC1(6)
62#define QEMU_KEY_DELETE QEMU_KEY_ESC1(3)
63
64#define QEMU_KEY_CTRL_UP 0xe400
65#define QEMU_KEY_CTRL_DOWN 0xe401
66#define QEMU_KEY_CTRL_LEFT 0xe402
67#define QEMU_KEY_CTRL_RIGHT 0xe403
68#define QEMU_KEY_CTRL_HOME 0xe404
69#define QEMU_KEY_CTRL_END 0xe405
70#define QEMU_KEY_CTRL_PAGEUP 0xe406
71#define QEMU_KEY_CTRL_PAGEDOWN 0xe407
72
73void kbd_put_keysym(int keysym);
74
75/* consoles */
76
7d957bd8
AL
77#define QEMU_BIG_ENDIAN_FLAG 0x01
78#define QEMU_ALLOCATED_FLAG 0x02
c18a2c36 79#define QEMU_REALPIXELS_FLAG 0x04
7d957bd8
AL
80
81struct PixelFormat {
82 uint8_t bits_per_pixel;
83 uint8_t bytes_per_pixel;
84 uint8_t depth; /* color depth in bits */
85 uint32_t rmask, gmask, bmask, amask;
86 uint8_t rshift, gshift, bshift, ashift;
87 uint8_t rmax, gmax, bmax, amax;
90a1e3c0 88 uint8_t rbits, gbits, bbits, abits;
7d957bd8
AL
89};
90
91struct DisplaySurface {
92 uint8_t flags;
87ecb68b
PB
93 int width;
94 int height;
7d957bd8
AL
95 int linesize; /* bytes per line */
96 uint8_t *data;
97
98 struct PixelFormat pf;
99};
100
101struct DisplayChangeListener {
102 int idle;
f442e08b 103 uint64_t gui_timer_interval;
87ecb68b
PB
104
105 void (*dpy_update)(struct DisplayState *s, int x, int y, int w, int h);
7d957bd8
AL
106 void (*dpy_resize)(struct DisplayState *s);
107 void (*dpy_setdata)(struct DisplayState *s);
87ecb68b
PB
108 void (*dpy_refresh)(struct DisplayState *s);
109 void (*dpy_copy)(struct DisplayState *s, int src_x, int src_y,
110 int dst_x, int dst_y, int w, int h);
111 void (*dpy_fill)(struct DisplayState *s, int x, int y,
112 int w, int h, uint32_t c);
4d3b6f6e 113 void (*dpy_text_cursor)(struct DisplayState *s, int x, int y);
7d957bd8
AL
114
115 struct DisplayChangeListener *next;
116};
117
7b5d76da
AL
118struct DisplayAllocator {
119 DisplaySurface* (*create_displaysurface)(int width, int height);
120 DisplaySurface* (*resize_displaysurface)(DisplaySurface *surface, int width, int height);
121 void (*free_displaysurface)(DisplaySurface *surface);
122};
123
7d957bd8
AL
124struct DisplayState {
125 struct DisplaySurface *surface;
126 void *opaque;
127 struct QEMUTimer *gui_timer;
128
7b5d76da 129 struct DisplayAllocator* allocator;
7d957bd8
AL
130 struct DisplayChangeListener* listeners;
131
87ecb68b
PB
132 void (*mouse_set)(int x, int y, int on);
133 void (*cursor_define)(int width, int height, int bpp, int hot_x, int hot_y,
134 uint8_t *image, uint8_t *mask);
3023f332
AL
135
136 struct DisplayState *next;
87ecb68b
PB
137};
138
3023f332
AL
139void register_displaystate(DisplayState *ds);
140DisplayState *get_displaystate(void);
7d957bd8
AL
141DisplaySurface* qemu_create_displaysurface_from(int width, int height, int bpp,
142 int linesize, uint8_t *data);
0da2ea1b 143PixelFormat qemu_different_endianness_pixelformat(int bpp);
144PixelFormat qemu_default_pixelformat(int bpp);
7d957bd8 145
7b5d76da
AL
146extern struct DisplayAllocator default_allocator;
147DisplayAllocator *register_displayallocator(DisplayState *ds, DisplayAllocator *da);
148DisplaySurface* defaultallocator_create_displaysurface(int width, int height);
149DisplaySurface* defaultallocator_resize_displaysurface(DisplaySurface *surface, int width, int height);
150void defaultallocator_free_displaysurface(DisplaySurface *surface);
151
152static inline DisplaySurface* qemu_create_displaysurface(DisplayState *ds, int width, int height)
153{
154 return ds->allocator->create_displaysurface(width, height);
155}
156
157static inline DisplaySurface* qemu_resize_displaysurface(DisplayState *ds, int width, int height)
158{
159 return ds->allocator->resize_displaysurface(ds->surface, width, height);
160}
161
162static inline void qemu_free_displaysurface(DisplayState *ds)
163{
164 ds->allocator->free_displaysurface(ds->surface);
165}
166
167static inline int is_surface_bgr(DisplaySurface *surface)
168{
169 if (surface->pf.bits_per_pixel == 32 && surface->pf.rshift == 0)
170 return 1;
171 else
172 return 0;
173}
174
7d957bd8
AL
175static inline int is_buffer_shared(DisplaySurface *surface)
176{
c18a2c36
SS
177 return (!(surface->flags & QEMU_ALLOCATED_FLAG) &&
178 !(surface->flags & QEMU_REALPIXELS_FLAG));
7d957bd8
AL
179}
180
181static inline void register_displaychangelistener(DisplayState *ds, DisplayChangeListener *dcl)
182{
183 dcl->next = ds->listeners;
184 ds->listeners = dcl;
185}
186
87ecb68b
PB
187static inline void dpy_update(DisplayState *s, int x, int y, int w, int h)
188{
7d957bd8
AL
189 struct DisplayChangeListener *dcl = s->listeners;
190 while (dcl != NULL) {
191 dcl->dpy_update(s, x, y, w, h);
192 dcl = dcl->next;
193 }
87ecb68b
PB
194}
195
7d957bd8 196static inline void dpy_resize(DisplayState *s)
87ecb68b 197{
7d957bd8
AL
198 struct DisplayChangeListener *dcl = s->listeners;
199 while (dcl != NULL) {
200 dcl->dpy_resize(s);
201 dcl = dcl->next;
202 }
87ecb68b
PB
203}
204
7d957bd8 205static inline void dpy_setdata(DisplayState *s)
4d3b6f6e 206{
7d957bd8
AL
207 struct DisplayChangeListener *dcl = s->listeners;
208 while (dcl != NULL) {
209 if (dcl->dpy_setdata) dcl->dpy_setdata(s);
210 dcl = dcl->next;
211 }
212}
213
214static inline void dpy_refresh(DisplayState *s)
215{
216 struct DisplayChangeListener *dcl = s->listeners;
217 while (dcl != NULL) {
218 if (dcl->dpy_refresh) dcl->dpy_refresh(s);
219 dcl = dcl->next;
220 }
221}
222
223static inline void dpy_copy(struct DisplayState *s, int src_x, int src_y,
224 int dst_x, int dst_y, int w, int h) {
225 struct DisplayChangeListener *dcl = s->listeners;
226 while (dcl != NULL) {
227 if (dcl->dpy_copy)
228 dcl->dpy_copy(s, src_x, src_y, dst_x, dst_y, w, h);
229 else /* TODO */
230 dcl->dpy_update(s, dst_x, dst_y, w, h);
231 dcl = dcl->next;
232 }
233}
234
235static inline void dpy_fill(struct DisplayState *s, int x, int y,
236 int w, int h, uint32_t c) {
237 struct DisplayChangeListener *dcl = s->listeners;
238 while (dcl != NULL) {
239 if (dcl->dpy_fill) dcl->dpy_fill(s, x, y, w, h, c);
240 dcl = dcl->next;
241 }
242}
243
244static inline void dpy_cursor(struct DisplayState *s, int x, int y) {
245 struct DisplayChangeListener *dcl = s->listeners;
246 while (dcl != NULL) {
247 if (dcl->dpy_text_cursor) dcl->dpy_text_cursor(s, x, y);
248 dcl = dcl->next;
249 }
4d3b6f6e
AZ
250}
251
0e1f5a0c
AL
252static inline int ds_get_linesize(DisplayState *ds)
253{
7d957bd8 254 return ds->surface->linesize;
0e1f5a0c
AL
255}
256
257static inline uint8_t* ds_get_data(DisplayState *ds)
258{
7d957bd8 259 return ds->surface->data;
0e1f5a0c
AL
260}
261
262static inline int ds_get_width(DisplayState *ds)
263{
7d957bd8 264 return ds->surface->width;
0e1f5a0c
AL
265}
266
267static inline int ds_get_height(DisplayState *ds)
268{
7d957bd8 269 return ds->surface->height;
0e1f5a0c
AL
270}
271
272static inline int ds_get_bits_per_pixel(DisplayState *ds)
273{
7d957bd8 274 return ds->surface->pf.bits_per_pixel;
0e1f5a0c
AL
275}
276
8927bcfd
AL
277static inline int ds_get_bytes_per_pixel(DisplayState *ds)
278{
7d957bd8 279 return ds->surface->pf.bytes_per_pixel;
8927bcfd
AL
280}
281
c227f099
AL
282typedef unsigned long console_ch_t;
283static inline void console_write_ch(console_ch_t *dest, uint32_t ch)
4d3b6f6e
AZ
284{
285 cpu_to_le32wu((uint32_t *) dest, ch);
286}
287
87ecb68b
PB
288typedef void (*vga_hw_update_ptr)(void *);
289typedef void (*vga_hw_invalidate_ptr)(void *);
290typedef void (*vga_hw_screen_dump_ptr)(void *, const char *);
c227f099 291typedef void (*vga_hw_text_update_ptr)(void *, console_ch_t *);
87ecb68b 292
3023f332
AL
293DisplayState *graphic_console_init(vga_hw_update_ptr update,
294 vga_hw_invalidate_ptr invalidate,
295 vga_hw_screen_dump_ptr screen_dump,
296 vga_hw_text_update_ptr text_update,
297 void *opaque);
298
87ecb68b
PB
299void vga_hw_update(void);
300void vga_hw_invalidate(void);
301void vga_hw_screen_dump(const char *filename);
c227f099 302void vga_hw_text_update(console_ch_t *chardata);
87ecb68b
PB
303
304int is_graphic_console(void);
c21bbcfa 305int is_fixedsize_console(void);
6ea314d9 306CharDriverState *text_console_init(QemuOpts *opts);
2796dae0 307void text_consoles_set_display(DisplayState *ds);
87ecb68b
PB
308void console_select(unsigned int index);
309void console_color_init(DisplayState *ds);
3023f332
AL
310void qemu_console_resize(DisplayState *ds, int width, int height);
311void qemu_console_copy(DisplayState *ds, int src_x, int src_y,
312 int dst_x, int dst_y, int w, int h);
87ecb68b
PB
313
314/* sdl.c */
315void sdl_display_init(DisplayState *ds, int full_screen, int no_frame);
316
317/* cocoa.m */
318void cocoa_display_init(DisplayState *ds, int full_screen);
319
320/* vnc.c */
321void vnc_display_init(DisplayState *ds);
322void vnc_display_close(DisplayState *ds);
323int vnc_display_open(DisplayState *ds, const char *display);
324int vnc_display_password(DisplayState *ds, const char *password);
376253ec 325void do_info_vnc(Monitor *mon);
f92f8afe 326char *vnc_display_local_addr(DisplayState *ds);
87ecb68b 327
4d3b6f6e
AZ
328/* curses.c */
329void curses_display_init(DisplayState *ds, int full_screen);
330
87ecb68b 331#endif