summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornicm <nicm@openbsd.org>2010-12-23 21:56:38 +0000
committernicm <nicm@openbsd.org>2010-12-23 21:56:38 +0000
commit5b75e6e6a9d4965b21f382d1dfae9710ed118499 (patch)
treee8ce7dffe13a19978fec315243c965df992dff7e
parentBetter malloc the right size, overruns are so 200x... Pass the brown paper (diff)
downloadwireguard-openbsd-5b75e6e6a9d4965b21f382d1dfae9710ed118499.tar.xz
wireguard-openbsd-5b75e6e6a9d4965b21f382d1dfae9710ed118499.zip
server_kill_window can modify the RB tree so don't use RB_FOREACH, fixes
crash seen by Dan Harnett.
-rw-r--r--usr.bin/tmux/server-fn.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/usr.bin/tmux/server-fn.c b/usr.bin/tmux/server-fn.c
index 7de70c49ffc..9c810b71965 100644
--- a/usr.bin/tmux/server-fn.c
+++ b/usr.bin/tmux/server-fn.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: server-fn.c,v 1.47 2010/12/21 22:37:59 nicm Exp $ */
+/* $OpenBSD: server-fn.c,v 1.48 2010/12/23 21:56:38 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -239,10 +239,14 @@ server_lock_client(struct client *c)
void
server_kill_window(struct window *w)
{
- struct session *s;
+ struct session *s, *next_s;
struct winlink *wl;
- RB_FOREACH(s, sessions, &sessions) {
+ next_s = RB_MIN(sessions, &sessions);
+ while (next_s != NULL) {
+ s = next_s;
+ next_s = RB_NEXT(sessions, &sessions, s);
+
if (session_has(s, w) == NULL)
continue;
while ((wl = winlink_find_by_window(&s->windows, w)) != NULL) {