Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/luna68k/dev Add a comment that .set_leds function w...
details: https://anonhg.NetBSD.org/src/rev/f7f4eeb79cb4
branches: trunk
changeset: 986340:f7f4eeb79cb4
user: tsutsui <tsutsui%NetBSD.org@localhost>
date: Mon Sep 20 08:31:09 2021 +0000
description:
Add a comment that .set_leds function won't work correctly on cngetc(9).
I'm afraid all other keyboard drivers that have .set_leds function
(like sgimips/dev/zs_kbd.c) have the same issue.
Maybe we needs 'polled' flag in .set_leds function, or an independent
.set_leds accessop in struct wskbd_consops for cons(9).
diffstat:
sys/arch/luna68k/dev/lunaws.c | 14 ++++++++++++--
1 files changed, 12 insertions(+), 2 deletions(-)
diffs (35 lines):
diff -r 25d7b9ce904a -r f7f4eeb79cb4 sys/arch/luna68k/dev/lunaws.c
--- a/sys/arch/luna68k/dev/lunaws.c Mon Sep 20 02:26:05 2021 +0000
+++ b/sys/arch/luna68k/dev/lunaws.c Mon Sep 20 08:31:09 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lunaws.c,v 1.37 2021/09/19 11:43:54 tsutsui Exp $ */
+/* $NetBSD: lunaws.c,v 1.38 2021/09/20 08:31:09 tsutsui Exp $ */
/*-
* Copyright (c) 2000 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: lunaws.c,v 1.37 2021/09/19 11:43:54 tsutsui Exp $");
+__KERNEL_RCSID(0, "$NetBSD: lunaws.c,v 1.38 2021/09/20 08:31:09 tsutsui Exp $");
#include "opt_wsdisplay_compat.h"
#include "wsmouse.h"
@@ -571,6 +571,16 @@
struct ws_softc *sc = cookie;
uint8_t ledcmd;
+ /*
+ * XXX:
+ * Why does MI wskbd(4) use a common .set_leds function
+ * for both kernel cons(9) and normal tty devices!?
+ *
+ * When CAP key is pressed in cngetc(9) (like ddb(4) etc.)
+ * after wskbd(4) is attached, all LED commands are queued
+ * into txq[] and will never be sent until ddb(4) returns.
+ */
+
sc->sc_leds = leds;
if ((leds & WSKBD_LED_CAPS) != 0) {
ledcmd = OMKBD_LED_ON_CAPS;
Home |
Main Index |
Thread Index |
Old Index