Skip to content

Commit 8ead779

Browse files
committed
Fix #78510: Partially uninitialized buffer returned by sodium_crypto_generichash_init()
Backport jedisct1/libsodium.php@28d13bf437cb969a0583031fc7ac54c5a8dc8116.
1 parent 41a4379 commit 8ead779

File tree

3 files changed

+19
-0
lines changed

3 files changed

+19
-0
lines changed

NEWS

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,10 @@ PHP NEWS
2121
- PDO_MySQL:
2222
. Fixed bug #41997 (SP call yields additional empty result set). (cmb)
2323

24+
- sodium:
25+
. Fixed bug #78510 (Partially uninitialized buffer returned by
26+
sodium_crypto_generichash_init()). (Frank Denis, cmb)
27+
2428
29 Aug 2019, PHP 7.2.22
2529

2630
- Core:

ext/sodium/libsodium.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -934,6 +934,7 @@ PHP_FUNCTION(sodium_crypto_generichash_init)
934934
zend_throw_exception(sodium_exception_ce, "unsupported key length", 0);
935935
return;
936936
}
937+
memset(&state_tmp, 0, sizeof state_tmp);
937938
if (crypto_generichash_init((void *) &state_tmp, key, (size_t) key_len,
938939
(size_t) hash_len) != 0) {
939940
zend_throw_exception(sodium_exception_ce, "internal error", 0);

ext/sodium/tests/bug78510.phpt

Lines changed: 14 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,14 @@
1+
--TEST--
2+
Bug #78510 (Partially uninitialized buffer returned by sodium_crypto_generichash_init())
3+
--SKIPIF--
4+
<?php
5+
if (!extension_loaded("sodium")) print "skip extension not loaded";
6+
?>
7+
--FILE--
8+
<?php
9+
$key = hex2bin('36be2998c85757e98c1abf3687c8db3a849a393701c05454023d9aba1096fd47');
10+
$y = sodium_crypto_generichash_init($key, 64);
11+
var_dump(bin2hex($y));
12+
?>
13+
--EXPECT--
14+
string(768) "48e9bdf267e6096a3ba7ca8485ae67bb2bf894fe72f36e3cf1361d5f3af54fa5d182e6ad7f520e511f6c3e2b8c68059b6bbd41fbabd9831f79217e1319cde05b000000000000000000000000000000000000000000000000000000000000000036be2998c85757e98c1abf3687c8db3a849a393701c05454023d9aba1096fd4700000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000008000000000000000000000000000000000000000000000000000000000000000"

0 commit comments

Comments
 (0)