mirror of
https://git.libssh.org/projects/libssh.git
synced 2025-11-30 13:01:23 +03:00
CVE-2012-4560: Fix a write one past the end of 'buf'.
This commit is contained in:
@@ -723,7 +723,8 @@ char *ssh_path_expand_escape(ssh_session session, const char *s) {
|
|||||||
if (*p != '%') {
|
if (*p != '%') {
|
||||||
buf[i] = *p;
|
buf[i] = *p;
|
||||||
i++;
|
i++;
|
||||||
if (i > MAX_BUF_SIZE) {
|
if (i >= MAX_BUF_SIZE) {
|
||||||
|
free(r);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
buf[i] = '\0';
|
buf[i] = '\0';
|
||||||
@@ -775,7 +776,7 @@ char *ssh_path_expand_escape(ssh_session session, const char *s) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
i += strlen(x);
|
i += strlen(x);
|
||||||
if (i > MAX_BUF_SIZE) {
|
if (i >= MAX_BUF_SIZE) {
|
||||||
ssh_set_error(session, SSH_FATAL,
|
ssh_set_error(session, SSH_FATAL,
|
||||||
"String too long");
|
"String too long");
|
||||||
free(x);
|
free(x);
|
||||||
|
|||||||
Reference in New Issue
Block a user