Skip to main content

Python interface to Intel hardware rng

Project description

A module to use Intel’s hardware RNG with python’s random class

USAGE

for full docs, see https://rdrand.rtfd.io

# easy_install rdrand
# python
>>> from rdrand import RdRandom
>>> r = RdRandom()

>>>from rdrand import RdSeedom >>>s = RdSeedom()

At this point, r and s will behave just like random

RdRandom is a subclass of random.Random, and behaves like random.Random, but it uses inline assembly to access the hardware RNG using the RdRand instruction. This should be a cryptographically secure drop in replacement for random with a prediction complexity bound of O(2^128), if the Intel random number generator is valid. No mitigation is done to modify the output of the hardware to prevent problems with Intel’s implementation. Caveat Emptor.

RdSeedom is a subclass of random.Random, and behaves like random.Random, but it uses inline assembly to access the hardware RNG using the RdSeed instruction. This should be a cryptographically secure drop in replacement for random returning full entropy bits, if the Intel random number generator is valid. No mitigation is done to modify the output of the hardware to prevent problems with Intel’s implementation. Caveat Emptor.

Also, both RdRandom and RdSeedom include the function r.getrandombytes(i) where i is a positive int. This returns a string of length i filled with random bytes, which is ideal for generating a key or using directly in a protocol.

Please note, as with any security solution, it is possible to subvert this. Please understand the full context before deploying. I am not liable for misuse or clever hackers.

Works with 32 and 64 bit builds of python.

Works with python2 and python3.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rdrand-1.5.0.tar.gz (6.2 kB view details)

Uploaded Source

File details

Details for the file rdrand-1.5.0.tar.gz.

File metadata

  • Download URL: rdrand-1.5.0.tar.gz
  • Upload date:
  • Size: 6.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for rdrand-1.5.0.tar.gz
Algorithm Hash digest
SHA256 d9917d0a365af31817914beadd7b8db200ca49a565e5f33fa90801fbc4d965ae
MD5 bfdfb2f3778cdf9d10e54f47c7ced5c8
BLAKE2b-256 58b8a6060f0973f9927c68ff937812ed25a12911a493180703e4cb43f8ffc624

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page