wsconsio.h revision 1.69
1/* $OpenBSD: wsconsio.h,v 1.69 2013/11/17 13:41:26 kettenis Exp $ */ 2/* $NetBSD: wsconsio.h,v 1.74 2005/04/28 07:15:44 martin Exp $ */ 3 4/* 5 * Copyright (c) 1996, 1997 Christopher G. Demetriou. All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 3. All advertising materials mentioning features or use of this software 16 * must display the following acknowledgement: 17 * This product includes software developed by Christopher G. Demetriou 18 * for the NetBSD Project. 19 * 4. The name of the author may not be used to endorse or promote products 20 * derived from this software without specific prior written permission 21 * 22 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 23 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 24 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 25 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 27 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 31 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 32 */ 33 34#ifndef _DEV_WSCONS_WSCONSIO_H_ 35#define _DEV_WSCONS_WSCONSIO_H_ 36 37/* 38 * WSCONS (wsdisplay, wskbd, wsmouse) exported interfaces. 39 * 40 * Ioctls are all in group 'W'. Ioctl number space is partitioned like: 41 * 0-31 keyboard ioctls (WSKBDIO) 42 * 32-63 mouse ioctls (WSMOUSEIO) 43 * 64-95 display ioctls (WSDISPLAYIO) 44 * 96-127 mux ioctls (WSMUXIO) 45 * 128-159 driver private ioctls 46 * 160-255 reserved for future use 47 */ 48 49#include <sys/types.h> 50#include <sys/ioccom.h> 51#include <dev/wscons/wsksymvar.h> 52 53#include <sys/pciio.h> 54 55#define WSSCREEN_NAME_SIZE 16 56#define WSEMUL_NAME_SIZE 16 57#define WSFONT_NAME_SIZE 16 58 59/* 60 * Common event structure (used by keyboard and mouse) 61 */ 62struct wscons_event { 63 u_int type; 64 int value; 65 struct timespec time; 66}; 67 68/* Event type definitions. Comment for each is information in value. */ 69#define WSCONS_EVENT_KEY_UP 1 /* key code */ 70#define WSCONS_EVENT_KEY_DOWN 2 /* key code */ 71#define WSCONS_EVENT_ALL_KEYS_UP 3 /* void */ 72#define WSCONS_EVENT_MOUSE_UP 4 /* button # (leftmost = 0) */ 73#define WSCONS_EVENT_MOUSE_DOWN 5 /* button # (leftmost = 0) */ 74#define WSCONS_EVENT_MOUSE_DELTA_X 6 /* X delta amount */ 75#define WSCONS_EVENT_MOUSE_DELTA_Y 7 /* Y delta amount */ 76#define WSCONS_EVENT_MOUSE_ABSOLUTE_X 8 /* X location */ 77#define WSCONS_EVENT_MOUSE_ABSOLUTE_Y 9 /* Y location */ 78#define WSCONS_EVENT_MOUSE_DELTA_Z 10 /* Z delta amount */ 79#define WSCONS_EVENT_MOUSE_ABSOLUTE_Z 11 /* Z location */ 80 /* 12-15, see below */ 81#define WSCONS_EVENT_MOUSE_DELTA_W 16 /* W delta amount */ 82#define WSCONS_EVENT_MOUSE_ABSOLUTE_W 17 /* W location */ 83#define WSCONS_EVENT_SYNC 18 84/* 85 * Following events are not real wscons_event but are used as parameters of the 86 * WSDISPLAYIO_WSMOUSED ioctl 87 */ 88#define WSCONS_EVENT_WSMOUSED_ON 12 /* wsmoused(8) active */ 89#define WSCONS_EVENT_WSMOUSED_OFF 13 /* wsmoused(8) inactive */ 90#define WSCONS_EVENT_WSMOUSED_SLEEP 14 /* wsmoused(8) sleeping */ 91#define WSCONS_EVENT_WSMOUSED_CLOSE 15 /* notify wsmoused(8) to close 92 mouse device */ 93 94#define IS_MOTION_EVENT(type) (((type) == WSCONS_EVENT_MOUSE_DELTA_X) || \ 95 ((type) == WSCONS_EVENT_MOUSE_DELTA_Y) || \ 96 ((type) == WSCONS_EVENT_MOUSE_DELTA_Z) || \ 97 ((type) == WSCONS_EVENT_MOUSE_DELTA_W)) 98#define IS_BUTTON_EVENT(type) (((type) == WSCONS_EVENT_MOUSE_UP) || \ 99 ((type) == WSCONS_EVENT_MOUSE_DOWN)) 100#define IS_CTRL_EVENT(type) ((type == WSCONS_EVENT_WSMOUSED_ON) || \ 101 (type == WSCONS_EVENT_WSMOUSED_OFF)|| \ 102 (type == WSCONS_EVENT_WSMOUSED_SLEEP)) 103 104/* 105 * Keyboard ioctls (0 - 31) 106 */ 107 108/* Get keyboard type. */ 109#define WSKBDIO_GTYPE _IOR('W', 0, u_int) 110#define WSKBD_TYPE_LK201 1 /* lk-201 */ 111#define WSKBD_TYPE_LK401 2 /* lk-401 */ 112#define WSKBD_TYPE_PC_XT 3 /* PC-ish, XT scancode */ 113#define WSKBD_TYPE_PC_AT 4 /* PC-ish, AT scancode */ 114#define WSKBD_TYPE_USB 5 /* USB, XT scancode */ 115#define WSKBD_TYPE_NEXT 6 /* NeXT keyboard */ 116#define WSKBD_TYPE_HPC_KBD 7 /* HPC builtin keyboard */ 117#define WSKBD_TYPE_HPC_BTN 8 /* HPC/PsPC buttons */ 118#define WSKBD_TYPE_ARCHIMEDES 9 /* Archimedes keyboard */ 119#define WSKBD_TYPE_ADB 10 /* Apple ADB keyboard */ 120#define WSKBD_TYPE_SUN 11 /* Sun Type3/4 */ 121#define WSKBD_TYPE_SUN5 12 /* Sun Type5 */ 122#define WSKBD_TYPE_HIL 13 /* HP HIL */ 123#define WSKBD_TYPE_GSC 14 /* HP PS/2 */ 124#define WSKBD_TYPE_LUNA 15 /* OMRON Luna */ 125#define WSKBD_TYPE_ZAURUS 16 /* Sharp Zaurus */ 126#define WSKBD_TYPE_DOMAIN 17 /* Apollo Domain */ 127#define WSKBD_TYPE_BLUETOOTH 18 /* Bluetooth keyboard */ 128#define WSKBD_TYPE_KPC 19 /* Palm keypad */ 129#define WSKBD_TYPE_SGI 20 /* SGI serial keyboard */ 130 131/* Manipulate the keyboard bell. */ 132struct wskbd_bell_data { 133 u_int which; /* values to get/set */ 134 u_int pitch; /* pitch, in Hz */ 135 u_int period; /* period, in milliseconds */ 136 u_int volume; /* percentage of max volume */ 137}; 138#define WSKBD_BELL_DOPITCH 0x1 /* get/set pitch */ 139#define WSKBD_BELL_DOPERIOD 0x2 /* get/set period */ 140#define WSKBD_BELL_DOVOLUME 0x4 /* get/set volume */ 141#define WSKBD_BELL_DOALL 0x7 /* all of the above */ 142 143#define WSKBDIO_BELL _IO('W', 1) 144#define WSKBDIO_COMPLEXBELL _IOW('W', 2, struct wskbd_bell_data) 145#define WSKBDIO_SETBELL _IOW('W', 3, struct wskbd_bell_data) 146#define WSKBDIO_GETBELL _IOR('W', 4, struct wskbd_bell_data) 147#define WSKBDIO_SETDEFAULTBELL _IOW('W', 5, struct wskbd_bell_data) 148#define WSKBDIO_GETDEFAULTBELL _IOR('W', 6, struct wskbd_bell_data) 149 150/* Manipulate the emulation key repeat settings. */ 151struct wskbd_keyrepeat_data { 152 u_int which; /* values to get/set */ 153 u_int del1; /* delay before first, ms */ 154 u_int delN; /* delay before rest, ms */ 155}; 156#define WSKBD_KEYREPEAT_DODEL1 0x1 /* get/set del1 */ 157#define WSKBD_KEYREPEAT_DODELN 0x2 /* get/set delN */ 158#define WSKBD_KEYREPEAT_DOALL 0x3 /* all of the above */ 159 160#define WSKBDIO_SETKEYREPEAT _IOW('W', 7, struct wskbd_keyrepeat_data) 161#define WSKBDIO_GETKEYREPEAT _IOR('W', 8, struct wskbd_keyrepeat_data) 162#define WSKBDIO_SETDEFAULTKEYREPEAT \ 163 _IOW('W', 9, struct wskbd_keyrepeat_data) 164#define WSKBDIO_GETDEFAULTKEYREPEAT \ 165 _IOR('W', 10, struct wskbd_keyrepeat_data) 166 167/* Get/set keyboard leds */ 168#define WSKBD_LED_CAPS 0x01 169#define WSKBD_LED_NUM 0x02 170#define WSKBD_LED_SCROLL 0x04 171#define WSKBD_LED_COMPOSE 0x08 172 173#define WSKBDIO_SETLEDS _IOW('W', 11, int) 174#define WSKBDIO_GETLEDS _IOR('W', 12, int) 175 176/* Manipulate keysym groups. */ 177struct wskbd_map_data { 178 u_int maplen; /* number of entries in map */ 179#define WSKBDIO_MAXMAPLEN 65536 180 struct wscons_keymap *map; /* map to get or set */ 181}; 182#define WSKBDIO_GETMAP _IOWR('W', 13, struct wskbd_map_data) 183#define WSKBDIO_SETMAP _IOW('W', 14, struct wskbd_map_data) 184#define WSKBDIO_GETENCODING _IOR('W', 15, kbd_t) 185#define WSKBDIO_SETENCODING _IOW('W', 16, kbd_t) 186 187/* internal use only */ 188#define WSKBDIO_SETMODE _IOW('W', 19, int) 189#define WSKBDIO_GETMODE _IOR('W', 20, int) 190#define WSKBD_TRANSLATED 0 191#define WSKBD_RAW 1 192 193/* 194 * Mouse ioctls (32 - 63) 195 */ 196 197/* Get mouse type */ 198#define WSMOUSEIO_GTYPE _IOR('W', 32, u_int) 199#define WSMOUSE_TYPE_VSXXX 1 /* DEC serial */ 200#define WSMOUSE_TYPE_PS2 2 /* PS/2-compatible */ 201#define WSMOUSE_TYPE_USB 3 /* USB mouse */ 202#define WSMOUSE_TYPE_LMS 4 /* Logitech busmouse */ 203#define WSMOUSE_TYPE_MMS 5 /* Microsoft InPort mouse */ 204#define WSMOUSE_TYPE_TPANEL 6 /* Generic Touch Panel */ 205#define WSMOUSE_TYPE_NEXT 7 /* NeXT mouse */ 206#define WSMOUSE_TYPE_ARCHIMEDES 8 /* Archimedes mouse */ 207#define WSMOUSE_TYPE_ADB 9 /* ADB */ 208#define WSMOUSE_TYPE_HIL 10 /* HP HIL */ 209#define WSMOUSE_TYPE_LUNA 11 /* OMRON Luna */ 210#define WSMOUSE_TYPE_DOMAIN 12 /* Apollo Domain */ 211#define WSMOUSE_TYPE_BLUETOOTH 13 /* Bluetooth mouse */ 212#define WSMOUSE_TYPE_SUN 14 /* SUN serial mouse */ 213#define WSMOUSE_TYPE_SYNAPTICS 15 /* Synaptics touchpad */ 214#define WSMOUSE_TYPE_ALPS 16 /* ALPS touchpad */ 215#define WSMOUSE_TYPE_SGI 17 /* SGI serial mouse */ 216#define WSMOUSE_TYPE_ELANTECH 18 /* Elantech touchpad */ 217 218/* Set resolution. Not applicable to all mouse types. */ 219#define WSMOUSEIO_SRES _IOW('W', 33, u_int) 220#define WSMOUSE_RES_MIN 0 221#define WSMOUSE_RES_DEFAULT 75 222#define WSMOUSE_RES_MAX 100 223 224/* Set scale factor (num / den). Not applicable to all mouse types. */ 225#define WSMOUSEIO_SSCALE _IOW('W', 34, u_int[2]) 226 227/* Set sample rate. Not applicable to all mouse types. */ 228#define WSMOUSEIO_SRATE _IOW('W', 35, u_int) 229#define WSMOUSE_RATE_MIN 0 230#define WSMOUSE_RATE_DEFAULT 50 231#define WSMOUSE_RATE_MAX 100 232 233/* Set/get sample coordinates for calibration */ 234#define WSMOUSE_CALIBCOORDS_MAX 16 235#define WSMOUSE_CALIBCOORDS_RESET -1 236struct wsmouse_calibcoords { 237 int minx, miny; /* minimum value of X/Y */ 238 int maxx, maxy; /* maximum value of X/Y */ 239 int swapxy; /* swap X/Y axis */ 240 int resx, resy; /* X/Y resolution */ 241 int samplelen; /* number of samples available or 242 WSMOUSE_CALIBCOORDS_RESET for raw mode */ 243 struct wsmouse_calibcoord { 244 int rawx, rawy; /* raw coordinate */ 245 int x, y; /* translated coordinate */ 246 } samples[WSMOUSE_CALIBCOORDS_MAX]; /* sample coordinates */ 247}; 248#define WSMOUSEIO_SCALIBCOORDS _IOW('W', 36, struct wsmouse_calibcoords) 249#define WSMOUSEIO_GCALIBCOORDS _IOR('W', 37, struct wsmouse_calibcoords) 250 251#define WSMOUSEIO_SETMODE _IOW('W', 38, int) 252#define WSMOUSE_COMPAT 0 253#define WSMOUSE_NATIVE 1 254 255/* 256 * Display ioctls (64 - 95) 257 */ 258 259/* Get display type */ 260#define WSDISPLAYIO_GTYPE _IOR('W', 64, u_int) 261#define WSDISPLAY_TYPE_UNKNOWN 0 /* unknown */ 262#define WSDISPLAY_TYPE_PM_MONO 1 /* DEC [23]100 mono */ 263#define WSDISPLAY_TYPE_PM_COLOR 2 /* DEC [23]100 color */ 264#define WSDISPLAY_TYPE_CFB 3 /* DEC TC CFB (CX) */ 265#define WSDISPLAY_TYPE_XCFB 4 /* DEC `maxine' onboard fb */ 266#define WSDISPLAY_TYPE_MFB 5 /* DEC TC MFB (MX) */ 267#define WSDISPLAY_TYPE_SFB 6 /* DEC TC SFB (HX) */ 268#define WSDISPLAY_TYPE_ISAVGA 7 /* (generic) ISA VGA */ 269#define WSDISPLAY_TYPE_PCIVGA 8 /* (generic) PCI VGA */ 270#define WSDISPLAY_TYPE_TGA 9 /* DEC PCI TGA */ 271#define WSDISPLAY_TYPE_SFBP 10 /* DEC TC SFB+ (HX+) */ 272#define WSDISPLAY_TYPE_PCIMISC 11 /* (generic) PCI misc. disp. */ 273#define WSDISPLAY_TYPE_NEXTMONO 12 /* NeXT mono display */ 274#define WSDISPLAY_TYPE_PX 13 /* DEC TC PX */ 275#define WSDISPLAY_TYPE_PXG 14 /* DEC TC PXG */ 276#define WSDISPLAY_TYPE_TX 15 /* DEC TC TX */ 277#define WSDISPLAY_TYPE_HPCFB 16 /* Handheld/PalmSize PC */ 278#define WSDISPLAY_TYPE_VIDC 17 /* Acorn/ARM VIDC */ 279#define WSDISPLAY_TYPE_SPX 18 /* DEC SPX (VS3100/VS4000) */ 280#define WSDISPLAY_TYPE_GPX 19 /* DEC GPX (uVAX/VS2K/VS3100) */ 281#define WSDISPLAY_TYPE_LCG 20 /* DEC LCG (VS4000) */ 282#define WSDISPLAY_TYPE_VAX_MONO 21 /* DEC VS2K/VS3100 mono */ 283#define WSDISPLAY_TYPE_SB_P9100 22 /* Tadpole SPARCbook P9100 */ 284#define WSDISPLAY_TYPE_EGA 23 /* (generic) EGA */ 285#define WSDISPLAY_TYPE_DCPVR 24 /* Dreamcast PowerVR */ 286#define WSDISPLAY_TYPE_SUN24 25 /* Sun 24 bit framebuffers */ 287#define WSDISPLAY_TYPE_SUNBW 26 /* Sun black and white fb */ 288#define WSDISPLAY_TYPE_STI 27 /* HP STI framebuffers */ 289#define WSDISPLAY_TYPE_SUNCG3 28 /* Sun cgthree */ 290#define WSDISPLAY_TYPE_SUNCG6 29 /* Sun cgsix */ 291#define WSDISPLAY_TYPE_SUNFFB 30 /* Sun creator FFB */ 292#define WSDISPLAY_TYPE_SUNCG14 31 /* Sun cgfourteen */ 293#define WSDISPLAY_TYPE_SUNCG2 32 /* Sun cgtwo */ 294#define WSDISPLAY_TYPE_SUNCG4 33 /* Sun cgfour */ 295#define WSDISPLAY_TYPE_SUNCG8 34 /* Sun cgeight */ 296#define WSDISPLAY_TYPE_SUNTCX 35 /* Sun TCX */ 297#define WSDISPLAY_TYPE_AGTEN 36 /* AG10E */ 298#define WSDISPLAY_TYPE_XVIDEO 37 /* Xvideo */ 299#define WSDISPLAY_TYPE_SUNCG12 38 /* Sun cgtwelve */ 300#define WSDISPLAY_TYPE_MGX 39 /* SMS MGX */ 301#define WSDISPLAY_TYPE_SB_P9000 40 /* Tadpole SPARCbook P9000 */ 302#define WSDISPLAY_TYPE_RFLEX 41 /* RasterFlex series */ 303#define WSDISPLAY_TYPE_LUNA 42 /* OMRON Luna */ 304#define WSDISPLAY_TYPE_DVBOX 43 /* HP DaVinci */ 305#define WSDISPLAY_TYPE_GBOX 44 /* HP Gatorbox */ 306#define WSDISPLAY_TYPE_RBOX 45 /* HP Renaissance */ 307#define WSDISPLAY_TYPE_HYPERION 46 /* HP Hyperion */ 308#define WSDISPLAY_TYPE_TOPCAT 47 /* HP Topcat */ 309#define WSDISPLAY_TYPE_PXALCD 48 /* PXALCD (Zaurus) */ 310#define WSDISPLAY_TYPE_MAC68K 49 /* Generic mac68k framebuffer */ 311#define WSDISPLAY_TYPE_SUNLEO 50 /* Sun ZX/Leo */ 312#define WSDISPLAY_TYPE_TVRX 51 /* HP TurboVRX */ 313#define WSDISPLAY_TYPE_CFXGA 52 /* CF VoyagerVGA */ 314#define WSDISPLAY_TYPE_LCSPX 53 /* DEC LCSPX (VS4000) */ 315#define WSDISPLAY_TYPE_GBE 54 /* SGI GBE frame buffer */ 316#define WSDISPLAY_TYPE_LEGSS 55 /* DEC LEGSS (VS35x0) */ 317#define WSDISPLAY_TYPE_IFB 56 /* Sun Expert3D{,-Lite} */ 318#define WSDISPLAY_TYPE_RAPTOR 57 /* Tech Source Raptor */ 319#define WSDISPLAY_TYPE_DL 58 /* DisplayLink DL-120/DL-160 */ 320#define WSDISPLAY_TYPE_MACHFB 59 /* Sun PGX/PGX64 */ 321#define WSDISPLAY_TYPE_GFXP 60 /* Sun PGX32 */ 322#define WSDISPLAY_TYPE_RADEONFB 61 /* Sun XVR-100 */ 323#define WSDISPLAY_TYPE_SMFB 62 /* SiliconMotion SM712 */ 324#define WSDISPLAY_TYPE_SISFB 63 /* SiS 315 Pro */ 325#define WSDISPLAY_TYPE_ODYSSEY 64 /* SGI Odyssey */ 326#define WSDISPLAY_TYPE_IMPACT 65 /* SGI Impact */ 327#define WSDISPLAY_TYPE_GRTWO 66 /* SGI GR2 */ 328#define WSDISPLAY_TYPE_NEWPORT 67 /* SGI Newport */ 329#define WSDISPLAY_TYPE_LIGHT 68 /* SGI Light */ 330#define WSDISPLAY_TYPE_INTELDRM 69 /* Intel KMS framebuffer */ 331#define WSDISPLAY_TYPE_RADEONDRM 70 /* ATI Radeon KMS framebuffer */ 332 333/* Basic display information. Not applicable to all display types. */ 334struct wsdisplay_fbinfo { 335 u_int height; /* height in pixels */ 336 u_int width; /* width in pixels */ 337 u_int depth; /* bits per pixel */ 338 u_int cmsize; /* color map size (entries) */ 339}; 340#define WSDISPLAYIO_GINFO _IOR('W', 65, struct wsdisplay_fbinfo) 341 342/* Colormap operations. Not applicable to all display types. */ 343struct wsdisplay_cmap { 344 u_int index; /* first element (0 origin) */ 345 u_int count; /* number of elements */ 346 u_char *red; /* red color map elements */ 347 u_char *green; /* green color map elements */ 348 u_char *blue; /* blue color map elements */ 349}; 350#define WSDISPLAYIO_GETCMAP _IOW('W', 66, struct wsdisplay_cmap) 351#define WSDISPLAYIO_PUTCMAP _IOW('W', 67, struct wsdisplay_cmap) 352 353/* Video control. Not applicable to all display types. */ 354#define WSDISPLAYIO_GVIDEO _IOR('W', 68, u_int) 355#define WSDISPLAYIO_SVIDEO _IOW('W', 69, u_int) 356#define WSDISPLAYIO_VIDEO_OFF 0 /* video off */ 357#define WSDISPLAYIO_VIDEO_ON 1 /* video on */ 358 359/* Cursor control. Not applicable to all display types. */ 360struct wsdisplay_curpos { /* cursor "position" */ 361 u_int x, y; 362}; 363 364struct wsdisplay_cursor { 365 u_int which; /* values to get/set */ 366 u_int enable; /* enable/disable */ 367 struct wsdisplay_curpos pos; /* position */ 368 struct wsdisplay_curpos hot; /* hot spot */ 369 struct wsdisplay_cmap cmap; /* color map info */ 370 struct wsdisplay_curpos size; /* bit map size */ 371 u_char *image; /* image data */ 372 u_char *mask; /* mask data */ 373}; 374#define WSDISPLAY_CURSOR_DOCUR 0x01 /* get/set enable */ 375#define WSDISPLAY_CURSOR_DOPOS 0x02 /* get/set pos */ 376#define WSDISPLAY_CURSOR_DOHOT 0x04 /* get/set hot spot */ 377#define WSDISPLAY_CURSOR_DOCMAP 0x08 /* get/set cmap */ 378#define WSDISPLAY_CURSOR_DOSHAPE 0x10 /* get/set img/mask */ 379#define WSDISPLAY_CURSOR_DOALL 0x1f /* all of the above */ 380 381/* Cursor control: get and set position */ 382#define WSDISPLAYIO_GCURPOS _IOR('W', 70, struct wsdisplay_curpos) 383#define WSDISPLAYIO_SCURPOS _IOW('W', 71, struct wsdisplay_curpos) 384 385/* Cursor control: get maximum size */ 386#define WSDISPLAYIO_GCURMAX _IOR('W', 72, struct wsdisplay_curpos) 387 388/* Cursor control: get/set cursor attributes/shape */ 389#define WSDISPLAYIO_GCURSOR _IOWR('W', 73, struct wsdisplay_cursor) 390#define WSDISPLAYIO_SCURSOR _IOW('W', 74, struct wsdisplay_cursor) 391 392/* Display mode: Emulation (text) vs. Mapped (graphics) mode */ 393#define WSDISPLAYIO_GMODE _IOR('W', 75, u_int) 394#define WSDISPLAYIO_SMODE _IOW('W', 76, u_int) 395#define WSDISPLAYIO_MODE_EMUL 0 /* emulation (text) mode */ 396#define WSDISPLAYIO_MODE_MAPPED 1 /* mapped (graphics) mode */ 397#define WSDISPLAYIO_MODE_DUMBFB 2 /* mapped (graphics) fb mode */ 398 399struct wsdisplay_font { 400 char name[WSFONT_NAME_SIZE]; 401 int index; 402 int firstchar, numchars; 403 int encoding; 404#define WSDISPLAY_FONTENC_ISO 0 405#define WSDISPLAY_FONTENC_IBM 1 406#define WSDISPLAY_FONTENC_PCVT 2 407#define WSDISPLAY_FONTENC_ISO7 3 /* greek */ 408 u_int fontwidth, fontheight, stride; 409#define WSDISPLAY_MAXFONTSZ (512*1024) 410 int bitorder, byteorder; 411#define WSDISPLAY_FONTORDER_KNOWN 0 /* i.e, no need to convert */ 412#define WSDISPLAY_FONTORDER_L2R 1 413#define WSDISPLAY_FONTORDER_R2L 2 414 void *cookie; 415 void *data; 416}; 417#define WSDISPLAYIO_LDFONT _IOW ('W', 77, struct wsdisplay_font) 418#define WSDISPLAYIO_LSFONT _IOWR('W', 78, struct wsdisplay_font) 419#define WSDISPLAYIO_DELFONT _IOW ('W', 79, struct wsdisplay_font) 420#define WSDISPLAYIO_USEFONT _IOW ('W', 80, struct wsdisplay_font) 421 422struct wsdisplay_burner { 423 u_int off; 424 u_int on; 425 u_int flags; 426#define WSDISPLAY_BURN_VBLANK 0x0001 427#define WSDISPLAY_BURN_KBD 0x0002 428#define WSDISPLAY_BURN_MOUSE 0x0004 429#define WSDISPLAY_BURN_OUTPUT 0x0008 430}; 431#define WSDISPLAYIO_SBURNER _IOW('W', 81, struct wsdisplay_burner) 432#define WSDISPLAYIO_GBURNER _IOR('W', 82, struct wsdisplay_burner) 433 434/* 435 * XXX WARNING 436 * XXX The following definitions are very preliminary and are likely 437 * XXX to be changed without care about backwards compatibility! 438 */ 439struct wsdisplay_addscreendata { 440 int idx; /* screen index */ 441 char screentype[WSSCREEN_NAME_SIZE]; 442 char emul[WSEMUL_NAME_SIZE]; 443}; 444#define WSDISPLAYIO_ADDSCREEN _IOW('W', 83, struct wsdisplay_addscreendata) 445 446struct wsdisplay_delscreendata { 447 int idx; /* screen index */ 448 int flags; 449#define WSDISPLAY_DELSCR_FORCE 0x01 450#define WSDISPLAY_DELSCR_QUIET 0x02 451}; 452#define WSDISPLAYIO_DELSCREEN _IOW('W', 84, struct wsdisplay_delscreendata) 453 454#define WSDISPLAYIO_GETSCREEN _IOWR('W', 85, struct wsdisplay_addscreendata) 455#define WSDISPLAYIO_SETSCREEN _IOW('W', 86, u_int) 456 457/* Display information: number of bytes per row, may be same as pixels */ 458#define WSDISPLAYIO_LINEBYTES _IOR('W', 95, u_int) 459 460/* Mouse console support */ 461#define WSDISPLAYIO_WSMOUSED _IOW('W', 88, struct wscons_event) 462 463/* Misc control. Not applicable to all display types. */ 464struct wsdisplay_param { 465 int param; 466#define WSDISPLAYIO_PARAM_BACKLIGHT 1 467#define WSDISPLAYIO_PARAM_BRIGHTNESS 2 468#define WSDISPLAYIO_PARAM_CONTRAST 3 469 int min, max, curval; 470 int reserved[4]; 471}; 472#define WSDISPLAYIO_GETPARAM _IOWR('W', 89, struct wsdisplay_param) 473#define WSDISPLAYIO_SETPARAM _IOWR('W', 90, struct wsdisplay_param) 474 475#define WSDISPLAYIO_GPCIID _IOR('W', 91, struct pcisel) 476 477/* graphical mode control */ 478 479#define WSDISPLAYIO_DEPTH_1 0x1 480#define WSDISPLAYIO_DEPTH_4 0x2 481#define WSDISPLAYIO_DEPTH_8 0x4 482#define WSDISPLAYIO_DEPTH_15 0x8 483#define WSDISPLAYIO_DEPTH_16 0x10 484#define WSDISPLAYIO_DEPTH_24_24 0x20 485#define WSDISPLAYIO_DEPTH_24_32 0x40 486#define WSDISPLAYIO_DEPTH_24 (WSDISPLAYIO_DEPTH_24_24|WSDISPLAYIO_DEPTH_24_32) 487 488#define WSDISPLAYIO_GETSUPPORTEDDEPTH _IOR('W', 92, unsigned int) 489 490struct wsdisplay_gfx_mode { 491 int width; 492 int height; 493 int depth; 494}; 495 496#define WSDISPLAYIO_SETGFXMODE _IOW('W', 92, struct wsdisplay_gfx_mode) 497 498struct wsdisplay_screentype { 499 int idx; 500 int nidx; 501 char name[WSSCREEN_NAME_SIZE]; 502 int ncols, nrows; 503 int fontwidth, fontheight; 504}; 505 506#define WSDISPLAYIO_GETSCREENTYPE _IOWR('W', 93, struct wsdisplay_screentype) 507 508struct wsdisplay_emultype { 509 int idx; 510 char name[WSSCREEN_NAME_SIZE]; 511}; 512 513#define WSDISPLAYIO_GETEMULTYPE _IOWR('W', 94, struct wsdisplay_emultype) 514 515/* XXX NOT YET DEFINED */ 516/* Mapping information retrieval. */ 517 518/* 519 * Mux ioctls (96 - 127) 520 */ 521 522#define WSMUXIO_INJECTEVENT _IOW('W', 96, struct wscons_event) 523#define WSMUX_INJECTEVENT WSMUXIO_INJECTEVENT /* XXX compat */ 524 525struct wsmux_device { 526 int type; 527#define WSMUX_MOUSE 1 528#define WSMUX_KBD 2 529#define WSMUX_MUX 3 530 int idx; 531}; 532#define WSMUXIO_ADD_DEVICE _IOW('W', 97, struct wsmux_device) 533#define WSMUX_ADD_DEVICE WSMUXIO_ADD_DEVICE /* XXX compat */ 534#define WSMUXIO_REMOVE_DEVICE _IOW('W', 98, struct wsmux_device) 535#define WSMUX_REMOVE_DEVICE WSMUXIO_REMOVE_DEVICE /* XXX compat */ 536 537#define WSMUX_MAXDEV 32 538struct wsmux_device_list { 539 int ndevices; 540 struct wsmux_device devices[WSMUX_MAXDEV]; 541}; 542#define WSMUXIO_LIST_DEVICES _IOWR('W', 99, struct wsmux_device_list) 543#define WSMUX_LIST_DEVICES WSMUXIO_LIST_DEVICES /* XXX compat */ 544 545#endif /* _DEV_WSCONS_WSCONSIO_H_ */ 546