mirror of
https://github.com/neovim/neovim.git
synced 2026-01-16 18:07:00 +00:00
vim-patch:9.1.0697: [security]: heap-buffer-overflow in ins_typebuf (#37372)
Problem: heap-buffer-overflow in ins_typebuf
(SuyueGuo)
Solution: When flushing the typeahead buffer, validate that there
is enough space left
Github Advisory:
https://github.com/vim/vim/security/advisories/GHSA-4ghr-c62x-cqfh
322ba91086
Co-authored-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
@@ -83,6 +83,7 @@ src/terminal.c
|
||||
src/termlib.c
|
||||
src/testdir/Make_amiga.mak
|
||||
src/testdir/Make_dos.mak
|
||||
src/testdir/crash/heap_overflow3
|
||||
src/testdir/keycode_check.vim
|
||||
src/testdir/lsan-suppress.txt
|
||||
src/testdir/samples/crypt_sodium_invalid.txt
|
||||
|
||||
@@ -449,9 +449,15 @@ void flush_buffers(flush_buffers_T flush_typeahead)
|
||||
while (read_readbuffers(true) != NUL) {}
|
||||
|
||||
if (flush_typeahead == FLUSH_MINIMAL) {
|
||||
// remove mapped characters at the start only
|
||||
typebuf.tb_off += typebuf.tb_maplen;
|
||||
typebuf.tb_len -= typebuf.tb_maplen;
|
||||
// remove mapped characters at the start only,
|
||||
// but only when enough space left in typebuf
|
||||
if (typebuf.tb_off + typebuf.tb_maplen >= typebuf.tb_buflen) {
|
||||
typebuf.tb_off = MAXMAPLEN;
|
||||
typebuf.tb_len = 0;
|
||||
} else {
|
||||
typebuf.tb_off += typebuf.tb_maplen;
|
||||
typebuf.tb_len -= typebuf.tb_maplen;
|
||||
}
|
||||
} else {
|
||||
// remove typeahead
|
||||
if (flush_typeahead == FLUSH_INPUT) {
|
||||
|
||||
@@ -220,6 +220,13 @@ func Test_crash1_3()
|
||||
call term_sendkeys(buf, args)
|
||||
call TermWait(buf, 150)
|
||||
|
||||
let file = 'crash/heap_overflow3'
|
||||
let cmn_args = "%s -u NONE -i NONE -n -X -m -n -e -s -S %s -c ':qa!'"
|
||||
let args = printf(cmn_args, vim, file)
|
||||
call term_sendkeys(buf, args)
|
||||
call TermWait(buf, 150)
|
||||
|
||||
|
||||
" clean up
|
||||
exe buf .. "bw!"
|
||||
bw!
|
||||
|
||||
Reference in New Issue
Block a user