2007-05-25 13:10:43 -06:00
|
|
|
/* $OpenBSD: keyboard.c,v 1.2 2007/05/25 19:10:43 matthieu Exp $ */
|
2007-05-25 09:33:32 -06:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2007 Matthieu Herrb <matthieu@openbsd.org>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, 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_CONFIG_H
|
|
|
|
#include <kdrive-config.h>
|
|
|
|
#endif
|
|
|
|
#include "kdrive.h"
|
|
|
|
|
|
|
|
#include <X11/keysym.h>
|
|
|
|
|
2007-05-25 13:10:43 -06:00
|
|
|
#include <errno.h>
|
|
|
|
#include <dev/wscons/wsconsio.h>
|
|
|
|
|
2007-05-25 09:33:32 -06:00
|
|
|
extern int WsconsConsoleFd;
|
|
|
|
static int WsconsKbdType;
|
|
|
|
|
|
|
|
static void
|
|
|
|
WsconsKeyboardLoad(void)
|
|
|
|
{
|
|
|
|
/* Read kernel Mapping */
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
WsconsKeyboardRead(int fd, void *closure)
|
|
|
|
{
|
|
|
|
unsigned char b;
|
|
|
|
|
|
|
|
/* read and enqueue events */
|
|
|
|
KdEnqueueKeyboardEvent(b & 0x7f, b & 0x80);
|
|
|
|
}
|
|
|
|
|
2007-05-25 13:10:43 -06:00
|
|
|
static int
|
2007-05-25 09:33:32 -06:00
|
|
|
WsconsKeyboardEnable(int fd, void *closure)
|
|
|
|
{
|
2007-05-25 13:10:43 -06:00
|
|
|
int option = WSKBD_RAW;
|
|
|
|
|
2007-05-25 09:33:32 -06:00
|
|
|
/* Switch to X mode */
|
2007-05-25 13:10:43 -06:00
|
|
|
if (ioctl(fd, WSKBDIO_SETMODE, &option) == -1) {
|
|
|
|
ErrorF("WsconsKeyboardEnable: WSKBDIO_SETMODE: %d\n", errno);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
return fd;
|
2007-05-25 09:33:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
WsconsKeyboardDisable(int fd, void *closure)
|
|
|
|
{
|
2007-05-25 13:10:43 -06:00
|
|
|
int option = WSKBD_TRANSLATED;
|
|
|
|
|
2007-05-25 09:33:32 -06:00
|
|
|
/* Back to console mode */
|
2007-05-25 13:10:43 -06:00
|
|
|
ioctl(fd, WSKBDIO_SETMODE, &option);
|
2007-05-25 09:33:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
WsconsKeyboardInit(void)
|
|
|
|
{
|
|
|
|
if (!WsconsKbdType)
|
|
|
|
WsconsKbdType = KdAllocInputType();
|
|
|
|
KdRegisterFd(WsconsKbdType, WsconsConsoleFd, WsconsKeyboardRead, 0);
|
|
|
|
WsconsKeyboardEnable(WsconsConsoleFd, 0);
|
|
|
|
KdRegisterFdEnableDisable(WsconsConsoleFd,
|
|
|
|
WsconsKeyboardEnable, WsconsKeyboardDisable);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
WsconsKeyboardFini(void)
|
|
|
|
{
|
|
|
|
WsconsKeyboardDisable(WsconsConsoleFd, 0);
|
|
|
|
KdUnregisterFds(WsconsKbdType, FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
WsconsKeyboardLeds(int leds)
|
|
|
|
{
|
2007-05-25 13:10:43 -06:00
|
|
|
ioctl(WsconsConsoleFd, WSKBDIO_SETLEDS, &leds);
|
2007-05-25 09:33:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
WsconsKeyboardBell(int volume, int pitch, int duration)
|
|
|
|
{
|
2007-05-25 13:10:43 -06:00
|
|
|
struct wskbd_bell_data wsb;
|
|
|
|
|
|
|
|
wsb.which = WSKBD_BELL_DOALL;
|
|
|
|
wsb.pitch = pitch;
|
|
|
|
wsb.period = duration;
|
|
|
|
wsb.volume = volume;
|
|
|
|
ioctl(WsconsConsoleFd, WSKBDIO_COMPLEXBELL, &wsb);
|
2007-05-25 09:33:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
KdKeyboardFuncs WsconsKeyboardFuncs = {
|
|
|
|
WsconsKeyboardLoad,
|
|
|
|
WsconsKeyboardInit,
|
|
|
|
WsconsKeyboardLeds,
|
|
|
|
WsconsKeyboardBell,
|
|
|
|
WsconsKeyboardFini,
|
|
|
|
3,
|
|
|
|
};
|