[email protected] | ead8c1f | 2012-05-30 14:26:13 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
3 | // found in the LICENSE file. | ||||
4 | |||||
5 | #include "base/rand_util.h" | ||||
6 | |||||
[email protected] | 09e5f47a | 2009-06-26 10:00:02 | [diff] [blame] | 7 | #include <errno.h> |
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 8 | #include <fcntl.h> |
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 9 | #include <unistd.h> |
10 | |||||
[email protected] | 4530149 | 2009-04-23 12:38:08 | [diff] [blame] | 11 | #include "base/file_util.h" |
[email protected] | 09e5f47a | 2009-06-26 10:00:02 | [diff] [blame] | 12 | #include "base/lazy_instance.h" |
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 13 | #include "base/logging.h" |
14 | |||||
[email protected] | 09e5f47a | 2009-06-26 10:00:02 | [diff] [blame] | 15 | namespace { |
16 | |||||
17 | // We keep the file descriptor for /dev/urandom around so we don't need to | ||||
18 | // reopen it (which is expensive), and since we may not even be able to reopen | ||||
19 | // it if we are later put in a sandbox. This class wraps the file descriptor so | ||||
20 | // we can use LazyInstance to handle opening it on the first access. | ||||
21 | class URandomFd { | ||||
22 | public: | ||||
23 | URandomFd() { | ||||
24 | fd_ = open("/dev/urandom", O_RDONLY); | ||||
[email protected] | a42d463 | 2011-10-26 21:48:00 | [diff] [blame] | 25 | DCHECK_GE(fd_, 0) << "Cannot open /dev/urandom: " << errno; |
[email protected] | 09e5f47a | 2009-06-26 10:00:02 | [diff] [blame] | 26 | } |
27 | |||||
28 | ~URandomFd() { | ||||
29 | close(fd_); | ||||
30 | } | ||||
31 | |||||
32 | int fd() const { return fd_; } | ||||
33 | |||||
34 | private: | ||||
35 | int fd_; | ||||
36 | }; | ||||
37 | |||||
[email protected] | 6ecc096 | 2012-12-21 02:59:50 | [diff] [blame] | 38 | base::LazyInstance<URandomFd>::Leaky g_urandom_fd = LAZY_INSTANCE_INITIALIZER; |
[email protected] | 09e5f47a | 2009-06-26 10:00:02 | [diff] [blame] | 39 | |
40 | } // namespace | ||||
41 | |||||
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 42 | namespace base { |
43 | |||||
[email protected] | 9b20578 | 2012-08-02 20:22:25 | [diff] [blame] | 44 | // NOTE: This function must be cryptographically secure. http://crbug.com/140076 |
[email protected] | ba99012 | 2008-11-14 23:28:29 | [diff] [blame] | 45 | uint64 RandUint64() { |
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 46 | uint64 number; |
47 | |||||
[email protected] | 09e5f47a | 2009-06-26 10:00:02 | [diff] [blame] | 48 | int urandom_fd = g_urandom_fd.Pointer()->fd(); |
[email protected] | 4530149 | 2009-04-23 12:38:08 | [diff] [blame] | 49 | bool success = file_util::ReadFromFD(urandom_fd, |
50 | reinterpret_cast<char*>(&number), | ||||
51 | sizeof(number)); | ||||
52 | CHECK(success); | ||||
[email protected] | 05f9b68 | 2008-09-29 22:18:01 | [diff] [blame] | 53 | |
54 | return number; | ||||
55 | } | ||||
56 | |||||
[email protected] | 1d87fad | 2010-03-04 20:18:55 | [diff] [blame] | 57 | int GetUrandomFD(void) { |
58 | return g_urandom_fd.Pointer()->fd(); | ||||
59 | } | ||||
[email protected] | ead8c1f | 2012-05-30 14:26:13 | [diff] [blame] | 60 | |
61 | } // namespace base |