mirror of
https://github.com/vim/vim.git
synced 2025-09-26 04:04:07 -04:00
patch 9.0.1858: [security] heap use after free in ins_compl_get_exp()
Problem: heap use after free in ins_compl_get_exp() Solution: validate buffer before accessing it Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
@@ -3850,7 +3850,7 @@ ins_compl_get_exp(pos_T *ini)
|
||||
else
|
||||
{
|
||||
// Mark a buffer scanned when it has been scanned completely
|
||||
if (type == 0 || type == CTRL_X_PATH_PATTERNS)
|
||||
if (buf_valid(st.ins_buf) && (type == 0 || type == CTRL_X_PATH_PATTERNS))
|
||||
st.ins_buf->b_scanned = TRUE;
|
||||
|
||||
compl_started = FALSE;
|
||||
|
6
src/testdir/crash/poc_tagfunc.vim
Normal file
6
src/testdir/crash/poc_tagfunc.vim
Normal file
@@ -0,0 +1,6 @@
|
||||
fu Tagfunc(t,f,o)
|
||||
bw
|
||||
endf
|
||||
set tagfunc=Tagfunc
|
||||
n0
|
||||
sil0norm0i
|
@@ -39,12 +39,17 @@ func Test_crash1()
|
||||
\ ' && echo "crash 4: [OK]" >> X_crash1_result.txt' .. "\<cr>")
|
||||
" clean up
|
||||
call delete('Xerr')
|
||||
|
||||
" This test takes a bit longer
|
||||
call TermWait(buf, 200)
|
||||
|
||||
let file = 'crash/poc_tagfunc.vim'
|
||||
let args = printf(cmn_args, vim, file)
|
||||
call term_sendkeys(buf, args ..
|
||||
\ ' || echo "crash 5: [OK]" >> X_crash1_result.txt' .. "\<cr>")
|
||||
|
||||
call TermWait(buf, 100)
|
||||
|
||||
" clean up
|
||||
call delete('Xerr')
|
||||
exe buf .. "bw!"
|
||||
|
||||
sp X_crash1_result.txt
|
||||
@@ -54,6 +59,7 @@ func Test_crash1()
|
||||
\ 'crash 2: [OK]',
|
||||
\ 'crash 3: [OK]',
|
||||
\ 'crash 4: [OK]',
|
||||
\ 'crash 5: [OK]',
|
||||
\ ]
|
||||
|
||||
call assert_equal(expected, getline(1, '$'))
|
||||
|
@@ -699,6 +699,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1858,
|
||||
/**/
|
||||
1857,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user