Revert 271602 "Implementation of leveldb-backed PrefStore."
[chromium-blink-merge.git] / base / rand_util_nacl.cc
blobf9751217326b4c72730b98fa1018be49f12a4b1a
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 "base/basictypes.h"
8 #include "base/lazy_instance.h"
9 #include "base/logging.h"
10 #include "native_client/src/untrusted/irt/irt.h"
12 namespace {
14 class NaclRandom {
15 public:
16 NaclRandom() {
17 const size_t result =
18 nacl_interface_query(NACL_IRT_RANDOM_v0_1, &random_, sizeof(random_));
19 CHECK_EQ(result, sizeof(random_));
22 ~NaclRandom() {}
24 void GetRandomBytes(void* output, size_t num_bytes) {
25 char* output_ptr = static_cast<char*>(output);
26 while (num_bytes > 0) {
27 size_t nread;
28 const int error = random_.get_random_bytes(output_ptr, num_bytes, &nread);
29 CHECK_EQ(error, 0);
30 CHECK_LE(nread, num_bytes);
31 output_ptr += nread;
32 num_bytes -= nread;
36 private:
37 nacl_irt_random random_;
40 base::LazyInstance<NaclRandom>::Leaky g_nacl_random = LAZY_INSTANCE_INITIALIZER;
42 } // namespace
44 namespace base {
46 // NOTE: This function must be cryptographically secure. http://crbug.com/140076
47 uint64 RandUint64() {
48 uint64 result;
49 g_nacl_random.Pointer()->GetRandomBytes(&result, sizeof(result));
50 return result;
53 void RandBytes(void* output, size_t output_length) {
54 g_nacl_random.Pointer()->GetRandomBytes(output, output_length);
57 } // namespace base