Roll src/third_party/WebKit 06cb9e9:a978ee5 (svn 202558:202559)
[chromium-blink-merge.git] / base / rand_util_nacl.cc
blobb771dc44547dbce7f3b99058cab0c6bce4c43fe1
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "base/rand_util.h"
7 #include <nacl/nacl_random.h>
9 #include "base/basictypes.h"
10 #include "base/logging.h"
12 namespace {
14 void GetRandomBytes(void* output, size_t num_bytes) {
15 char* output_ptr = static_cast<char*>(output);
16 while (num_bytes > 0) {
17 size_t nread;
18 const int error = nacl_secure_random(output_ptr, num_bytes, &nread);
19 CHECK_EQ(error, 0);
20 CHECK_LE(nread, num_bytes);
21 output_ptr += nread;
22 num_bytes -= nread;
26 } // namespace
28 namespace base {
30 // NOTE: This function must be cryptographically secure. http://crbug.com/140076
31 uint64 RandUint64() {
32 uint64 result;
33 GetRandomBytes(&result, sizeof(result));
34 return result;
37 void RandBytes(void* output, size_t output_length) {
38 GetRandomBytes(output, output_length);
41 } // namespace base