]>
git.saurik.com Git - apple/security.git/blob - OSX/libsecurity_utilities/lib/devrandom.h
adf38e6a6810ae61f0977602d50e8cf7a452656d
   2  * Copyright (c) 2000-2004,2011,2014 Apple Inc. All Rights Reserved. 
   4  * @APPLE_LICENSE_HEADER_START@ 
   6  * This file contains Original Code and/or Modifications of Original Code 
   7  * as defined in and that are subject to the Apple Public Source License 
   8  * Version 2.0 (the 'License'). You may not use this file except in 
   9  * compliance with the License. Please obtain a copy of the License at 
  10  * http://www.opensource.apple.com/apsl/ and read it before using this 
  13  * The Original Code and all software distributed under the License are 
  14  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  15  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  16  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 
  17  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
  18  * Please see the License for the specific language governing rights and 
  19  * limitations under the License. 
  21  * @APPLE_LICENSE_HEADER_END@ 
  26 // devrandom - RNG operations based on /dev/random 
  31 #include <security_utilities/utilities.h> 
  32 #include <security_utilities/unix++.h> 
  33 #include <security_utilities/globalizer.h> 
  40 // This RNG uses /dev/random. 
  41 // It is not repeatable. AddEntropy() contributes random entropy to a global pool (only). 
  43 class DevRandomGenerator 
{ 
  44         struct Readonly 
: public UnixPlusPlus::FileDesc 
{ 
  45                 Readonly() { open("/dev/random", O_RDONLY
); } 
  48         struct Writable 
: public UnixPlusPlus::FileDesc 
{ 
  49                 Writable() { open("/dev/random", O_RDWR
); } 
  53     DevRandomGenerator(bool writable 
= false); 
  55     void random(void *data
, size_t length
); 
  56     void addEntropy(const void *data
, size_t length
); 
  59     static ModuleNexus
<Readonly
> mReader
; 
  60         static ModuleNexus
<Writable
> mWriter
; 
  64 };      // end namespace Security