summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorStefan Fritsch <sf@cvs.openbsd.org>2015-07-20 22:28:58 +0000
committerStefan Fritsch <sf@cvs.openbsd.org>2015-07-20 22:28:58 +0000
commit25c89c82900dd98c762e2dcca00616c2003e370b (patch)
tree81bc1d401bb90e8c36fa203e695b76a875e670c4 /sys
parente092a1e351caa61327936f333a86f2f5805a1207 (diff)
Fix tty hiwat handling a bit
- Introduce new defines TTHIWATMINSPACE, TTMINHIWAT for some magic values that are used in tty.c. - Remove hiwat adjustments in ttwrite(). This fixes this codepath not being interrupt safe. - Change ttysetwater() to keep at least TTHIWATMINSPACE space above the high water mark. This makes it consistent with ttycheckoutq(). Without this change, the hiwat adjustment change above causes deadlocks in pty. ok kspillner@ commit it now deraadt@
Diffstat (limited to 'sys')
-rw-r--r--sys/kern/tty.c19
-rw-r--r--sys/sys/tty.h4
2 files changed, 8 insertions, 15 deletions
diff --git a/sys/kern/tty.c b/sys/kern/tty.c
index c0ec4f0e259..354d14d52d2 100644
--- a/sys/kern/tty.c
+++ b/sys/kern/tty.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: tty.c,v 1.121 2015/02/10 21:56:10 miod Exp $ */
+/* $OpenBSD: tty.c,v 1.122 2015/07/20 22:28:57 sf Exp $ */
/* $NetBSD: tty.c,v 1.68.4.2 1996/06/06 16:04:52 thorpej Exp $ */
/*-
@@ -1688,7 +1688,7 @@ ttycheckoutq(struct tty *tp, int wait)
hiwat = tp->t_hiwat;
s = spltty();
oldsig = wait ? curproc->p_siglist : 0;
- if (tp->t_outq.c_cc > hiwat + 200)
+ if (tp->t_outq.c_cc > hiwat + TTHIWATMINSPACE)
while (tp->t_outq.c_cc > hiwat) {
ttstart(tp);
if (wait == 0 || curproc->p_siglist != oldsig) {
@@ -1823,7 +1823,7 @@ loop:
tp->t_rocount = 0;
if (ttyoutput(*cp, tp) >= 0) {
/* out of space */
- goto overfull;
+ goto ovhiwat;
}
cp++;
cc--;
@@ -1849,7 +1849,7 @@ loop:
tp->t_outcc += ce;
if (i > 0) {
/* out of space */
- goto overfull;
+ goto ovhiwat;
}
if (ISSET(tp->t_lflag, FLUSHO) ||
tp->t_outq.c_cc > hiwat)
@@ -1869,15 +1869,6 @@ done:
explicit_bzero(obuf, obufcc);
return (error);
-overfull:
- /*
- * Since we are using ring buffers, if we can't insert any more into
- * the output queue, we can assume the ring is full and that someone
- * forgot to set the high water mark correctly. We set it and then
- * proceed as normal.
- */
- hiwat = tp->t_outq.c_cc - 1;
-
ovhiwat:
ttstart(tp);
s = spltty();
@@ -2114,7 +2105,7 @@ ttsetwater(struct tty *tp)
cps = tp->t_ospeed / 10;
tp->t_lowat = x = CLAMP(cps / 2, TTMAXLOWAT, TTMINLOWAT);
x += cps;
- tp->t_hiwat = CLAMP(x, tp->t_outq.c_cn, 100);
+ tp->t_hiwat = CLAMP(x, tp->t_outq.c_cn - TTHIWATMINSPACE, TTMINHIWAT);
#undef CLAMP
}
diff --git a/sys/sys/tty.h b/sys/sys/tty.h
index 0bd2f34d403..e3ee7237e85 100644
--- a/sys/sys/tty.h
+++ b/sys/sys/tty.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: tty.h,v 1.34 2014/09/15 19:08:21 miod Exp $ */
+/* $OpenBSD: tty.h,v 1.35 2015/07/20 22:28:57 sf Exp $ */
/* $NetBSD: tty.h,v 1.30.4.1 1996/06/02 09:08:13 mrg Exp $ */
/*-
@@ -171,6 +171,8 @@ struct itty {
#ifdef _KERNEL
#define TTMAXLOWAT 256
#define TTMINLOWAT 32
+#define TTMINHIWAT 100
+#define TTHIWATMINSPACE 200 /* Min space above hiwat */
#endif
/* These flags are kept in t_state. */