Security
Headlines
HeadlinesLatestCVEs

Headline

CVE-2023-2610: patch 9.0.1532: crash when expanding "~" in substitute causes very lo… · vim/vim@ab9a2d8

Integer Overflow or Wraparound in GitHub repository vim/vim prior to 9.0.1532.

CVE
#git

Expand Up

@@ -1767,10 +1767,7 @@ do_Lower(int *d, int c)

regtilde(char_u *source, int magic)

{

char_u *newsub = source;

char_u *tmpsub;

char_u *p;

int len;

int prevlen;

for (p = newsub; *p; ++p)

{

Expand All

@@ -1779,24 +1776,35 @@ regtilde(char_u *source, int magic)

if (reg_prev_sub != NULL)

{

// length = len(newsub) - 1 + len(prev_sub) + 1

prevlen = (int)STRLEN(reg_prev_sub);

tmpsub = alloc(STRLEN(newsub) + prevlen);

// Avoid making the text longer than MAXCOL, it will cause

// trouble at some point.

size_t prevsublen = STRLEN(reg_prev_sub);

size_t newsublen = STRLEN(newsub);

if (prevsublen > MAXCOL || newsublen > MAXCOL

|| newsublen + prevsublen > MAXCOL)

{

emsg(_(e_resulting_text_too_long));

break;

}

char_u *tmpsub = alloc(newsublen + prevsublen);

if (tmpsub != NULL)

{

// copy prefix

len = (int)(p - newsub); // not including ~

mch_memmove(tmpsub, newsub, (size_t)len);

size_t prefixlen = p - newsub; // not including ~

mch_memmove(tmpsub, newsub, prefixlen);

// interpret tilde

mch_memmove(tmpsub + len, reg_prev_sub, (size_t)prevlen);

mch_memmove(tmpsub + prefixlen, reg_prev_sub,

prevsublen);

// copy postfix

if (!magic)

++p; // back off backslash

STRCPY(tmpsub + len + prevlen, p + 1);

STRCPY(tmpsub + prefixlen + prevsublen, p + 1);

if (newsub != source) // already allocated newsub

if (newsub != source) // allocated newsub before

vim_free(newsub);

newsub = tmpsub;

p = newsub + len + prevlen;

p = newsub + prefixlen + prevsublen;

}

}

else if (magic)

Expand Down

Related news

Ubuntu Security Notice USN-6154-1

Ubuntu Security Notice 6154-1 - It was discovered that Vim was using uninitialized memory when fuzzy matching, which could lead to invalid memory access. An attacker could possibly use this issue to cause a denial of service or execute arbitrary code. This issue only affected Ubuntu 22.04 LTS, Ubuntu 22.10 and Ubuntu 23.04. It was discovered that Vim was not properly performing bounds checks when processing register contents, which could lead to a NULL pointer dereference. An attacker could possibly use this issue to cause a denial of service or execute arbitrary code.

CVE: Latest News

CVE-2023-50976: Transactions API Authorization by oleiman · Pull Request #14969 · redpanda-data/redpanda