summaryrefslogtreecommitdiff
path: root/sys/kern/subr_terminal.c
diff options
context:
space:
mode:
authorJonathan T. Looney <jtl@FreeBSD.org>2017-02-23 01:18:47 +0000
committerJonathan T. Looney <jtl@FreeBSD.org>2017-02-23 01:18:47 +0000
commitc9cde8251ce38433c15d991cfa51f40a51cf1ff4 (patch)
tree78efdaa94f107636b2dc4246740ba9c813fe51ed /sys/kern/subr_terminal.c
parente278d94bcaa58236dbb6f1849ed7c046ef740193 (diff)
Notes
Diffstat (limited to 'sys/kern/subr_terminal.c')
-rw-r--r--sys/kern/subr_terminal.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/sys/kern/subr_terminal.c b/sys/kern/subr_terminal.c
index 76c6cfbf6453..5ac6a03b8979 100644
--- a/sys/kern/subr_terminal.c
+++ b/sys/kern/subr_terminal.c
@@ -375,7 +375,10 @@ termtty_outwakeup(struct tty *tp)
TERMINAL_UNLOCK_TTY(tm);
}
- tm->tm_class->tc_done(tm);
+ TERMINAL_LOCK_TTY(tm);
+ if (!(tm->tm_flags & TF_MUTE))
+ tm->tm_class->tc_done(tm);
+ TERMINAL_UNLOCK_TTY(tm);
if (flags & TF_BELL)
tm->tm_class->tc_bell(tm);
}
@@ -545,10 +548,9 @@ termcn_cnputc(struct consdev *cp, int c)
teken_set_curattr(&tm->tm_emulator, &kernel_message);
teken_input(&tm->tm_emulator, &cv, 1);
teken_set_curattr(&tm->tm_emulator, &backup);
+ tm->tm_class->tc_done(tm);
}
TERMINAL_UNLOCK_CONS(tm);
-
- tm->tm_class->tc_done(tm);
}
/*