Make kbd_iopen/kbd_iclose internal routines; introduce kbd_cc_{open,close}
for opening and closing the device when attached to /dev/console.
This commit is contained in:
parent
82d947ce4d
commit
4174ad4b3d
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: kbd.c,v 1.23 2000/03/19 12:50:43 pk Exp $ */
|
/* $NetBSD: kbd.c,v 1.24 2000/03/22 16:08:51 pk Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1992, 1993
|
* Copyright (c) 1992, 1993
|
||||||
@ -86,12 +86,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* Prototypes */
|
/* Prototypes */
|
||||||
static void kbd_new_layout(struct kbd_softc *k);
|
static void kbd_new_layout __P((struct kbd_softc *));
|
||||||
static void kbd_repeat(void *arg);
|
static void kbd_repeat __P((void *));
|
||||||
static void kbd_set_leds(struct kbd_softc *k, int leds);
|
static void kbd_set_leds __P((struct kbd_softc *, int));
|
||||||
static void kbd_update_leds(struct kbd_softc *k);
|
static void kbd_update_leds __P((struct kbd_softc *));
|
||||||
static void kbd_was_reset(struct kbd_softc *k);
|
static void kbd_was_reset __P((struct kbd_softc *));
|
||||||
static int kbd_drain_tx(struct kbd_softc *k);
|
static int kbd_drain_tx __P((struct kbd_softc *));
|
||||||
|
static int kbd_iopen __P((struct kbd_softc *));
|
||||||
|
static int kbd_iclose __P((struct kbd_softc *));
|
||||||
|
|
||||||
cdev_decl(kbd); /* open, close, read, write, ioctl, stop, ... */
|
cdev_decl(kbd); /* open, close, read, write, ioctl, stop, ... */
|
||||||
|
|
||||||
@ -128,7 +130,7 @@ kbdopen(dev, flags, mode, p)
|
|||||||
return (EBUSY);
|
return (EBUSY);
|
||||||
k->k_events.ev_io = p;
|
k->k_events.ev_io = p;
|
||||||
|
|
||||||
if ((error = kbd_iopen(k->k_cc)) != 0) {
|
if ((error = kbd_iopen(k)) != 0) {
|
||||||
k->k_events.ev_io = NULL;
|
k->k_events.ev_io = NULL;
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
@ -782,20 +784,37 @@ kbd_input_raw(k, c)
|
|||||||
EV_WAKEUP(&k->k_events);
|
EV_WAKEUP(&k->k_events);
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************
|
/****************************************************************/
|
||||||
* misc...
|
|
||||||
****************************************************************/
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialization to be done at first open.
|
* Open/close routines called upon opening /dev/console
|
||||||
* This is called from kbdopen or kdopen (in kd.c)
|
* if we serve console input.
|
||||||
* Called with user context.
|
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
kbd_iopen(cc)
|
kbd_cc_open(cc)
|
||||||
struct cons_channel *cc;
|
struct cons_channel *cc;
|
||||||
{
|
{
|
||||||
struct kbd_softc *k = (struct kbd_softc *)cc->cc_dev;
|
struct kbd_softc *k = (struct kbd_softc *)cc->cc_dev;
|
||||||
|
return (kbd_iopen(k));
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
kbd_cc_close(cc)
|
||||||
|
struct cons_channel *cc;
|
||||||
|
{
|
||||||
|
struct kbd_softc *k = (struct kbd_softc *)cc->cc_dev;
|
||||||
|
return (kbd_iclose(k));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Initialization to be done at first open.
|
||||||
|
* This is called from kbdopen() or kd_cc_open()
|
||||||
|
* Called with user context.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
kbd_iopen(k)
|
||||||
|
struct kbd_softc *k;
|
||||||
|
{
|
||||||
struct kbd_state *ks;
|
struct kbd_state *ks;
|
||||||
int error, s;
|
int error, s;
|
||||||
|
|
||||||
@ -859,8 +878,8 @@ out:
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
kbd_iclose(cc)
|
kbd_iclose(k)
|
||||||
struct cons_channel *cc;
|
struct kbd_softc *k;
|
||||||
{
|
{
|
||||||
/* For now: */ return (0);
|
/* For now: */ return (0);
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: kbd_zs.c,v 1.2 2000/03/19 12:50:43 pk Exp $ */
|
/* $NetBSD: kbd_zs.c,v 1.3 2000/03/22 16:08:51 pk Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1992, 1993
|
* Copyright (c) 1992, 1993
|
||||||
@ -153,8 +153,8 @@ kbd_zs_attach(parent, self, aux)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
cc->cc_dev = self;
|
cc->cc_dev = self;
|
||||||
cc->cc_iopen = kbd_iopen;
|
cc->cc_iopen = kbd_cc_open;
|
||||||
cc->cc_iclose = kbd_iclose;
|
cc->cc_iclose = kbd_cc_close;
|
||||||
cc->cc_upstream = NULL;
|
cc->cc_upstream = NULL;
|
||||||
cons_attach_input(cc);
|
cons_attach_input(cc);
|
||||||
k->k_cc = cc;
|
k->k_cc = cc;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: kbdvar.h,v 1.2 2000/03/19 12:50:43 pk Exp $ */
|
/* $NetBSD: kbdvar.h,v 1.3 2000/03/22 16:08:51 pk Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1992, 1993
|
* Copyright (c) 1992, 1993
|
||||||
@ -147,6 +147,8 @@ struct kbd_softc {
|
|||||||
void kbd_input_raw __P((struct kbd_softc *k, int));
|
void kbd_input_raw __P((struct kbd_softc *k, int));
|
||||||
void kbd_output(struct kbd_softc *k, int c);
|
void kbd_output(struct kbd_softc *k, int c);
|
||||||
void kbd_start_tx(struct kbd_softc *k);
|
void kbd_start_tx(struct kbd_softc *k);
|
||||||
|
int kbd_cc_open __P((struct cons_channel *));
|
||||||
|
int kbd_cc_close __P((struct cons_channel *));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* kbd console input channel interface.
|
* kbd console input channel interface.
|
||||||
@ -166,6 +168,3 @@ struct cons_channel {
|
|||||||
|
|
||||||
/* Special hook to attach the keyboard driver to the console */
|
/* Special hook to attach the keyboard driver to the console */
|
||||||
void cons_attach_input __P((struct cons_channel *));
|
void cons_attach_input __P((struct cons_channel *));
|
||||||
|
|
||||||
int kbd_iopen __P((struct cons_channel *));
|
|
||||||
int kbd_iclose __P((struct cons_channel *));
|
|
||||||
|
Loading…
Reference in New Issue
Block a user