From 259699b294163f99205912e9e2ffcd59d1fbf9b8 Mon Sep 17 00:00:00 2001 From: "Wojciech A. Koszek" Date: Sat, 29 Dec 2007 21:55:25 +0000 Subject: [PATCH] Remove explicit calls to keyboard methods with their respective variants implemented with macros. This patch improves code readability. Reasoning behind kbdd_* is a "keyboard discipline". List of macros is supposed to be complete--all methods of keyboard_switch should have their respective macros from now on. Functionally, this code should be no-op. My intention is to leave current behaviour of code as is. Glanced at by: rwatson Reviewed by: emax, marcel Approved by: cognet --- sys/dev/atkbdc/atkbd.c | 8 ++--- sys/dev/atkbdc/atkbd_atkbdc.c | 8 ++--- sys/dev/kbd/kbd.c | 29 ++++++++---------- sys/dev/kbd/kbdreg.h | 44 +++++++++++++++++++++++++++ sys/dev/kbdmux/kbdmux.c | 49 +++++++++--------------------- sys/dev/syscons/syscons.c | 56 +++++++++++++++++------------------ sys/dev/syscons/syscons.h | 20 ------------- sys/dev/usb/ukbd.c | 10 +++---- sys/dev/vkbd/vkbd.c | 9 +++--- 9 files changed, 115 insertions(+), 118 deletions(-) diff --git a/sys/dev/atkbdc/atkbd.c b/sys/dev/atkbdc/atkbd.c index 778515eac0e7..0149cb89998c 100644 --- a/sys/dev/atkbdc/atkbd.c +++ b/sys/dev/atkbdc/atkbd.c @@ -162,15 +162,15 @@ atkbd_timeout(void *arg) */ s = spltty(); kbd = (keyboard_t *)arg; - if ((*kbdsw[kbd->kb_index]->lock)(kbd, TRUE)) { + if (kbdd_lock(kbd, TRUE)) { /* * We have seen the lock flag is not set. Let's reset * the flag early, otherwise the LED update routine fails * which may want the lock during the interrupt routine. */ - (*kbdsw[kbd->kb_index]->lock)(kbd, FALSE); - if ((*kbdsw[kbd->kb_index]->check_char)(kbd)) - (*kbdsw[kbd->kb_index]->intr)(kbd, NULL); + kbdd_lock(kbd, FALSE); + if (kbdd_check_char(kbd)) + kbdd_intr(kbd, NULL); } splx(s); timeout(atkbd_timeout, arg, hz/10); diff --git a/sys/dev/atkbdc/atkbd_atkbdc.c b/sys/dev/atkbdc/atkbd_atkbdc.c index ec6555b1e0a9..9531fa232f98 100644 --- a/sys/dev/atkbdc/atkbd_atkbdc.c +++ b/sys/dev/atkbdc/atkbd_atkbdc.c @@ -158,9 +158,9 @@ atkbdresume(device_t dev) kbd->kb_flags &= ~KB_INITIALIZED; args[0] = device_get_unit(device_get_parent(dev)); args[1] = rman_get_start(sc->intr); - (*kbdsw[kbd->kb_index]->init)(device_get_unit(dev), &kbd, - args, device_get_flags(dev)); - (*kbdsw[kbd->kb_index]->clear_state)(kbd); + kbdd_init(kbd, device_get_unit(dev), &kbd, args, + device_get_flags(dev)); + kbdd_clear_state(kbd); } return 0; } @@ -171,7 +171,7 @@ atkbdintr(void *arg) keyboard_t *kbd; kbd = (keyboard_t *)arg; - (*kbdsw[kbd->kb_index]->intr)(kbd, NULL); + kbdd_intr(kbd, NULL); } DRIVER_MODULE(atkbd, atkbdc, atkbd_driver, atkbd_devclass, 0, 0); diff --git a/sys/dev/kbd/kbd.c b/sys/dev/kbd/kbd.c index 462983fecca7..15a3e2219960 100644 --- a/sys/dev/kbd/kbd.c +++ b/sys/dev/kbd/kbd.c @@ -219,8 +219,7 @@ kbd_register(keyboard_t *kbd) strcpy(ki.kb_name, kbd->kb_name); ki.kb_unit = kbd->kb_unit; - (*kbdsw[mux->kb_index]->ioctl) - (mux, KBADDKBD, (caddr_t) &ki); + kbdd_ioctl(mux, KBADDKBD, (caddr_t) &ki); } return (index); @@ -237,8 +236,7 @@ kbd_register(keyboard_t *kbd) strcpy(ki.kb_name, kbd->kb_name); ki.kb_unit = kbd->kb_unit; - (*kbdsw[mux->kb_index]->ioctl) - (mux, KBADDKBD, (caddr_t) &ki); + kbdd_ioctl(mux, KBADDKBD, (caddr_t) &ki); } return (index); @@ -363,7 +361,7 @@ kbd_allocate(char *driver, int unit, void *id, kbd_callback_func_t *func, KBD_BUSY(keyboard[index]); keyboard[index]->kb_callback.kc_func = func; keyboard[index]->kb_callback.kc_arg = arg; - (*kbdsw[index]->clear_state)(keyboard[index]); + kbdd_clear_state(keyboard[index]); } splx(s); return (index); @@ -385,7 +383,7 @@ kbd_release(keyboard_t *kbd, void *id) KBD_UNBUSY(kbd); kbd->kb_callback.kc_func = NULL; kbd->kb_callback.kc_arg = NULL; - (*kbdsw[kbd->kb_index]->clear_state)(kbd); + kbdd_clear_state(kbd); error = 0; } splx(s); @@ -664,7 +662,7 @@ genkbdioctl(struct cdev *dev, u_long cmd, caddr_t arg, int flag, struct thread * kbd = kbd_get_keyboard(KBD_INDEX(dev)); if ((kbd == NULL) || !KBD_IS_VALID(kbd)) return (ENXIO); - error = (*kbdsw[kbd->kb_index]->ioctl)(kbd, cmd, arg); + error = kbdd_ioctl(kbd, cmd, arg); if (error == ENOIOCTL) error = ENODEV; return (error); @@ -723,12 +721,12 @@ genkbd_event(keyboard_t *kbd, int event, void *arg) } /* obtain the current key input mode */ - if ((*kbdsw[kbd->kb_index]->ioctl)(kbd, KDGKBMODE, (caddr_t)&mode)) + if (kbdd_ioctl(kbd, KDGKBMODE, (caddr_t)&mode)) mode = K_XLATE; /* read all pending input */ - while ((*kbdsw[kbd->kb_index]->check_char)(kbd)) { - c = (*kbdsw[kbd->kb_index]->read_char)(kbd, FALSE); + while (kbdd_check_char(kbd)) { + c = kbdd_read_char(kbd, FALSE); if (c == NOKEY) continue; if (c == ERRKEY) /* XXX: ring bell? */ @@ -771,8 +769,7 @@ genkbd_event(keyboard_t *kbd, int event, void *arg) putc(KEYCHAR(c), &sc->gkb_q); break; case FKEY | SPCLKEY: /* a function key, return string */ - cp = (*kbdsw[kbd->kb_index]->get_fkeystr)(kbd, - KEYCHAR(c), &len); + cp = kbdd_get_fkeystr(kbd, KEYCHAR(c), &len); if (cp != NULL) { while (len-- > 0) putc(*cp++, &sc->gkb_q); @@ -1110,7 +1107,7 @@ genkbd_diag(keyboard_t *kbd, int level) (s) |= l ## DOWN; \ (s) ^= l ## ED; \ i = (s) & LOCK_MASK; \ - (*kbdsw[(k)->kb_index]->ioctl)((k), KDSETLED, (caddr_t)&i); \ + kbdd_ioctl((k), KDSETLED, (caddr_t)&i); \ } static u_int @@ -1270,8 +1267,7 @@ genkbd_keyaction(keyboard_t *kbd, int keycode, int up, int *shiftstate, #else state &= ~CLKED; i = state & LOCK_MASK; - (*kbdsw[kbd->kb_index]->ioctl)(kbd, KDSETLED, - (caddr_t)&i); + kbdd_ioctl(kbd, KDSETLED, (caddr_t)&i); #endif break; case SLK: @@ -1307,8 +1303,7 @@ genkbd_keyaction(keyboard_t *kbd, int keycode, int up, int *shiftstate, #else state |= CLKED; i = state & LOCK_MASK; - (*kbdsw[kbd->kb_index]->ioctl)(kbd, KDSETLED, - (caddr_t)&i); + kbdd_ioctl(kbd, KDSETLED, (caddr_t)&i); #endif break; case SLK: diff --git a/sys/dev/kbd/kbdreg.h b/sys/dev/kbd/kbdreg.h index 184c607a015a..5b81123f275c 100644 --- a/sys/dev/kbd/kbdreg.h +++ b/sys/dev/kbd/kbdreg.h @@ -157,6 +157,50 @@ typedef struct keyboard_switch { kbd_diag_t *diag; } keyboard_switch_t; +/* + * Keyboard disciplines: call actual handlers via kbdsw[]. + */ +#define kbdd_probe(kbd, unit, arg, flags) \ + (*kbdsw[(kbd)->kb_index]->probe)((unit), (arg), (flags)) +#define kbdd_init(kbd, unit, kbdpp, arg, flags) \ + (*kbdsw[(kbd)->kb_index]->init)((unit), (kbdpp), (arg), (flags)) +#define kbdd_term(kbd) \ + (*kbdsw[(kbd)->kb_index]->term)((kbd)) +#define kbdd_intr(kbd, arg) \ + (*kbdsw[(kbd)->kb_index]->intr)((kbd), (arg)) +#define kbdd_test_if(kbd) \ + (*kbdsw[(kbd)->kb_index]->test_if)((kbd)) +#define kbdd_enable(kbd) \ + (*kbdsw[(kbd)->kb_index]->enable)((kbd)) +#define kbdd_disable(kbd) \ + (*kbdsw[(kbd)->kb_index]->disable)((kbd)) +#define kbdd_read(kbd, wait) \ + (*kbdsw[(kbd)->kb_index]->read)((kbd), (wait)) +#define kbdd_check(kbd) \ + (*kbdsw[(kbd)->kb_index]->check)((kbd)) +#define kbdd_read_char(kbd, wait) \ + (*kbdsw[(kbd)->kb_index]->read_char)((kbd), (wait)) +#define kbdd_check_char(kbd) \ + (*kbdsw[(kbd)->kb_index]->check_char)((kbd)) +#define kbdd_ioctl(kbd, cmd, arg) \ + (((kbd) == NULL) ? \ + ENODEV : \ + (*kbdsw[(kbd)->kb_index]->ioctl)((kbd), (cmd), (arg))) +#define kbdd_lock(kbd, lockf) \ + (*kbdsw[(kbd)->kb_index]->lock)((kbd), (lockf)) +#define kbdd_clear_state(kbd) \ + (*kbdsw[(kbd)->kb_index]->clear_state)((kbd)) +#define kbdd_get_state(kbd, buf, len) \ + (*kbdsw[(kbd)->kb_index]->get_state)((kbd), (buf), (len)) +#define kbdd_set_state(kbd, buf, len) \ + (*kbdsw[(kbd)->kb_index]->set_state)((kbd), (buf), (len)) +#define kbdd_get_fkeystr(kbd, fkey, len) \ + (*kbdsw[(kbd)->kb_index]->get_fkeystr)((kbd), (fkey), (len)) +#define kbdd_poll(kbd, on) \ + (*kbdsw[(kbd)->kb_index]->poll)((kbd), (on)) +#define kbdd_diag(kbd, level) \ + (*kbdsw[(kbd)->kb_index]->diag)((kbd), (leve)) + /* keyboard driver */ typedef struct keyboard_driver { SLIST_ENTRY(keyboard_driver) link; diff --git a/sys/dev/kbdmux/kbdmux.c b/sys/dev/kbdmux/kbdmux.c index 63f3db6cbeb5..7be985829a18 100644 --- a/sys/dev/kbdmux/kbdmux.c +++ b/sys/dev/kbdmux/kbdmux.c @@ -118,27 +118,6 @@ MALLOC_DEFINE(M_KBDMUX, KEYBOARD_NAME, "Keyboard multiplexor"); taskqueue_enqueue(taskqueue_swi_giant, &(s)->ks_task) #endif /* not yet */ -#define KBDMUX_INTR(kbd, arg) \ - (*kbdsw[(kbd)->kb_index]->intr)((kbd), (arg)) - -#define KBDMUX_IOCTL(kbd, cmd, arg) \ - (*kbdsw[(kbd)->kb_index]->ioctl)((kbd), (cmd), (caddr_t) (arg)) - -#define KBDMUX_CHECK_CHAR(kbd) \ - (*kbdsw[(kbd)->kb_index]->check_char)((kbd)) - -#define KBDMUX_READ_CHAR(kbd, wait) \ - (*kbdsw[(kbd)->kb_index]->read_char)((kbd), (wait)) - -#define KBDMUX_ENABLE(kbd) \ - (*kbdsw[(kbd)->kb_index]->enable)((kbd)) - -#define KBDMUX_POLL(kbd, on) \ - (*kbdsw[(kbd)->kb_index]->poll)((kbd), (on)) - -#define KBDMUX_CLEAR_STATE(kbd) \ - (*kbdsw[(kbd)->kb_index]->clear_state)((kbd)) - /* * kbdmux keyboard */ @@ -197,7 +176,7 @@ kbdmux_kbd_intr(void *xkbd, int pending) keyboard_t *kbd = (keyboard_t *) xkbd; kbdmux_state_t *state = (kbdmux_state_t *) kbd->kb_data; - KBDMUX_INTR(kbd, NULL); + kbdd_intr(kbd, NULL); KBDMUX_LOCK(state); @@ -258,8 +237,8 @@ kbdmux_kbd_event(keyboard_t *kbd, int event, void *arg) * NOKEY. */ - while (KBDMUX_CHECK_CHAR(kbd)) { - c = KBDMUX_READ_CHAR(kbd, 0); + while (kbdd_check_char(kbd)) { + c = kbdd_read_char(kbd, 0); if (c == NOKEY) break; if (c == ERRKEY) @@ -662,8 +641,8 @@ next_code: kbdmux_kbd_t *k; SLIST_FOREACH(k, &state->ks_kbds, next) { - while (KBDMUX_CHECK_CHAR(k->kbd)) { - scancode = KBDMUX_READ_CHAR(k->kbd, 0); + while (kbdd_check_char(k->kbd)) { + scancode = kbdd_read_char(k->kbd, 0); if (scancode == NOKEY) break; if (scancode == ERRKEY) @@ -992,16 +971,16 @@ kbdmux_ioctl(keyboard_t *kbd, u_long cmd, caddr_t arg) return (EINVAL); /* bad keyboard */ } - KBDMUX_ENABLE(k->kbd); - KBDMUX_CLEAR_STATE(k->kbd); + kbdd_enable(k->kbd); + kbdd_clear_state(k->kbd); /* set K_RAW mode on slave keyboard */ mode = K_RAW; - error = KBDMUX_IOCTL(k->kbd, KDSKBMODE, &mode); + error = kbdd_ioctl(k->kbd, KDSKBMODE, (caddr_t)&mode); if (error == 0) { /* set lock keys state on slave keyboard */ mode = state->ks_state & LOCK_MASK; - error = KBDMUX_IOCTL(k->kbd, KDSKBSTATE, &mode); + error = kbdd_ioctl(k->kbd, KDSKBSTATE, (caddr_t)&mode); } if (error != 0) { @@ -1115,7 +1094,7 @@ kbdmux_ioctl(keyboard_t *kbd, u_long cmd, caddr_t arg) /* KDSETLED on all slave keyboards */ SLIST_FOREACH(k, &state->ks_kbds, next) - KBDMUX_IOCTL(k->kbd, KDSETLED, arg); + kbdd_ioctl(k->kbd, KDSETLED, arg); KBDMUX_UNLOCK(state); break; @@ -1146,7 +1125,7 @@ kbdmux_ioctl(keyboard_t *kbd, u_long cmd, caddr_t arg) /* KDSKBSTATE on all slave keyboards */ SLIST_FOREACH(k, &state->ks_kbds, next) - KBDMUX_IOCTL(k->kbd, KDSKBSTATE, arg); + kbdd_ioctl(k->kbd, KDSKBSTATE, arg); KBDMUX_UNLOCK(state); @@ -1192,7 +1171,7 @@ kbdmux_ioctl(keyboard_t *kbd, u_long cmd, caddr_t arg) /* perform command on all slave keyboards */ SLIST_FOREACH(k, &state->ks_kbds, next) - KBDMUX_IOCTL(k->kbd, cmd, arg); + kbdd_ioctl(k->kbd, cmd, arg); KBDMUX_UNLOCK(state); break; @@ -1205,7 +1184,7 @@ kbdmux_ioctl(keyboard_t *kbd, u_long cmd, caddr_t arg) /* perform command on all slave keyboards */ SLIST_FOREACH(k, &state->ks_kbds, next) - KBDMUX_IOCTL(k->kbd, cmd, arg); + kbdd_ioctl(k->kbd, cmd, arg); KBDMUX_UNLOCK(state); /* FALLTHROUGH */ @@ -1302,7 +1281,7 @@ kbdmux_poll(keyboard_t *kbd, int on) /* set poll on slave keyboards */ SLIST_FOREACH(k, &state->ks_kbds, next) - KBDMUX_POLL(k->kbd, on); + kbdd_poll(k->kbd, on); KBDMUX_UNLOCK(state); diff --git a/sys/dev/syscons/syscons.c b/sys/dev/syscons/syscons.c index b74989571c0f..cc273e6ccaf6 100644 --- a/sys/dev/syscons/syscons.c +++ b/sys/dev/syscons/syscons.c @@ -393,7 +393,7 @@ sc_attach_unit(int unit, int flags) scrn_timer(sc); /* set up the keyboard */ - kbd_ioctl(sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); + kbdd_ioctl(sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); update_kbd_state(scp, scp->status, LOCK_MASK); printf("%s%d: %s <%d virtual consoles, flags=0x%x>\n", @@ -510,7 +510,7 @@ scopen(struct cdev *dev, int flag, int mode, struct thread *td) #ifndef __sparc64__ if (sc->kbd != NULL) { key.keynum = KEYCODE_BS; - kbd_ioctl(sc->kbd, GIO_KEYMAPENT, (caddr_t)&key); + kbdd_ioctl(sc->kbd, GIO_KEYMAPENT, (caddr_t)&key); tp->t_cc[VERASE] = key.key.map[0]; } #endif @@ -577,7 +577,7 @@ scclose(struct cdev *dev, int flag, int mode, struct thread *td) #endif scp->kbd_mode = K_XLATE; if (scp == scp->sc->cur_scp) - kbd_ioctl(scp->sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); + kbdd_ioctl(scp->sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); DPRINTF(5, ("done.\n")); } spltty(); @@ -641,7 +641,7 @@ sckbdevent(keyboard_t *thiskbd, int event, void *arg) ttyld_rint(cur_tty, KEYCHAR(c)); break; case FKEY: /* function key, return string */ - cp = kbd_get_fkeystr(thiskbd, KEYCHAR(c), &len); + cp = kbdd_get_fkeystr(thiskbd, KEYCHAR(c), &len); if (cp != NULL) { while (len-- > 0) ttyld_rint(cur_tty, *cp++); @@ -1137,7 +1137,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) case KDGETREPEAT: /* get keyboard repeat & delay rates */ case KDSETREPEAT: /* set keyboard repeat & delay rates (new) */ - error = kbd_ioctl(sc->kbd, cmd, data); + error = kbdd_ioctl(sc->kbd, cmd, data); if (error == ENOIOCTL) error = ENODEV; return error; @@ -1152,7 +1152,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) case KDSETRAD: /* set keyboard repeat & delay rates (old) */ if (*(int *)data & ~0x7f) return EINVAL; - error = kbd_ioctl(sc->kbd, KDSETRAD, data); + error = kbdd_ioctl(sc->kbd, KDSETRAD, data); if (error == ENOIOCTL) error = ENODEV; return error; @@ -1171,7 +1171,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) case K_CODE: /* switch to CODE mode */ scp->kbd_mode = *(int *)data; if (scp == sc->cur_scp) - kbd_ioctl(sc->kbd, KDSKBMODE, data); + kbdd_ioctl(sc->kbd, KDSKBMODE, data); return 0; default: return EINVAL; @@ -1183,7 +1183,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) return 0; case KDGKBINFO: - error = kbd_ioctl(sc->kbd, cmd, data); + error = kbdd_ioctl(sc->kbd, cmd, data); if (error == ENOIOCTL) error = ENODEV; return error; @@ -1220,7 +1220,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) return 0; case KDGKBTYPE: /* get keyboard type */ - error = kbd_ioctl(sc->kbd, cmd, data); + error = kbdd_ioctl(sc->kbd, cmd, data); if (error == ENOIOCTL) { /* always return something? XXX */ *(int *)data = 0; @@ -1251,7 +1251,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) case KBADDKBD: /* add/remove keyboard to/from mux */ case KBRELKBD: - error = kbd_ioctl(sc->kbd, cmd, data); + error = kbdd_ioctl(sc->kbd, cmd, data); if (error == ENOIOCTL) error = ENODEV; return error; @@ -1285,7 +1285,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) } sc->kbd = kbd_get_keyboard(i); /* sc->kbd == newkbd */ sc->keyboard = i; - kbd_ioctl(sc->kbd, KDSKBMODE, + kbdd_ioctl(sc->kbd, KDSKBMODE, (caddr_t)&sc->cur_scp->kbd_mode); update_kbd_state(sc->cur_scp, sc->cur_scp->status, LOCK_MASK); @@ -1359,7 +1359,7 @@ scioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thread *td) case PIO_DEADKEYMAP: /* set accent key translation table */ case GETFKEY: /* get function key string */ case SETFKEY: /* set function key string */ - error = kbd_ioctl(sc->kbd, cmd, data); + error = kbdd_ioctl(sc->kbd, cmd, data); if (error == ENOIOCTL) error = ENODEV; return error; @@ -1612,27 +1612,27 @@ sccngetch(int flags) * Make sure the keyboard is accessible even when the kbd device * driver is disabled. */ - kbd_enable(scp->sc->kbd); + kbdd_enable(scp->sc->kbd); /* we shall always use the keyboard in the XLATE mode here */ cur_mode = scp->kbd_mode; scp->kbd_mode = K_XLATE; - kbd_ioctl(scp->sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); + kbdd_ioctl(scp->sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); - kbd_poll(scp->sc->kbd, TRUE); + kbdd_poll(scp->sc->kbd, TRUE); c = scgetc(scp->sc, SCGETC_CN | flags); - kbd_poll(scp->sc->kbd, FALSE); + kbdd_poll(scp->sc->kbd, FALSE); scp->kbd_mode = cur_mode; - kbd_ioctl(scp->sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); - kbd_disable(scp->sc->kbd); + kbdd_ioctl(scp->sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); + kbdd_disable(scp->sc->kbd); splx(s); switch (KEYFLAGS(c)) { case 0: /* normal char */ return KEYCHAR(c); case FKEY: /* function key */ - p = kbd_get_fkeystr(scp->sc->kbd, KEYCHAR(c), (size_t *)&fkeycp); + p = kbdd_get_fkeystr(scp->sc->kbd, KEYCHAR(c), (size_t *)&fkeycp); fkey.len = fkeycp; if ((p != NULL) && (fkey.len > 0)) { bcopy(p, fkey.str, fkey.len); @@ -1717,7 +1717,7 @@ scrn_timer(void *arg) sc->keyboard = sc_allocate_keyboard(sc, -1); if (sc->keyboard >= 0) { sc->kbd = kbd_get_keyboard(sc->keyboard); - kbd_ioctl(sc->kbd, KDSKBMODE, + kbdd_ioctl(sc->kbd, KDSKBMODE, (caddr_t)&sc->cur_scp->kbd_mode); update_kbd_state(sc->cur_scp, sc->cur_scp->status, LOCK_MASK); @@ -2501,7 +2501,7 @@ exchange_scr(sc_softc_t *sc) /* set up the keyboard for the new screen */ if (sc->old_scp->kbd_mode != scp->kbd_mode) - kbd_ioctl(sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); + kbdd_ioctl(sc->kbd, KDSKBMODE, (caddr_t)&scp->kbd_mode); update_kbd_state(scp, scp->status, LOCK_MASK); mark_all(scp); @@ -3182,7 +3182,7 @@ next_code: scp = sc->cur_scp; /* first see if there is something in the keyboard port */ for (;;) { - c = kbd_read_char(sc->kbd, !(flags & SCGETC_NONBLOCK)); + c = kbdd_read_char(sc->kbd, !(flags & SCGETC_NONBLOCK)); if (c == ERRKEY) { if (!(flags & SCGETC_CN)) sc_bell(scp, bios_value.bell_pitch, BELL_DURATION); @@ -3278,7 +3278,7 @@ next_code: case NLK: case CLK: case ALK: break; case SLK: - kbd_ioctl(sc->kbd, KDGKBSTATE, (caddr_t)&f); + kbdd_ioctl(sc->kbd, KDGKBSTATE, (caddr_t)&f); if (f & SLKED) { scp->status |= SLKED; } else { @@ -3446,7 +3446,7 @@ save_kbd_state(scr_stat *scp) int state; int error; - error = kbd_ioctl(scp->sc->kbd, KDGKBSTATE, (caddr_t)&state); + error = kbdd_ioctl(scp->sc->kbd, KDGKBSTATE, (caddr_t)&state); if (error == ENOIOCTL) error = ENODEV; if (error == 0) { @@ -3463,7 +3463,7 @@ update_kbd_state(scr_stat *scp, int new_bits, int mask) int error; if (mask != LOCK_MASK) { - error = kbd_ioctl(scp->sc->kbd, KDGKBSTATE, (caddr_t)&state); + error = kbdd_ioctl(scp->sc->kbd, KDGKBSTATE, (caddr_t)&state); if (error == ENOIOCTL) error = ENODEV; if (error) @@ -3473,7 +3473,7 @@ update_kbd_state(scr_stat *scp, int new_bits, int mask) } else { state = new_bits & LOCK_MASK; } - error = kbd_ioctl(scp->sc->kbd, KDSKBSTATE, (caddr_t)&state); + error = kbdd_ioctl(scp->sc->kbd, KDSKBSTATE, (caddr_t)&state); if (error == ENOIOCTL) error = ENODEV; return error; @@ -3485,7 +3485,7 @@ update_kbd_leds(scr_stat *scp, int which) int error; which &= LOCK_MASK; - error = kbd_ioctl(scp->sc->kbd, KDSETLED, (caddr_t)&which); + error = kbdd_ioctl(scp->sc->kbd, KDSETLED, (caddr_t)&which); if (error == ENOIOCTL) error = ENODEV; return error; @@ -3693,7 +3693,7 @@ sc_allocate_keyboard(sc_softc_t *sc, int unit) strcpy(ki.kb_name, k->kb_name); ki.kb_unit = k->kb_unit; - kbd_ioctl(k0, KBADDKBD, (caddr_t) &ki); + kbdd_ioctl(k0, KBADDKBD, (caddr_t) &ki); } } else idx0 = kbd_allocate("*", unit, (void *)&sc->keyboard, sckbdevent, sc); diff --git a/sys/dev/syscons/syscons.h b/sys/dev/syscons/syscons.h index 53e5ab7b4bc0..1a19b605c187 100644 --- a/sys/dev/syscons/syscons.h +++ b/sys/dev/syscons/syscons.h @@ -516,26 +516,6 @@ typedef struct { #define ISSIGVALID(sig) ((sig) > 0 && (sig) < NSIG) -#define kbd_read_char(kbd, wait) \ - (*kbdsw[(kbd)->kb_index]->read_char)((kbd), (wait)) -#define kbd_check_char(kbd) \ - (*kbdsw[(kbd)->kb_index]->check_char)((kbd)) -#define kbd_enable(kbd) \ - (*kbdsw[(kbd)->kb_index]->enable)((kbd)) -#define kbd_disable(kbd) \ - (*kbdsw[(kbd)->kb_index]->disable)((kbd)) -#define kbd_lock(kbd, lockf) \ - (*kbdsw[(kbd)->kb_index]->lock)((kbd), (lockf)) -#define kbd_ioctl(kbd, cmd, arg) \ - (((kbd) == NULL) ? \ - ENODEV : (*kbdsw[(kbd)->kb_index]->ioctl)((kbd), (cmd), (arg))) -#define kbd_clear_state(kbd) \ - (*kbdsw[(kbd)->kb_index]->clear_state)((kbd)) -#define kbd_get_fkeystr(kbd, fkey, len) \ - (*kbdsw[(kbd)->kb_index]->get_fkeystr)((kbd), (fkey), (len)) -#define kbd_poll(kbd, on) \ - (*kbdsw[(kbd)->kb_index]->poll)((kbd), (on)) - #define SC_VIDEO_LOCKINIT(sc) \ mtx_init(&(sc)->video_mtx, "syscons video lock", NULL,MTX_SPIN); #define SC_VIDEO_LOCK(sc) \ diff --git a/sys/dev/usb/ukbd.c b/sys/dev/usb/ukbd.c index 6d2943d9a318..01efc7f740b7 100644 --- a/sys/dev/usb/ukbd.c +++ b/sys/dev/usb/ukbd.c @@ -222,14 +222,14 @@ ukbd_detach(device_t self) DPRINTF(("%s: keyboard not attached!?\n", device_get_nameunit(self))); return ENXIO; } - (*kbdsw[kbd->kb_index]->disable)(kbd); + kbdd_disable(kbd); #ifdef KBD_INSTALL_CDEV error = kbd_detach(kbd); if (error) return error; #endif - error = (*kbdsw[kbd->kb_index]->term)(kbd); + error = kbdd_term(kbd); if (error) return error; @@ -246,7 +246,7 @@ ukbd_resume(device_t self) kbd = kbd_get_keyboard(kbd_find_keyboard(DRIVER_NAME, device_get_unit(self))); if (kbd) - (*kbdsw[kbd->kb_index]->clear_state)(kbd); + kbdd_clear_state(kbd); return (0); } @@ -255,7 +255,7 @@ ukbd_intr(usbd_xfer_handle xfer, usbd_private_handle addr, usbd_status status) { keyboard_t *kbd = (keyboard_t *)addr; - (*kbdsw[kbd->kb_index]->intr)(kbd, (void *)status); + kbdd_intr(kbd, (void *)status); } #define UKBD_DEFAULT 0 @@ -705,7 +705,7 @@ ukbd_timeout(void *arg) kbd = (keyboard_t *)arg; state = (ukbd_state_t *)kbd->kb_data; s = splusb(); - (*kbdsw[kbd->kb_index]->intr)(kbd, (void *)USBD_NORMAL_COMPLETION); + kbdd_intr(kbd, (void *)USBD_NORMAL_COMPLETION); callout_reset(&state->ks_timeout_handle, hz / 40, ukbd_timeout, arg); splx(s); } diff --git a/sys/dev/vkbd/vkbd.c b/sys/dev/vkbd/vkbd.c index 9eca6de588d3..9807036a57e8 100644 --- a/sys/dev/vkbd/vkbd.c +++ b/sys/dev/vkbd/vkbd.c @@ -278,11 +278,11 @@ vkbd_dev_close(struct cdev *dev, int foo, int bar, struct thread *td) VKBD_UNLOCK(state); - (*kbdsw[kbd->kb_index]->disable)(kbd); + kbdd_disable(kbd); #ifdef KBD_INSTALL_CDEV kbd_detach(kbd); #endif /* def KBD_INSTALL_CDEV */ - (*kbdsw[kbd->kb_index]->term)(kbd); + kbdd_term(kbd); /* XXX FIXME: dev->si_drv1 locking */ dev->si_drv1 = NULL; @@ -437,8 +437,7 @@ vkbd_dev_ioctl(struct cdev *dev, u_long cmd, caddr_t data, int flag, struct thre { keyboard_t *kbd = VKBD_KEYBOARD(dev); - return ((kbd == NULL)? ENXIO : - (*kbdsw[kbd->kb_index]->ioctl)(kbd, cmd, data)); + return ((kbd == NULL)? ENXIO : kbdd_ioctl(kbd, cmd, data)); } /* Poll device */ @@ -482,7 +481,7 @@ vkbd_dev_intr(void *xkbd, int pending) keyboard_t *kbd = (keyboard_t *) xkbd; vkbd_state_t *state = (vkbd_state_t *) kbd->kb_data; - (*kbdsw[kbd->kb_index]->intr)(kbd, NULL); + kbdd_intr(kbd, NULL); VKBD_LOCK(state);