Skip to content

Commit

Permalink
patch 9.0.1858: [security] heap use after free in ins_compl_get_exp()
Browse files Browse the repository at this point in the history
Problem:  heap use after free in ins_compl_get_exp()
Solution: validate buffer before accessing it

Signed-off-by: Christian Brabandt <cb@256bit.org>
  • Loading branch information
chrisbra committed Sep 3, 2023
1 parent fc68299 commit ee9166e
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 3 deletions.
2 changes: 1 addition & 1 deletion src/insexpand.c
Expand Up @@ -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;
Expand Down
6 changes: 6 additions & 0 deletions src/testdir/crash/poc_tagfunc.vim
@@ -0,0 +1,6 @@
fu Tagfunc(t,f,o)
bw
endf
set tagfunc=Tagfunc
n0
sil0norm0i
10 changes: 8 additions & 2 deletions src/testdir/test_crash.vim
Expand Up @@ -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
Expand All @@ -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, '$'))
Expand Down
2 changes: 2 additions & 0 deletions src/version.c
Expand Up @@ -699,6 +699,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1858,
/**/
1857,
/**/
Expand Down

0 comments on commit ee9166e

Please sign in to comment.