mirror of
https://github.com/neovim/neovim.git
synced 2025-09-29 06:28:35 +00:00
vim-patch:9.0.2010: [security] use-after-free from buf_contents_changed()
Problem: [security] use-after-free from buf_contents_changed()
Solution: block autocommands
41e6f7d6ba
Co-authored-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
@@ -4223,6 +4223,10 @@ bool buf_contents_changed(buf_T *buf)
|
||||
aco_save_T aco;
|
||||
aucmd_prepbuf(&aco, newbuf);
|
||||
|
||||
// We don't want to trigger autocommands now, they may have nasty
|
||||
// side-effects like wiping buffers
|
||||
block_autocmds();
|
||||
|
||||
if (ml_open(curbuf) == OK
|
||||
&& readfile(buf->b_ffname, buf->b_fname,
|
||||
0, 0, (linenr_T)MAXLNUM,
|
||||
@@ -4247,6 +4251,8 @@ bool buf_contents_changed(buf_T *buf)
|
||||
wipe_buffer(newbuf, false);
|
||||
}
|
||||
|
||||
unblock_autocmds();
|
||||
|
||||
return differ;
|
||||
}
|
||||
|
||||
|
BIN
test/old/testdir/crash/editing_arg_idx_POC_1
Normal file
BIN
test/old/testdir/crash/editing_arg_idx_POC_1
Normal file
Binary file not shown.
@@ -78,6 +78,14 @@ func Test_crash1()
|
||||
\ ' && echo "crash 9: [OK]" >> X_crash1_result.txt' .. "\<cr>")
|
||||
call TermWait(buf, 1000)
|
||||
|
||||
let file = 'crash/editing_arg_idx_POC_1'
|
||||
let args = printf(cmn_args, vim, file)
|
||||
call term_sendkeys(buf, args ..
|
||||
\ ' || echo "crash 10: [OK]" >> X_crash1_result.txt' .. "\<cr>")
|
||||
call TermWait(buf, 1000)
|
||||
call delete('Xerr')
|
||||
call delete('@')
|
||||
|
||||
" clean up
|
||||
exe buf .. "bw!"
|
||||
|
||||
@@ -93,6 +101,7 @@ func Test_crash1()
|
||||
\ 'crash 7: [OK]',
|
||||
\ 'crash 8: [OK]',
|
||||
\ 'crash 9: [OK]',
|
||||
\ 'crash 10: [OK]',
|
||||
\ ]
|
||||
|
||||
call assert_equal(expected, getline(1, '$'))
|
||||
|
Reference in New Issue
Block a user