completely remove OS keyboard layer
Completely axe the keyboard layer from os-support.
This commit is contained in:
parent
9525c2709e
commit
008aa7eb6e
|
@ -61,7 +61,6 @@
|
|||
#endif
|
||||
|
||||
#include "xf86OSmouse.h"
|
||||
#include "xf86OSKbd.h"
|
||||
|
||||
#ifdef DEBUG
|
||||
# define DEBUG_P(x) ErrorF(x"\n");
|
||||
|
@ -259,59 +258,21 @@ MiscExtGetKbdSettings(pointer *kbd)
|
|||
{
|
||||
kbdParamsPtr kbdptr;
|
||||
InputInfoPtr pInfo;
|
||||
KbdDevPtr pKbd;
|
||||
|
||||
DEBUG_P("MiscExtGetKbdSettings");
|
||||
|
||||
kbdptr = MiscExtCreateStruct(MISC_KEYBOARD);
|
||||
if (!kbdptr)
|
||||
return FALSE;
|
||||
|
||||
pInfo = inputInfo.keyboard->public.devicePrivate;
|
||||
pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
kbdptr->type = pKbd->kbdType;
|
||||
kbdptr->rate = pKbd->rate;
|
||||
kbdptr->delay = pKbd->delay;
|
||||
*kbd = kbdptr;
|
||||
|
||||
return TRUE;
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
_X_EXPORT int
|
||||
MiscExtGetKbdValue(pointer keyboard, MiscExtKbdValType valtype)
|
||||
{
|
||||
kbdParamsPtr kbd = keyboard;
|
||||
|
||||
DEBUG_P("MiscExtGetKbdValue");
|
||||
switch (valtype) {
|
||||
case MISC_KBD_TYPE: return kbd->type;
|
||||
case MISC_KBD_RATE: return kbd->rate;
|
||||
case MISC_KBD_DELAY: return kbd->delay;
|
||||
case MISC_KBD_SERVNUMLOCK: return 0;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
MiscExtSetKbdValue(pointer keyboard, MiscExtKbdValType valtype, int value)
|
||||
{
|
||||
kbdParamsPtr kbd = keyboard;
|
||||
|
||||
DEBUG_P("MiscExtSetKbdValue");
|
||||
switch (valtype) {
|
||||
case MISC_KBD_TYPE:
|
||||
kbd->type = value;
|
||||
return TRUE;
|
||||
case MISC_KBD_RATE:
|
||||
kbd->rate = value;
|
||||
return TRUE;
|
||||
case MISC_KBD_DELAY:
|
||||
kbd->delay = value;
|
||||
return TRUE;
|
||||
case MISC_KBD_SERVNUMLOCK:
|
||||
return TRUE;
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
|
@ -595,39 +556,7 @@ MiscExtApply(pointer structure, MiscExtStructType mse_or_kbd)
|
|||
xf86ReplaceBoolOption(pInfo->options, "ClearRTS",
|
||||
pMse->mouseFlags | MF_CLEAR_RTS);
|
||||
}
|
||||
if (mse_or_kbd == MISC_KEYBOARD) {
|
||||
kbdParamsPtr kbd = structure;
|
||||
InputInfoPtr pInfo;
|
||||
KbdDevPtr pKbd;
|
||||
|
||||
pInfo = inputInfo.keyboard->public.devicePrivate;
|
||||
pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
if (kbd->rate < 0)
|
||||
return MISC_RET_BADVAL;
|
||||
if (kbd->delay < 0)
|
||||
return MISC_RET_BADVAL;
|
||||
if (kbd->type < KTYPE_UNKNOWN || kbd->type > KTYPE_XQUEUE)
|
||||
return MISC_RET_BADKBDTYPE;
|
||||
|
||||
if (pKbd->rate!=kbd->rate || pKbd->delay!=kbd->delay) {
|
||||
char rad;
|
||||
|
||||
pKbd->rate = kbd->rate;
|
||||
pKbd->delay = kbd->delay;
|
||||
if (pKbd->delay <= 375) rad = 0x00;
|
||||
else if (pKbd->delay <= 625) rad = 0x20;
|
||||
else if (pKbd->delay <= 875) rad = 0x40;
|
||||
else rad = 0x60;
|
||||
|
||||
if (pKbd->rate <= 2) rad |= 0x1F;
|
||||
else if (pKbd->rate >= 30) rad |= 0x00;
|
||||
else rad |= ((58/pKbd->rate)-2);
|
||||
|
||||
pKbd->SetKbdRepeat(pInfo, rad);
|
||||
}
|
||||
}
|
||||
return MISC_RET_SUCCESS;
|
||||
return MISC_RET_BADVAL;
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
|
|
|
@ -31,7 +31,6 @@
|
|||
|
||||
#include "xf86.h"
|
||||
#include "xf86OSmouse.h"
|
||||
#include "xf86OSKbd.h"
|
||||
|
||||
static CARD32 registeredVersions[NUM_BUILTIN_IFS];
|
||||
|
||||
|
@ -51,8 +50,6 @@ xf86GetBuiltinInterfaceVersion(BuiltinInterface iface, int flags)
|
|||
switch (iface) {
|
||||
case BUILTIN_IF_OSMOUSE:
|
||||
return OS_MOUSE_VERSION_CURRENT;
|
||||
case BUILTIN_IF_OSKBD:
|
||||
return OS_KBD_VERSION_CURRENT;
|
||||
default:
|
||||
xf86Msg(X_ERROR, "xf86GetBuiltinInterfaceVersion: internal error: "
|
||||
"interface %d not handled\n", iface);
|
||||
|
|
|
@ -70,7 +70,6 @@
|
|||
# include "xf86Xinput.h"
|
||||
#endif
|
||||
#include "xf86OSmouse.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "xf86xv.h"
|
||||
#include "xf86xvmc.h"
|
||||
#include "xf86cmap.h"
|
||||
|
@ -280,7 +279,6 @@ _X_HIDDEN void *xfree86LookupTab[] = {
|
|||
SYMFUNC(xf86SerialModemClearBits)
|
||||
SYMFUNC(xf86LoadKernelModule)
|
||||
SYMFUNC(xf86OSMouseInit)
|
||||
SYMFUNC(xf86OSKbdPreInit)
|
||||
SYMFUNC(xf86AgpGARTSupported)
|
||||
SYMFUNC(xf86GetAGPInfo)
|
||||
SYMFUNC(xf86AcquireGART)
|
||||
|
|
|
@ -6,7 +6,7 @@ SUBDIRS = bus @XORG_OS_SUBDIR@ misc $(DRI_SUBDIRS)
|
|||
DIST_SUBDIRS = bsd bus drm misc linux lynxos solaris sysv sco usl
|
||||
|
||||
sdk_HEADERS = xf86_OSproc.h xf86_OSlib.h xf86_ansic.h xf86_libc.h \
|
||||
assyntax.h xf86OSKbd.h xf86OSmouse.h
|
||||
assyntax.h xf86OSmouse.h
|
||||
|
||||
EXTRA_DIST = int10Defines.h xf86OSpriv.h README.OS-lib xf86drm.h
|
||||
|
||||
|
|
|
@ -55,18 +55,14 @@ AM_CFLAGS = -DUSESTDRES $(XORG_CFLAGS)
|
|||
INCLUDES = $(XORG_INCS)
|
||||
|
||||
libbsd_la_SOURCES = \
|
||||
$(srcdir)/../shared/at_scancode.c \
|
||||
$(srcdir)/../shared/libc_wrapper.c \
|
||||
$(srcdir)/../shared/posix_tty.c \
|
||||
$(srcdir)/../shared/sigio.c \
|
||||
$(srcdir)/../shared/std_kbdEv.c \
|
||||
$(srcdir)/../shared/stdPci.c \
|
||||
$(srcdir)/../shared/vidmem.c \
|
||||
bsd_VTsw.c \
|
||||
bsd_init.c \
|
||||
bsd_io.c \
|
||||
bsd_kbd.c \
|
||||
bsd_KbdMap.c \
|
||||
bsd_mouse.c \
|
||||
$(ARCH_SOURCES) \
|
||||
$(AGP_SOURCES) \
|
||||
|
@ -80,7 +76,6 @@ libbsd_la_SOURCES = \
|
|||
EXTRA_DIST = \
|
||||
bsd_apm.c \
|
||||
bsd_jstk.c \
|
||||
bsd_kbd.h \
|
||||
bsd_kqueue_apm.c \
|
||||
bsdResource.c \
|
||||
memrange.h \
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,572 +0,0 @@
|
|||
|
||||
/*
|
||||
* Copyright (c) 2002 by The XFree86 Project, Inc.
|
||||
* Author: Ivan Pascal.
|
||||
*
|
||||
* Based on the code from bsd_io.c which is
|
||||
* Copyright 1992 by Rich Murphey <Rich@Rice.edu>
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*/
|
||||
|
||||
#define NEED_EVENTS
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
#include <termios.h>
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
#include "bsd_kbd.h"
|
||||
|
||||
extern Bool VTSwitchEnabled;
|
||||
#ifdef USE_VT_SYSREQ
|
||||
extern Bool VTSysreqToggle;
|
||||
#endif
|
||||
|
||||
static KbdProtocolRec protocols[] = {
|
||||
{"standard", PROT_STD },
|
||||
#ifdef WSCONS_SUPPORT
|
||||
{"wskbd", PROT_WSCONS },
|
||||
#endif
|
||||
{ NULL, PROT_UNKNOWN_KBD }
|
||||
};
|
||||
|
||||
typedef struct {
|
||||
struct termios kbdtty;
|
||||
} BsdKbdPrivRec, *BsdKbdPrivPtr;
|
||||
|
||||
static
|
||||
int KbdInit(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
BsdKbdPrivPtr priv = (BsdKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
switch (pKbd->consType) {
|
||||
#if defined(PCCONS_SUPPORT) || defined(SYSCONS_SUPPORT) || defined (PCVT_SUPPORT) || defined (WSCONS_SUPPORT)
|
||||
case PCCONS:
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
#if defined WSCONS_SUPPORT
|
||||
case WSCONS:
|
||||
#endif
|
||||
tcgetattr(pInfo->fd, &(priv->kbdtty));
|
||||
#endif
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdLeds(InputInfoPtr pInfo, int leds)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int real_leds = 0;
|
||||
|
||||
#ifdef LED_CAP
|
||||
if (leds & XLED1) real_leds |= LED_CAP;
|
||||
#endif
|
||||
#ifdef LED_NUM
|
||||
if (leds & XLED2) real_leds |= LED_NUM;
|
||||
#endif
|
||||
#ifdef LED_SCR
|
||||
if (leds & XLED3) real_leds |= LED_SCR;
|
||||
if (leds & XLED4) real_leds |= LED_SCR;
|
||||
#endif
|
||||
|
||||
switch (pKbd->consType) {
|
||||
|
||||
case PCCONS:
|
||||
break;
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT)
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
ioctl(pInfo->fd, KDSETLED, real_leds);
|
||||
break;
|
||||
#endif
|
||||
#if defined(WSCONS_SUPPORT)
|
||||
case WSCONS:
|
||||
ioctl(pInfo->fd, WSKBDIO_SETLEDS, &real_leds);
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
static int
|
||||
GetKbdLeds(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int leds = 0, real_leds = 0;
|
||||
|
||||
switch (pKbd->consType) {
|
||||
case PCCONS:
|
||||
break;
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT)
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
ioctl(pInfo->fd, KDGETLED, &real_leds);
|
||||
break;
|
||||
#endif
|
||||
#if defined(WSCONS_SUPPORT)
|
||||
case WSCONS:
|
||||
ioctl(pInfo->fd, WSKBDIO_GETLEDS, &real_leds);
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
|
||||
#ifdef LED_CAP
|
||||
if (real_leds & LED_CAP) leds |= XLED1;
|
||||
#endif
|
||||
#ifdef LED_NUM
|
||||
if (real_leds & LED_NUM) leds |= XLED2;
|
||||
#endif
|
||||
#ifdef LED_SCR
|
||||
if (real_leds & LED_SCR) leds |= XLED3;
|
||||
#endif
|
||||
|
||||
return(leds);
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdRepeat(InputInfoPtr pInfo, char rad)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
switch (pKbd->consType) {
|
||||
|
||||
case PCCONS:
|
||||
break;
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT)
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
ioctl(pInfo->fd, KDSETRAD, rad);
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOn(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
#if defined(SYSCONS_SUPPORT) || defined(PCCONS_SUPPORT) || defined(PCVT_SUPPORT) || defined(WSCONS_SUPPORT)
|
||||
BsdKbdPrivPtr priv = (BsdKbdPrivPtr) pKbd->private;
|
||||
struct termios nTty;
|
||||
#endif
|
||||
#ifdef WSCONS_SUPPORT
|
||||
int option;
|
||||
#endif
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
switch (pKbd->consType) {
|
||||
|
||||
#if defined(SYSCONS_SUPPORT) || defined(PCCONS_SUPPORT) || defined(PCVT_SUPPORT) || defined(WSCONS_SUPPORT)
|
||||
case SYSCONS:
|
||||
case PCCONS:
|
||||
case PCVT:
|
||||
#ifdef WSCONS_SUPPORT
|
||||
case WSCONS:
|
||||
#endif
|
||||
nTty = priv->kbdtty;
|
||||
nTty.c_iflag = IGNPAR | IGNBRK;
|
||||
nTty.c_oflag = 0;
|
||||
nTty.c_cflag = CREAD | CS8;
|
||||
nTty.c_lflag = 0;
|
||||
nTty.c_cc[VTIME] = 0;
|
||||
nTty.c_cc[VMIN] = 1;
|
||||
cfsetispeed(&nTty, 9600);
|
||||
cfsetospeed(&nTty, 9600);
|
||||
if (tcsetattr(pInfo->fd, TCSANOW, &nTty) < 0) {
|
||||
xf86Msg(X_ERROR, "KbdOn: tcsetattr: %s\n",
|
||||
strerror(errno));
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT) || defined (WSCONS_SUPPORT)
|
||||
switch (pKbd->consType) {
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
#ifdef K_CODE
|
||||
if (pKbd->CustomKeycodes)
|
||||
ioctl(pInfo->fd, KDSKBMODE, K_CODE);
|
||||
else
|
||||
ioctl(pInfo->fd, KDSKBMODE, K_RAW);
|
||||
#else
|
||||
ioctl(pInfo->fd, KDSKBMODE, K_RAW);
|
||||
#endif
|
||||
break;
|
||||
#endif
|
||||
#ifdef WSCONS_SUPPORT
|
||||
case WSCONS:
|
||||
option = WSKBD_RAW;
|
||||
if (ioctl(pInfo->fd, WSKBDIO_SETMODE, &option) == -1) {
|
||||
FatalError("can't switch keyboard to raw mode. "
|
||||
"Enable support for it in the kernel\n"
|
||||
"or use for example:\n\n"
|
||||
"Option \"Protocol\" \"wskbd\"\n"
|
||||
"Option \"Device\" \"/dev/wskbd0\"\n"
|
||||
"\nin your xorg.conf(5) file\n");
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOff(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
BsdKbdPrivPtr priv = (BsdKbdPrivPtr) pKbd->private;
|
||||
#ifdef WSCONS_SUPPORT
|
||||
int option;
|
||||
#endif
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
switch (pKbd->consType) {
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT)
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
ioctl(pInfo->fd, KDSKBMODE, K_XLATE);
|
||||
/* FALL THROUGH */
|
||||
#endif
|
||||
#if defined(SYSCONS_SUPPORT) || defined(PCCONS_SUPPORT) || defined(PCVT_SUPPORT)
|
||||
case PCCONS:
|
||||
tcsetattr(pInfo->fd, TCSANOW, &(priv->kbdtty));
|
||||
break;
|
||||
#endif
|
||||
#ifdef WSCONS_SUPPORT
|
||||
case WSCONS:
|
||||
option = WSKBD_TRANSLATED;
|
||||
ioctl(xf86Info.consoleFd, WSKBDIO_SETMODE, &option);
|
||||
tcsetattr(pInfo->fd, TCSANOW, &(priv->kbdtty));
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
return Success;
|
||||
}
|
||||
|
||||
static void
|
||||
SoundBell(InputInfoPtr pInfo, int loudness, int pitch, int duration)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
#ifdef WSCONS_SUPPORT
|
||||
struct wskbd_bell_data wsb;
|
||||
#endif
|
||||
|
||||
if (loudness && pitch) {
|
||||
switch (pKbd->consType) {
|
||||
#ifdef PCCONS_SUPPORT
|
||||
case PCCONS:
|
||||
{ int data[2];
|
||||
data[0] = pitch;
|
||||
data[1] = (duration * loudness) / 50;
|
||||
ioctl(pInfo->fd, CONSOLE_X_BELL, data);
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT)
|
||||
case SYSCONS:
|
||||
case PCVT:
|
||||
ioctl(pInfo->fd, KDMKTONE,
|
||||
((1193190 / pitch) & 0xffff) |
|
||||
(((unsigned long)duration*loudness/50)<<16));
|
||||
break;
|
||||
#endif
|
||||
#if defined (WSCONS_SUPPORT)
|
||||
case WSCONS:
|
||||
wsb.which = WSKBD_BELL_DOALL;
|
||||
wsb.pitch = pitch;
|
||||
wsb.period = duration;
|
||||
wsb.volume = loudness;
|
||||
ioctl(pInfo->fd, WSKBDIO_COMPLEXBELL, &wsb);
|
||||
break;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#define ModifierSet(k) ((modifiers & (k)) == (k))
|
||||
|
||||
static
|
||||
Bool SpecialKey(InputInfoPtr pInfo, int key, Bool down, int modifiers)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
if(!pKbd->vtSwitchSupported)
|
||||
return FALSE;
|
||||
|
||||
if ((ModifierSet(ControlMask | AltMask)) ||
|
||||
(ModifierSet(ControlMask | AltLangMask))) {
|
||||
if (VTSwitchEnabled && !xf86Info.vtSysreq && !xf86Info.dontVTSwitch) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
#ifdef VT_ACTIVATE
|
||||
if (down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F1 + 1);
|
||||
return TRUE;
|
||||
}
|
||||
#endif
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
#ifdef VT_ACTIVATE
|
||||
if (down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F11 + 11);
|
||||
return TRUE;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
#ifdef USE_VT_SYSREQ
|
||||
if (VTSwitchEnabled && xf86Info.vtSysreq && !xf86Info.dontVTSwitch) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F1 + 1);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F11 + 11);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
/* Ignore these keys -- ie don't let them cancel an alt-sysreq */
|
||||
case KEY_Alt:
|
||||
case KEY_AltLang:
|
||||
break;
|
||||
case KEY_SysReqest:
|
||||
if ((ModifierSet(AltMask) || ModifierSet(AltLangMask)) && down)
|
||||
VTSysreqToggle = TRUE;
|
||||
break;
|
||||
default:
|
||||
/*
|
||||
* We only land here when Alt-SysReq is followed by a
|
||||
* non-switching key.
|
||||
*/
|
||||
if (VTSysreqToggle)
|
||||
VTSysreqToggle = FALSE;
|
||||
}
|
||||
}
|
||||
#endif /* USE_VT_SYSREQ */
|
||||
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static void
|
||||
stdReadInput(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
unsigned char rBuf[64];
|
||||
int nBytes, i;
|
||||
if ((nBytes = read( pInfo->fd, (char *)rBuf, sizeof(rBuf))) > 0) {
|
||||
for (i = 0; i < nBytes; i++)
|
||||
pKbd->PostEvent(pInfo, rBuf[i] & 0x7f,
|
||||
rBuf[i] & 0x80 ? FALSE : TRUE);
|
||||
}
|
||||
}
|
||||
|
||||
#ifdef WSCONS_SUPPORT
|
||||
|
||||
static void
|
||||
WSReadInput(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
struct wscons_event events[64];
|
||||
int type;
|
||||
int blocked, n, i;
|
||||
|
||||
if ((n = read( pInfo->fd, events, sizeof(events))) > 0) {
|
||||
n /= sizeof(struct wscons_event);
|
||||
for (i = 0; i < n; i++) {
|
||||
type = events[i].type;
|
||||
if (type == WSCONS_EVENT_KEY_UP || type == WSCONS_EVENT_KEY_DOWN) {
|
||||
/* It seems better to block SIGIO there */
|
||||
blocked = xf86BlockSIGIO();
|
||||
pKbd->PostEvent(pInfo, (unsigned int)(events[i].value),
|
||||
type == WSCONS_EVENT_KEY_DOWN ? TRUE : FALSE);
|
||||
xf86UnblockSIGIO(blocked);
|
||||
}
|
||||
} /* for */
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
printWsType(char *type, char *devname)
|
||||
{
|
||||
xf86Msg(X_PROBED, "%s: Keyboard type: %s\n", type, devname);
|
||||
}
|
||||
#endif
|
||||
|
||||
static Bool
|
||||
OpenKeyboard(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int i;
|
||||
KbdProtocolId prot = PROT_UNKNOWN_KBD;
|
||||
char *s;
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Protocol", NULL);
|
||||
for (i = 0; protocols[i].name; i++) {
|
||||
if (xf86NameCmp(s, protocols[i].name) == 0) {
|
||||
prot = protocols[i].id;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch (prot) {
|
||||
case PROT_STD:
|
||||
pInfo->read_input = stdReadInput;
|
||||
break;
|
||||
#ifdef WSCONS_SUPPORT
|
||||
case PROT_WSCONS:
|
||||
pInfo->read_input = WSReadInput;
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
xf86Msg(X_ERROR,"\"%s\" is not a valid keyboard protocol name\n", s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
xf86Msg(X_CONFIG, "%s: Protocol: %s\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Device", NULL);
|
||||
if (s == NULL) {
|
||||
if (prot == PROT_WSCONS) {
|
||||
xf86Msg(X_ERROR,"A \"device\" option is required with"
|
||||
" the \"wskbd\" keyboard protocol\n");
|
||||
return FALSE;
|
||||
} else {
|
||||
pInfo->fd = xf86Info.consoleFd;
|
||||
pKbd->isConsole = TRUE;
|
||||
pKbd->consType = xf86Info.consType;
|
||||
}
|
||||
} else {
|
||||
pInfo->fd = open(s, O_RDONLY | O_NONBLOCK | O_EXCL);
|
||||
if (pInfo->fd == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot open \"%s\"\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
pKbd->isConsole = FALSE;
|
||||
pKbd->consType = xf86Info.consType;
|
||||
xfree(s);
|
||||
}
|
||||
|
||||
#if defined (SYSCONS_SUPPORT) || defined (PCVT_SUPPORT)
|
||||
if (pKbd->isConsole &&
|
||||
((pKbd->consType == SYSCONS) || (pKbd->consType == PCVT)))
|
||||
pKbd->vtSwitchSupported = TRUE;
|
||||
#endif
|
||||
|
||||
#ifdef WSCONS_SUPPORT
|
||||
if( prot == PROT_WSCONS) {
|
||||
pKbd->consType = WSCONS;
|
||||
/* Find out keyboard type */
|
||||
if (ioctl(pInfo->fd, WSKBDIO_GTYPE, &(pKbd->wsKbdType)) == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot get keyboard type", pInfo->name);
|
||||
close(pInfo->fd);
|
||||
return FALSE;
|
||||
}
|
||||
switch (pKbd->wsKbdType) {
|
||||
case WSKBD_TYPE_PC_XT:
|
||||
printWsType("XT", pInfo->name);
|
||||
break;
|
||||
case WSKBD_TYPE_PC_AT:
|
||||
printWsType("AT", pInfo->name);
|
||||
break;
|
||||
case WSKBD_TYPE_USB:
|
||||
printWsType("USB", pInfo->name);
|
||||
break;
|
||||
#ifdef WSKBD_TYPE_ADB
|
||||
case WSKBD_TYPE_ADB:
|
||||
printWsType("ADB", pInfo->name);
|
||||
break;
|
||||
#endif
|
||||
#ifdef WSKBD_TYPE_SUN
|
||||
case WSKBD_TYPE_SUN:
|
||||
printWsType("Sun", pInfo->name);
|
||||
break;
|
||||
#endif
|
||||
#ifdef WSKBD_TYPE_SUN5
|
||||
case WSKBD_TYPE_SUN5:
|
||||
xf86Msg(X_PROBED, "Keyboard type: Sun5\n");
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
xf86Msg(X_ERROR, "%s: Unsupported wskbd type \"%d\"",
|
||||
pInfo->name, pKbd->wsKbdType);
|
||||
close(pInfo->fd);
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = pInfo->private;
|
||||
|
||||
pKbd->KbdInit = KbdInit;
|
||||
pKbd->KbdOn = KbdOn;
|
||||
pKbd->KbdOff = KbdOff;
|
||||
pKbd->Bell = SoundBell;
|
||||
pKbd->SetLeds = SetKbdLeds;
|
||||
pKbd->GetLeds = GetKbdLeds;
|
||||
pKbd->SetKbdRepeat = SetKbdRepeat;
|
||||
pKbd->KbdGetMapping = KbdGetMapping;
|
||||
pKbd->SpecialKey = SpecialKey;
|
||||
|
||||
pKbd->RemapScanCode = NULL;
|
||||
pKbd->GetSpecialKey = NULL;
|
||||
|
||||
pKbd->OpenKeyboard = OpenKeyboard;
|
||||
pKbd->vtSwitchSupported = FALSE;
|
||||
pKbd->CustomKeycodes = FALSE;
|
||||
|
||||
pKbd->private = xcalloc(sizeof(BsdKbdPrivRec), 1);
|
||||
if (pKbd->private == NULL) {
|
||||
xf86Msg(X_ERROR,"can't allocate keyboard OS private data\n");
|
||||
return FALSE;
|
||||
}
|
||||
return TRUE;
|
||||
}
|
|
@ -1,4 +0,0 @@
|
|||
|
||||
extern void KbdGetMapping(InputInfoPtr pInfo, KeySymsPtr pKeySyms,
|
||||
CARD8 *pModMap);
|
||||
|
|
@ -19,17 +19,15 @@ APM_SOURCES = lnx_apm.c
|
|||
XORG_CFLAGS += -DHAVE_APM
|
||||
endif
|
||||
|
||||
liblinux_la_SOURCES = lnx_init.c lnx_video.c lnx_kbd.c lnx_mouse.c \
|
||||
lnx_pci.c lnx_agp.c lnx_kmod.c lnx_KbdMap.c \
|
||||
liblinux_la_SOURCES = lnx_init.c lnx_video.c lnx_mouse.c \
|
||||
lnx_pci.c lnx_agp.c lnx_kmod.c \
|
||||
$(srcdir)/../shared/bios_mmap.c \
|
||||
$(srcdir)/../shared/VTsw_usl.c \
|
||||
$(srcdir)/../shared/std_kbdEv.c \
|
||||
$(srcdir)/../shared/posix_tty.c \
|
||||
$(srcdir)/../shared/vidmem.c \
|
||||
$(srcdir)/../shared/sigio.c \
|
||||
$(srcdir)/../shared/stdResource.c \
|
||||
$(srcdir)/../shared/libc_wrapper.c \
|
||||
$(srcdir)/../shared/at_scancode.c \
|
||||
$(ACPI_SOURCES) \
|
||||
$(APM_SOURCES) \
|
||||
$(PLATFORM_PCI_SUPPORT)
|
||||
|
|
|
@ -1,606 +0,0 @@
|
|||
/* $XFree86$ */
|
||||
|
||||
/*
|
||||
* Slightly modified xf86KbdLnx.c which is
|
||||
*
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany.
|
||||
*/
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
#include <X11/Xmd.h>
|
||||
#include "input.h"
|
||||
#include "scrnintstr.h"
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
|
||||
#include "xf86Keymap.h"
|
||||
|
||||
#include "lnx_kbd.h"
|
||||
|
||||
/*ARGSUSED*/
|
||||
|
||||
/*
|
||||
* KbdGetMapping --
|
||||
* Get the national keyboard mapping. The keyboard type is set, a new map
|
||||
* and the modifiermap is computed.
|
||||
*/
|
||||
|
||||
static void readKernelMapping(InputInfoPtr pInfo,
|
||||
KeySymsPtr pKeySyms, CARD8 *pModMap);
|
||||
void
|
||||
KbdGetMapping (InputInfoPtr pInfo, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
KeySym *k;
|
||||
char type;
|
||||
int i;
|
||||
|
||||
readKernelMapping(pInfo, pKeySyms, pModMap);
|
||||
|
||||
/*
|
||||
* compute the modifier map
|
||||
*/
|
||||
for (i = 0; i < MAP_LENGTH; i++)
|
||||
pModMap[i] = NoSymbol; /* make sure it is restored */
|
||||
|
||||
for (k = map, i = MIN_KEYCODE;
|
||||
i < (NUM_KEYCODES + MIN_KEYCODE);
|
||||
i++, k += 4)
|
||||
|
||||
switch(*k) {
|
||||
|
||||
case XK_Shift_L:
|
||||
case XK_Shift_R:
|
||||
pModMap[i] = ShiftMask;
|
||||
break;
|
||||
|
||||
case XK_Control_L:
|
||||
case XK_Control_R:
|
||||
pModMap[i] = ControlMask;
|
||||
break;
|
||||
|
||||
case XK_Caps_Lock:
|
||||
pModMap[i] = LockMask;
|
||||
break;
|
||||
|
||||
case XK_Alt_L:
|
||||
case XK_Alt_R:
|
||||
pModMap[i] = AltMask;
|
||||
break;
|
||||
|
||||
case XK_Num_Lock:
|
||||
pModMap[i] = NumLockMask;
|
||||
break;
|
||||
|
||||
case XK_Scroll_Lock:
|
||||
pModMap[i] = ScrollLockMask;
|
||||
break;
|
||||
|
||||
/* kana support */
|
||||
case XK_Kana_Lock:
|
||||
case XK_Kana_Shift:
|
||||
pModMap[i] = KanaMask;
|
||||
break;
|
||||
|
||||
/* alternate toggle for multinational support */
|
||||
case XK_Mode_switch:
|
||||
pModMap[i] = AltLangMask;
|
||||
break;
|
||||
|
||||
}
|
||||
|
||||
pKbd->kbdType = ioctl(pInfo->fd, KDGKBTYPE, &type) != -1 ? type : KB_101;
|
||||
|
||||
pKeySyms->map = map;
|
||||
pKeySyms->mapWidth = GLYPHS_PER_KEY;
|
||||
pKeySyms->minKeyCode = MIN_KEYCODE;
|
||||
pKeySyms->maxKeyCode = MAX_KEYCODE;
|
||||
}
|
||||
|
||||
#include <linux/keyboard.h>
|
||||
|
||||
static KeySym linux_to_x[256] = {
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_BackSpace, XK_Tab, XK_Linefeed, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, XK_Escape,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_space, XK_exclam, XK_quotedbl, XK_numbersign,
|
||||
XK_dollar, XK_percent, XK_ampersand, XK_apostrophe,
|
||||
XK_parenleft, XK_parenright, XK_asterisk, XK_plus,
|
||||
XK_comma, XK_minus, XK_period, XK_slash,
|
||||
XK_0, XK_1, XK_2, XK_3,
|
||||
XK_4, XK_5, XK_6, XK_7,
|
||||
XK_8, XK_9, XK_colon, XK_semicolon,
|
||||
XK_less, XK_equal, XK_greater, XK_question,
|
||||
XK_at, XK_A, XK_B, XK_C,
|
||||
XK_D, XK_E, XK_F, XK_G,
|
||||
XK_H, XK_I, XK_J, XK_K,
|
||||
XK_L, XK_M, XK_N, XK_O,
|
||||
XK_P, XK_Q, XK_R, XK_S,
|
||||
XK_T, XK_U, XK_V, XK_W,
|
||||
XK_X, XK_Y, XK_Z, XK_bracketleft,
|
||||
XK_backslash, XK_bracketright,XK_asciicircum, XK_underscore,
|
||||
XK_grave, XK_a, XK_b, XK_c,
|
||||
XK_d, XK_e, XK_f, XK_g,
|
||||
XK_h, XK_i, XK_j, XK_k,
|
||||
XK_l, XK_m, XK_n, XK_o,
|
||||
XK_p, XK_q, XK_r, XK_s,
|
||||
XK_t, XK_u, XK_v, XK_w,
|
||||
XK_x, XK_y, XK_z, XK_braceleft,
|
||||
XK_bar, XK_braceright, XK_asciitilde, XK_BackSpace,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_nobreakspace,XK_exclamdown, XK_cent, XK_sterling,
|
||||
XK_currency, XK_yen, XK_brokenbar, XK_section,
|
||||
XK_diaeresis, XK_copyright, XK_ordfeminine, XK_guillemotleft,
|
||||
XK_notsign, XK_hyphen, XK_registered, XK_macron,
|
||||
XK_degree, XK_plusminus, XK_twosuperior, XK_threesuperior,
|
||||
XK_acute, XK_mu, XK_paragraph, XK_periodcentered,
|
||||
XK_cedilla, XK_onesuperior, XK_masculine, XK_guillemotright,
|
||||
XK_onequarter, XK_onehalf, XK_threequarters,XK_questiondown,
|
||||
XK_Agrave, XK_Aacute, XK_Acircumflex, XK_Atilde,
|
||||
XK_Adiaeresis, XK_Aring, XK_AE, XK_Ccedilla,
|
||||
XK_Egrave, XK_Eacute, XK_Ecircumflex, XK_Ediaeresis,
|
||||
XK_Igrave, XK_Iacute, XK_Icircumflex, XK_Idiaeresis,
|
||||
XK_ETH, XK_Ntilde, XK_Ograve, XK_Oacute,
|
||||
XK_Ocircumflex, XK_Otilde, XK_Odiaeresis, XK_multiply,
|
||||
XK_Ooblique, XK_Ugrave, XK_Uacute, XK_Ucircumflex,
|
||||
XK_Udiaeresis, XK_Yacute, XK_THORN, XK_ssharp,
|
||||
XK_agrave, XK_aacute, XK_acircumflex, XK_atilde,
|
||||
XK_adiaeresis, XK_aring, XK_ae, XK_ccedilla,
|
||||
XK_egrave, XK_eacute, XK_ecircumflex, XK_ediaeresis,
|
||||
XK_igrave, XK_iacute, XK_icircumflex, XK_idiaeresis,
|
||||
XK_eth, XK_ntilde, XK_ograve, XK_oacute,
|
||||
XK_ocircumflex, XK_otilde, XK_odiaeresis, XK_division,
|
||||
XK_oslash, XK_ugrave, XK_uacute, XK_ucircumflex,
|
||||
XK_udiaeresis, XK_yacute, XK_thorn, XK_ydiaeresis
|
||||
};
|
||||
|
||||
/*
|
||||
* Maps the AT keycodes to Linux keycodes
|
||||
*/
|
||||
static unsigned char at2lnx[] =
|
||||
{
|
||||
0x01, /* KEY_Escape */ 0x02, /* KEY_1 */
|
||||
0x03, /* KEY_2 */ 0x04, /* KEY_3 */
|
||||
0x05, /* KEY_4 */ 0x06, /* KEY_5 */
|
||||
0x07, /* KEY_6 */ 0x08, /* KEY_7 */
|
||||
0x09, /* KEY_8 */ 0x0a, /* KEY_9 */
|
||||
0x0b, /* KEY_0 */ 0x0c, /* KEY_Minus */
|
||||
0x0d, /* KEY_Equal */ 0x0e, /* KEY_BackSpace */
|
||||
0x0f, /* KEY_Tab */ 0x10, /* KEY_Q */
|
||||
0x11, /* KEY_W */ 0x12, /* KEY_E */
|
||||
0x13, /* KEY_R */ 0x14, /* KEY_T */
|
||||
0x15, /* KEY_Y */ 0x16, /* KEY_U */
|
||||
0x17, /* KEY_I */ 0x18, /* KEY_O */
|
||||
0x19, /* KEY_P */ 0x1a, /* KEY_LBrace */
|
||||
0x1b, /* KEY_RBrace */ 0x1c, /* KEY_Enter */
|
||||
0x1d, /* KEY_LCtrl */ 0x1e, /* KEY_A */
|
||||
0x1f, /* KEY_S */ 0x20, /* KEY_D */
|
||||
0x21, /* KEY_F */ 0x22, /* KEY_G */
|
||||
0x23, /* KEY_H */ 0x24, /* KEY_J */
|
||||
0x25, /* KEY_K */ 0x26, /* KEY_L */
|
||||
0x27, /* KEY_SemiColon */ 0x28, /* KEY_Quote */
|
||||
0x29, /* KEY_Tilde */ 0x2a, /* KEY_ShiftL */
|
||||
0x2b, /* KEY_BSlash */ 0x2c, /* KEY_Z */
|
||||
0x2d, /* KEY_X */ 0x2e, /* KEY_C */
|
||||
0x2f, /* KEY_V */ 0x30, /* KEY_B */
|
||||
0x31, /* KEY_N */ 0x32, /* KEY_M */
|
||||
0x33, /* KEY_Comma */ 0x34, /* KEY_Period */
|
||||
0x35, /* KEY_Slash */ 0x36, /* KEY_ShiftR */
|
||||
0x37, /* KEY_KP_Multiply */ 0x38, /* KEY_Alt */
|
||||
0x39, /* KEY_Space */ 0x3a, /* KEY_CapsLock */
|
||||
0x3b, /* KEY_F1 */ 0x3c, /* KEY_F2 */
|
||||
0x3d, /* KEY_F3 */ 0x3e, /* KEY_F4 */
|
||||
0x3f, /* KEY_F5 */ 0x40, /* KEY_F6 */
|
||||
0x41, /* KEY_F7 */ 0x42, /* KEY_F8 */
|
||||
0x43, /* KEY_F9 */ 0x44, /* KEY_F10 */
|
||||
0x45, /* KEY_NumLock */ 0x46, /* KEY_ScrollLock */
|
||||
0x47, /* KEY_KP_7 */ 0x48, /* KEY_KP_8 */
|
||||
0x49, /* KEY_KP_9 */ 0x4a, /* KEY_KP_Minus */
|
||||
0x4b, /* KEY_KP_4 */ 0x4c, /* KEY_KP_5 */
|
||||
0x4d, /* KEY_KP_6 */ 0x4e, /* KEY_KP_Plus */
|
||||
0x4f, /* KEY_KP_1 */ 0x50, /* KEY_KP_2 */
|
||||
0x51, /* KEY_KP_3 */ 0x52, /* KEY_KP_0 */
|
||||
0x53, /* KEY_KP_Decimal */ 0x54, /* KEY_SysReqest */
|
||||
0x00, /* 0x55 */ 0x56, /* KEY_Less */
|
||||
0x57, /* KEY_F11 */ 0x58, /* KEY_F12 */
|
||||
0x66, /* KEY_Home */ 0x67, /* KEY_Up */
|
||||
0x68, /* KEY_PgUp */ 0x69, /* KEY_Left */
|
||||
0x5d, /* KEY_Begin */ 0x6a, /* KEY_Right */
|
||||
0x6b, /* KEY_End */ 0x6c, /* KEY_Down */
|
||||
0x6d, /* KEY_PgDown */ 0x6e, /* KEY_Insert */
|
||||
0x6f, /* KEY_Delete */ 0x60, /* KEY_KP_Enter */
|
||||
0x61, /* KEY_RCtrl */ 0x77, /* KEY_Pause */
|
||||
0x63, /* KEY_Print */ 0x62, /* KEY_KP_Divide */
|
||||
0x64, /* KEY_AltLang */ 0x65, /* KEY_Break */
|
||||
0x00, /* KEY_LMeta */ 0x00, /* KEY_RMeta */
|
||||
0x7A, /* KEY_Menu/FOCUS_PF11*/0x00, /* 0x6e */
|
||||
0x7B, /* FOCUS_PF12 */ 0x00, /* 0x70 */
|
||||
0x00, /* 0x71 */ 0x00, /* 0x72 */
|
||||
0x59, /* FOCUS_PF2 */ 0x78, /* FOCUS_PF9 */
|
||||
0x00, /* 0x75 */ 0x00, /* 0x76 */
|
||||
0x5A, /* FOCUS_PF3 */ 0x5B, /* FOCUS_PF4 */
|
||||
0x5C, /* FOCUS_PF5 */ 0x5D, /* FOCUS_PF6 */
|
||||
0x5E, /* FOCUS_PF7 */ 0x5F, /* FOCUS_PF8 */
|
||||
0x7C, /* JAP_86 */ 0x79, /* FOCUS_PF10 */
|
||||
0x00, /* 0x7f */
|
||||
};
|
||||
#define NUM_AT2LNX (sizeof(at2lnx) / sizeof(at2lnx[0]))
|
||||
|
||||
#define NUM_CUSTOMKEYS NR_KEYS
|
||||
|
||||
static void
|
||||
readKernelMapping(InputInfoPtr pInfo, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
KeySym *k;
|
||||
int i;
|
||||
int maxkey;
|
||||
static unsigned char tbl[GLYPHS_PER_KEY] =
|
||||
{
|
||||
0, /* unshifted */
|
||||
1, /* shifted */
|
||||
0, /* modeswitch unshifted */
|
||||
0 /* modeswitch shifted */
|
||||
};
|
||||
|
||||
/*
|
||||
* Read the mapping from the kernel.
|
||||
* Since we're still using the XFree86 scancode->AT keycode mapping
|
||||
* routines, we need to convert the AT keycodes to Linux keycodes,
|
||||
* then translate the Linux keysyms into X keysyms.
|
||||
*
|
||||
* First, figure out which tables to use for the modeswitch columns
|
||||
* above, from the XF86Config fields.
|
||||
*/
|
||||
tbl[2] = 8; /* alt */
|
||||
tbl[3] = tbl[2] | 1;
|
||||
|
||||
if (pKbd->CustomKeycodes) {
|
||||
k = map;
|
||||
maxkey = NUM_CUSTOMKEYS;
|
||||
}
|
||||
else {
|
||||
k = map+GLYPHS_PER_KEY;
|
||||
maxkey = NUM_AT2LNX;
|
||||
}
|
||||
|
||||
for (i = 0; i < maxkey; ++i)
|
||||
{
|
||||
struct kbentry kbe;
|
||||
int j;
|
||||
|
||||
if (pKbd->CustomKeycodes)
|
||||
kbe.kb_index = i;
|
||||
else
|
||||
kbe.kb_index = at2lnx[i];
|
||||
|
||||
for (j = 0; j < GLYPHS_PER_KEY; ++j, ++k)
|
||||
{
|
||||
unsigned short kval;
|
||||
|
||||
*k = NoSymbol;
|
||||
|
||||
kbe.kb_table = tbl[j];
|
||||
if (
|
||||
(!pKbd->CustomKeycodes && kbe.kb_index == 0) ||
|
||||
ioctl(pInfo->fd, KDGKBENT, &kbe))
|
||||
continue;
|
||||
|
||||
kval = KVAL(kbe.kb_value);
|
||||
switch (KTYP(kbe.kb_value))
|
||||
{
|
||||
case KT_LATIN:
|
||||
case KT_LETTER:
|
||||
*k = linux_to_x[kval];
|
||||
break;
|
||||
|
||||
case KT_FN:
|
||||
if (kval <= 19)
|
||||
*k = XK_F1 + kval;
|
||||
else switch (kbe.kb_value)
|
||||
{
|
||||
case K_FIND:
|
||||
*k = XK_Home; /* or XK_Find */
|
||||
break;
|
||||
case K_INSERT:
|
||||
*k = XK_Insert;
|
||||
break;
|
||||
case K_REMOVE:
|
||||
*k = XK_Delete;
|
||||
break;
|
||||
case K_SELECT:
|
||||
*k = XK_End; /* or XK_Select */
|
||||
break;
|
||||
case K_PGUP:
|
||||
*k = XK_Prior;
|
||||
break;
|
||||
case K_PGDN:
|
||||
*k = XK_Next;
|
||||
break;
|
||||
case K_HELP:
|
||||
*k = XK_Help;
|
||||
break;
|
||||
case K_DO:
|
||||
*k = XK_Execute;
|
||||
break;
|
||||
case K_PAUSE:
|
||||
*k = XK_Pause;
|
||||
break;
|
||||
case K_MACRO:
|
||||
*k = XK_Menu;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
case KT_SPEC:
|
||||
switch (kbe.kb_value)
|
||||
{
|
||||
case K_ENTER:
|
||||
*k = XK_Return;
|
||||
break;
|
||||
case K_BREAK:
|
||||
*k = XK_Break;
|
||||
break;
|
||||
case K_CAPS:
|
||||
*k = XK_Caps_Lock;
|
||||
break;
|
||||
case K_NUM:
|
||||
*k = XK_Num_Lock;
|
||||
break;
|
||||
case K_HOLD:
|
||||
*k = XK_Scroll_Lock;
|
||||
break;
|
||||
case K_COMPOSE:
|
||||
*k = XK_Multi_key;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
case KT_PAD:
|
||||
switch (kbe.kb_value)
|
||||
{
|
||||
case K_PPLUS:
|
||||
*k = XK_KP_Add;
|
||||
break;
|
||||
case K_PMINUS:
|
||||
*k = XK_KP_Subtract;
|
||||
break;
|
||||
case K_PSTAR:
|
||||
*k = XK_KP_Multiply;
|
||||
break;
|
||||
case K_PSLASH:
|
||||
*k = XK_KP_Divide;
|
||||
break;
|
||||
case K_PENTER:
|
||||
*k = XK_KP_Enter;
|
||||
break;
|
||||
case K_PCOMMA:
|
||||
*k = XK_KP_Separator;
|
||||
break;
|
||||
case K_PDOT:
|
||||
*k = XK_KP_Decimal;
|
||||
break;
|
||||
case K_PPLUSMINUS:
|
||||
*k = XK_KP_Subtract;
|
||||
break;
|
||||
default:
|
||||
if (kval <= 9)
|
||||
*k = XK_KP_0 + kval;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
/*
|
||||
* KT_DEAD keys are for accelerated diacritical creation.
|
||||
*/
|
||||
case KT_DEAD:
|
||||
switch (kbe.kb_value)
|
||||
{
|
||||
case K_DGRAVE:
|
||||
*k = XK_dead_grave;
|
||||
break;
|
||||
case K_DACUTE:
|
||||
*k = XK_dead_acute;
|
||||
break;
|
||||
case K_DCIRCM:
|
||||
*k = XK_dead_circumflex;
|
||||
break;
|
||||
case K_DTILDE:
|
||||
*k = XK_dead_tilde;
|
||||
break;
|
||||
case K_DDIERE:
|
||||
*k = XK_dead_diaeresis;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
case KT_CUR:
|
||||
switch (kbe.kb_value)
|
||||
{
|
||||
case K_DOWN:
|
||||
*k = XK_Down;
|
||||
break;
|
||||
case K_LEFT:
|
||||
*k = XK_Left;
|
||||
break;
|
||||
case K_RIGHT:
|
||||
*k = XK_Right;
|
||||
break;
|
||||
case K_UP:
|
||||
*k = XK_Up;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
case KT_SHIFT:
|
||||
switch (kbe.kb_value)
|
||||
{
|
||||
case K_ALTGR:
|
||||
*k = XK_Alt_R;
|
||||
break;
|
||||
case K_ALT:
|
||||
*k = (kbe.kb_index == 0x64 ?
|
||||
XK_Alt_R : XK_Alt_L);
|
||||
break;
|
||||
case K_CTRL:
|
||||
*k = (kbe.kb_index == 0x61 ?
|
||||
XK_Control_R : XK_Control_L);
|
||||
break;
|
||||
case K_CTRLL:
|
||||
*k = XK_Control_L;
|
||||
break;
|
||||
case K_CTRLR:
|
||||
*k = XK_Control_R;
|
||||
break;
|
||||
case K_SHIFT:
|
||||
*k = (kbe.kb_index == 0x36 ?
|
||||
XK_Shift_R : XK_Shift_L);
|
||||
break;
|
||||
case K_SHIFTL:
|
||||
*k = XK_Shift_L;
|
||||
break;
|
||||
case K_SHIFTR:
|
||||
*k = XK_Shift_R;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
/*
|
||||
* KT_ASCII keys accumulate a 3 digit decimal number that gets
|
||||
* emitted when the shift state changes. We can't emulate that.
|
||||
*/
|
||||
case KT_ASCII:
|
||||
break;
|
||||
|
||||
case KT_LOCK:
|
||||
if (kbe.kb_value == K_SHIFTLOCK)
|
||||
*k = XK_Shift_Lock;
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (k[-1] == k[-2]) k[-1] = NoSymbol;
|
||||
if (k[-2] == k[-3]) k[-2] = NoSymbol;
|
||||
if (k[-3] == k[-4]) k[-3] = NoSymbol;
|
||||
if (k[-4] == k[-2] && k[-3] == k[-1]) k[-2] = k[-1] = NoSymbol;
|
||||
if (k[-1] == k[-4] && k[-2] == k[-3] && k[-2] == NoSymbol) k[-1] =NoSymbol;
|
||||
}
|
||||
|
||||
if (!pKbd->CustomKeycodes)
|
||||
return;
|
||||
|
||||
/*
|
||||
* Find the Mapping for the special server functions
|
||||
*/
|
||||
pKbd->specialMap = (TransMapPtr) xcalloc(NUM_CUSTOMKEYS, 1);
|
||||
if (pKbd->specialMap != NULL) {
|
||||
pKbd->specialMap->end = NUM_CUSTOMKEYS;
|
||||
pKbd->specialMap->map = (unsigned char*) xcalloc(NUM_CUSTOMKEYS, 1);
|
||||
if (pKbd->specialMap == NULL) {
|
||||
xfree(pKbd->specialMap);
|
||||
pKbd->specialMap = NULL;
|
||||
}
|
||||
}
|
||||
if (pKbd->specialMap == NULL) {
|
||||
xf86Msg(X_ERROR, "%s can't allocate \"special map\"\n", pInfo->name);
|
||||
return;
|
||||
}
|
||||
|
||||
for (i = 0; i < NUM_CUSTOMKEYS; ++i) {
|
||||
struct kbentry kbe;
|
||||
int special = 0;
|
||||
|
||||
kbe.kb_index = i;
|
||||
kbe.kb_table = 0; /* Plain map */
|
||||
if (!ioctl(pInfo->fd, KDGKBENT, &kbe))
|
||||
switch (kbe.kb_value) {
|
||||
case K(KT_LATIN,0x7f): /* This catches DEL too... But who cares? */
|
||||
special = KEY_BackSpace;
|
||||
break;
|
||||
case K_PMINUS:
|
||||
special = KEY_KP_Minus;
|
||||
break;
|
||||
case K_PPLUS:
|
||||
special = KEY_KP_Plus;
|
||||
break;
|
||||
case K_F1:
|
||||
special = KEY_F1;
|
||||
break;
|
||||
case K_F2:
|
||||
special = KEY_F2;
|
||||
break;
|
||||
case K_F3:
|
||||
special = KEY_F3;
|
||||
break;
|
||||
case K_F4:
|
||||
special = KEY_F4;
|
||||
break;
|
||||
case K_F5:
|
||||
special = KEY_F5;
|
||||
break;
|
||||
case K_F6:
|
||||
special = KEY_F6;
|
||||
break;
|
||||
case K_F7:
|
||||
special = KEY_F7;
|
||||
break;
|
||||
case K_F8:
|
||||
special = KEY_F8;
|
||||
break;
|
||||
case K_F9:
|
||||
special = KEY_F9;
|
||||
break;
|
||||
case K_F10:
|
||||
special = KEY_F10;
|
||||
break;
|
||||
case K_F11:
|
||||
special = KEY_F11;
|
||||
break;
|
||||
case K_F12:
|
||||
special = KEY_F12;
|
||||
break;
|
||||
case K_ALT:
|
||||
special = KEY_Alt;
|
||||
break;
|
||||
case K_ALTGR:
|
||||
special = KEY_AltLang;
|
||||
break;
|
||||
case K_CONS:
|
||||
special = KEY_SysReqest;
|
||||
break;
|
||||
}
|
||||
pKbd->specialMap->map[i] = special;
|
||||
}
|
||||
}
|
|
@ -1,530 +0,0 @@
|
|||
|
||||
/*
|
||||
* Copyright (c) 2002 by The XFree86 Project, Inc.
|
||||
* Author: Ivan Pascal.
|
||||
*
|
||||
* Based on the code from lnx_io.c which is
|
||||
* Copyright 1992 by Orest Zborowski <obz@Kodak.com>
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*/
|
||||
|
||||
#define NEED_EVENTS
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
#if defined(DO_OS_FONTRESTORE)
|
||||
#include "lnx.h"
|
||||
#endif
|
||||
#include "lnx_kbd.h"
|
||||
|
||||
#define KBC_TIMEOUT 250 /* Timeout in ms for sending to keyboard controller */
|
||||
|
||||
static KbdProtocolRec protocols[] = {
|
||||
{"standard", PROT_STD },
|
||||
{ NULL, PROT_UNKNOWN_KBD }
|
||||
};
|
||||
|
||||
extern Bool VTSwitchEnabled;
|
||||
#ifdef USE_VT_SYSREQ
|
||||
extern Bool VTSysreqToggle;
|
||||
#endif
|
||||
|
||||
static void
|
||||
SoundBell(InputInfoPtr pInfo, int loudness, int pitch, int duration)
|
||||
{
|
||||
if (loudness && pitch)
|
||||
{
|
||||
ioctl(pInfo->fd, KDMKTONE,
|
||||
((1193190 / pitch) & 0xffff) |
|
||||
(((unsigned long)duration *
|
||||
loudness / 50) << 16));
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdLeds(InputInfoPtr pInfo, int leds)
|
||||
{
|
||||
int real_leds = 0;
|
||||
|
||||
#if defined (__sparc__)
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
if (pKbd->sunKbd) {
|
||||
if (leds & 0x08) real_leds |= XLED1;
|
||||
if (leds & 0x04) real_leds |= XLED3;
|
||||
if (leds & 0x02) real_leds |= XLED4;
|
||||
if (leds & 0x01) real_leds |= XLED2;
|
||||
leds = real_leds;
|
||||
real_leds = 0;
|
||||
}
|
||||
#endif /* defined (__sparc__) */
|
||||
#ifdef LED_CAP
|
||||
if (leds & XLED1) real_leds |= LED_CAP;
|
||||
if (leds & XLED2) real_leds |= LED_NUM;
|
||||
if (leds & XLED3) real_leds |= LED_SCR;
|
||||
#ifdef LED_COMP
|
||||
if (leds & XLED4) real_leds |= LED_COMP;
|
||||
#else
|
||||
if (leds & XLED4) real_leds |= LED_SCR;
|
||||
#endif
|
||||
#endif
|
||||
ioctl(pInfo->fd, KDSETLED, real_leds);
|
||||
}
|
||||
|
||||
static int
|
||||
GetKbdLeds(InputInfoPtr pInfo)
|
||||
{
|
||||
int real_leds, leds = 0;
|
||||
|
||||
ioctl(pInfo->fd, KDGETLED, &real_leds);
|
||||
|
||||
if (real_leds & LED_CAP) leds |= XLED1;
|
||||
if (real_leds & LED_NUM) leds |= XLED2;
|
||||
if (real_leds & LED_SCR) leds |= XLED3;
|
||||
|
||||
return(leds);
|
||||
}
|
||||
|
||||
static int
|
||||
KDKBDREP_ioctl_ok(int rate, int delay) {
|
||||
#if defined(KDKBDREP) && !defined(__sparc__)
|
||||
/* This ioctl is defined in <linux/kd.h> but is not
|
||||
implemented anywhere - must be in some m68k patches. */
|
||||
struct kbd_repeat kbdrep_s;
|
||||
|
||||
/* don't change, just test */
|
||||
kbdrep_s.LNX_KBD_PERIOD_NAME = -1;
|
||||
kbdrep_s.delay = -1;
|
||||
if (ioctl( xf86Info.consoleFd, KDKBDREP, &kbdrep_s )) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* do the change */
|
||||
if (rate == 0) /* switch repeat off */
|
||||
kbdrep_s.LNX_KBD_PERIOD_NAME = 0;
|
||||
else
|
||||
kbdrep_s.LNX_KBD_PERIOD_NAME = 10000 / rate; /* convert cps to msec */
|
||||
if (kbdrep_s.LNX_KBD_PERIOD_NAME < 1)
|
||||
kbdrep_s.LNX_KBD_PERIOD_NAME = 1;
|
||||
kbdrep_s.delay = delay;
|
||||
if (kbdrep_s.delay < 1)
|
||||
kbdrep_s.delay = 1;
|
||||
|
||||
if (ioctl( xf86Info.consoleFd, KDKBDREP, &kbdrep_s )) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
return 1; /* success! */
|
||||
#else /* no KDKBDREP */
|
||||
return 0;
|
||||
#endif /* KDKBDREP */
|
||||
}
|
||||
|
||||
static int
|
||||
KIOCSRATE_ioctl_ok(int rate, int delay) {
|
||||
#ifdef KIOCSRATE
|
||||
struct kbd_rate kbdrate_s;
|
||||
int fd;
|
||||
|
||||
fd = open("/dev/kbd", O_RDONLY);
|
||||
if (fd == -1)
|
||||
return 0;
|
||||
|
||||
kbdrate_s.rate = (rate + 5) / 10; /* must be integer, so round up */
|
||||
kbdrate_s.delay = delay * HZ / 1000; /* convert ms to Hz */
|
||||
if (kbdrate_s.rate > 50)
|
||||
kbdrate_s.rate = 50;
|
||||
|
||||
if (ioctl( fd, KIOCSRATE, &kbdrate_s )) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
close( fd );
|
||||
|
||||
return 1;
|
||||
#else /* no KIOCSRATE */
|
||||
return 0;
|
||||
#endif /* KIOCSRATE */
|
||||
}
|
||||
|
||||
#undef rate
|
||||
|
||||
static void
|
||||
SetKbdRepeat(InputInfoPtr pInfo, char rad)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int i;
|
||||
int timeout;
|
||||
int value = 0x7f; /* Maximum delay with slowest rate */
|
||||
|
||||
#ifdef __sparc__
|
||||
int rate = 500; /* Default rate */
|
||||
int delay = 200; /* Default delay */
|
||||
#else
|
||||
int rate = 300; /* Default rate */
|
||||
int delay = 250; /* Default delay */
|
||||
#endif
|
||||
|
||||
static int valid_rates[] = { 300, 267, 240, 218, 200, 185, 171, 160, 150,
|
||||
133, 120, 109, 100, 92, 86, 80, 75, 67,
|
||||
60, 55, 50, 46, 43, 40, 37, 33, 30, 27,
|
||||
25, 23, 21, 20 };
|
||||
#define RATE_COUNT (sizeof( valid_rates ) / sizeof( int ))
|
||||
|
||||
static int valid_delays[] = { 250, 500, 750, 1000 };
|
||||
#define DELAY_COUNT (sizeof( valid_delays ) / sizeof( int ))
|
||||
|
||||
if (pKbd->rate >= 0)
|
||||
rate = pKbd->rate * 10;
|
||||
if (pKbd->delay >= 0)
|
||||
delay = pKbd->delay;
|
||||
|
||||
if(KDKBDREP_ioctl_ok(rate, delay)) /* m68k? */
|
||||
return;
|
||||
|
||||
if(KIOCSRATE_ioctl_ok(rate, delay)) /* sparc? */
|
||||
return;
|
||||
|
||||
if (xf86IsPc98())
|
||||
return;
|
||||
|
||||
#if defined(__alpha__) || defined (__i386__) || defined(__ia64__)
|
||||
|
||||
if (!xorgHWAccess) {
|
||||
if (xf86EnableIO())
|
||||
xorgHWAccess = TRUE;
|
||||
else
|
||||
return;
|
||||
}
|
||||
|
||||
/* The ioport way */
|
||||
|
||||
for (i = 0; i < RATE_COUNT; i++)
|
||||
if (rate >= valid_rates[i]) {
|
||||
value &= 0x60;
|
||||
value |= i;
|
||||
break;
|
||||
}
|
||||
|
||||
for (i = 0; i < DELAY_COUNT; i++)
|
||||
if (delay <= valid_delays[i]) {
|
||||
value &= 0x1f;
|
||||
value |= i << 5;
|
||||
break;
|
||||
}
|
||||
|
||||
timeout = KBC_TIMEOUT;
|
||||
while (((inb(0x64) & 2) == 2) && --timeout)
|
||||
usleep(1000); /* wait */
|
||||
|
||||
if (timeout == 0)
|
||||
return;
|
||||
|
||||
outb(0x60, 0xf3); /* set typematic rate */
|
||||
while (((inb(0x64) & 2) == 2) && --timeout)
|
||||
usleep(1000); /* wait */
|
||||
|
||||
usleep(10000);
|
||||
outb(0x60, value);
|
||||
|
||||
#endif /* __alpha__ || __i386__ || __ia64__ */
|
||||
}
|
||||
|
||||
typedef struct {
|
||||
int kbdtrans;
|
||||
struct termios kbdtty;
|
||||
} LnxKbdPrivRec, *LnxKbdPrivPtr;
|
||||
|
||||
static int
|
||||
KbdInit(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
LnxKbdPrivPtr priv = (LnxKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
ioctl (pInfo->fd, KDGKBMODE, &(priv->kbdtrans));
|
||||
tcgetattr (pInfo->fd, &(priv->kbdtty));
|
||||
}
|
||||
if (!pKbd->CustomKeycodes) {
|
||||
pKbd->RemapScanCode = ATScancode;
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOn(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
LnxKbdPrivPtr priv = (LnxKbdPrivPtr) pKbd->private;
|
||||
struct termios nTty;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
if (pKbd->CustomKeycodes)
|
||||
ioctl(pInfo->fd, KDSKBMODE, K_MEDIUMRAW);
|
||||
else
|
||||
ioctl(pInfo->fd, KDSKBMODE, K_RAW);
|
||||
|
||||
nTty = priv->kbdtty;
|
||||
nTty.c_iflag = (IGNPAR | IGNBRK) & (~PARMRK) & (~ISTRIP);
|
||||
nTty.c_oflag = 0;
|
||||
nTty.c_cflag = CREAD | CS8;
|
||||
nTty.c_lflag = 0;
|
||||
nTty.c_cc[VTIME]=0;
|
||||
nTty.c_cc[VMIN]=1;
|
||||
cfsetispeed(&nTty, 9600);
|
||||
cfsetospeed(&nTty, 9600);
|
||||
tcsetattr(pInfo->fd, TCSANOW, &nTty);
|
||||
}
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOff(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
LnxKbdPrivPtr priv = (LnxKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
ioctl(pInfo->fd, KDSKBMODE, priv->kbdtrans);
|
||||
tcsetattr(pInfo->fd, TCSANOW, &(priv->kbdtty));
|
||||
}
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
GetSpecialKey(InputInfoPtr pInfo, int scanCode)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int specialkey = scanCode;
|
||||
|
||||
#if defined (__sparc__)
|
||||
if (pKbd->sunKbd) {
|
||||
switch (scanCode) {
|
||||
case 0x2b: specialkey = KEY_BackSpace; break;
|
||||
case 0x47: specialkey = KEY_KP_Minus; break;
|
||||
case 0x7d: specialkey = KEY_KP_Plus; break;
|
||||
/* XXX needs cases for KEY_KP_Divide and KEY_KP_Multiply */
|
||||
case 0x05: specialkey = KEY_F1; break;
|
||||
case 0x06: specialkey = KEY_F2; break;
|
||||
case 0x08: specialkey = KEY_F3; break;
|
||||
case 0x0a: specialkey = KEY_F4; break;
|
||||
case 0x0c: specialkey = KEY_F5; break;
|
||||
case 0x0e: specialkey = KEY_F6; break;
|
||||
case 0x10: specialkey = KEY_F7; break;
|
||||
case 0x11: specialkey = KEY_F8; break;
|
||||
case 0x12: specialkey = KEY_F9; break;
|
||||
case 0x07: specialkey = KEY_F10; break;
|
||||
case 0x09: specialkey = KEY_F11; break;
|
||||
case 0x0b: specialkey = KEY_F12; break;
|
||||
default: specialkey = 0; break;
|
||||
}
|
||||
return specialkey;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (pKbd->CustomKeycodes) {
|
||||
specialkey = pKbd->specialMap->map[scanCode];
|
||||
}
|
||||
return specialkey;
|
||||
}
|
||||
|
||||
#define ModifierSet(k) ((modifiers & (k)) == (k))
|
||||
|
||||
static
|
||||
Bool SpecialKey(InputInfoPtr pInfo, int key, Bool down, int modifiers)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
if(!pKbd->vtSwitchSupported)
|
||||
return FALSE;
|
||||
|
||||
if ((ModifierSet(ControlMask | AltMask)) ||
|
||||
(ModifierSet(ControlMask | AltLangMask))) {
|
||||
if (VTSwitchEnabled && !xf86Info.vtSysreq && !xf86Info.dontVTSwitch) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F1 + 1);
|
||||
return TRUE;
|
||||
}
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F11 + 11);
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
#ifdef USE_VT_SYSREQ
|
||||
if (VTSwitchEnabled && xf86Info.vtSysreq && !xf86Info.dontVTSwitch) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F1 + 1);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(xf86Info.consoleFd, VT_ACTIVATE, key - KEY_F11 + 11);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
/* Ignore these keys -- ie don't let them cancel an alt-sysreq */
|
||||
case KEY_Alt:
|
||||
case KEY_AltLang:
|
||||
break;
|
||||
case KEY_SysReqest:
|
||||
if ((ModifierSet(AltMask) || ModifierSet(AltLangMask)) && down)
|
||||
VTSysreqToggle = TRUE;
|
||||
break;
|
||||
default:
|
||||
/*
|
||||
* We only land here when Alt-SysReq is followed by a
|
||||
* non-switching key.
|
||||
*/
|
||||
if (VTSysreqToggle)
|
||||
VTSysreqToggle = FALSE;
|
||||
}
|
||||
}
|
||||
#endif /* USE_VT_SYSREQ */
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static void
|
||||
stdReadInput(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
unsigned char rBuf[64];
|
||||
int nBytes, i;
|
||||
if ((nBytes = read( pInfo->fd, (char *)rBuf, sizeof(rBuf))) > 0) {
|
||||
for (i = 0; i < nBytes; i++)
|
||||
pKbd->PostEvent(pInfo, rBuf[i] & 0x7f,
|
||||
rBuf[i] & 0x80 ? FALSE : TRUE);
|
||||
}
|
||||
}
|
||||
|
||||
static Bool
|
||||
OpenKeyboard(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int i;
|
||||
KbdProtocolId prot = PROT_UNKNOWN_KBD;
|
||||
char *s;
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Protocol", NULL);
|
||||
for (i = 0; protocols[i].name; i++) {
|
||||
if (xf86NameCmp(s, protocols[i].name) == 0) {
|
||||
prot = protocols[i].id;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch (prot) {
|
||||
case PROT_STD:
|
||||
pInfo->read_input = stdReadInput;
|
||||
break;
|
||||
default:
|
||||
xf86Msg(X_ERROR,"\"%s\" is not a valid keyboard protocol name\n", s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
xf86Msg(X_CONFIG, "%s: Protocol: %s\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Device", NULL);
|
||||
if (s == NULL) {
|
||||
pInfo->fd = xf86Info.consoleFd;
|
||||
pKbd->isConsole = TRUE;
|
||||
} else {
|
||||
pInfo->fd = open(s, O_RDONLY | O_NONBLOCK | O_EXCL);
|
||||
if (pInfo->fd == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot open \"%s\"\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
pKbd->isConsole = FALSE;
|
||||
xfree(s);
|
||||
}
|
||||
|
||||
if (pKbd->isConsole)
|
||||
pKbd->vtSwitchSupported = TRUE;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = pInfo->private;
|
||||
|
||||
pKbd->KbdInit = KbdInit;
|
||||
pKbd->KbdOn = KbdOn;
|
||||
pKbd->KbdOff = KbdOff;
|
||||
pKbd->Bell = SoundBell;
|
||||
pKbd->SetLeds = SetKbdLeds;
|
||||
pKbd->GetLeds = GetKbdLeds;
|
||||
pKbd->SetKbdRepeat = SetKbdRepeat;
|
||||
pKbd->KbdGetMapping = KbdGetMapping;
|
||||
pKbd->SpecialKey = SpecialKey;
|
||||
|
||||
pKbd->RemapScanCode = NULL;
|
||||
pKbd->GetSpecialKey = GetSpecialKey;
|
||||
|
||||
pKbd->OpenKeyboard = OpenKeyboard;
|
||||
pKbd->vtSwitchSupported = FALSE;
|
||||
|
||||
pKbd->private = xcalloc(sizeof(LnxKbdPrivRec), 1);
|
||||
if (pKbd->private == NULL) {
|
||||
xf86Msg(X_ERROR,"can't allocate keyboard OS private data\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
#if defined(__powerpc__)
|
||||
{
|
||||
FILE *f;
|
||||
f = fopen("/proc/sys/dev/mac_hid/keyboard_sends_linux_keycodes","r");
|
||||
if (f) {
|
||||
if (fgetc(f) == '0')
|
||||
pKbd->CustomKeycodes = TRUE;
|
||||
fclose(f);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
return TRUE;
|
||||
}
|
|
@ -1,165 +0,0 @@
|
|||
/*
|
||||
* Copyright 1993 by Thomas Mueller
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the name of Thomas Mueller not be used in
|
||||
* advertising or publicity pertaining to distribution of the software without
|
||||
* specific, written prior permission. Thomas Mueller makes no representations
|
||||
* about the suitability of this software for any purpose. It is provided
|
||||
* "as is" without express or implied warranty.
|
||||
*
|
||||
* THOMAS MUELLER DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||||
* EVENT SHALL THOMAS MUELLER BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
|
||||
* DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
||||
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
* PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
#if defined(KDMKTONE) || defined(KIOCSOUND)
|
||||
/* Lynx 2.2.1 has sophisticated atc stuff.... */
|
||||
_X_EXPORT void
|
||||
xf86SoundKbdBell(int loudness, int pitch, int duration)
|
||||
{
|
||||
if (loudness && pitch)
|
||||
{
|
||||
#ifdef KDMKTONE
|
||||
/*
|
||||
* If we have KDMKTONE use it to avoid putting the server
|
||||
* to sleep
|
||||
*/
|
||||
ioctl(xf86Info.consoleFd, KDMKTONE,
|
||||
(pitch & 0xffff) |
|
||||
(((unsigned long)duration *
|
||||
loudness / 50) << 16));
|
||||
#else
|
||||
ioctl(xf86Info.consoleFd, KIOCSOUND, pitch);
|
||||
usleep(xf86Info.bell_duration * loudness * 20);
|
||||
ioctl(xf86Info.consoleFd, KIOCSOUND, 0);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
/* this is pulled from /sys/drivers/vt100/atbeep.c */
|
||||
|
||||
#define SPEAKER_CONTROL 0x61
|
||||
#define TIMER_CONTROL 0x43
|
||||
#define TIMER_DATA 0x42
|
||||
#define TIMER_LOAD_CMD 0xb6
|
||||
|
||||
#define TIMER_CONSTANT 1193280
|
||||
#define FREQ_LO(f) ((TIMER_CONSTANT / (f)) % 256)
|
||||
#define FREQ_HI(f) ((TIMER_CONSTANT / (f)) / 256)
|
||||
|
||||
void
|
||||
xf86SoundKbdBell(int loudness, int pitch, int duration)
|
||||
{
|
||||
int flo = FREQ_LO(pitch);
|
||||
int fhi = FREQ_HI(pitch);
|
||||
|
||||
outb(TIMER_CONTROL, TIMER_LOAD_CMD);
|
||||
outb(TIMER_DATA, flo);
|
||||
outb(TIMER_DATA, fhi);
|
||||
|
||||
/* speaker on */
|
||||
outb(SPEAKER_CONTROL, inb(SPEAKER_CONTROL) | 3);
|
||||
usleep(xf86Info.bell_duration * loudness * 20);
|
||||
/* speaker off */
|
||||
outb(SPEAKER_CONTROL, inb(SPEAKER_CONTROL) & ~3);
|
||||
}
|
||||
#endif
|
||||
|
||||
void
|
||||
xf86SetKbdLeds(int leds)
|
||||
{
|
||||
#ifdef KBD_SET_LEDS
|
||||
ioctl(xf86Info.consoleFd, KBD_SET_LEDS, &leds);
|
||||
#endif
|
||||
}
|
||||
|
||||
int
|
||||
xf86GetKbdLeds()
|
||||
{
|
||||
#ifdef KBD_SET_LEDS
|
||||
int leds;
|
||||
|
||||
if (ioctl(xf86Info.consoleFd, KBD_SET_LEDS, &leds) < 0)
|
||||
return 0;
|
||||
|
||||
return leds;
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
xf86SetKbdRepeat(char rad)
|
||||
{
|
||||
}
|
||||
|
||||
static struct termio kbdtty;
|
||||
|
||||
void
|
||||
xf86KbdInit()
|
||||
{
|
||||
ioctl(xf86Info.consoleFd, TCGETA, &kbdtty);
|
||||
}
|
||||
|
||||
int
|
||||
xf86KbdOn()
|
||||
{
|
||||
struct termio nTty;
|
||||
|
||||
/* set CAPS_LOCK to behave as CAPS_LOCK not as CTRL */
|
||||
write(xf86Info.consoleFd, "\033<", 2);
|
||||
|
||||
/* enable scan mode */
|
||||
ioctl(xf86Info.consoleFd, TIO_ENSCANMODE, NULL);
|
||||
|
||||
nTty = kbdtty;
|
||||
nTty.c_iflag = (IGNPAR | IGNBRK) & (~PARMRK) & (~ISTRIP);
|
||||
nTty.c_oflag = 0;
|
||||
nTty.c_cflag = CREAD | CS8;
|
||||
nTty.c_lflag = 0;
|
||||
nTty.c_cc[VTIME]=0;
|
||||
nTty.c_cc[VMIN]=1;
|
||||
ioctl(xf86Info.consoleFd, TCSETA, &nTty);
|
||||
|
||||
return(xf86Info.consoleFd);
|
||||
}
|
||||
|
||||
int
|
||||
xf86KbdOff()
|
||||
{
|
||||
/* disable scan mode */
|
||||
ioctl(xf86Info.consoleFd, TIO_DISSCANMODE, NULL);
|
||||
ioctl(xf86Info.consoleFd, TCSETA, &kbdtty);
|
||||
return(xf86Info.consoleFd);
|
||||
}
|
||||
|
||||
#include "xf86OSKbd.h"
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
return FALSE;
|
||||
}
|
|
@ -4,7 +4,5 @@ EXTRA_DIST = \
|
|||
sco_init.c \
|
||||
sco_io.c \
|
||||
sco_iop.c \
|
||||
sco_kbd.c \
|
||||
sco_kbd.h \
|
||||
sco_mouse.c \
|
||||
sco_video.c
|
||||
|
|
|
@ -1,304 +0,0 @@
|
|||
/* $XFree86$ */
|
||||
/*
|
||||
* Copyright 2005 by J. Kean Johnston <jkj@sco.com>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the name J. Kean Johnston not be used in
|
||||
* advertising or publicity pertaining to distribution of the software without
|
||||
* specific, written prior permission. J. Kean Johnston makes no
|
||||
* representations about the suitability of this software for any purpose.
|
||||
* It is provided "as is" without express or implied warranty.
|
||||
*
|
||||
* J. KEAN JOHNSTON DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||||
* EVENT SHALL J. KEAN JOHNSTON BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
* PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
|
||||
/*
|
||||
* Based on xf86KbdMap.c, which is
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany.
|
||||
* Copyright (c) 1992-2003 by The XFree86 Project, Inc.
|
||||
*/
|
||||
|
||||
#include "X.h"
|
||||
#include "Xmd.h"
|
||||
#include "input.h"
|
||||
#include "scrnintstr.h"
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
#include "xf86Keymap.h"
|
||||
|
||||
#include "sco_kbd.h"
|
||||
|
||||
#define KD_GET_ENTRY(i,n) \
|
||||
eascii_to_x[((priv->keymap.key[i].spcl << (n+1)) & 0x100) + priv->keymap.key[i].map[n]]
|
||||
|
||||
/*
|
||||
* NOTE: Not all possible remappable symbols are remapped. There are two main
|
||||
* reasons:
|
||||
* a) The mapping between scancode and SYSV/386 - symboltable
|
||||
* is inconsistent between different versions and has some
|
||||
* BIG mistakes.
|
||||
* b) In X-Windows there is a difference between numpad-keys
|
||||
* and normal keys. SYSV/386 uses for both kinds of keys
|
||||
* the same symbol.
|
||||
*
|
||||
* Thus only the alpha keypad and the function keys are translated.
|
||||
* Also CapsLock, NumLock, ScrollLock, Shift, Control & Alt.
|
||||
*/
|
||||
|
||||
static unsigned char remap[128] = {
|
||||
0, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, /* 0x00 - 0x07 */
|
||||
0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, /* 0x08 - 0x0f */
|
||||
0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, /* 0x10 - 0x17 */
|
||||
0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f, /* 0x18 - 0x1f */
|
||||
0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, /* 0x20 - 0x27 */
|
||||
0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, /* 0x28 - 0x2f */
|
||||
0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0, /* 0x30 - 0x37 */
|
||||
0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, /* 0x38 - 0x3f */
|
||||
0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0, /* 0x40 - 0x47 */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x48 - 0x4f */
|
||||
0, 0, 0, 0, 0, 0, 0x56, 0x57, /* 0x50 - 0x57 */
|
||||
0x58, 0, 0, 0, 0, 0, 0, 0, /* 0x58 - 0x5f */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x60 - 0x67 */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x68 - 0x6f */
|
||||
0, 0, 0x69, 0x65, 0, 0, 0, 0, /* 0x70 - 0x77 */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x78 - 0x7f */
|
||||
};
|
||||
|
||||
static KeySym eascii_to_x[512] = {
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_BackSpace, XK_Tab, XK_Linefeed, NoSymbol,
|
||||
NoSymbol, XK_Return, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, XK_Escape,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_space, XK_exclam, XK_quotedbl, XK_numbersign,
|
||||
XK_dollar, XK_percent, XK_ampersand, XK_apostrophe,
|
||||
XK_parenleft, XK_parenright, XK_asterisk, XK_plus,
|
||||
XK_comma, XK_minus, XK_period, XK_slash,
|
||||
XK_0, XK_1, XK_2, XK_3,
|
||||
XK_4, XK_5, XK_6, XK_7,
|
||||
XK_8, XK_9, XK_colon, XK_semicolon,
|
||||
XK_less, XK_equal, XK_greater, XK_question,
|
||||
XK_at, XK_A, XK_B, XK_C,
|
||||
XK_D, XK_E, XK_F, XK_G,
|
||||
XK_H, XK_I, XK_J, XK_K,
|
||||
XK_L, XK_M, XK_N, XK_O,
|
||||
XK_P, XK_Q, XK_R, XK_S,
|
||||
XK_T, XK_U, XK_V, XK_W,
|
||||
XK_X, XK_Y, XK_Z, XK_bracketleft,
|
||||
XK_backslash, XK_bracketright,XK_asciicircum, XK_underscore,
|
||||
XK_grave, XK_a, XK_b, XK_c,
|
||||
XK_d, XK_e, XK_f, XK_g,
|
||||
XK_h, XK_i, XK_j, XK_k,
|
||||
XK_l, XK_m, XK_n, XK_o,
|
||||
XK_p, XK_q, XK_r, XK_s,
|
||||
XK_t, XK_u, XK_v, XK_w,
|
||||
XK_x, XK_y, XK_z, XK_braceleft,
|
||||
XK_bar, XK_braceright, XK_asciitilde, XK_Delete,
|
||||
XK_Ccedilla, XK_udiaeresis, XK_eacute, XK_acircumflex,
|
||||
XK_adiaeresis, XK_agrave, XK_aring, XK_ccedilla,
|
||||
XK_ecircumflex, XK_ediaeresis, XK_egrave, XK_idiaeresis,
|
||||
XK_icircumflex, XK_igrave, XK_Adiaeresis, XK_Aring,
|
||||
XK_Eacute, XK_ae, XK_AE, XK_ocircumflex,
|
||||
XK_odiaeresis, XK_ograve, XK_ucircumflex, XK_ugrave,
|
||||
XK_ydiaeresis, XK_Odiaeresis, XK_Udiaeresis, XK_cent,
|
||||
XK_sterling, XK_yen, XK_paragraph, XK_section,
|
||||
XK_aacute, XK_iacute, XK_oacute, XK_uacute,
|
||||
XK_ntilde, XK_Ntilde, XK_ordfeminine, XK_masculine,
|
||||
XK_questiondown,XK_hyphen, XK_notsign, XK_onehalf,
|
||||
XK_onequarter, XK_exclamdown, XK_guillemotleft,XK_guillemotright,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_Greek_alpha, XK_ssharp, XK_Greek_GAMMA, XK_Greek_pi,
|
||||
XK_Greek_SIGMA, XK_Greek_sigma, XK_mu, XK_Greek_tau,
|
||||
XK_Greek_PHI, XK_Greek_THETA, XK_Greek_OMEGA, XK_Greek_delta,
|
||||
XK_infinity, XK_Ooblique, XK_Greek_epsilon, XK_intersection,
|
||||
XK_identical, XK_plusminus, XK_greaterthanequal, XK_lessthanequal,
|
||||
XK_topintegral, XK_botintegral, XK_division, XK_similarequal,
|
||||
XK_degree, NoSymbol, NoSymbol, XK_radical,
|
||||
XK_Greek_eta, XK_twosuperior, XK_periodcentered, NoSymbol,
|
||||
|
||||
/*
|
||||
* special marked entries (256 + x)
|
||||
*/
|
||||
|
||||
NoSymbol, NoSymbol, XK_Shift_L, XK_Shift_R,
|
||||
XK_Caps_Lock, XK_Num_Lock, XK_Scroll_Lock, XK_Alt_L,
|
||||
NoSymbol, XK_Control_L, XK_Alt_L, XK_Alt_R,
|
||||
XK_Control_L, XK_Control_R, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, XK_F1,
|
||||
XK_F2, XK_F3, XK_F4, XK_F5,
|
||||
XK_F6, XK_F7, XK_F8, XK_F9,
|
||||
XK_F10, XK_F11, XK_F12, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
};
|
||||
|
||||
/*
|
||||
* KbdGetMapping --
|
||||
* Get the national keyboard mapping. The keyboard type is set, a new map
|
||||
* and the modifiermap is computed.
|
||||
*/
|
||||
|
||||
void
|
||||
KbdGetMapping (InputInfoPtr pInfo, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
ScoKbdPrivPtr priv = (ScoKbdPrivPtr) pKbd->private;
|
||||
KeySym *k;
|
||||
int i;
|
||||
KeySym *pMap = map;
|
||||
|
||||
for (i = 0; i < priv->keymap.n_keys && i < NUM_KEYCODES; i++) {
|
||||
if (remap[i]) {
|
||||
k = pMap + (remap[i] << 2);
|
||||
|
||||
k[0] = KD_GET_ENTRY(i,0); /* non-shifed */
|
||||
k[1] = KD_GET_ENTRY(i,1); /* shifted */
|
||||
k[2] = KD_GET_ENTRY(i,4); /* alt */
|
||||
k[3] = KD_GET_ENTRY(i,5); /* alt - shifted */
|
||||
|
||||
if (k[3] == k[2]) k[3] = NoSymbol;
|
||||
if (k[2] == k[1]) k[2] = NoSymbol;
|
||||
if (k[1] == k[0]) k[1] = NoSymbol;
|
||||
if (k[0] == k[2] && k[1] == k[3]) k[2] = k[3] = NoSymbol;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* compute the modifier map
|
||||
*/
|
||||
for (i = 0; i < MAP_LENGTH; i++)
|
||||
pModMap[i] = NoSymbol; /* make sure it is restored */
|
||||
|
||||
for (k = pMap, i = MIN_KEYCODE;
|
||||
i < (NUM_KEYCODES + MIN_KEYCODE);
|
||||
i++, k += GLYPHS_PER_KEY) {
|
||||
|
||||
switch(*k) {
|
||||
case XK_Shift_L:
|
||||
case XK_Shift_R:
|
||||
pModMap[i] = ShiftMask;
|
||||
break;
|
||||
|
||||
case XK_Control_L:
|
||||
case XK_Control_R:
|
||||
pModMap[i] = ControlMask;
|
||||
break;
|
||||
|
||||
case XK_Caps_Lock:
|
||||
pModMap[i] = LockMask;
|
||||
break;
|
||||
|
||||
case XK_Alt_L:
|
||||
case XK_Alt_R:
|
||||
pModMap[i] = AltMask;
|
||||
break;
|
||||
|
||||
case XK_Num_Lock:
|
||||
pModMap[i] = NumLockMask;
|
||||
break;
|
||||
|
||||
case XK_Scroll_Lock:
|
||||
pModMap[i] = ScrollLockMask;
|
||||
break;
|
||||
|
||||
/* kana support */
|
||||
case XK_Kana_Lock:
|
||||
case XK_Kana_Shift:
|
||||
pModMap[i] = KanaMask;
|
||||
break;
|
||||
|
||||
/* alternate toggle for multinational support */
|
||||
case XK_Mode_switch:
|
||||
pModMap[i] = AltLangMask;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
pKeySyms->map = pMap;
|
||||
pKeySyms->mapWidth = GLYPHS_PER_KEY;
|
||||
pKeySyms->minKeyCode = MIN_KEYCODE;
|
||||
pKeySyms->maxKeyCode = MAX_KEYCODE;
|
||||
}
|
|
@ -1,530 +0,0 @@
|
|||
/* $XFree86$ */
|
||||
/*
|
||||
* Copyright 2005 by J. Kean Johnston <jkj@sco.com>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the name J. Kean Johnston not be used in
|
||||
* advertising or publicity pertaining to distribution of the software without
|
||||
* specific, written prior permission. J. Kean Johnston makes no
|
||||
* representations about the suitability of this software for any purpose.
|
||||
* It is provided "as is" without express or implied warranty.
|
||||
*
|
||||
* J. KEAN JOHNSTON DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||||
* EVENT SHALL J. KEAN JOHNSTON BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
* PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
/* $XConsortium$ */
|
||||
|
||||
/*
|
||||
* Based on sco_io.c which is
|
||||
* (C) Copyright 2003 J. Kean Johnston <jkj@sco.com>
|
||||
*
|
||||
* Based on lnx_kbd.c which is
|
||||
* Copyright (c) 2002 by The XFree86 Project, Inc.
|
||||
*
|
||||
* Based on the code from lnx_io.c which is
|
||||
* Copyright 1992 by Orest Zborowski <obz@Kodak.com>
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*/
|
||||
|
||||
#define NEED_EVENTS
|
||||
#include "X.h"
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#define _NEED_SYSI86
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86OSpriv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
#include "sco_kbd.h"
|
||||
|
||||
#include <sys/param.h>
|
||||
#include <sys/emap.h>
|
||||
#include <sys/nmap.h>
|
||||
|
||||
static KbdProtocolRec protocols[] = {
|
||||
{ "standard", PROT_STD },
|
||||
{ NULL, PROT_UNKNOWN_KBD }
|
||||
};
|
||||
|
||||
extern Bool VTSwitchEnabled;
|
||||
#ifdef USE_VT_SYSREQ
|
||||
extern Bool VTSysreqToggle;
|
||||
#endif
|
||||
|
||||
static void
|
||||
SoundBell(InputInfoPtr pInfo, int loudness, int pitch, int duration)
|
||||
{
|
||||
if (loudness && pitch) {
|
||||
ioctl(pInfo->fd, KIOCSOUND, 1193180 / pitch);
|
||||
usleep(duration * loudness * 20);
|
||||
ioctl(pInfo->fd, KIOCSOUND, 0);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdLeds(InputInfoPtr pInfo, int leds)
|
||||
{
|
||||
int real_leds = 0;
|
||||
static int once = 1;
|
||||
|
||||
/*
|
||||
* sleep the first time through under SCO. There appears to be a
|
||||
* timing problem in the driver which causes the keyboard to be lost.
|
||||
* This usleep stops it from occurring. NOTE: this was in the old code.
|
||||
* I am not convinced it is true any longer, but it doesn't hurt to
|
||||
* leave this in here.
|
||||
*/
|
||||
if (once) {
|
||||
usleep(100);
|
||||
once = 0;
|
||||
}
|
||||
|
||||
#ifdef LED_CAP
|
||||
if (leds & XLED1)
|
||||
real_leds |= LED_CAP;
|
||||
if (leds & XLED2)
|
||||
real_leds |= LED_NUM;
|
||||
if (leds & XLED3)
|
||||
real_leds |= LED_SCR;
|
||||
#ifdef LED_COMP
|
||||
if (leds & XLED4)
|
||||
real_leds |= LED_COMP;
|
||||
#else
|
||||
if (leds & XLED4)
|
||||
real_leds |= LED_SCR;
|
||||
#endif
|
||||
#endif
|
||||
ioctl(pInfo->fd, KDSETLED, real_leds);
|
||||
}
|
||||
|
||||
static int
|
||||
GetKbdLeds(InputInfoPtr pInfo)
|
||||
{
|
||||
int real_leds, leds = 0;
|
||||
|
||||
ioctl(pInfo->fd, KDGETLED, &real_leds);
|
||||
|
||||
if (real_leds & LED_CAP) leds |= XLED1;
|
||||
if (real_leds & LED_NUM) leds |= XLED2;
|
||||
if (real_leds & LED_SCR) leds |= XLED3;
|
||||
|
||||
return(leds);
|
||||
}
|
||||
|
||||
/*
|
||||
* NOTE: Only OpenServer Release 5.0.6 with Release Supplement 5.0.6A
|
||||
* and later have the required ioctl. 5.0.6A or higher is HIGHLY
|
||||
* recommended. The console driver is quite a different beast on that OS.
|
||||
*/
|
||||
#undef rate
|
||||
|
||||
static void
|
||||
SetKbdRepeat(InputInfoPtr pInfo, char rad)
|
||||
{
|
||||
#if defined(KBIO_SETRATE)
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int i;
|
||||
int value = 0x7f; /* Maximum delay with slowest rate */
|
||||
int delay = 250; /* Default delay */
|
||||
int rate = 300; /* Default repeat rate */
|
||||
|
||||
static int valid_rates[] = { 300, 267, 240, 218, 200, 185, 171, 160, 150,
|
||||
133, 120, 109, 100, 92, 86, 80, 75, 67,
|
||||
60, 55, 50, 46, 43, 40, 37, 33, 30, 27,
|
||||
25, 23, 21, 20 };
|
||||
#define RATE_COUNT (sizeof( valid_rates ) / sizeof( int ))
|
||||
|
||||
static int valid_delays[] = { 250, 500, 750, 1000 };
|
||||
#define DELAY_COUNT (sizeof( valid_delays ) / sizeof( int ))
|
||||
|
||||
if (pKbd->rate >= 0)
|
||||
rate = pKbd->rate * 10;
|
||||
if (pKbd->delay >= 0)
|
||||
delay = pKbd->delay;
|
||||
|
||||
for (i = 0; i < RATE_COUNT; i++)
|
||||
if (rate >= valid_rates[i]) {
|
||||
value &= 0x60;
|
||||
value |= i;
|
||||
break;
|
||||
}
|
||||
|
||||
for (i = 0; i < DELAY_COUNT; i++)
|
||||
if (delay <= valid_delays[i]) {
|
||||
value &= 0x1f;
|
||||
value |= i << 5;
|
||||
break;
|
||||
}
|
||||
|
||||
ioctl (pInfo->fd, KBIO_SETRATE, value);
|
||||
#endif /* defined(KBIO_SETRATE) */
|
||||
}
|
||||
|
||||
static int
|
||||
KbdInit(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
ScoKbdPrivPtr priv = (ScoKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
priv->use_tcs = 1;
|
||||
priv->use_kd = 1;
|
||||
priv->no_nmap = 1;
|
||||
priv->no_emap = 1;
|
||||
priv->orig_getsc = 0;
|
||||
|
||||
if (ioctl (pInfo->fd, TCGETSC, &priv->orig_getsc) < 0)
|
||||
priv->use_tcs = 0;
|
||||
if (ioctl (pInfo->fd, KDGKBMODE, &priv->orig_kbm) < 0)
|
||||
priv->use_kd = 0;
|
||||
|
||||
if (!priv->use_tcs && !priv->use_kd) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Could not determine keyboard mode\n");
|
||||
return !Success;
|
||||
}
|
||||
|
||||
/*
|
||||
* One day this should be fixed to translate normal ASCII characters
|
||||
* back into scancodes or into events that XFree86 wants, but not
|
||||
* now. For the time being, we only support scancode mode screens.
|
||||
*/
|
||||
if (priv->use_tcs && !(priv->orig_getsc & KB_ISSCANCODE)) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Keyboard can not send scancodes\n");
|
||||
return !Success;
|
||||
}
|
||||
|
||||
/*
|
||||
* We need to get the original keyboard map and NUL out the lock
|
||||
* modifiers. This prevents the scancode API from messing with
|
||||
* the keyboard LED's. We restore the original map when we exit.
|
||||
*/
|
||||
if (ioctl (pInfo->fd, GIO_KEYMAP, &priv->keymap) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to get keyboard map (%s)\n",
|
||||
strerror(errno));
|
||||
return !Success;
|
||||
}
|
||||
if (ioctl (pInfo->fd, GIO_KEYMAP, &priv->noledmap) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to get keyboard map (%s)\n",
|
||||
strerror(errno));
|
||||
return !Success;
|
||||
} else {
|
||||
int i, j;
|
||||
|
||||
for (i = 0; i < priv->noledmap.n_keys; i++) {
|
||||
for (j = 0; j < NUM_STATES; j++) {
|
||||
if (IS_SPECIAL(priv->noledmap, i, j) &&
|
||||
((priv->noledmap.key[i].map[j] == K_CLK) ||
|
||||
(priv->noledmap.key[i].map[j] == K_NLK) ||
|
||||
(priv->noledmap.key[i].map[j] == K_SLK))) {
|
||||
priv->noledmap.key[i].map[j] = K_NOP;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (ioctl (pInfo->fd, XCGETA, &priv->kbdtty) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to get terminal modes (%s)\n",
|
||||
strerror(errno));
|
||||
return !Success;
|
||||
}
|
||||
|
||||
priv->sc_mapbuf = xalloc (10*BSIZE);
|
||||
priv->sc_mapbuf2 = xalloc(10*BSIZE);
|
||||
|
||||
/* Get the emap */
|
||||
if (ioctl (pInfo->fd, LDGMAP, priv->sc_mapbuf) < 0) {
|
||||
if (errno != ENAVAIL) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to retrieve e-map (%s)\n",
|
||||
strerror (errno));
|
||||
return !Success;
|
||||
}
|
||||
priv->no_emap = 0;
|
||||
}
|
||||
|
||||
/* Get the nmap */
|
||||
if (ioctl (pInfo->fd, NMGMAP, priv->sc_mapbuf2) < 0) {
|
||||
if (errno != ENAVAIL) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to retrieve n-map (%s)\n",
|
||||
strerror (errno));
|
||||
return !Success;
|
||||
}
|
||||
priv->no_nmap = 0;
|
||||
}
|
||||
} /* End of if we are on a console */
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOn(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
ScoKbdPrivPtr priv = (ScoKbdPrivPtr) pKbd->private;
|
||||
struct termios newtio;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
ioctl (pInfo->fd, LDNMAP); /* Turn e-mapping off */
|
||||
ioctl (pInfo->fd, NMNMAP); /* Turn n-mapping off */
|
||||
|
||||
newtio = priv->kbdtty; /* structure copy */
|
||||
newtio.c_iflag = (IGNPAR | IGNBRK) & (~PARMRK) & (~ISTRIP);
|
||||
newtio.c_oflag = 0;
|
||||
newtio.c_cflag = CREAD | CS8 | B9600;
|
||||
newtio.c_lflag = 0;
|
||||
newtio.c_cc[VTIME]=0;
|
||||
newtio.c_cc[VMIN]=1;
|
||||
cfsetispeed(&newtio, 9600);
|
||||
cfsetospeed(&newtio, 9600);
|
||||
ioctl(pInfo->fd, XCSETA, &newtio);
|
||||
|
||||
/* Now tell the keyboard driver to send us raw scancodes */
|
||||
if (priv->use_tcs) {
|
||||
int nm = priv->orig_getsc;
|
||||
nm &= ~KB_XSCANCODE;
|
||||
ioctl (pInfo->fd, TCSETSC, &nm);
|
||||
}
|
||||
|
||||
if (priv->use_kd)
|
||||
ioctl (pInfo->fd, KDSKBMODE, K_RAW);
|
||||
|
||||
ioctl (pInfo->fd, PIO_KEYMAP, &priv->noledmap);
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOff(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
ScoKbdPrivPtr priv = (ScoKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
/* Revert back to original translate scancode mode */
|
||||
if (priv->use_tcs)
|
||||
ioctl (pInfo->fd, TCSETSC, &priv->orig_getsc);
|
||||
if (priv->use_kd)
|
||||
ioctl (pInfo->fd, KDSKBMODE, priv->orig_kbm);
|
||||
|
||||
ioctl (pInfo->fd, PIO_KEYMAP, &priv->keymap);
|
||||
|
||||
if (priv->no_emap)
|
||||
ioctl (pInfo->fd, LDSMAP, priv->sc_mapbuf);
|
||||
if (priv->no_nmap)
|
||||
ioctl (pInfo->fd, NMSMAP, priv->sc_mapbuf2);
|
||||
|
||||
ioctl(pInfo->fd, XCSETA, &priv->kbdtty);
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
GetSpecialKey(InputInfoPtr pInfo, int scanCode)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int specialkey = scanCode;
|
||||
|
||||
if (pKbd->CustomKeycodes) {
|
||||
specialkey = pKbd->specialMap->map[scanCode];
|
||||
}
|
||||
return specialkey;
|
||||
}
|
||||
|
||||
#define ModifierSet(k) ((modifiers & (k)) == (k))
|
||||
|
||||
static Bool
|
||||
SpecialKey(InputInfoPtr pInfo, int key, Bool down, int modifiers)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
if(!pKbd->vtSwitchSupported)
|
||||
return FALSE;
|
||||
|
||||
if ((!ModifierSet(ShiftMask)) && ((ModifierSet(ControlMask | AltMask)) ||
|
||||
(ModifierSet(ControlMask | AltLangMask)))) {
|
||||
if (VTSwitchEnabled && !xf86Info.vtSysreq) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (down) {
|
||||
int sts = key - KEY_F1;
|
||||
if (sts != xf86Info.vtno) {
|
||||
ioctl(pInfo->fd, VT_ACTIVATE, sts);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (down) {
|
||||
int sts = key - KEY_F11 + 10;
|
||||
if (sts != xf86Info.vtno) {
|
||||
ioctl(pInfo->fd, VT_ACTIVATE, sts);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
#ifdef USE_VT_SYSREQ
|
||||
if (VTSwitchEnabled && xf86Info.vtSysreq) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(pInfo->fd, VT_ACTIVATE, key - KEY_F1);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(pInfo->fd, VT_ACTIVATE, key - KEY_F11 + 10);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
/* Ignore these keys -- ie don't let them cancel an alt-sysreq */
|
||||
case KEY_Alt:
|
||||
case KEY_AltLang:
|
||||
break;
|
||||
case KEY_SysReqest:
|
||||
if (!(ModifierSet(ShiftMask) || ModifierSet(ControlMask))) {
|
||||
if ((ModifierSet(AltMask) || ModifierSet(AltLangMask)) && down)
|
||||
VTSysreqToggle = TRUE;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
/*
|
||||
* We only land here when Alt-SysReq is followed by a
|
||||
* non-switching key.
|
||||
*/
|
||||
if (VTSysreqToggle)
|
||||
VTSysreqToggle = FALSE;
|
||||
}
|
||||
}
|
||||
#endif /* USE_VT_SYSREQ */
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static void
|
||||
stdReadInput(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
unsigned char rBuf[64];
|
||||
int nBytes, i;
|
||||
|
||||
if ((nBytes = read( pInfo->fd, (char *)rBuf, sizeof(rBuf))) > 0) {
|
||||
for (i = 0; i < nBytes; i++) {
|
||||
pKbd->PostEvent(pInfo, rBuf[i] & 0x7f, rBuf[i] & 0x80 ? FALSE : TRUE);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static Bool
|
||||
OpenKeyboard(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int i;
|
||||
KbdProtocolId prot = PROT_UNKNOWN_KBD;
|
||||
char *s;
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Protocol", NULL);
|
||||
for (i = 0; protocols[i].name; i++) {
|
||||
if (xf86NameCmp(s, protocols[i].name) == 0) {
|
||||
prot = protocols[i].id;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch (prot) {
|
||||
case PROT_STD:
|
||||
pInfo->read_input = stdReadInput;
|
||||
break;
|
||||
default:
|
||||
xf86Msg(X_ERROR,"\"%s\" is not a valid keyboard protocol name\n", s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
xf86Msg(X_CONFIG, "%s: Protocol: %s\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Device", NULL);
|
||||
if (s == NULL) {
|
||||
pInfo->fd = xf86Info.consoleFd;
|
||||
pKbd->isConsole = TRUE;
|
||||
} else {
|
||||
pInfo->fd = open(s, O_RDONLY | O_NONBLOCK | O_EXCL);
|
||||
if (pInfo->fd == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot open \"%s\"\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
pKbd->isConsole = FALSE;
|
||||
xfree(s);
|
||||
}
|
||||
|
||||
if (pKbd->isConsole)
|
||||
pKbd->vtSwitchSupported = TRUE;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = pInfo->private;
|
||||
|
||||
pKbd->KbdInit = KbdInit;
|
||||
pKbd->KbdOn = KbdOn;
|
||||
pKbd->KbdOff = KbdOff;
|
||||
pKbd->Bell = SoundBell;
|
||||
pKbd->SetLeds = SetKbdLeds;
|
||||
pKbd->GetLeds = GetKbdLeds;
|
||||
pKbd->SetKbdRepeat = SetKbdRepeat;
|
||||
pKbd->KbdGetMapping = KbdGetMapping;
|
||||
pKbd->SpecialKey = SpecialKey;
|
||||
pKbd->GetSpecialKey = GetSpecialKey;
|
||||
pKbd->OpenKeyboard = OpenKeyboard;
|
||||
pKbd->RemapScanCode = ATScancode;
|
||||
pKbd->vtSwitchSupported = FALSE;
|
||||
|
||||
pKbd->private = xcalloc(sizeof(ScoKbdPrivRec), 1);
|
||||
if (pKbd->private == NULL) {
|
||||
xf86Msg(X_ERROR,"can't allocate keyboard OS private data\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
|
@ -1,20 +0,0 @@
|
|||
/* $XFree86$ */
|
||||
#ifndef SCO_KBD_HDR
|
||||
#define SCO_KBD_HDR
|
||||
|
||||
typedef struct {
|
||||
int use_tcs;
|
||||
int use_kd;
|
||||
int no_nmap;
|
||||
int no_emap;
|
||||
int orig_getsc;
|
||||
int orig_kbm;
|
||||
struct termios kbdtty;
|
||||
keymap_t keymap, noledmap;
|
||||
uchar_t *sc_mapbuf;
|
||||
uchar_t *sc_mapbuf2;
|
||||
} ScoKbdPrivRec, *ScoKbdPrivPtr;
|
||||
|
||||
extern void KbdGetMapping(InputInfoPtr pInfo, KeySymsPtr pKeySyms,
|
||||
CARD8 *pModMap);
|
||||
#endif /* SCO_KBD_HDR */
|
|
@ -1,131 +0,0 @@
|
|||
/*
|
||||
* Copyright (c) 2002-2003 by The XFree86 Project, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Except as contained in this notice, the name of the copyright holder(s)
|
||||
* and author(s) shall not be used in advertising or otherwise to promote
|
||||
* the sale, use or other dealings in this Software without prior written
|
||||
* authorization from the copyright holder(s) and author(s).
|
||||
*/
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
|
||||
Bool
|
||||
ATScancode(InputInfoPtr pInfo, int *scanCode)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
switch (pKbd->scanPrefix) {
|
||||
case 0:
|
||||
switch (*scanCode) {
|
||||
case KEY_Prefix0:
|
||||
case KEY_Prefix1:
|
||||
pKbd->scanPrefix = *scanCode; /* special prefixes */
|
||||
return TRUE;
|
||||
}
|
||||
if (!xf86IsPc98()) {
|
||||
switch (*scanCode) {
|
||||
case 0x59: *scanCode = KEY_0x59; break;
|
||||
case 0x5a: *scanCode = KEY_0x5A; break;
|
||||
case 0x5b: *scanCode = KEY_0x5B; break;
|
||||
case 0x5c: *scanCode = KEY_KP_Equal; break; /* Keypad Equal */
|
||||
case 0x5d: *scanCode = KEY_0x5D; break;
|
||||
case 0x5e: *scanCode = KEY_0x5E; break;
|
||||
case 0x5f: *scanCode = KEY_0x5F; break;
|
||||
case 0x62: *scanCode = KEY_0x62; break;
|
||||
case 0x63: *scanCode = KEY_0x63; break;
|
||||
case 0x64: *scanCode = KEY_0x64; break;
|
||||
case 0x65: *scanCode = KEY_0x65; break;
|
||||
case 0x66: *scanCode = KEY_0x66; break;
|
||||
case 0x67: *scanCode = KEY_0x67; break;
|
||||
case 0x68: *scanCode = KEY_0x68; break;
|
||||
case 0x69: *scanCode = KEY_0x69; break;
|
||||
case 0x6a: *scanCode = KEY_0x6A; break;
|
||||
case 0x6b: *scanCode = KEY_0x6B; break;
|
||||
case 0x6c: *scanCode = KEY_0x6C; break;
|
||||
case 0x6d: *scanCode = KEY_0x6D; break;
|
||||
case 0x6e: *scanCode = KEY_0x6E; break;
|
||||
case 0x6f: *scanCode = KEY_0x6F; break;
|
||||
case 0x70: *scanCode = KEY_0x70; break;
|
||||
case 0x71: *scanCode = KEY_0x71; break;
|
||||
case 0x72: *scanCode = KEY_0x72; break;
|
||||
case 0x73: *scanCode = KEY_0x73; break;
|
||||
case 0x74: *scanCode = KEY_0x74; break;
|
||||
case 0x75: *scanCode = KEY_0x75; break;
|
||||
case 0x76: *scanCode = KEY_0x76; break;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case KEY_Prefix0:
|
||||
pKbd->scanPrefix = 0;
|
||||
switch (*scanCode) {
|
||||
case KEY_KP_7: *scanCode = KEY_Home; break; /* curs home */
|
||||
case KEY_KP_8: *scanCode = KEY_Up; break; /* curs up */
|
||||
case KEY_KP_9: *scanCode = KEY_PgUp; break; /* curs pgup */
|
||||
case KEY_KP_4: *scanCode = KEY_Left; break; /* curs left */
|
||||
case KEY_KP_5: *scanCode = KEY_Begin; break; /* curs begin */
|
||||
case KEY_KP_6: *scanCode = KEY_Right; break; /* curs right */
|
||||
case KEY_KP_1: *scanCode = KEY_End; break; /* curs end */
|
||||
case KEY_KP_2: *scanCode = KEY_Down; break; /* curs down */
|
||||
case KEY_KP_3: *scanCode = KEY_PgDown; break; /* curs pgdown */
|
||||
case KEY_KP_0: *scanCode = KEY_Insert; break; /* curs insert */
|
||||
case KEY_KP_Decimal: *scanCode = KEY_Delete; break; /* curs delete */
|
||||
case KEY_Enter: *scanCode = KEY_KP_Enter; break; /* keypad enter */
|
||||
case KEY_LCtrl: *scanCode = KEY_RCtrl; break; /* right ctrl */
|
||||
case KEY_KP_Multiply: *scanCode = KEY_Print; break; /* print */
|
||||
case KEY_Slash: *scanCode = KEY_KP_Divide; break; /* keyp divide */
|
||||
case KEY_Alt: *scanCode = KEY_AltLang; break; /* right alt */
|
||||
case KEY_ScrollLock: *scanCode = KEY_Break; break; /* curs break */
|
||||
case 0x5b: *scanCode = KEY_LMeta; break;
|
||||
case 0x5c: *scanCode = KEY_RMeta; break;
|
||||
case 0x5d: *scanCode = KEY_Menu; break;
|
||||
case KEY_F3: *scanCode = KEY_F13; break;
|
||||
case KEY_F4: *scanCode = KEY_F14; break;
|
||||
case KEY_F5: *scanCode = KEY_F15; break;
|
||||
case KEY_F6: *scanCode = KEY_F16; break;
|
||||
case KEY_F7: *scanCode = KEY_F17; break;
|
||||
case KEY_KP_Plus: *scanCode = KEY_KP_DEC; break;
|
||||
case 0x2A:
|
||||
case 0x36:
|
||||
return TRUE;
|
||||
default:
|
||||
xf86MsgVerb(X_INFO, 4, "Unreported Prefix0 scancode: 0x%02x\n",
|
||||
*scanCode);
|
||||
*scanCode += 0x78;
|
||||
}
|
||||
break;
|
||||
case KEY_Prefix1:
|
||||
pKbd->scanPrefix = (*scanCode == KEY_LCtrl) ? KEY_LCtrl : 0;
|
||||
return TRUE;
|
||||
case KEY_LCtrl:
|
||||
pKbd->scanPrefix = 0;
|
||||
if (*scanCode != KEY_NumLock)
|
||||
return TRUE;
|
||||
*scanCode = KEY_Pause; /* pause */
|
||||
}
|
||||
return FALSE;
|
||||
}
|
|
@ -1,38 +0,0 @@
|
|||
/*
|
||||
* Copyright (c) 2001-2003 by The XFree86 Project, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Except as contained in this notice, the name of the copyright holder(s)
|
||||
* and author(s) shall not be used in advertising or otherwise to promote
|
||||
* the sale, use or other dealings in this Software without prior written
|
||||
* authorization from the copyright holder(s) and author(s).
|
||||
*/
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include "xf86OSKbd.h"
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
return FALSE;
|
||||
}
|
|
@ -1,49 +0,0 @@
|
|||
/*
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the names of Thomas Roell and David Dawes
|
||||
* not be used in advertising or publicity pertaining to distribution of
|
||||
* the software without specific, written prior permission. Thomas Roell and
|
||||
* David Dawes makes no representations about the suitability of this
|
||||
* software for any purpose. It is provided "as is" without express or
|
||||
* implied warranty.
|
||||
*
|
||||
* THOMAS ROELL AND DAVID DAWES DISCLAIMS ALL WARRANTIES WITH REGARD TO
|
||||
* THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS, IN NO EVENT SHALL THOMAS ROELL OR DAVID DAWES BE LIABLE FOR
|
||||
* ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||
* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
*/
|
||||
/* $XConsortium: std_kbdEv.c /main/4 1996/03/11 10:47:33 kaleb $ */
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
void
|
||||
xf86KbdEvents()
|
||||
{
|
||||
unsigned char rBuf[64];
|
||||
int nBytes, i;
|
||||
|
||||
if ((nBytes = read( xf86Info.consoleFd, (char *)rBuf, sizeof(rBuf)))
|
||||
> 0)
|
||||
{
|
||||
for (i = 0; i < nBytes; i++)
|
||||
xf86PostKbdEvent(rBuf[i]);
|
||||
}
|
||||
}
|
||||
|
|
@ -1,105 +0,0 @@
|
|||
/*
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany
|
||||
* Copyright 1993 by David Dawes <dawes@XFree86.org>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the names of Thomas Roell and David Dawes
|
||||
* not be used in advertising or publicity pertaining to distribution of
|
||||
* the software without specific, written prior permission. Thomas Roell and
|
||||
* David Dawes makes no representations about the suitability of this
|
||||
* software for any purpose. It is provided "as is" without express or
|
||||
* implied warranty.
|
||||
*
|
||||
* THOMAS ROELL AND DAVID DAWES DISCLAIMS ALL WARRANTIES WITH REGARD TO
|
||||
* THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS, IN NO EVENT SHALL THOMAS ROELL OR DAVID DAWES BE LIABLE FOR
|
||||
* ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||
* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
*/
|
||||
/* $XConsortium: sysv_kbd.c /main/3 1996/02/21 17:53:59 kaleb $ */
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
int
|
||||
xf86GetKbdLeds()
|
||||
{
|
||||
int leds;
|
||||
|
||||
ioctl(xf86Info.consoleFd, KDGETLED, &leds);
|
||||
return(leds);
|
||||
}
|
||||
|
||||
void
|
||||
xf86SetKbdRepeat(char rad)
|
||||
{
|
||||
#ifdef KDSETRAD
|
||||
ioctl(xf86Info.consoleFd, KDSETRAD, rad);
|
||||
#endif
|
||||
}
|
||||
|
||||
static int kbdtrans;
|
||||
static struct termio kbdtty;
|
||||
static char *kbdemap = NULL;
|
||||
|
||||
void
|
||||
xf86KbdInit()
|
||||
{
|
||||
#ifdef KDGKBMODE
|
||||
ioctl (xf86Info.consoleFd, KDGKBMODE, &kbdtrans);
|
||||
#endif
|
||||
ioctl (xf86Info.consoleFd, TCGETA, &kbdtty);
|
||||
#if defined(E_TABSZ)
|
||||
kbdemap = xalloc(E_TABSZ);
|
||||
if (ioctl(xf86Info.consoleFd, LDGMAP, kbdemap) < 0)
|
||||
{
|
||||
xfree(kbdemap);
|
||||
kbdemap = NULL;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
int
|
||||
xf86KbdOn()
|
||||
{
|
||||
struct termio nTty;
|
||||
|
||||
ioctl(xf86Info.consoleFd, KDSKBMODE, K_RAW);
|
||||
ioctl(xf86Info.consoleFd, LDNMAP, 0); /* disable mapping completely */
|
||||
nTty = kbdtty;
|
||||
nTty.c_iflag = (IGNPAR | IGNBRK) & (~PARMRK) & (~ISTRIP);
|
||||
nTty.c_oflag = 0;
|
||||
nTty.c_cflag = CREAD | CS8 | B9600;
|
||||
nTty.c_lflag = 0;
|
||||
nTty.c_cc[VTIME]=0;
|
||||
nTty.c_cc[VMIN]=1;
|
||||
ioctl(xf86Info.consoleFd, TCSETA, &nTty);
|
||||
return(xf86Info.consoleFd);
|
||||
}
|
||||
|
||||
int
|
||||
xf86KbdOff()
|
||||
{
|
||||
if (kbdemap)
|
||||
{
|
||||
ioctl(xf86Info.consoleFd, LDSMAP, kbdemap);
|
||||
}
|
||||
ioctl(xf86Info.consoleFd, KDSKBMODE, kbdtrans);
|
||||
ioctl(xf86Info.consoleFd, TCSETA, &kbdtty);
|
||||
return(xf86Info.consoleFd);
|
||||
}
|
|
@ -1,10 +1,8 @@
|
|||
if SOLARIS_USL_CONSOLE
|
||||
IO_SRC = $(srcdir)/../sysv/sysv_io.c
|
||||
KBD_SRCS = $(srcdir)/../shared/sysv_kbd.c $(srcdir)/../shared/std_kbdEv.c
|
||||
VTSW_SRC = $(srcdir)/../shared/VTsw_usl.c
|
||||
else
|
||||
IO_SRC = sun_io.c sun_kbd.h
|
||||
KBD_SRCS = sun_kbd.c sun_kbdEv.c sun_kbd.h
|
||||
IO_SRC = sun_io.c
|
||||
VTSW_SRC = $(srcdir)/../shared/VTsw_noop.c
|
||||
endif
|
||||
|
||||
|
@ -22,7 +20,7 @@ solaris-$(SOLARIS_INOUT_ARCH).il: solaris-${SOLARIS_INOUT_ARCH}.S
|
|||
$(CPP) -P -DINLINE_ASM solaris-${SOLARIS_INOUT_ARCH}.S > $@
|
||||
|
||||
noinst_LTLIBRARIES = libsolaris.la
|
||||
libsolaris_la_SOURCES = sun_bios.c sun_init.c $(IO_SRC) $(KBD_SRCS) \
|
||||
libsolaris_la_SOURCES = sun_bios.c sun_init.c $(IO_SRC) \
|
||||
sun_mouse.c sun_vid.c $(AGP_SRC) \
|
||||
$(srcdir)/../shared/libc_wrapper.c \
|
||||
$(srcdir)/../shared/kmod_noop.c $(srcdir)/../shared/pm_noop.c \
|
||||
|
|
|
@ -1,660 +0,0 @@
|
|||
/*
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany
|
||||
* Copyright 1993 by David Dawes <dawes@XFree86.org>
|
||||
* Copyright 1999 by David Holland <davidh@iquest.net)
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that copyright
|
||||
* notice and this permission notice appear in supporting documentation, and
|
||||
* that the names of Thomas Roell, David Dawes, and David Holland not be used
|
||||
* in advertising or publicity pertaining to distribution of the software
|
||||
* without specific, written prior permission. Thomas Roell, David Dawes, and
|
||||
* David Holland make no representations about the suitability of this software
|
||||
* for any purpose. It is provided "as is" without express or implied
|
||||
* warranty.
|
||||
*
|
||||
* THOMAS ROELL, DAVID DAWES, AND DAVID HOLLAND DISCLAIM ALL WARRANTIES WITH
|
||||
* REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||
* AND FITNESS. IN NO EVENT SHALL THOMAS ROELL, DAVID DAWES, OR DAVID HOLLAND
|
||||
* BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
||||
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
/* Copyright 2004-2005 Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the
|
||||
* "Software"), to deal in the Software without restriction, including
|
||||
* without limitation the rights to use, copy, modify, merge, publish,
|
||||
* distribute, and/or sell copies of the Software, and to permit persons
|
||||
* to whom the Software is furnished to do so, provided that the above
|
||||
* copyright notice(s) and this permission notice appear in all copies of
|
||||
* the Software and that both the above copyright notice(s) and this
|
||||
* permission notice appear in supporting documentation.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
|
||||
* OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||
* HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL
|
||||
* INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING
|
||||
* FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
|
||||
* NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
|
||||
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
* Except as contained in this notice, the name of a copyright holder
|
||||
* shall not be used in advertising or otherwise to promote the sale, use
|
||||
* or other dealings in this Software without prior written authorization
|
||||
* of the copyright holder.
|
||||
*/
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "sun_kbd.h"
|
||||
|
||||
/* Define to provide support for using /dev/audio to ring the bell instead of
|
||||
the keyboard beeper */
|
||||
#define AUDIO_BELL
|
||||
|
||||
#ifdef AUDIO_BELL
|
||||
#include <sys/audio.h>
|
||||
#include <sys/uio.h>
|
||||
#include <limits.h>
|
||||
#include <math.h>
|
||||
#include <poll.h>
|
||||
#endif
|
||||
|
||||
/***************************************************************************
|
||||
* Common implementation of routines shared by "keyboard" driver in sun_io.c
|
||||
* and "kbd" driver (later on in this file)
|
||||
*/
|
||||
|
||||
#include <sys/stropts.h>
|
||||
#include <sys/vuid_event.h>
|
||||
#include <sys/kbd.h>
|
||||
|
||||
_X_HIDDEN int
|
||||
sunKbdOpen(const char *devName, pointer options)
|
||||
{
|
||||
int kbdFD;
|
||||
const char *kbdPath = NULL;
|
||||
const char *defaultKbd = "/dev/kbd";
|
||||
|
||||
if (options != NULL) {
|
||||
kbdPath = xf86SetStrOption(options, "Device", NULL);
|
||||
}
|
||||
if (kbdPath == NULL) {
|
||||
kbdPath = defaultKbd;
|
||||
}
|
||||
|
||||
kbdFD = open(kbdPath, O_RDONLY | O_NONBLOCK);
|
||||
|
||||
if (kbdFD == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot open \"%s\"\n", devName, kbdPath);
|
||||
} else {
|
||||
xf86MsgVerb(X_INFO, 3, "%s: Opened device \"%s\"\n", devName, kbdPath);
|
||||
}
|
||||
|
||||
if ((kbdPath != NULL) && (kbdPath != defaultKbd)) {
|
||||
xfree(kbdPath);
|
||||
}
|
||||
return kbdFD;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Save initial keyboard state. This is called at the start of each server
|
||||
* generation.
|
||||
*/
|
||||
|
||||
_X_HIDDEN int
|
||||
sunKbdInit(sunKbdPrivPtr priv, int kbdFD, const char *devName, pointer options)
|
||||
{
|
||||
int ktype, klayout, i;
|
||||
const char *ktype_name;
|
||||
|
||||
priv->kbdFD = kbdFD;
|
||||
priv->devName = devName;
|
||||
priv->otranslation = -1;
|
||||
priv->odirect = -1;
|
||||
|
||||
if (options != NULL) {
|
||||
priv->strmod = xf86SetStrOption(options, "StreamsModule", NULL);
|
||||
priv->audioDevName = xf86SetStrOption(options, "BellDevice", NULL);
|
||||
|
||||
if (priv->audioDevName && (priv->audioDevName[0] == '\0')) {
|
||||
xfree(priv->audioDevName);
|
||||
priv->audioDevName = NULL;
|
||||
}
|
||||
} else {
|
||||
priv->strmod = NULL;
|
||||
priv->audioDevName = NULL;
|
||||
}
|
||||
|
||||
if (priv->strmod) {
|
||||
SYSCALL(i = ioctl(priv->kbdFD, I_PUSH, priv->strmod));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: cannot push module '%s' onto keyboard device: %s\n",
|
||||
priv->devName, priv->strmod, strerror(errno));
|
||||
}
|
||||
}
|
||||
|
||||
SYSCALL(i = ioctl(kbdFD, KIOCTYPE, &ktype));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Unable to determine keyboard type: %s\n",
|
||||
devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
|
||||
SYSCALL(i = ioctl(kbdFD, KIOCLAYOUT, &klayout));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Unable to determine keyboard layout: %s\n",
|
||||
devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
|
||||
switch (ktype) {
|
||||
case KB_SUN3:
|
||||
ktype_name = "Sun Type 3"; break;
|
||||
case KB_SUN4:
|
||||
ktype_name = "Sun Type 4/5/6"; break;
|
||||
case KB_USB:
|
||||
ktype_name = "USB"; break;
|
||||
case KB_PC:
|
||||
ktype_name = "PC"; break;
|
||||
default:
|
||||
ktype_name = "Unknown"; break;
|
||||
}
|
||||
|
||||
xf86Msg(X_PROBED, "%s: Keyboard type: %s (%d)\n",
|
||||
devName, ktype_name, ktype);
|
||||
xf86Msg(X_PROBED, "%s: Keyboard layout: %d\n", devName, klayout);
|
||||
|
||||
priv->ktype = ktype;
|
||||
priv->keyMap = sunGetKbdMapping(ktype);
|
||||
priv->audioState = AB_INITIALIZING;
|
||||
priv->oleds = sunKbdGetLeds(priv);
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
_X_HIDDEN int
|
||||
sunKbdOn(sunKbdPrivPtr priv)
|
||||
{
|
||||
int ktrans, kdirect, i;
|
||||
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCGDIRECT, &kdirect));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: Unable to determine keyboard direct setting: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
|
||||
priv->odirect = kdirect;
|
||||
kdirect = 1;
|
||||
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCSDIRECT, &kdirect));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Failed turning keyboard direct mode on: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
|
||||
/* Setup translation */
|
||||
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCGTRANS, &ktrans));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: Unable to determine keyboard translation mode: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
|
||||
priv->otranslation = ktrans;
|
||||
ktrans = TR_UNTRANS_EVENT;
|
||||
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCTRANS, &ktrans));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Failed setting keyboard translation mode: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
_X_HIDDEN int
|
||||
sunKbdOff(sunKbdPrivPtr priv)
|
||||
{
|
||||
int i;
|
||||
|
||||
/* restore original state */
|
||||
|
||||
sunKbdSetLeds(priv, priv->oleds);
|
||||
|
||||
if (priv->otranslation != -1) {
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCTRANS, &priv->otranslation));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: Unable to restore keyboard translation mode: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
priv->otranslation = -1;
|
||||
}
|
||||
|
||||
if (priv->odirect != -1) {
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCSDIRECT, &priv->odirect));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: Unable to restore keyboard direct setting: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
return BadImplementation;
|
||||
}
|
||||
priv->odirect = -1;
|
||||
}
|
||||
|
||||
if (priv->strmod) {
|
||||
SYSCALL(i = ioctl(priv->kbdFD, I_POP, priv->strmod));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_WARNING,
|
||||
"%s: cannot pop module '%s' off keyboard device: %s\n",
|
||||
priv->devName, priv->strmod, strerror(errno));
|
||||
}
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
#ifdef AUDIO_BELL
|
||||
|
||||
/* Helper function to ring bell via audio device instead of keyboard beeper */
|
||||
|
||||
#define BELL_RATE 48000 /* Samples per second */
|
||||
#define BELL_HZ 50 /* Fraction of a second i.e. 1/x */
|
||||
#define BELL_MS (1000/BELL_HZ) /* MS */
|
||||
#define BELL_SAMPLES (BELL_RATE / BELL_HZ)
|
||||
#define BELL_MIN 3 /* Min # of repeats */
|
||||
|
||||
static int
|
||||
sunKbdAudioBell(sunKbdPrivPtr priv, int loudness, int pitch, int duration)
|
||||
{
|
||||
static short samples[BELL_SAMPLES];
|
||||
static short silence[BELL_SAMPLES]; /* "The Sound of Silence" */
|
||||
static int lastFreq;
|
||||
int cnt;
|
||||
int i;
|
||||
int written;
|
||||
int repeats;
|
||||
int freq;
|
||||
audio_info_t audioInfo;
|
||||
struct iovec iov[IOV_MAX];
|
||||
int iovcnt;
|
||||
double ampl, cyclen, phase;
|
||||
int audioFD;
|
||||
|
||||
if ((loudness <= 0) || (pitch <= 0) || (duration <= 0)) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ((priv == NULL) || (priv->audioDevName == NULL)) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (priv->audioState == AB_INITIALIZING) {
|
||||
priv->audioState = AB_NORMAL;
|
||||
lastFreq = 0;
|
||||
bzero(silence, sizeof(silence));
|
||||
}
|
||||
|
||||
audioFD = open(priv->audioDevName, O_WRONLY | O_NONBLOCK);
|
||||
if (audioFD == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot open audio device \"%s\": %s\n",
|
||||
priv->devName, priv->audioDevName, strerror(errno));
|
||||
return -1;
|
||||
}
|
||||
|
||||
freq = pitch;
|
||||
freq = min(freq, (BELL_RATE / 2) - 1);
|
||||
freq = max(freq, 2 * BELL_HZ);
|
||||
|
||||
/*
|
||||
* Ensure full waves per buffer
|
||||
*/
|
||||
freq -= freq % BELL_HZ;
|
||||
|
||||
if (freq != lastFreq) {
|
||||
lastFreq = freq;
|
||||
ampl = 16384.0;
|
||||
|
||||
cyclen = (double) freq / (double) BELL_RATE;
|
||||
phase = 0.0;
|
||||
|
||||
for (i = 0; i < BELL_SAMPLES; i++) {
|
||||
samples[i] = (short) (ampl * sin(2.0 * M_PI * phase));
|
||||
phase += cyclen;
|
||||
if (phase >= 1.0)
|
||||
phase -= 1.0;
|
||||
}
|
||||
}
|
||||
|
||||
repeats = (duration + (BELL_MS / 2)) / BELL_MS;
|
||||
repeats = max(repeats, BELL_MIN);
|
||||
|
||||
loudness = max(0, loudness);
|
||||
loudness = min(loudness, 100);
|
||||
|
||||
#ifdef DEBUG
|
||||
ErrorF("BELL : freq %d volume %d duration %d repeats %d\n",
|
||||
freq, loudness, duration, repeats);
|
||||
#endif
|
||||
|
||||
AUDIO_INITINFO(&audioInfo);
|
||||
audioInfo.play.encoding = AUDIO_ENCODING_LINEAR;
|
||||
audioInfo.play.sample_rate = BELL_RATE;
|
||||
audioInfo.play.channels = 2;
|
||||
audioInfo.play.precision = 16;
|
||||
audioInfo.play.gain = min(AUDIO_MAX_GAIN, AUDIO_MAX_GAIN * loudness / 100);
|
||||
|
||||
if (ioctl(audioFD, AUDIO_SETINFO, &audioInfo) < 0){
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: AUDIO_SETINFO failed on audio device \"%s\": %s\n",
|
||||
priv->devName, priv->audioDevName, strerror(errno));
|
||||
close(audioFD);
|
||||
return -1;
|
||||
}
|
||||
|
||||
iovcnt = 0;
|
||||
|
||||
for (cnt = 0; cnt <= repeats; cnt++) {
|
||||
iov[iovcnt].iov_base = (char *) samples;
|
||||
iov[iovcnt++].iov_len = sizeof(samples);
|
||||
if (cnt == repeats) {
|
||||
/* Insert a bit of silence so that multiple beeps are distinct and
|
||||
* not compressed into a single tone.
|
||||
*/
|
||||
iov[iovcnt].iov_base = (char *) silence;
|
||||
iov[iovcnt++].iov_len = sizeof(silence);
|
||||
}
|
||||
if ((iovcnt >= IOV_MAX) || (cnt == repeats)) {
|
||||
written = writev(audioFD, iov, iovcnt);
|
||||
|
||||
if ((written < ((int)(sizeof(samples) * iovcnt)))) {
|
||||
/* audio buffer was full! */
|
||||
|
||||
int naptime;
|
||||
|
||||
if (written == -1) {
|
||||
if (errno != EAGAIN) {
|
||||
xf86Msg(X_ERROR,
|
||||
"%s: writev failed on audio device \"%s\": %s\n",
|
||||
priv->devName, priv->audioDevName,
|
||||
strerror(errno));
|
||||
close(audioFD);
|
||||
return -1;
|
||||
}
|
||||
i = iovcnt;
|
||||
} else {
|
||||
i = ((sizeof(samples) * iovcnt) - written)
|
||||
/ sizeof(samples);
|
||||
}
|
||||
cnt -= i;
|
||||
|
||||
/* sleep a little to allow audio buffer to drain */
|
||||
naptime = BELL_MS * i;
|
||||
poll(NULL, 0, naptime);
|
||||
|
||||
i = ((sizeof(samples) * iovcnt) - written) % sizeof(samples);
|
||||
iovcnt = 0;
|
||||
if ((written != -1) && (i > 0)) {
|
||||
iov[iovcnt].iov_base = ((char *) samples) + i;
|
||||
iov[iovcnt++].iov_len = sizeof(samples) - i;
|
||||
}
|
||||
} else {
|
||||
iovcnt = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
close(audioFD);
|
||||
return 0;
|
||||
}
|
||||
|
||||
#endif /* AUDIO_BELL */
|
||||
|
||||
_X_HIDDEN void
|
||||
sunKbdSoundBell(sunKbdPrivPtr priv, int loudness, int pitch, int duration)
|
||||
{
|
||||
int kbdCmd, i;
|
||||
|
||||
if (loudness && pitch)
|
||||
{
|
||||
#ifdef AUDIO_BELL
|
||||
if (priv->audioDevName != NULL) {
|
||||
if (sunKbdAudioBell(priv, loudness, pitch, duration) == 0) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
kbdCmd = KBD_CMD_BELL;
|
||||
|
||||
SYSCALL(i = ioctl (priv->kbdFD, KIOCCMD, &kbdCmd));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Failed to activate bell: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
}
|
||||
|
||||
usleep(duration * loudness * 20);
|
||||
|
||||
kbdCmd = KBD_CMD_NOBELL;
|
||||
SYSCALL(i = ioctl (priv->kbdFD, KIOCCMD, &kbdCmd));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Failed to deactivate bell: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
_X_HIDDEN void
|
||||
sunKbdSetLeds(sunKbdPrivPtr priv, int leds)
|
||||
{
|
||||
int i;
|
||||
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCSLED, &leds));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Failed to set keyboard LED's: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
}
|
||||
}
|
||||
|
||||
_X_HIDDEN int
|
||||
sunKbdGetLeds(sunKbdPrivPtr priv)
|
||||
{
|
||||
int i, leds = 0;
|
||||
|
||||
SYSCALL(i = ioctl(priv->kbdFD, KIOCGLED, &leds));
|
||||
if (i < 0) {
|
||||
xf86Msg(X_ERROR, "%s: Failed to get keyboard LED's: %s\n",
|
||||
priv->devName, strerror(errno));
|
||||
}
|
||||
return leds;
|
||||
}
|
||||
|
||||
/* ARGSUSED0 */
|
||||
_X_HIDDEN void
|
||||
sunKbdSetRepeat(sunKbdPrivPtr priv, char rad)
|
||||
{
|
||||
/* Nothing to do */
|
||||
}
|
||||
|
||||
/***************************************************************************
|
||||
* Routines called from "kbd" driver via proc vectors filled in by
|
||||
* xf86OSKbdPreInit().
|
||||
*/
|
||||
|
||||
|
||||
static int
|
||||
KbdInit(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
|
||||
return sunKbdInit(priv, pInfo->fd, pInfo->name, pInfo->options);
|
||||
}
|
||||
|
||||
|
||||
static int
|
||||
KbdOn(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
|
||||
return sunKbdOn(priv);
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOff(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
|
||||
return sunKbdOff(priv);
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
SoundKbdBell(InputInfoPtr pInfo, int loudness, int pitch, int duration)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
|
||||
sunKbdSoundBell(priv, loudness, pitch, duration);
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdLeds(InputInfoPtr pInfo, int leds)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
int real_leds = sunKbdGetLeds(priv);
|
||||
|
||||
real_leds &= ~(LED_CAPS_LOCK | LED_NUM_LOCK | LED_SCROLL_LOCK | LED_COMPOSE);
|
||||
|
||||
if (leds & XLED1) real_leds |= LED_CAPS_LOCK;
|
||||
if (leds & XLED2) real_leds |= LED_NUM_LOCK;
|
||||
if (leds & XLED3) real_leds |= LED_SCROLL_LOCK;
|
||||
if (leds & XLED4) real_leds |= LED_COMPOSE;
|
||||
|
||||
sunKbdSetLeds(priv, real_leds);
|
||||
}
|
||||
|
||||
static int
|
||||
GetKbdLeds(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
int leds = 0;
|
||||
int real_leds = sunKbdGetLeds(priv);
|
||||
|
||||
if (real_leds & LED_CAPS_LOCK) leds |= XLED1;
|
||||
if (real_leds & LED_NUM_LOCK) leds |= XLED2;
|
||||
if (real_leds & LED_SCROLL_LOCK) leds |= XLED3;
|
||||
if (real_leds & LED_COMPOSE) leds |= XLED4;
|
||||
|
||||
return leds;
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdRepeat(InputInfoPtr pInfo, char rad)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
|
||||
sunKbdSetRepeat(priv, rad);
|
||||
}
|
||||
|
||||
static void
|
||||
KbdGetMapping (InputInfoPtr pInfo, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
||||
{
|
||||
/* Should probably do something better here */
|
||||
xf86KbdGetMapping(pKeySyms, pModMap);
|
||||
}
|
||||
|
||||
static void
|
||||
ReadInput(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
Firm_event event[64];
|
||||
int nBytes, i;
|
||||
|
||||
/* I certainly hope its not possible to read partial events */
|
||||
|
||||
if ((nBytes = read(pInfo->fd, (char *)event, sizeof(event))) > 0)
|
||||
{
|
||||
for (i = 0; i < (nBytes / sizeof(Firm_event)); i++) {
|
||||
pKbd->PostEvent(pInfo, priv->keyMap[event[i].id],
|
||||
event[i].value == VKEY_DOWN ? TRUE : FALSE);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static Bool
|
||||
OpenKeyboard(InputInfoPtr pInfo)
|
||||
{
|
||||
pInfo->fd = sunKbdOpen(pInfo->name, pInfo->options);
|
||||
|
||||
if (pInfo->fd >= 0) {
|
||||
pInfo->read_input = ReadInput;
|
||||
return TRUE;
|
||||
} else {
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = pInfo->private;
|
||||
|
||||
pKbd->KbdInit = KbdInit;
|
||||
pKbd->KbdOn = KbdOn;
|
||||
pKbd->KbdOff = KbdOff;
|
||||
pKbd->Bell = SoundKbdBell;
|
||||
pKbd->SetLeds = SetKbdLeds;
|
||||
pKbd->GetLeds = GetKbdLeds;
|
||||
pKbd->SetKbdRepeat = SetKbdRepeat;
|
||||
pKbd->KbdGetMapping = KbdGetMapping;
|
||||
|
||||
pKbd->RemapScanCode = NULL;
|
||||
pKbd->GetSpecialKey = NULL;
|
||||
pKbd->SpecialKey = NULL;
|
||||
|
||||
pKbd->OpenKeyboard = OpenKeyboard;
|
||||
|
||||
pKbd->vtSwitchSupported = FALSE;
|
||||
pKbd->CustomKeycodes = FALSE;
|
||||
|
||||
pKbd->private = xcalloc(sizeof(sunKbdPrivRec), 1);
|
||||
if (pKbd->private == NULL) {
|
||||
xf86Msg(X_ERROR,"can't allocate keyboard OS private data\n");
|
||||
return FALSE;
|
||||
} else {
|
||||
sunKbdPrivPtr priv = (sunKbdPrivPtr) pKbd->private;
|
||||
priv->otranslation = -1;
|
||||
priv->odirect = -1;
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
|
@ -1,72 +0,0 @@
|
|||
/* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the
|
||||
* "Software"), to deal in the Software without restriction, including
|
||||
* without limitation the rights to use, copy, modify, merge, publish,
|
||||
* distribute, and/or sell copies of the Software, and to permit persons
|
||||
* to whom the Software is furnished to do so, provided that the above
|
||||
* copyright notice(s) and this permission notice appear in all copies of
|
||||
* the Software and that both the above copyright notice(s) and this
|
||||
* permission notice appear in supporting documentation.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
|
||||
* OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
||||
* HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL
|
||||
* INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING
|
||||
* FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
|
||||
* NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
|
||||
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
* Except as contained in this notice, the name of a copyright holder
|
||||
* shall not be used in advertising or otherwise to promote the sale, use
|
||||
* or other dealings in this Software without prior written authorization
|
||||
* of the copyright holder.
|
||||
*/
|
||||
|
||||
#ifndef _XORG_SUN_KBD_H_
|
||||
#define _XORG_SUN_KBD_H_
|
||||
|
||||
/*
|
||||
* Keyboard common implementation routines shared by "keyboard" driver
|
||||
* in sun_io.c and "kbd" driver in sun_kbd.c
|
||||
*/
|
||||
|
||||
typedef struct {
|
||||
int kbdFD;
|
||||
const char * devName;
|
||||
int ktype; /* Keyboard type from KIOCTYPE */
|
||||
Bool kbdActive; /* Have we set kbd modes for X? */
|
||||
int otranslation; /* Original translation mode */
|
||||
int odirect; /* Original "direct" mode setting */
|
||||
unsigned char oleds; /* Original LED state */
|
||||
const char * strmod; /* Streams module pushed on kbd device */
|
||||
const char * audioDevName; /* Audio device path to use for bell
|
||||
or NULL to use keyboard beeper */
|
||||
enum {AB_INITIALIZING, AB_NORMAL} audioState;
|
||||
const unsigned char *keyMap;
|
||||
} sunKbdPrivRec, *sunKbdPrivPtr;
|
||||
|
||||
/* sun_kbd.c */
|
||||
extern int sunKbdOpen (const char *devName, pointer options);
|
||||
extern int sunKbdInit (sunKbdPrivPtr priv, int kbdFD,
|
||||
const char *devName, pointer options);
|
||||
extern int sunKbdOn (sunKbdPrivPtr priv);
|
||||
extern int sunKbdOff (sunKbdPrivPtr priv);
|
||||
|
||||
extern void sunKbdSoundBell (sunKbdPrivPtr priv,
|
||||
int loudness, int pitch, int duration);
|
||||
|
||||
extern void sunKbdSetLeds (sunKbdPrivPtr priv, int leds);
|
||||
extern int sunKbdGetLeds (sunKbdPrivPtr priv);
|
||||
extern void sunKbdSetRepeat (sunKbdPrivPtr priv, char rad);
|
||||
|
||||
/* sun_kbdEv.c */
|
||||
#include <sys/vuid_event.h>
|
||||
extern void sunPostKbdEvent (int ktype, Firm_event *event);
|
||||
|
||||
extern const unsigned char *sunGetKbdMapping(int ktype);
|
||||
|
||||
#endif
|
|
@ -1,854 +0,0 @@
|
|||
/*
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany.
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that copyright
|
||||
* notice and this permission notice appear in supporting documentation, and
|
||||
* that the names of Thomas Roell and David Dawes not be used in advertising or
|
||||
* publicity pertaining to distribution of the software without specific,
|
||||
* written prior permission. Thomas Roell and David Dawes make no
|
||||
* representations about the suitability of this software for any purpose. It
|
||||
* is provided "as is" without express or implied warranty.
|
||||
*
|
||||
* THOMAS ROELL AND DAVID DAWES DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
||||
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
|
||||
* IN NO EVENT SHALL THOMAS ROELL OR DAVID DAWES BE LIABLE FOR ANY SPECIAL,
|
||||
* INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
||||
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
||||
* OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
* PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
|
||||
/* [JCH-96/01/21] Extended std reverse map to four buttons. */
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
#include "sun_kbd.h"
|
||||
|
||||
#ifdef XINPUT
|
||||
#include <X11/extensions/XI.h>
|
||||
#include <X11/extensions/XIproto.h>
|
||||
#include "xf86Xinput.h"
|
||||
#else
|
||||
#include "inputstr.h"
|
||||
#endif
|
||||
|
||||
#include <sys/kbd.h>
|
||||
#include "atKeynames.h"
|
||||
|
||||
#ifdef XKB
|
||||
extern Bool noXkbExtension;
|
||||
#endif
|
||||
|
||||
#define XE_POINTER 1
|
||||
#define XE_KEYBOARD 2
|
||||
|
||||
#ifdef XINPUT
|
||||
#define ENQUEUE(ev, code, direction, dev_type) \
|
||||
(ev)->u.u.detail = (code); \
|
||||
(ev)->u.u.type = (direction); \
|
||||
xf86eqEnqueue((ev))
|
||||
#else
|
||||
#define ENQUEUE(ev, code, direction, dev_type) \
|
||||
(ev)->u.u.detail = (code); \
|
||||
(ev)->u.u.type = (direction); \
|
||||
mieqEnqueue((ev))
|
||||
#endif
|
||||
|
||||
static void startautorepeat(long keycode);
|
||||
static CARD32 processautorepeat(OsTimerPtr timer, CARD32 now, pointer arg);
|
||||
|
||||
static OsTimerPtr sunTimer = NULL;
|
||||
|
||||
/* Map the Solaris keycodes to the "XFree86" keycodes. */
|
||||
/*
|
||||
* This doesn't seem right. It probably needs to be dependent on a keyboard
|
||||
* type.
|
||||
*/
|
||||
|
||||
/* Additional Sun Japanese Keyboard Keys not defined in common/atKeynames.h */
|
||||
#define KEY_Kanji 0x82
|
||||
#define KEY_Execute 0x83
|
||||
|
||||
static unsigned char map[256] = {
|
||||
#if defined(i386) || defined(__i386) || defined(__i386__) || defined(__x86)
|
||||
KEY_NOTUSED, /* 0 */
|
||||
KEY_Tilde, /* 1 */
|
||||
KEY_1, /* 2 */
|
||||
KEY_2, /* 3 */
|
||||
KEY_3, /* 4 */
|
||||
KEY_4, /* 5 */
|
||||
KEY_5, /* 6 */
|
||||
KEY_6, /* 7 */
|
||||
KEY_7, /* 8 */
|
||||
KEY_8, /* 9 */
|
||||
KEY_9, /* 10 */
|
||||
KEY_0, /* 11 */
|
||||
KEY_Minus, /* 12 */
|
||||
KEY_Equal, /* 13 */
|
||||
0x7D, /*KEY_P_YEN*/ /* 14 */
|
||||
KEY_BackSpace, /* 15 */
|
||||
KEY_Tab, /* 16 */
|
||||
KEY_Q, /* 17 */
|
||||
KEY_W, /* 18 */
|
||||
KEY_E, /* 19 */
|
||||
KEY_R, /* 20 */
|
||||
KEY_T, /* 21 */
|
||||
KEY_Y, /* 22 */
|
||||
KEY_U, /* 23 */
|
||||
KEY_I, /* 24 */
|
||||
KEY_O, /* 25 */
|
||||
KEY_P, /* 26 */
|
||||
KEY_LBrace, /* 27 */
|
||||
KEY_RBrace, /* 28 */
|
||||
KEY_BSlash, /* 29 */
|
||||
KEY_CapsLock, /* 30 */
|
||||
KEY_A, /* 31 */
|
||||
KEY_S, /* 32 */
|
||||
KEY_D, /* 33 */
|
||||
KEY_F, /* 34 */
|
||||
KEY_G, /* 35 */
|
||||
KEY_H, /* 36 */
|
||||
KEY_J, /* 37 */
|
||||
KEY_K, /* 38 */
|
||||
KEY_L, /* 39 */
|
||||
KEY_SemiColon, /* 40 */
|
||||
KEY_Quote, /* 41 */
|
||||
KEY_UNKNOWN, /* 42 */
|
||||
KEY_Enter, /* 43 */
|
||||
KEY_ShiftL, /* 44 */
|
||||
KEY_Less, /* 45 */
|
||||
KEY_Z, /* 46 */
|
||||
KEY_X, /* 47 */
|
||||
KEY_C, /* 48 */
|
||||
KEY_V, /* 49 */
|
||||
KEY_B, /* 50 */
|
||||
KEY_N, /* 51 */
|
||||
KEY_M, /* 52 */
|
||||
KEY_Comma, /* 53 */
|
||||
KEY_Period, /* 54 */
|
||||
KEY_Slash, /* 55 */
|
||||
KEY_BSlash2, /* 56 */
|
||||
KEY_ShiftR, /* 57 */
|
||||
KEY_LCtrl, /* 58 */
|
||||
KEY_LMeta, /* 59 */
|
||||
KEY_Alt, /* 60 */
|
||||
KEY_Space, /* 61 */
|
||||
KEY_AltLang, /* 62 */
|
||||
KEY_RMeta, /* 63 */
|
||||
KEY_RCtrl, /* 64 */
|
||||
KEY_Menu, /* 65 */
|
||||
KEY_UNKNOWN, /* 66 */
|
||||
KEY_UNKNOWN, /* 67 */
|
||||
KEY_UNKNOWN, /* 68 */
|
||||
KEY_UNKNOWN, /* 69 */
|
||||
KEY_UNKNOWN, /* 70 */
|
||||
KEY_UNKNOWN, /* 71 */
|
||||
KEY_UNKNOWN, /* 72 */
|
||||
KEY_UNKNOWN, /* 73 */
|
||||
KEY_UNKNOWN, /* 74 */
|
||||
KEY_Insert, /* 75 */
|
||||
KEY_Delete, /* 76 */
|
||||
KEY_UNKNOWN, /* 77 */
|
||||
KEY_UNKNOWN, /* 78 */
|
||||
KEY_Left, /* 79 */
|
||||
KEY_Home, /* 80 */
|
||||
KEY_End, /* 81 */
|
||||
KEY_UNKNOWN, /* 82 */
|
||||
KEY_Up, /* 83 */
|
||||
KEY_Down, /* 84 */
|
||||
KEY_PgUp, /* 85 */
|
||||
KEY_PgDown, /* 86 */
|
||||
KEY_UNKNOWN, /* 87 */
|
||||
KEY_UNKNOWN, /* 88 */
|
||||
KEY_Right, /* 89 */
|
||||
KEY_NumLock, /* 90 */
|
||||
KEY_KP_7, /* 91 */
|
||||
KEY_KP_4, /* 92 */
|
||||
KEY_KP_1, /* 93 */
|
||||
KEY_UNKNOWN, /* 94 */
|
||||
KEY_KP_Divide, /* 95 */
|
||||
KEY_KP_8, /* 96 */
|
||||
KEY_KP_5, /* 97 */
|
||||
KEY_KP_2, /* 98 */
|
||||
KEY_KP_0, /* 99 */
|
||||
KEY_KP_Multiply, /* 100 */
|
||||
KEY_KP_9, /* 101 */
|
||||
KEY_KP_6, /* 102 */
|
||||
KEY_KP_3, /* 103 */
|
||||
KEY_KP_Decimal, /* 104 */
|
||||
KEY_KP_Minus, /* 105 */
|
||||
KEY_KP_Plus, /* 106 */
|
||||
KEY_UNKNOWN, /* 107 */
|
||||
KEY_KP_Enter, /* 108 */
|
||||
KEY_UNKNOWN, /* 109 */
|
||||
KEY_Escape, /* 110 */
|
||||
KEY_UNKNOWN, /* 111 */
|
||||
KEY_F1, /* 112 */
|
||||
KEY_F2, /* 113 */
|
||||
KEY_F3, /* 114 */
|
||||
KEY_F4, /* 115 */
|
||||
KEY_F5, /* 116 */
|
||||
KEY_F6, /* 117 */
|
||||
KEY_F7, /* 118 */
|
||||
KEY_F8, /* 119 */
|
||||
KEY_F9, /* 120 */
|
||||
KEY_F10, /* 121 */
|
||||
KEY_F11, /* 122 */
|
||||
KEY_F12, /* 123 */
|
||||
KEY_Print, /* 124 */
|
||||
KEY_ScrollLock, /* 125 */
|
||||
KEY_Pause, /* 126 */
|
||||
KEY_UNKNOWN, /* 127 */
|
||||
KEY_UNKNOWN, /* 128 */
|
||||
KEY_UNKNOWN, /* 129 */
|
||||
KEY_UNKNOWN, /* 130 */
|
||||
KEY_NFER, /* 131 */
|
||||
KEY_XFER, /* 132 */
|
||||
KEY_HKTG, /* 133 */
|
||||
KEY_UNKNOWN, /* 134 */
|
||||
#elif defined(sparc) || defined(__sparc__)
|
||||
KEY_UNKNOWN, /* 0x00 */
|
||||
KEY_UNKNOWN, /* 0x01 */
|
||||
KEY_UNKNOWN, /* 0x02 */
|
||||
KEY_UNKNOWN, /* 0x03 */
|
||||
KEY_UNKNOWN, /* 0x04 */
|
||||
KEY_F1, /* 0x05 */
|
||||
KEY_F2, /* 0x06 */
|
||||
KEY_F10, /* 0x07 */
|
||||
KEY_F3, /* 0x08 */
|
||||
KEY_F11, /* 0x09 */
|
||||
KEY_F4, /* 0x0A */
|
||||
KEY_F12, /* 0x0B */
|
||||
KEY_F5, /* 0x0C */
|
||||
KEY_UNKNOWN, /* 0x0D */
|
||||
KEY_F6, /* 0x0E */
|
||||
KEY_UNKNOWN, /* 0x0F */
|
||||
KEY_F7, /* 0x10 */
|
||||
KEY_F8, /* 0x11 */
|
||||
KEY_F9, /* 0x12 */
|
||||
KEY_Alt, /* 0x13 */
|
||||
KEY_Up, /* 0x14 */
|
||||
KEY_Pause, /* 0x15 */
|
||||
KEY_SysReqest, /* 0x16 */
|
||||
KEY_ScrollLock, /* 0x17 */
|
||||
KEY_Left, /* 0x18 */
|
||||
KEY_UNKNOWN, /* 0x19 */
|
||||
KEY_UNKNOWN, /* 0x1A */
|
||||
KEY_Down, /* 0x1B */
|
||||
KEY_Right, /* 0x1C */
|
||||
KEY_Escape, /* 0x1D */
|
||||
KEY_1, /* 0x1E */
|
||||
KEY_2, /* 0x1F */
|
||||
KEY_3, /* 0x20 */
|
||||
KEY_4, /* 0x21 */
|
||||
KEY_5, /* 0x22 */
|
||||
KEY_6, /* 0x23 */
|
||||
KEY_7, /* 0x24 */
|
||||
KEY_8, /* 0x25 */
|
||||
KEY_9, /* 0x26 */
|
||||
KEY_0, /* 0x27 */
|
||||
KEY_Minus, /* 0x28 */
|
||||
KEY_Equal, /* 0x29 */
|
||||
KEY_Tilde, /* 0x2A */
|
||||
KEY_BackSpace, /* 0x2B */
|
||||
KEY_Insert, /* 0x2C */
|
||||
KEY_UNKNOWN, /* 0x2D */
|
||||
KEY_KP_Divide, /* 0x2E */
|
||||
KEY_KP_Multiply, /* 0x2F */
|
||||
KEY_UNKNOWN, /* 0x30 */
|
||||
KEY_UNKNOWN, /* 0x31 */
|
||||
KEY_KP_Decimal, /* 0x32 */
|
||||
KEY_UNKNOWN, /* 0x33 */
|
||||
KEY_Home, /* 0x34 */
|
||||
KEY_Tab, /* 0x35 */
|
||||
KEY_Q, /* 0x36 */
|
||||
KEY_W, /* 0x37 */
|
||||
KEY_E, /* 0x38 */
|
||||
KEY_R, /* 0x39 */
|
||||
KEY_T, /* 0x3A */
|
||||
KEY_Y, /* 0x3B */
|
||||
KEY_U, /* 0x3C */
|
||||
KEY_I, /* 0x3D */
|
||||
KEY_O, /* 0x3E */
|
||||
KEY_P, /* 0x3F */
|
||||
KEY_LBrace, /* 0x40 */
|
||||
KEY_RBrace, /* 0x41 */
|
||||
KEY_Delete, /* 0x42 */
|
||||
KEY_UNKNOWN, /* 0x43 */
|
||||
KEY_KP_7, /* 0x44 */
|
||||
KEY_KP_8, /* 0x45 */
|
||||
KEY_KP_9, /* 0x46 */
|
||||
KEY_KP_Minus, /* 0x47 */
|
||||
KEY_UNKNOWN, /* 0x48 */
|
||||
KEY_UNKNOWN, /* 0x49 */
|
||||
KEY_End, /* 0x4A */
|
||||
KEY_UNKNOWN, /* 0x4B */
|
||||
KEY_LCtrl, /* 0x4C */
|
||||
KEY_A, /* 0x4D */
|
||||
KEY_S, /* 0x4E */
|
||||
KEY_D, /* 0x4F */
|
||||
KEY_F, /* 0x50 */
|
||||
KEY_G, /* 0x51 */
|
||||
KEY_H, /* 0x52 */
|
||||
KEY_J, /* 0x53 */
|
||||
KEY_K, /* 0x54 */
|
||||
KEY_L, /* 0x55 */
|
||||
KEY_SemiColon, /* 0x56 */
|
||||
KEY_Quote, /* 0x57 */
|
||||
KEY_BSlash, /* 0x58 */
|
||||
KEY_Enter, /* 0x59 */
|
||||
KEY_KP_Enter, /* 0x5A */
|
||||
KEY_KP_4, /* 0x5B */
|
||||
KEY_KP_5, /* 0x5C */
|
||||
KEY_KP_6, /* 0x5D */
|
||||
KEY_KP_0, /* 0x5E */
|
||||
KEY_UNKNOWN, /* 0x5F */
|
||||
KEY_PgUp, /* 0x60 */
|
||||
KEY_UNKNOWN, /* 0x61 */
|
||||
KEY_NumLock, /* 0x62 */
|
||||
KEY_ShiftL, /* 0x63 */
|
||||
KEY_Z, /* 0x64 */
|
||||
KEY_X, /* 0x65 */
|
||||
KEY_C, /* 0x66 */
|
||||
KEY_V, /* 0x67 */
|
||||
KEY_B, /* 0x68 */
|
||||
KEY_N, /* 0x69 */
|
||||
KEY_M, /* 0x6A */
|
||||
KEY_Comma, /* 0x6B */
|
||||
KEY_Period, /* 0x6C */
|
||||
KEY_Slash, /* 0x6D */
|
||||
KEY_ShiftR, /* 0x6E */
|
||||
KEY_UNKNOWN, /* 0x6F */
|
||||
KEY_KP_1, /* 0x70 */
|
||||
KEY_KP_2, /* 0x71 */
|
||||
KEY_KP_3, /* 0x72 */
|
||||
KEY_UNKNOWN, /* 0x73 */
|
||||
KEY_UNKNOWN, /* 0x74 */
|
||||
KEY_UNKNOWN, /* 0x75 */
|
||||
KEY_UNKNOWN, /* 0x76 */
|
||||
KEY_CapsLock, /* 0x77 */
|
||||
KEY_LMeta, /* 0x78 */
|
||||
KEY_Space, /* 0x79 */
|
||||
KEY_RMeta, /* 0x7A */
|
||||
KEY_PgDown, /* 0x7B */
|
||||
KEY_UNKNOWN, /* 0x7C */
|
||||
KEY_KP_Plus, /* 0x7D */
|
||||
KEY_UNKNOWN, /* 0x7E */
|
||||
KEY_UNKNOWN, /* 0x7F */
|
||||
#endif
|
||||
/* The rest default to KEY_UNKNOWN */
|
||||
};
|
||||
|
||||
#if defined(KB_USB)
|
||||
static unsigned char usbmap[256] = {
|
||||
/*
|
||||
* partially taken from ../bsd/bsd_KbdMap.c
|
||||
*
|
||||
* added keycodes for Sun special keys (left function keys, audio control)
|
||||
*/
|
||||
/* 0 */ KEY_NOTUSED,
|
||||
/* 1 */ KEY_NOTUSED,
|
||||
/* 2 */ KEY_NOTUSED,
|
||||
/* 3 */ KEY_NOTUSED,
|
||||
/* 4 */ KEY_A,
|
||||
/* 5 */ KEY_B,
|
||||
/* 6 */ KEY_C,
|
||||
/* 7 */ KEY_D,
|
||||
/* 8 */ KEY_E,
|
||||
/* 9 */ KEY_F,
|
||||
/* 10 */ KEY_G,
|
||||
/* 11 */ KEY_H,
|
||||
/* 12 */ KEY_I,
|
||||
/* 13 */ KEY_J,
|
||||
/* 14 */ KEY_K,
|
||||
/* 15 */ KEY_L,
|
||||
/* 16 */ KEY_M,
|
||||
/* 17 */ KEY_N,
|
||||
/* 18 */ KEY_O,
|
||||
/* 19 */ KEY_P,
|
||||
/* 20 */ KEY_Q,
|
||||
/* 21 */ KEY_R,
|
||||
/* 22 */ KEY_S,
|
||||
/* 23 */ KEY_T,
|
||||
/* 24 */ KEY_U,
|
||||
/* 25 */ KEY_V,
|
||||
/* 26 */ KEY_W,
|
||||
/* 27 */ KEY_X,
|
||||
/* 28 */ KEY_Y,
|
||||
/* 29 */ KEY_Z,
|
||||
/* 30 */ KEY_1, /* 1 !*/
|
||||
/* 31 */ KEY_2, /* 2 @ */
|
||||
/* 32 */ KEY_3, /* 3 # */
|
||||
/* 33 */ KEY_4, /* 4 $ */
|
||||
/* 34 */ KEY_5, /* 5 % */
|
||||
/* 35 */ KEY_6, /* 6 ^ */
|
||||
/* 36 */ KEY_7, /* 7 & */
|
||||
/* 37 */ KEY_8, /* 8 * */
|
||||
/* 38 */ KEY_9, /* 9 ( */
|
||||
/* 39 */ KEY_0, /* 0 ) */
|
||||
/* 40 */ KEY_Enter, /* Return */
|
||||
/* 41 */ KEY_Escape, /* Escape */
|
||||
/* 42 */ KEY_BackSpace, /* Backspace Delete */
|
||||
/* 43 */ KEY_Tab, /* Tab */
|
||||
/* 44 */ KEY_Space, /* Space */
|
||||
/* 45 */ KEY_Minus, /* - _ */
|
||||
/* 46 */ KEY_Equal, /* = + */
|
||||
/* 47 */ KEY_LBrace, /* [ { */
|
||||
/* 48 */ KEY_RBrace, /* ] } */
|
||||
/* 49 */ KEY_BSlash, /* \ | */
|
||||
/* 50 */ KEY_BSlash, /* \ _ # ~ on some keyboards */
|
||||
/* 51 */ KEY_SemiColon, /* ; : */
|
||||
/* 52 */ KEY_Quote, /* ' " */
|
||||
/* 53 */ KEY_Tilde, /* ` ~ */
|
||||
/* 54 */ KEY_Comma, /* , < */
|
||||
/* 55 */ KEY_Period, /* . > */
|
||||
/* 56 */ KEY_Slash, /* / ? */
|
||||
/* 57 */ KEY_CapsLock, /* Caps Lock */
|
||||
/* 58 */ KEY_F1, /* F1 */
|
||||
/* 59 */ KEY_F2, /* F2 */
|
||||
/* 60 */ KEY_F3, /* F3 */
|
||||
/* 61 */ KEY_F4, /* F4 */
|
||||
/* 62 */ KEY_F5, /* F5 */
|
||||
/* 63 */ KEY_F6, /* F6 */
|
||||
/* 64 */ KEY_F7, /* F7 */
|
||||
/* 65 */ KEY_F8, /* F8 */
|
||||
/* 66 */ KEY_F9, /* F9 */
|
||||
/* 67 */ KEY_F10, /* F10 */
|
||||
/* 68 */ KEY_F11, /* F11 */
|
||||
/* 69 */ KEY_F12, /* F12 */
|
||||
/* 70 */ KEY_Print, /* PrintScrn SysReq */
|
||||
/* 71 */ KEY_ScrollLock, /* Scroll Lock */
|
||||
/* 72 */ KEY_Pause, /* Pause Break */
|
||||
/* 73 */ KEY_Insert, /* Insert XXX Help on some Mac Keyboards */
|
||||
/* 74 */ KEY_Home, /* Home */
|
||||
/* 75 */ KEY_PgUp, /* Page Up */
|
||||
/* 76 */ KEY_Delete, /* Delete */
|
||||
/* 77 */ KEY_End, /* End */
|
||||
/* 78 */ KEY_PgDown, /* Page Down */
|
||||
/* 79 */ KEY_Right, /* Right Arrow */
|
||||
/* 80 */ KEY_Left, /* Left Arrow */
|
||||
/* 81 */ KEY_Down, /* Down Arrow */
|
||||
/* 82 */ KEY_Up, /* Up Arrow */
|
||||
/* 83 */ KEY_NumLock, /* Num Lock */
|
||||
/* 84 */ KEY_KP_Divide, /* Keypad / */
|
||||
/* 85 */ KEY_KP_Multiply, /* Keypad * */
|
||||
/* 86 */ KEY_KP_Minus, /* Keypad - */
|
||||
/* 87 */ KEY_KP_Plus, /* Keypad + */
|
||||
/* 88 */ KEY_KP_Enter, /* Keypad Enter */
|
||||
/* 89 */ KEY_KP_1, /* Keypad 1 End */
|
||||
/* 90 */ KEY_KP_2, /* Keypad 2 Down */
|
||||
/* 91 */ KEY_KP_3, /* Keypad 3 Pg Down */
|
||||
/* 92 */ KEY_KP_4, /* Keypad 4 Left */
|
||||
/* 93 */ KEY_KP_5, /* Keypad 5 */
|
||||
/* 94 */ KEY_KP_6, /* Keypad 6 */
|
||||
/* 95 */ KEY_KP_7, /* Keypad 7 Home */
|
||||
/* 96 */ KEY_KP_8, /* Keypad 8 Up */
|
||||
/* 97 */ KEY_KP_9, /* KEypad 9 Pg Up */
|
||||
/* 98 */ KEY_KP_0, /* Keypad 0 Ins */
|
||||
/* 99 */ KEY_KP_Decimal, /* Keypad . Del */
|
||||
/* 100 */ KEY_Less, /* < > on some keyboards */
|
||||
/* 101 */ KEY_Menu, /* Menu */
|
||||
/* 102 */ KEY_Power, /* Sun: Power */
|
||||
/* 103 */ KEY_KP_Equal, /* Keypad = on Mac keyboards */
|
||||
/* 104 */ KEY_NOTUSED,
|
||||
/* 105 */ KEY_NOTUSED,
|
||||
/* 106 */ KEY_NOTUSED,
|
||||
/* 107 */ KEY_NOTUSED,
|
||||
/* 108 */ KEY_NOTUSED,
|
||||
/* 109 */ KEY_NOTUSED,
|
||||
/* 110 */ KEY_NOTUSED,
|
||||
/* 111 */ KEY_NOTUSED,
|
||||
/* 112 */ KEY_NOTUSED,
|
||||
/* 113 */ KEY_NOTUSED,
|
||||
/* 114 */ KEY_NOTUSED,
|
||||
/* 115 */ KEY_NOTUSED,
|
||||
/* 116 */ KEY_L7, /* Sun: Open */
|
||||
/* 117 */ KEY_Help, /* Sun: Help */
|
||||
/* 118 */ KEY_L3, /* Sun: Props */
|
||||
/* 119 */ KEY_L5, /* Sun: Front */
|
||||
/* 120 */ KEY_L1, /* Sun: Stop */
|
||||
/* 121 */ KEY_L2, /* Sun: Again */
|
||||
/* 122 */ KEY_L4, /* Sun: Undo */
|
||||
/* 123 */ KEY_L10, /* Sun: Cut */
|
||||
/* 124 */ KEY_L6, /* Sun: Copy */
|
||||
/* 125 */ KEY_L8, /* Sun: Paste */
|
||||
/* 126 */ KEY_L9, /* Sun: Find */
|
||||
/* 127 */ KEY_Mute, /* Sun: AudioMute */
|
||||
/* 128 */ KEY_AudioRaise, /* Sun: AudioRaise */
|
||||
/* 129 */ KEY_AudioLower, /* Sun: AudioLower */
|
||||
/* 130 */ KEY_NOTUSED,
|
||||
/* 131 */ KEY_NOTUSED,
|
||||
/* 132 */ KEY_NOTUSED,
|
||||
/* 133 */ KEY_NOTUSED,
|
||||
/* 134 */ KEY_NOTUSED,
|
||||
/* 135 */ KEY_BSlash2, /* Sun Japanese Kbd: Backslash / Underscore */
|
||||
/* 136 */ KEY_XFER, /* Sun Japanese Kbd: Henkan Mode */
|
||||
/* 137 */ KEY_Yen, /* Sun Japanese Kbd: Yen / Brokenbar */
|
||||
/* 138 */ KEY_Kanji, /* Sun Japanese Kbd: Kanji */
|
||||
/* 139 */ KEY_Execute, /* Sun Japanese Kbd: Execute */
|
||||
/* 140 */ KEY_NOTUSED,
|
||||
/* 141 */ KEY_NOTUSED,
|
||||
/* 142 */ KEY_NOTUSED,
|
||||
/* 143 */ KEY_NOTUSED,
|
||||
/* 144 */ KEY_NOTUSED,
|
||||
/* 145 */ KEY_NOTUSED,
|
||||
/* 146 */ KEY_NOTUSED,
|
||||
/* 147 */ KEY_NOTUSED,
|
||||
/* 148 */ KEY_NOTUSED,
|
||||
/* 149 */ KEY_NOTUSED,
|
||||
/* 150 */ KEY_NOTUSED,
|
||||
/* 151 */ KEY_NOTUSED,
|
||||
/* 152 */ KEY_NOTUSED,
|
||||
/* 153 */ KEY_NOTUSED,
|
||||
/* 154 */ KEY_NOTUSED,
|
||||
/* 155 */ KEY_NOTUSED,
|
||||
/* 156 */ KEY_NOTUSED,
|
||||
/* 157 */ KEY_NOTUSED,
|
||||
/* 158 */ KEY_NOTUSED,
|
||||
/* 159 */ KEY_NOTUSED,
|
||||
/* 160 */ KEY_NOTUSED,
|
||||
/* 161 */ KEY_NOTUSED,
|
||||
/* 162 */ KEY_NOTUSED,
|
||||
/* 163 */ KEY_NOTUSED,
|
||||
/* 164 */ KEY_NOTUSED,
|
||||
/* 165 */ KEY_NOTUSED,
|
||||
/* 166 */ KEY_NOTUSED,
|
||||
/* 167 */ KEY_NOTUSED,
|
||||
/* 168 */ KEY_NOTUSED,
|
||||
/* 169 */ KEY_NOTUSED,
|
||||
/* 170 */ KEY_NOTUSED,
|
||||
/* 171 */ KEY_NOTUSED,
|
||||
/* 172 */ KEY_NOTUSED,
|
||||
/* 173 */ KEY_NOTUSED,
|
||||
/* 174 */ KEY_NOTUSED,
|
||||
/* 175 */ KEY_NOTUSED,
|
||||
/* 176 */ KEY_NOTUSED,
|
||||
/* 177 */ KEY_NOTUSED,
|
||||
/* 178 */ KEY_NOTUSED,
|
||||
/* 179 */ KEY_NOTUSED,
|
||||
/* 180 */ KEY_NOTUSED,
|
||||
/* 181 */ KEY_NOTUSED,
|
||||
/* 182 */ KEY_NOTUSED,
|
||||
/* 183 */ KEY_NOTUSED,
|
||||
/* 184 */ KEY_NOTUSED,
|
||||
/* 185 */ KEY_NOTUSED,
|
||||
/* 186 */ KEY_NOTUSED,
|
||||
/* 187 */ KEY_NOTUSED,
|
||||
/* 188 */ KEY_NOTUSED,
|
||||
/* 189 */ KEY_NOTUSED,
|
||||
/* 190 */ KEY_NOTUSED,
|
||||
/* 191 */ KEY_NOTUSED,
|
||||
/* 192 */ KEY_NOTUSED,
|
||||
/* 193 */ KEY_NOTUSED,
|
||||
/* 194 */ KEY_NOTUSED,
|
||||
/* 195 */ KEY_NOTUSED,
|
||||
/* 196 */ KEY_NOTUSED,
|
||||
/* 197 */ KEY_NOTUSED,
|
||||
/* 198 */ KEY_NOTUSED,
|
||||
/* 199 */ KEY_NOTUSED,
|
||||
/* 200 */ KEY_NOTUSED,
|
||||
/* 201 */ KEY_NOTUSED,
|
||||
/* 202 */ KEY_NOTUSED,
|
||||
/* 203 */ KEY_NOTUSED,
|
||||
/* 204 */ KEY_NOTUSED,
|
||||
/* 205 */ KEY_NOTUSED,
|
||||
/* 206 */ KEY_NOTUSED,
|
||||
/* 207 */ KEY_NOTUSED,
|
||||
/* 208 */ KEY_NOTUSED,
|
||||
/* 209 */ KEY_NOTUSED,
|
||||
/* 210 */ KEY_NOTUSED,
|
||||
/* 211 */ KEY_NOTUSED,
|
||||
/* 212 */ KEY_NOTUSED,
|
||||
/* 213 */ KEY_NOTUSED,
|
||||
/* 214 */ KEY_NOTUSED,
|
||||
/* 215 */ KEY_NOTUSED,
|
||||
/* 216 */ KEY_NOTUSED,
|
||||
/* 217 */ KEY_NOTUSED,
|
||||
/* 218 */ KEY_NOTUSED,
|
||||
/* 219 */ KEY_NOTUSED,
|
||||
/* 220 */ KEY_NOTUSED,
|
||||
/* 221 */ KEY_NOTUSED,
|
||||
/* 222 */ KEY_NOTUSED,
|
||||
/* 223 */ KEY_NOTUSED,
|
||||
/* 224 */ KEY_LCtrl, /* Left Control */
|
||||
/* 225 */ KEY_ShiftL, /* Left Shift */
|
||||
/* 226 */ KEY_Alt, /* Left Alt */
|
||||
/* 227 */ KEY_LMeta, /* Left Meta */
|
||||
/* 228 */ KEY_RCtrl, /* Right Control */
|
||||
/* 229 */ KEY_ShiftR, /* Right Shift */
|
||||
/* 230 */ KEY_AltLang, /* Right Alt, AKA AltGr */
|
||||
/* 231 */ KEY_RMeta, /* Right Meta */
|
||||
};
|
||||
|
||||
#endif /* KB_USB */
|
||||
|
||||
_X_HIDDEN const unsigned char *
|
||||
sunGetKbdMapping(int ktype) {
|
||||
#if defined(KB_USB)
|
||||
if (ktype == KB_USB)
|
||||
return usbmap;
|
||||
else
|
||||
#endif
|
||||
return map;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* sunPostKbdEvent --
|
||||
* Translate the raw hardware Firm_event into an XEvent, and tell DIX
|
||||
* about it. KeyCode preprocessing and so on is done ...
|
||||
*
|
||||
* Most of the Solaris stuff has whacked Panix/PC98 support in the
|
||||
* interests of simplicity - DWH 8/30/99
|
||||
*/
|
||||
|
||||
_X_HIDDEN void
|
||||
sunPostKbdEvent(int sun_ktype, Firm_event *event)
|
||||
{
|
||||
Bool down;
|
||||
KeyClassRec *keyc = ((DeviceIntPtr)xf86Info.pKeyboard)->key;
|
||||
Bool updateLeds = FALSE;
|
||||
xEvent kevent;
|
||||
KeySym *keysym;
|
||||
int keycode;
|
||||
static int lockkeys = 0;
|
||||
|
||||
/* Give down a value */
|
||||
if (event->value == VKEY_DOWN)
|
||||
down = TRUE;
|
||||
else
|
||||
down = FALSE;
|
||||
|
||||
|
||||
#if defined(KB_USB)
|
||||
if(sun_ktype == KB_USB)
|
||||
keycode = usbmap[event->id];
|
||||
else
|
||||
#endif
|
||||
keycode = map[event->id];
|
||||
|
||||
/*
|
||||
* and now get some special keysequences
|
||||
*/
|
||||
|
||||
#ifdef XKB
|
||||
if (((xf86Info.ddxSpecialKeys == SKWhenNeeded) &&
|
||||
(!xf86Info.ActionKeyBindingsSet)) ||
|
||||
noXkbExtension || (xf86Info.ddxSpecialKeys == SKAlways))
|
||||
#endif
|
||||
{
|
||||
if (!(ModifierDown(ShiftMask)) &&
|
||||
((ModifierDown(ControlMask | AltMask)) ||
|
||||
(ModifierDown(ControlMask | AltLangMask))))
|
||||
{
|
||||
switch (keycode) {
|
||||
/*
|
||||
* The idea here is to pass the scancode down to a list of
|
||||
* registered routines. There should be some standard conventions
|
||||
* for processing certain keys.
|
||||
*/
|
||||
case KEY_BackSpace:
|
||||
xf86ProcessActionEvent(ACTION_TERMINATE, NULL);
|
||||
break;
|
||||
|
||||
/*
|
||||
* Check grabs
|
||||
*/
|
||||
case KEY_KP_Divide:
|
||||
xf86ProcessActionEvent(ACTION_DISABLEGRAB, NULL);
|
||||
break;
|
||||
case KEY_KP_Multiply:
|
||||
xf86ProcessActionEvent(ACTION_CLOSECLIENT, NULL);
|
||||
break;
|
||||
|
||||
/*
|
||||
* Video mode switches
|
||||
*/
|
||||
case KEY_KP_Minus: /* Keypad - */
|
||||
if (down) xf86ProcessActionEvent(ACTION_PREV_MODE, NULL);
|
||||
if (!xf86Info.dontZoom) return;
|
||||
break;
|
||||
|
||||
case KEY_KP_Plus: /* Keypad + */
|
||||
if (down) xf86ProcessActionEvent(ACTION_NEXT_MODE, NULL);
|
||||
if (!xf86Info.dontZoom) return;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Now map the scancodes to real X-keycodes ...
|
||||
*/
|
||||
if (keycode == KEY_NOTUSED) {
|
||||
xf86MsgVerb(X_INFO, 0,
|
||||
"raw code %d mapped to KEY_NOTUSED -- please report\n", event->id);
|
||||
return;
|
||||
}
|
||||
if (keycode == KEY_UNKNOWN) {
|
||||
xf86MsgVerb(X_INFO, 0,
|
||||
"raw code %d mapped to KEY_UNKNOWN -- please report\n", event->id);
|
||||
return;
|
||||
}
|
||||
keycode += MIN_KEYCODE;
|
||||
keysym = keyc->curKeySyms.map +
|
||||
(keyc->curKeySyms.mapWidth *
|
||||
(keycode - keyc->curKeySyms.minKeyCode));
|
||||
|
||||
#ifdef XKB
|
||||
if (noXkbExtension)
|
||||
#endif
|
||||
{
|
||||
/*
|
||||
* Toggle lock keys.
|
||||
*/
|
||||
#define CAPSFLAG 0x01
|
||||
#define NUMFLAG 0x02
|
||||
#define SCROLLFLAG 0x04
|
||||
#define MODEFLAG 0x08
|
||||
|
||||
if (down) {
|
||||
/*
|
||||
* Handle the KeyPresses of the lock keys.
|
||||
*/
|
||||
|
||||
switch (keysym[0]) {
|
||||
|
||||
case XK_Caps_Lock:
|
||||
if (lockkeys & CAPSFLAG) {
|
||||
lockkeys &= ~CAPSFLAG;
|
||||
return;
|
||||
}
|
||||
lockkeys |= CAPSFLAG;
|
||||
updateLeds = TRUE;
|
||||
xf86Info.capsLock = down;
|
||||
break;
|
||||
|
||||
case XK_Num_Lock:
|
||||
if (lockkeys & NUMFLAG) {
|
||||
lockkeys &= ~NUMFLAG;
|
||||
return;
|
||||
}
|
||||
lockkeys |= NUMFLAG;
|
||||
updateLeds = TRUE;
|
||||
xf86Info.numLock = down;
|
||||
break;
|
||||
|
||||
case XK_Scroll_Lock:
|
||||
if (lockkeys & SCROLLFLAG) {
|
||||
lockkeys &= ~SCROLLFLAG;
|
||||
return;
|
||||
}
|
||||
lockkeys |= SCROLLFLAG;
|
||||
updateLeds = TRUE;
|
||||
xf86Info.scrollLock = down;
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
/*
|
||||
* Handle the releases of the lock keys.
|
||||
*/
|
||||
|
||||
switch (keysym[0]) {
|
||||
|
||||
case XK_Caps_Lock:
|
||||
if (lockkeys & CAPSFLAG)
|
||||
return;
|
||||
updateLeds = TRUE;
|
||||
xf86Info.capsLock = down;
|
||||
break;
|
||||
|
||||
case XK_Num_Lock:
|
||||
if (lockkeys & NUMFLAG)
|
||||
return;
|
||||
updateLeds = TRUE;
|
||||
xf86Info.numLock = down;
|
||||
break;
|
||||
|
||||
case XK_Scroll_Lock:
|
||||
if (lockkeys & SCROLLFLAG)
|
||||
return;
|
||||
updateLeds = TRUE;
|
||||
xf86Info.scrollLock = down;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (updateLeds)
|
||||
xf86KbdLeds();
|
||||
|
||||
/*
|
||||
* If this keycode is not a modifier key, and its down initiate the
|
||||
* autorepeate sequence. (Only necessary if not using XKB).
|
||||
*
|
||||
* If its not down, then reset the timer.
|
||||
*/
|
||||
if (!keyc->modifierMap[keycode]) {
|
||||
if (down) {
|
||||
startautorepeat(keycode);
|
||||
} else {
|
||||
TimerFree(sunTimer);
|
||||
sunTimer = NULL;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
xf86Info.lastEventTime =
|
||||
kevent.u.keyButtonPointer.time =
|
||||
GetTimeInMillis();
|
||||
|
||||
/*
|
||||
* And now send these prefixes ...
|
||||
* NOTE: There cannot be multiple Mode_Switch keys !!!!
|
||||
*/
|
||||
|
||||
ENQUEUE(&kevent, keycode, (down ? KeyPress : KeyRelease), XE_KEYBOARD);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* Autorepeat stuff
|
||||
*/
|
||||
|
||||
void
|
||||
startautorepeat(long keycode)
|
||||
{
|
||||
sunTimer = TimerSet(sunTimer, /* Timer */
|
||||
0, /* Flags */
|
||||
xf86Info.kbdDelay, /* millis */
|
||||
processautorepeat, /* callback */
|
||||
(pointer) keycode); /* arg for timer */
|
||||
}
|
||||
|
||||
CARD32
|
||||
processautorepeat(OsTimerPtr timer, CARD32 now, pointer arg)
|
||||
{
|
||||
xEvent kevent;
|
||||
int keycode;
|
||||
|
||||
keycode = (long)arg;
|
||||
|
||||
xf86Info.lastEventTime =
|
||||
kevent.u.keyButtonPointer.time =
|
||||
GetTimeInMillis();
|
||||
|
||||
/*
|
||||
* Repeat a key by faking a KeyRelease, and a KeyPress event in rapid
|
||||
* succession
|
||||
*/
|
||||
|
||||
ENQUEUE(&kevent, keycode, KeyRelease, XE_KEYBOARD);
|
||||
ENQUEUE(&kevent, keycode, KeyPress, XE_KEYBOARD);
|
||||
|
||||
/* And return the appropriate value so we get rescheduled */
|
||||
return xf86Info.kbdRate;
|
||||
}
|
|
@ -1,77 +0,0 @@
|
|||
/*
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the names of Thomas Roell and David Dawes
|
||||
* not be used in advertising or publicity pertaining to distribution of
|
||||
* the software without specific, written prior permission. Thomas Roell and
|
||||
* David Dawes makes no representations about the suitability of this
|
||||
* software for any purpose. It is provided "as is" without express or
|
||||
* implied warranty.
|
||||
*
|
||||
* THOMAS ROELL AND DAVID DAWES DISCLAIMS ALL WARRANTIES WITH REGARD TO
|
||||
* THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS, IN NO EVENT SHALL THOMAS ROELL OR DAVID DAWES BE LIABLE FOR
|
||||
* ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||
* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*
|
||||
*/
|
||||
/* $XConsortium: sysv_io.c /main/8 1996/10/19 18:08:06 kaleb $ */
|
||||
|
||||
#ifdef HAVE_XORG_CONFIG_H
|
||||
#include <xorg-config.h>
|
||||
#endif
|
||||
|
||||
#include <X11/X.h>
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
_X_EXPORT void
|
||||
xf86SoundKbdBell(int loudness, int pitch, int duration)
|
||||
{
|
||||
if (loudness && pitch)
|
||||
{
|
||||
#ifdef KDMKTONE
|
||||
/*
|
||||
* If we have KDMKTONE use it to avoid putting the server
|
||||
* to sleep
|
||||
*/
|
||||
ioctl(xf86Info.consoleFd, KDMKTONE,
|
||||
((1193190 / pitch) & 0xffff) |
|
||||
(((unsigned long)duration *
|
||||
loudness / 50) << 16));
|
||||
#else
|
||||
ioctl(xf86Info.consoleFd, KIOCSOUND, 1193180 / pitch);
|
||||
usleep(xf86Info.bell_duration * loudness * 20);
|
||||
ioctl(xf86Info.consoleFd, KIOCSOUND, 0);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
xf86SetKbdLeds(int leds)
|
||||
{
|
||||
#ifdef KBIO_SETMODE
|
||||
ioctl(xf86Info.consoleFd, KBIO_SETMODE, KBM_AT);
|
||||
ioctl(xf86Info.consoleFd, KDSETLED, leds);
|
||||
ioctl(xf86Info.consoleFd, KBIO_SETMODE, KBM_XT);
|
||||
#endif
|
||||
}
|
||||
|
||||
#include "xf86OSKbd.h"
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
return FALSE;
|
||||
}
|
|
@ -2,9 +2,6 @@ EXTRA_DIST = \
|
|||
usl_init.c \
|
||||
usl_io.c \
|
||||
usl_iop.c \
|
||||
usl_kbd.c \
|
||||
usl_kbd.h \
|
||||
usl_KbdMap.c \
|
||||
usl_mouse.c \
|
||||
usl_video.c \
|
||||
usl_vtsw.c \
|
||||
|
|
|
@ -1,304 +0,0 @@
|
|||
/* $XdotOrg$ */
|
||||
/*
|
||||
* Copyright 2005 by J. Kean Johnston <jkj@sco.com>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the name J. Kean Johnston not be used in
|
||||
* advertising or publicity pertaining to distribution of the software without
|
||||
* specific, written prior permission. J. Kean Johnston makes no
|
||||
* representations about the suitability of this software for any purpose.
|
||||
* It is provided "as is" without express or implied warranty.
|
||||
*
|
||||
* J. KEAN JOHNSTON DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||||
* EVENT SHALL J. KEAN JOHNSTON BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
* PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
|
||||
/*
|
||||
* Based on xf86KbdMap.c, which is
|
||||
* Copyright 1990,91 by Thomas Roell, Dinkelscherben, Germany.
|
||||
* Copyright (c) 1992-2003 by The XFree86 Project, Inc.
|
||||
*/
|
||||
|
||||
#include "X.h"
|
||||
#include "Xmd.h"
|
||||
#include "input.h"
|
||||
#include "scrnintstr.h"
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
#include "xf86Keymap.h"
|
||||
|
||||
#include "usl_kbd.h"
|
||||
|
||||
#define KD_GET_ENTRY(i,n) \
|
||||
eascii_to_x[((priv->keymap.key[i].spcl << (n+1)) & 0x100) + priv->keymap.key[i].map[n]]
|
||||
|
||||
/*
|
||||
* NOTE: Not all possible remappable symbols are remapped. There are two main
|
||||
* reasons:
|
||||
* a) The mapping between scancode and SYSV/386 - symboltable
|
||||
* is inconsistent between different versions and has some
|
||||
* BIG mistakes.
|
||||
* b) In X-Windows there is a difference between numpad-keys
|
||||
* and normal keys. SYSV/386 uses for both kinds of keys
|
||||
* the same symbol.
|
||||
*
|
||||
* Thus only the alpha keypad and the function keys are translated.
|
||||
* Also CapsLock, NumLock, ScrollLock, Shift, Control & Alt.
|
||||
*/
|
||||
|
||||
static unsigned char remap[128] = {
|
||||
0, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, /* 0x00 - 0x07 */
|
||||
0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, /* 0x08 - 0x0f */
|
||||
0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, /* 0x10 - 0x17 */
|
||||
0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f, /* 0x18 - 0x1f */
|
||||
0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, /* 0x20 - 0x27 */
|
||||
0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d, 0x2e, 0x2f, /* 0x28 - 0x2f */
|
||||
0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0, /* 0x30 - 0x37 */
|
||||
0x38, 0x39, 0x3a, 0x3b, 0x3c, 0x3d, 0x3e, 0x3f, /* 0x38 - 0x3f */
|
||||
0x40, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46, 0, /* 0x40 - 0x47 */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x48 - 0x4f */
|
||||
0, 0, 0, 0, 0, 0, 0x56, 0x57, /* 0x50 - 0x57 */
|
||||
0x58, 0, 0, 0, 0, 0, 0, 0, /* 0x58 - 0x5f */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x60 - 0x67 */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x68 - 0x6f */
|
||||
0, 0, 0x69, 0x65, 0, 0, 0, 0, /* 0x70 - 0x77 */
|
||||
0, 0, 0, 0, 0, 0, 0, 0, /* 0x78 - 0x7f */
|
||||
};
|
||||
|
||||
static KeySym eascii_to_x[512] = {
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_BackSpace, XK_Tab, XK_Linefeed, NoSymbol,
|
||||
NoSymbol, XK_Return, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, XK_Escape,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_space, XK_exclam, XK_quotedbl, XK_numbersign,
|
||||
XK_dollar, XK_percent, XK_ampersand, XK_apostrophe,
|
||||
XK_parenleft, XK_parenright, XK_asterisk, XK_plus,
|
||||
XK_comma, XK_minus, XK_period, XK_slash,
|
||||
XK_0, XK_1, XK_2, XK_3,
|
||||
XK_4, XK_5, XK_6, XK_7,
|
||||
XK_8, XK_9, XK_colon, XK_semicolon,
|
||||
XK_less, XK_equal, XK_greater, XK_question,
|
||||
XK_at, XK_A, XK_B, XK_C,
|
||||
XK_D, XK_E, XK_F, XK_G,
|
||||
XK_H, XK_I, XK_J, XK_K,
|
||||
XK_L, XK_M, XK_N, XK_O,
|
||||
XK_P, XK_Q, XK_R, XK_S,
|
||||
XK_T, XK_U, XK_V, XK_W,
|
||||
XK_X, XK_Y, XK_Z, XK_bracketleft,
|
||||
XK_backslash, XK_bracketright,XK_asciicircum, XK_underscore,
|
||||
XK_grave, XK_a, XK_b, XK_c,
|
||||
XK_d, XK_e, XK_f, XK_g,
|
||||
XK_h, XK_i, XK_j, XK_k,
|
||||
XK_l, XK_m, XK_n, XK_o,
|
||||
XK_p, XK_q, XK_r, XK_s,
|
||||
XK_t, XK_u, XK_v, XK_w,
|
||||
XK_x, XK_y, XK_z, XK_braceleft,
|
||||
XK_bar, XK_braceright, XK_asciitilde, XK_Delete,
|
||||
XK_Ccedilla, XK_udiaeresis, XK_eacute, XK_acircumflex,
|
||||
XK_adiaeresis, XK_agrave, XK_aring, XK_ccedilla,
|
||||
XK_ecircumflex, XK_ediaeresis, XK_egrave, XK_idiaeresis,
|
||||
XK_icircumflex, XK_igrave, XK_Adiaeresis, XK_Aring,
|
||||
XK_Eacute, XK_ae, XK_AE, XK_ocircumflex,
|
||||
XK_odiaeresis, XK_ograve, XK_ucircumflex, XK_ugrave,
|
||||
XK_ydiaeresis, XK_Odiaeresis, XK_Udiaeresis, XK_cent,
|
||||
XK_sterling, XK_yen, XK_paragraph, XK_section,
|
||||
XK_aacute, XK_iacute, XK_oacute, XK_uacute,
|
||||
XK_ntilde, XK_Ntilde, XK_ordfeminine, XK_masculine,
|
||||
XK_questiondown,XK_hyphen, XK_notsign, XK_onehalf,
|
||||
XK_onequarter, XK_exclamdown, XK_guillemotleft,XK_guillemotright,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
XK_Greek_alpha, XK_ssharp, XK_Greek_GAMMA, XK_Greek_pi,
|
||||
XK_Greek_SIGMA, XK_Greek_sigma, XK_mu, XK_Greek_tau,
|
||||
XK_Greek_PHI, XK_Greek_THETA, XK_Greek_OMEGA, XK_Greek_delta,
|
||||
XK_infinity, XK_Ooblique, XK_Greek_epsilon, XK_intersection,
|
||||
XK_identical, XK_plusminus, XK_greaterthanequal, XK_lessthanequal,
|
||||
XK_topintegral, XK_botintegral, XK_division, XK_similarequal,
|
||||
XK_degree, NoSymbol, NoSymbol, XK_radical,
|
||||
XK_Greek_eta, XK_twosuperior, XK_periodcentered, NoSymbol,
|
||||
|
||||
/*
|
||||
* special marked entries (256 + x)
|
||||
*/
|
||||
|
||||
NoSymbol, NoSymbol, XK_Shift_L, XK_Shift_R,
|
||||
XK_Caps_Lock, XK_Num_Lock, XK_Scroll_Lock, XK_Alt_L,
|
||||
NoSymbol, XK_Control_L, XK_Alt_L, XK_Alt_R,
|
||||
XK_Control_L, XK_Control_R, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, XK_F1,
|
||||
XK_F2, XK_F3, XK_F4, XK_F5,
|
||||
XK_F6, XK_F7, XK_F8, XK_F9,
|
||||
XK_F10, XK_F11, XK_F12, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
NoSymbol, NoSymbol, NoSymbol, NoSymbol,
|
||||
};
|
||||
|
||||
/*
|
||||
* KbdGetMapping --
|
||||
* Get the national keyboard mapping. The keyboard type is set, a new map
|
||||
* and the modifiermap is computed.
|
||||
*/
|
||||
|
||||
void
|
||||
KbdGetMapping (InputInfoPtr pInfo, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
USLKbdPrivPtr priv = (USLKbdPrivPtr) pKbd->private;
|
||||
KeySym *k;
|
||||
int i;
|
||||
KeySym *pMap = map;
|
||||
|
||||
for (i = 0; i < priv->keymap.n_keys && i < NUM_KEYCODES; i++) {
|
||||
if (remap[i]) {
|
||||
k = pMap + (remap[i] << 2);
|
||||
|
||||
k[0] = KD_GET_ENTRY(i,0); /* non-shifed */
|
||||
k[1] = KD_GET_ENTRY(i,1); /* shifted */
|
||||
k[2] = KD_GET_ENTRY(i,4); /* alt */
|
||||
k[3] = KD_GET_ENTRY(i,5); /* alt - shifted */
|
||||
|
||||
if (k[3] == k[2]) k[3] = NoSymbol;
|
||||
if (k[2] == k[1]) k[2] = NoSymbol;
|
||||
if (k[1] == k[0]) k[1] = NoSymbol;
|
||||
if (k[0] == k[2] && k[1] == k[3]) k[2] = k[3] = NoSymbol;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* compute the modifier map
|
||||
*/
|
||||
for (i = 0; i < MAP_LENGTH; i++)
|
||||
pModMap[i] = NoSymbol; /* make sure it is restored */
|
||||
|
||||
for (k = pMap, i = MIN_KEYCODE;
|
||||
i < (NUM_KEYCODES + MIN_KEYCODE);
|
||||
i++, k += 4) {
|
||||
|
||||
switch(*k) {
|
||||
case XK_Shift_L:
|
||||
case XK_Shift_R:
|
||||
pModMap[i] = ShiftMask;
|
||||
break;
|
||||
|
||||
case XK_Control_L:
|
||||
case XK_Control_R:
|
||||
pModMap[i] = ControlMask;
|
||||
break;
|
||||
|
||||
case XK_Caps_Lock:
|
||||
pModMap[i] = LockMask;
|
||||
break;
|
||||
|
||||
case XK_Alt_L:
|
||||
case XK_Alt_R:
|
||||
pModMap[i] = AltMask;
|
||||
break;
|
||||
|
||||
case XK_Num_Lock:
|
||||
pModMap[i] = NumLockMask;
|
||||
break;
|
||||
|
||||
case XK_Scroll_Lock:
|
||||
pModMap[i] = ScrollLockMask;
|
||||
break;
|
||||
|
||||
/* kana support */
|
||||
case XK_Kana_Lock:
|
||||
case XK_Kana_Shift:
|
||||
pModMap[i] = KanaMask;
|
||||
break;
|
||||
|
||||
/* alternate toggle for multinational support */
|
||||
case XK_Mode_switch:
|
||||
pModMap[i] = AltLangMask;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
pKeySyms->map = pMap;
|
||||
pKeySyms->mapWidth = GLYPHS_PER_KEY;
|
||||
pKeySyms->minKeyCode = MIN_KEYCODE;
|
||||
pKeySyms->maxKeyCode = MAX_KEYCODE;
|
||||
}
|
|
@ -1,455 +0,0 @@
|
|||
/*
|
||||
* Copyright 2005 by Kean Johnston <jkj@sco.com>
|
||||
*
|
||||
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||
* documentation for any purpose is hereby granted without fee, provided that
|
||||
* the above copyright notice appear in all copies and that both that
|
||||
* copyright notice and this permission notice appear in supporting
|
||||
* documentation, and that the name Kean Johnston not be used in
|
||||
* advertising or publicity pertaining to distribution of the software without
|
||||
* specific, written prior permission. Kean Johnston makes no
|
||||
* representations about the suitability of this software for any purpose.
|
||||
* It is provided "as is" without express or implied warranty.
|
||||
*
|
||||
* KEAN JOHNSTON DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
|
||||
* EVENT SHALL KEAN JOHNSTON BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||
* PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
/* $XConsortium$ */
|
||||
|
||||
/*
|
||||
* Based on sco_io.c which is
|
||||
* (C) Copyright 2003 Kean Johnston <jkj@sco.com>
|
||||
*
|
||||
* Based on lnx_kbd.c which is
|
||||
* Copyright (c) 2002 by The XFree86 Project, Inc.
|
||||
*
|
||||
* Based on the code from lnx_io.c which is
|
||||
* Copyright 1992 by Orest Zborowski <obz@Kodak.com>
|
||||
* Copyright 1993 by David Dawes <dawes@xfree86.org>
|
||||
*/
|
||||
|
||||
#define NEED_EVENTS
|
||||
#include "X.h"
|
||||
|
||||
#include "compiler.h"
|
||||
|
||||
#define _NEED_SYSI86
|
||||
#include "xf86.h"
|
||||
#include "xf86Priv.h"
|
||||
#include "xf86OSpriv.h"
|
||||
#include "xf86_OSlib.h"
|
||||
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "atKeynames.h"
|
||||
#include "usl_kbd.h"
|
||||
#include "usl_xqueue.h"
|
||||
|
||||
#include <sys/param.h>
|
||||
|
||||
static KbdProtocolRec protocols[] = {
|
||||
{ "standard", PROT_STD },
|
||||
{ "Xqueue", PROT_XQUEUE },
|
||||
{ NULL, PROT_UNKNOWN_KBD }
|
||||
};
|
||||
|
||||
extern Bool VTSwitchEnabled;
|
||||
#ifdef USE_VT_SYSREQ
|
||||
extern Bool VTSysreqToggle;
|
||||
#endif
|
||||
|
||||
static void
|
||||
SoundBell(InputInfoPtr pInfo, int loudness, int pitch, int duration)
|
||||
{
|
||||
if (loudness && pitch) {
|
||||
ioctl(pInfo->fd, KIOCSOUND, 1193180 / pitch);
|
||||
usleep(duration * loudness * 20);
|
||||
ioctl(pInfo->fd, KIOCSOUND, 0);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdLeds(InputInfoPtr pInfo, int leds)
|
||||
{
|
||||
int real_leds = 0;
|
||||
|
||||
if (leds & XLED1)
|
||||
real_leds |= LED_CAP;
|
||||
if (leds & XLED2)
|
||||
real_leds |= LED_NUM;
|
||||
if (leds & XLED3)
|
||||
real_leds |= LED_SCR;
|
||||
ioctl(pInfo->fd, KDSETLED, real_leds);
|
||||
}
|
||||
|
||||
static int
|
||||
GetKbdLeds(InputInfoPtr pInfo)
|
||||
{
|
||||
int real_leds, leds = 0;
|
||||
|
||||
ioctl(pInfo->fd, KDGETLED, &real_leds);
|
||||
|
||||
if (real_leds & LED_CAP) leds |= XLED1;
|
||||
if (real_leds & LED_NUM) leds |= XLED2;
|
||||
if (real_leds & LED_SCR) leds |= XLED3;
|
||||
|
||||
return(leds);
|
||||
}
|
||||
|
||||
static void
|
||||
SetKbdRepeat(InputInfoPtr pInfo, char rad)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
int i;
|
||||
int value = 0x7f; /* Maximum delay with slowest rate */
|
||||
int delay = 250; /* Default delay */
|
||||
int rate = 300; /* Default repeat rate */
|
||||
|
||||
static int valid_rates[] = { 300, 267, 240, 218, 200, 185, 171, 160, 150,
|
||||
133, 120, 109, 100, 92, 86, 80, 75, 67,
|
||||
60, 55, 50, 46, 43, 40, 37, 33, 30, 27,
|
||||
25, 23, 21, 20 };
|
||||
#define RATE_COUNT (sizeof( valid_rates ) / sizeof( int ))
|
||||
|
||||
static int valid_delays[] = { 250, 500, 750, 1000 };
|
||||
#define DELAY_COUNT (sizeof( valid_delays ) / sizeof( int ))
|
||||
|
||||
if (pKbd->rate >= 0)
|
||||
rate = pKbd->rate * 10;
|
||||
if (pKbd->delay >= 0)
|
||||
delay = pKbd->delay;
|
||||
|
||||
for (i = 0; i < RATE_COUNT; i++)
|
||||
if (rate >= valid_rates[i]) {
|
||||
value &= 0x60;
|
||||
value |= i;
|
||||
break;
|
||||
}
|
||||
|
||||
for (i = 0; i < DELAY_COUNT; i++)
|
||||
if (delay <= valid_delays[i]) {
|
||||
value &= 0x1f;
|
||||
value |= i << 5;
|
||||
break;
|
||||
}
|
||||
|
||||
ioctl (pInfo->fd, KDSETTYPEMATICS, value);
|
||||
}
|
||||
|
||||
static int
|
||||
KbdInit(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
USLKbdPrivPtr priv = (USLKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
if (ioctl (pInfo->fd, KDGKBMODE, &priv->orig_kbm) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Could not determine keyboard mode\n");
|
||||
return !Success;
|
||||
}
|
||||
|
||||
/*
|
||||
* We need to get the original keyboard map and NUL out the lock
|
||||
* modifiers. This prevents the kernel from messing with
|
||||
* the keyboard LED's. We restore the original map when we exit.
|
||||
* Note that we also have to eliminate screen switch sequences
|
||||
* else the VT manager will switch for us, which we don't want.
|
||||
* For example, lets say you had changed the VT manager to switch
|
||||
* on Alt-Fx instead of Ctrl-Alt-Fx. This means that while inside
|
||||
* X, you cant use, for example, Alt-F4, which is a pain in the
|
||||
* fundamental when you're using CDE-like thingies.
|
||||
*/
|
||||
if (ioctl (pInfo->fd, GIO_KEYMAP, &priv->keymap) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to get keyboard map (%s)\n",
|
||||
strerror(errno));
|
||||
return !Success;
|
||||
}
|
||||
if (ioctl (pInfo->fd, GIO_KEYMAP, &priv->noledmap) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to get keyboard map (%s)\n",
|
||||
strerror(errno));
|
||||
return !Success;
|
||||
} else {
|
||||
int i, j;
|
||||
|
||||
for (i = 0; i < priv->noledmap.n_keys; i++) {
|
||||
for (j = 0; j < NUM_STATES; j++) {
|
||||
if (IS_SPECKEY(&priv->noledmap, i, j) &&
|
||||
((priv->noledmap.key[i].map[j] == K_CLK) ||
|
||||
(priv->noledmap.key[i].map[j] == K_NLK) ||
|
||||
(priv->noledmap.key[i].map[j] == K_SLK) ||
|
||||
(priv->noledmap.key[i].map[j] == K_FRCNEXT) ||
|
||||
(priv->noledmap.key[i].map[j] == K_FRCPREV) ||
|
||||
((priv->noledmap.key[i].map[j] >= K_VTF) &&
|
||||
(priv->noledmap.key[i].map[j] <= K_VTL)) )) {
|
||||
priv->noledmap.key[i].map[j] = K_NOP;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (ioctl (pInfo->fd, TCGETA, &priv->kbdtty) < 0) {
|
||||
xf86Msg (X_ERROR, "KbdInit: Failed to get terminal modes (%s)\n",
|
||||
strerror(errno));
|
||||
return !Success;
|
||||
}
|
||||
} /* End of if we are on a console */
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOn(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
USLKbdPrivPtr priv = (USLKbdPrivPtr) pKbd->private;
|
||||
struct termio newtio;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
/*
|
||||
* Use the calculated keyboard map that does not have active
|
||||
* LED lock handling (we track LEDs ourselves).
|
||||
*/
|
||||
ioctl (pInfo->fd, PIO_KEYMAP, &priv->noledmap);
|
||||
|
||||
#ifdef NOTYET
|
||||
newtio = priv->kbdtty; /* structure copy */
|
||||
newtio.c_iflag = (IGNPAR | IGNBRK) & (~PARMRK) & (~ISTRIP);
|
||||
newtio.c_oflag = 0;
|
||||
newtio.c_cflag = CREAD | CS8 | B9600;
|
||||
newtio.c_lflag = 0;
|
||||
newtio.c_cc[VTIME]=0;
|
||||
newtio.c_cc[VMIN]=1;
|
||||
ioctl(pInfo->fd, TCSETA, &newtio);
|
||||
|
||||
if (priv->xq == 0)
|
||||
ioctl (pInfo->fd, KDSKBMODE, K_RAW);
|
||||
else
|
||||
#endif
|
||||
XqKbdOnOff (pInfo, 1);
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
static int
|
||||
KbdOff(InputInfoPtr pInfo, int what)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
USLKbdPrivPtr priv = (USLKbdPrivPtr) pKbd->private;
|
||||
|
||||
if (pKbd->isConsole) {
|
||||
/* Revert back to original translate scancode mode */
|
||||
#ifdef NOTYET
|
||||
if (priv->xq == 0)
|
||||
ioctl (pInfo->fd, KDSKBMODE, priv->orig_kbm);
|
||||
else
|
||||
#endif
|
||||
XqKbdOnOff (pInfo, 0);
|
||||
|
||||
ioctl (pInfo->fd, PIO_KEYMAP, &priv->keymap);
|
||||
ioctl(pInfo->fd, TCSETA, &priv->kbdtty);
|
||||
}
|
||||
|
||||
return Success;
|
||||
}
|
||||
|
||||
#define ModifierSet(k) ((modifiers & (k)) == (k))
|
||||
|
||||
static Bool
|
||||
SpecialKey(InputInfoPtr pInfo, int key, Bool down, int modifiers)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
|
||||
if(!pKbd->vtSwitchSupported)
|
||||
return FALSE;
|
||||
|
||||
if ((!ModifierSet(ShiftMask)) && ((ModifierSet(ControlMask | AltMask)) ||
|
||||
(ModifierSet(ControlMask | AltLangMask)))) {
|
||||
if (VTSwitchEnabled && !xf86Info.vtSysreq) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (down) {
|
||||
int sts = key - KEY_F1;
|
||||
if (sts != xf86Info.vtno) {
|
||||
ioctl(pInfo->fd, VT_SWITCH, sts);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (down) {
|
||||
int sts = key - KEY_F11 + 10;
|
||||
if (sts != xf86Info.vtno) {
|
||||
ioctl(pInfo->fd, VT_SWITCH, sts);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
#ifdef USE_VT_SYSREQ
|
||||
if (VTSwitchEnabled && xf86Info.vtSysreq) {
|
||||
switch (key) {
|
||||
case KEY_F1:
|
||||
case KEY_F2:
|
||||
case KEY_F3:
|
||||
case KEY_F4:
|
||||
case KEY_F5:
|
||||
case KEY_F6:
|
||||
case KEY_F7:
|
||||
case KEY_F8:
|
||||
case KEY_F9:
|
||||
case KEY_F10:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(pInfo->fd, VT_ACTIVATE, key - KEY_F1);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
case KEY_F11:
|
||||
case KEY_F12:
|
||||
if (VTSysreqToggle && down) {
|
||||
ioctl(pInfo->fd, VT_ACTIVATE, key - KEY_F11 + 10);
|
||||
VTSysreqToggle = FALSE;
|
||||
return TRUE;
|
||||
}
|
||||
break;
|
||||
/* Ignore these keys -- ie don't let them cancel an alt-sysreq */
|
||||
case KEY_Alt:
|
||||
case KEY_AltLang:
|
||||
break;
|
||||
case KEY_SysReqest:
|
||||
if (!(ModifierSet(ShiftMask) || ModifierSet(ControlMask))) {
|
||||
if ((ModifierSet(AltMask) || ModifierSet(AltLangMask)) && down)
|
||||
VTSysreqToggle = TRUE;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
/*
|
||||
* We only land here when Alt-SysReq is followed by a
|
||||
* non-switching key.
|
||||
*/
|
||||
if (VTSysreqToggle)
|
||||
VTSysreqToggle = FALSE;
|
||||
}
|
||||
}
|
||||
#endif /* USE_VT_SYSREQ */
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
#ifdef NOTYET
|
||||
static void
|
||||
stdReadInput(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
unsigned char rBuf[64];
|
||||
int nBytes, i;
|
||||
|
||||
if ((nBytes = read( pInfo->fd, (char *)rBuf, sizeof(rBuf))) > 0) {
|
||||
for (i = 0; i < nBytes; i++) {
|
||||
pKbd->PostEvent(pInfo, rBuf[i] & 0x7f, rBuf[i] & 0x80 ? FALSE : TRUE);
|
||||
}
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
static Bool
|
||||
OpenKeyboard(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = (KbdDevPtr) pInfo->private;
|
||||
USLKbdPrivPtr priv = (USLKbdPrivPtr) pKbd->private;
|
||||
int i;
|
||||
KbdProtocolId prot = PROT_UNKNOWN_KBD;
|
||||
char *s;
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Protocol", NULL);
|
||||
for (i = 0; protocols[i].name; i++) {
|
||||
if (xf86NameCmp(s, protocols[i].name) == 0) {
|
||||
prot = protocols[i].id;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch (prot) {
|
||||
case PROT_STD:
|
||||
#ifdef NOTYET
|
||||
pInfo->read_input = stdReadInput;
|
||||
priv->xq = 0;
|
||||
break;
|
||||
#endif
|
||||
case PROT_XQUEUE:
|
||||
pInfo->read_input = NULL; /* Handled by the XQUEUE signal handler */
|
||||
priv->xq = 1;
|
||||
break;
|
||||
default:
|
||||
xf86Msg(X_ERROR,"\"%s\" is not a valid keyboard protocol name\n", s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
xf86Msg(X_CONFIG, "%s: Protocol: %s\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
|
||||
s = xf86SetStrOption(pInfo->options, "Device", NULL);
|
||||
if (s == NULL) {
|
||||
pInfo->fd = xf86Info.consoleFd;
|
||||
pKbd->isConsole = TRUE;
|
||||
} else {
|
||||
pInfo->fd = open(s, O_RDONLY | O_NONBLOCK | O_EXCL);
|
||||
if (pInfo->fd == -1) {
|
||||
xf86Msg(X_ERROR, "%s: cannot open \"%s\"\n", pInfo->name, s);
|
||||
xfree(s);
|
||||
return FALSE;
|
||||
}
|
||||
pKbd->isConsole = FALSE;
|
||||
xfree(s);
|
||||
}
|
||||
|
||||
if (pKbd->isConsole)
|
||||
pKbd->vtSwitchSupported = TRUE;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
_X_EXPORT Bool
|
||||
xf86OSKbdPreInit(InputInfoPtr pInfo)
|
||||
{
|
||||
KbdDevPtr pKbd = pInfo->private;
|
||||
|
||||
pKbd->KbdInit = KbdInit;
|
||||
pKbd->KbdOn = KbdOn;
|
||||
pKbd->KbdOff = KbdOff;
|
||||
pKbd->Bell = SoundBell;
|
||||
pKbd->SetLeds = SetKbdLeds;
|
||||
pKbd->GetLeds = GetKbdLeds;
|
||||
pKbd->SetKbdRepeat = SetKbdRepeat;
|
||||
pKbd->KbdGetMapping = KbdGetMapping;
|
||||
pKbd->SpecialKey = SpecialKey;
|
||||
pKbd->OpenKeyboard = OpenKeyboard;
|
||||
|
||||
pKbd->GetSpecialKey = NULL;
|
||||
pKbd->RemapScanCode = ATScancode;
|
||||
pKbd->vtSwitchSupported = FALSE;
|
||||
|
||||
pKbd->private = xcalloc(sizeof(USLKbdPrivRec), 1);
|
||||
if (pKbd->private == NULL) {
|
||||
xf86Msg(X_ERROR,"can't allocate keyboard OS private data\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
|
@ -1,14 +0,0 @@
|
|||
/* $XdotOrg$ */
|
||||
#ifndef SCO_KBD_HDR
|
||||
#define SCO_KBD_HDR
|
||||
|
||||
typedef struct {
|
||||
int orig_kbm;
|
||||
struct termio kbdtty;
|
||||
keymap_t keymap, noledmap;
|
||||
int xq;
|
||||
} USLKbdPrivRec, *USLKbdPrivPtr;
|
||||
|
||||
extern void KbdGetMapping(InputInfoPtr pInfo, KeySymsPtr pKeySyms,
|
||||
CARD8 *pModMap);
|
||||
#endif /* SCO_KBD_HDR */
|
|
@ -33,7 +33,6 @@
|
|||
#include "xf86_OSlib.h"
|
||||
#include "xf86Xinput.h"
|
||||
#include "xf86OSmouse.h"
|
||||
#include "xf86OSKbd.h"
|
||||
#include "usl_xqueue.h"
|
||||
|
||||
#ifdef XKB
|
||||
|
|
|
@ -1,132 +0,0 @@
|
|||
/*
|
||||
* Copyright (c) 2002-2003 by The XFree86 Project, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Except as contained in this notice, the name of the copyright holder(s)
|
||||
* and author(s) shall not be used in advertising or otherwise to promote
|
||||
* the sale, use or other dealings in this Software without prior written
|
||||
* authorization from the copyright holder(s) and author(s).
|
||||
*
|
||||
* Author: Ivan Pascal.
|
||||
*/
|
||||
|
||||
#include "xf86Xinput.h"
|
||||
|
||||
Bool ATScancode(InputInfoPtr pInfo, int *scanCode);
|
||||
|
||||
/* Public interface to OS-specific keyboard support. */
|
||||
|
||||
typedef int (*KbdInitProc)(InputInfoPtr pInfo, int what);
|
||||
typedef int (*KbdOnProc)(InputInfoPtr pInfo, int what);
|
||||
typedef int (*KbdOffProc)(InputInfoPtr pInfo, int what);
|
||||
typedef void (*BellProc)(InputInfoPtr pInfo,
|
||||
int loudness, int pitch, int duration);
|
||||
typedef void (*SetLedsProc)(InputInfoPtr pInfo, int leds);
|
||||
typedef int (*GetLedsProc)(InputInfoPtr pInfo);
|
||||
typedef void (*SetKbdRepeatProc)(InputInfoPtr pInfo, char rad);
|
||||
typedef void (*KbdGetMappingProc)(InputInfoPtr pInfo,
|
||||
KeySymsPtr pKeySyms, CARD8* pModMap);
|
||||
typedef int (*GetSpecialKeyProc)(InputInfoPtr pInfo, int scanCode);
|
||||
typedef Bool (*SpecialKeyProc)(InputInfoPtr pInfo,
|
||||
int key, Bool down, int modifiers);
|
||||
typedef int (*RemapScanCodeProc)(InputInfoPtr pInfo, int *scanCode);
|
||||
typedef Bool (*OpenKeyboardProc)(InputInfoPtr pInfo);
|
||||
typedef void (*PostEventProc)(InputInfoPtr pInfo,
|
||||
unsigned int key, Bool down);
|
||||
typedef struct {
|
||||
int begin;
|
||||
int end;
|
||||
unsigned char *map;
|
||||
} TransMapRec, *TransMapPtr;
|
||||
|
||||
typedef struct {
|
||||
KbdInitProc KbdInit;
|
||||
KbdOnProc KbdOn;
|
||||
KbdOffProc KbdOff;
|
||||
BellProc Bell;
|
||||
SetLedsProc SetLeds;
|
||||
GetLedsProc GetLeds;
|
||||
SetKbdRepeatProc SetKbdRepeat;
|
||||
KbdGetMappingProc KbdGetMapping;
|
||||
RemapScanCodeProc RemapScanCode;
|
||||
GetSpecialKeyProc GetSpecialKey;
|
||||
SpecialKeyProc SpecialKey;
|
||||
|
||||
OpenKeyboardProc OpenKeyboard;
|
||||
PostEventProc PostEvent;
|
||||
|
||||
int rate;
|
||||
int delay;
|
||||
int bell_pitch;
|
||||
int bell_duration;
|
||||
Bool autoRepeat;
|
||||
unsigned long leds;
|
||||
unsigned long xledsMask;
|
||||
unsigned long keyLeds;
|
||||
int scanPrefix;
|
||||
Bool vtSwitchSupported;
|
||||
Bool CustomKeycodes;
|
||||
Bool noXkb;
|
||||
Bool isConsole;
|
||||
TransMapPtr scancodeMap;
|
||||
TransMapPtr specialMap;
|
||||
|
||||
/* os specific */
|
||||
pointer private;
|
||||
int kbdType;
|
||||
int consType;
|
||||
int wsKbdType;
|
||||
Bool sunKbd;
|
||||
Bool Panix106;
|
||||
|
||||
} KbdDevRec, *KbdDevPtr;
|
||||
|
||||
typedef enum {
|
||||
PROT_STD,
|
||||
PROT_XQUEUE,
|
||||
PROT_WSCONS,
|
||||
PROT_USB,
|
||||
PROT_UNKNOWN_KBD
|
||||
} KbdProtocolId;
|
||||
|
||||
typedef struct {
|
||||
const char *name;
|
||||
KbdProtocolId id;
|
||||
} KbdProtocolRec;
|
||||
|
||||
Bool xf86OSKbdPreInit(InputInfoPtr pInfo);
|
||||
|
||||
/* Adjust this when the kbd interface changes. */
|
||||
|
||||
/*
|
||||
* History:
|
||||
*
|
||||
* 1.0.0 - Initial version.
|
||||
*/
|
||||
|
||||
#define OS_KBD_VERSION_MAJOR 1
|
||||
#define OS_KBD_VERSION_MINOR 0
|
||||
#define OS_KBD_VERSION_PATCH 0
|
||||
|
||||
#define OS_KBD_VERSION_CURRENT \
|
||||
BUILTIN_INTERFACE_VERSION_NUMERIC(OS_KBD_VERSION_MAJOR, \
|
||||
OS_KBD_VERSION_MINOR, \
|
||||
OS_KBD_VERSION_PATCH)
|
||||
|
Loading…
Reference in New Issue
Block a user