mirror of
https://github.com/PowerShell/openssh-portable.git
synced 2025-09-25 19:08:56 +02:00
Fix _rs_init split in half during merge (#734)
This commit is contained in:
parent
661803c9ec
commit
e829ad267c
@ -97,6 +97,14 @@ _rs_init(u_char *buf, size_t n)
|
|||||||
{
|
{
|
||||||
if (n < KEYSZ + IVSZ)
|
if (n < KEYSZ + IVSZ)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (rs == NULL) {
|
||||||
|
if (_rs_allocate(&rs, &rsx) == -1)
|
||||||
|
_exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
chacha_keysetup(&rsx->rs_chacha, buf, KEYSZ * 8);
|
||||||
|
chacha_ivsetup(&rsx->rs_chacha, buf + KEYSZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef WITH_OPENSSL
|
#ifndef WITH_OPENSSL
|
||||||
@ -135,14 +143,18 @@ getrnd(u_char *s, size_t len)
|
|||||||
return;
|
return;
|
||||||
fatal("Couldn't open %s: %s", SSH_RANDOM_DEV,
|
fatal("Couldn't open %s: %s", SSH_RANDOM_DEV,
|
||||||
strerror(save_errno));
|
strerror(save_errno));
|
||||||
|
|
||||||
if (rs == NULL) {
|
|
||||||
if (_rs_allocate(&rs, &rsx) == -1)
|
|
||||||
_exit(1);
|
|
||||||
}
|
}
|
||||||
|
while (o < len) {
|
||||||
chacha_keysetup(&rsx->rs_chacha, buf, KEYSZ * 8);
|
r = read(fd, s + o, len - o);
|
||||||
chacha_ivsetup(&rsx->rs_chacha, buf + KEYSZ);
|
if (r < 0) {
|
||||||
|
if (errno == EAGAIN || errno == EINTR ||
|
||||||
|
errno == EWOULDBLOCK)
|
||||||
|
continue;
|
||||||
|
fatal("read %s: %s", SSH_RANDOM_DEV, strerror(errno));
|
||||||
|
}
|
||||||
|
o += r;
|
||||||
|
}
|
||||||
|
close(fd);
|
||||||
}
|
}
|
||||||
#endif /* !WINDOWS */
|
#endif /* !WINDOWS */
|
||||||
#endif /* WITH_OPENSSL */
|
#endif /* WITH_OPENSSL */
|
||||||
@ -290,4 +302,4 @@ arc4random_buf(void *_buf, size_t n)
|
|||||||
}
|
}
|
||||||
explicit_bzero(&r, sizeof(r));
|
explicit_bzero(&r, sizeof(r));
|
||||||
}
|
}
|
||||||
#endif /* !defined(HAVE_ARC4RANDOM_BUF) && defined(HAVE_ARC4RANDOM) */
|
#endif /* !defined(HAVE_ARC4RANDOM_BUF) && defined(HAVE_ARC4RANDOM) */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user