diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-11-09 05:12:59 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-11-09 05:12:59 +0000 |
commit | 26c046fbc57d53136b4fb3b5e0d18298318125d4 (patch) | |
tree | 0397d2184e7fba8a51f7fb9a6fc01a82d0748411 /nss/lib/freebl/sysrand.c | |
parent | c416b91e36567df4ec765a495c5a6ca6a1853f58 (diff) | |
download | nss-26c046fbc57d53136b4fb3b5e0d18298318125d4.tar.gz |
nss-3.21nss-3.21
Diffstat (limited to 'nss/lib/freebl/sysrand.c')
-rw-r--r-- | nss/lib/freebl/sysrand.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/nss/lib/freebl/sysrand.c b/nss/lib/freebl/sysrand.c new file mode 100644 index 0000000..e6dd56a --- /dev/null +++ b/nss/lib/freebl/sysrand.c @@ -0,0 +1,49 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifdef FREEBL_NO_DEPEND +#include "stubs.h" +#endif + +#include "seccomon.h" + +#ifndef XP_WIN +static size_t rng_systemFromNoise(unsigned char *dest, size_t maxLen); +#endif + +#if defined(XP_UNIX) || defined(XP_BEOS) +#include "unix_rand.c" +#endif +#ifdef XP_WIN +#include "win_rand.c" +#endif +#ifdef XP_OS2 +#include "os2_rand.c" +#endif + +#ifndef XP_WIN +/* + * Normal RNG_SystemRNG() isn't available, use the system noise to collect + * the required amount of entropy. + */ +static size_t +rng_systemFromNoise(unsigned char *dest, size_t maxLen) +{ + size_t retBytes = maxLen; + + while (maxLen) { + size_t nbytes = RNG_GetNoise(dest, maxLen); + + PORT_Assert(nbytes != 0); + + dest += nbytes; + maxLen -= nbytes; + + /* some hw op to try to introduce more entropy into the next + * RNG_GetNoise call */ + rng_systemJitter(); + } + return retBytes; +} +#endif |