mirror of
https://github.com/neovim/neovim.git
synced 2025-09-12 06:18:16 +00:00
vim-patch:8.0.1421: accessing invalid memory with overlong byte sequence
Problem: Accessing invalid memory with overlong byte sequence.
Solution: Check for NUL character. (test by Dominique Pelle, closes vim/vim#2485)
e6640ad44e
This commit is contained in:
@@ -344,14 +344,17 @@ char *strcase_save(const char *const orig, bool upper)
|
|||||||
|
|
||||||
char *p = res;
|
char *p = res;
|
||||||
while (*p != NUL) {
|
while (*p != NUL) {
|
||||||
int l;
|
|
||||||
|
|
||||||
int c = utf_ptr2char((const char_u *)p);
|
int c = utf_ptr2char((const char_u *)p);
|
||||||
|
int l = utf_ptr2len((const char_u *)p);
|
||||||
|
if (c == 0) {
|
||||||
|
// overlong sequence, use only the first byte
|
||||||
|
c = *p;
|
||||||
|
l = 1;
|
||||||
|
}
|
||||||
int uc = upper ? mb_toupper(c) : mb_tolower(c);
|
int uc = upper ? mb_toupper(c) : mb_tolower(c);
|
||||||
|
|
||||||
// Reallocate string when byte count changes. This is rare,
|
// Reallocate string when byte count changes. This is rare,
|
||||||
// thus it's OK to do another malloc()/free().
|
// thus it's OK to do another malloc()/free().
|
||||||
l = utf_ptr2len((const char_u *)p);
|
|
||||||
int newl = utf_char2len(uc);
|
int newl = utf_char2len(uc);
|
||||||
if (newl != l) {
|
if (newl != l) {
|
||||||
// TODO(philix): use xrealloc() in strup_save()
|
// TODO(philix): use xrealloc() in strup_save()
|
||||||
|
@@ -299,6 +299,11 @@ func Test_tolower()
|
|||||||
" Ⱥ (U+023A) and Ⱦ (U+023E) are the *only* code points to increase
|
" Ⱥ (U+023A) and Ⱦ (U+023E) are the *only* code points to increase
|
||||||
" in length (2 to 3 bytes) when lowercased. So let's test them.
|
" in length (2 to 3 bytes) when lowercased. So let's test them.
|
||||||
call assert_equal("ⱥ ⱦ", tolower("Ⱥ Ⱦ"))
|
call assert_equal("ⱥ ⱦ", tolower("Ⱥ Ⱦ"))
|
||||||
|
|
||||||
|
" This call to tolower with invalid utf8 sequence used to cause access to
|
||||||
|
" invalid memory.
|
||||||
|
call tolower("\xC0\x80\xC0")
|
||||||
|
call tolower("123\xC0\x80\xC0")
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func Test_toupper()
|
func Test_toupper()
|
||||||
@@ -369,6 +374,11 @@ func Test_toupper()
|
|||||||
call assert_equal("ZŹŻŽƵẐẔ", toupper("ZŹŻŽƵẐẔ"))
|
call assert_equal("ZŹŻŽƵẐẔ", toupper("ZŹŻŽƵẐẔ"))
|
||||||
|
|
||||||
call assert_equal("Ⱥ Ⱦ", toupper("ⱥ ⱦ"))
|
call assert_equal("Ⱥ Ⱦ", toupper("ⱥ ⱦ"))
|
||||||
|
|
||||||
|
" This call to toupper with invalid utf8 sequence used to cause access to
|
||||||
|
" invalid memory.
|
||||||
|
call toupper("\xC0\x80\xC0")
|
||||||
|
call toupper("123\xC0\x80\xC0")
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" Tests for the mode() function
|
" Tests for the mode() function
|
||||||
|
Reference in New Issue
Block a user