diff options
author | nicm <nicm> | 2020-10-29 16:33:01 +0000 |
---|---|---|
committer | nicm <nicm> | 2020-10-29 16:33:01 +0000 |
commit | a868bacb46e3c900530bed47a1c6f85b0fbe701c (patch) | |
tree | 2121794347b7f9ebb5b187e9117ce33e9ae64675 /input.c | |
parent | b33a302235affc19d8a1d8f7473fe589d1bcd17e (diff) | |
download | rtmux-a868bacb46e3c900530bed47a1c6f85b0fbe701c.tar.gz rtmux-a868bacb46e3c900530bed47a1c6f85b0fbe701c.tar.bz2 rtmux-a868bacb46e3c900530bed47a1c6f85b0fbe701c.zip |
Do not write after the end of the array and overwrite the stack when
colon-separated SGR sequences contain empty arguments. Reported by Sergey
Nizovtsev.
Diffstat (limited to 'input.c')
-rw-r--r-- | input.c | 7 |
1 files changed, 6 insertions, 1 deletions
@@ -1976,8 +1976,13 @@ input_csi_dispatch_sgr_colon(struct input_ctx *ictx, u_int i) free(copy); return; } - } else + } else { n++; + if (n == nitems(p)) { + free(copy); + return; + } + } log_debug("%s: %u = %d", __func__, n - 1, p[n - 1]); } free(copy); |