, 5 tweets, 1 min read Read on Twitter
One of the fun stories of crypto. RC4 was originally a trade secret -- you had to license it from RSA. Then in 1994 it was published by cypherpunks. But we couldn't certain it was the same algorithm, so it was called "alleged RC4" or ARC4.
Because RC4 is a stream cipher, it works by generating a stream of random numbers XORed with the plain-text to create cipher-text. That means it can also be used as a random number generator, which we call 'arc4random()'.
But weaknesses were found in RC4, so we replaced the underlying algorithm in 'arc4random()' with another stream cipher, ChaCha20. So now when you see "ARC4", it might refer to "ChaCha20".
The original 'rand()' function isn't cryptographically secure, meaning attackers can observe a few outputs and guess the entire sequence. So OpenBSD has taken the radical approach of replacing 'rand()' with 'arc4random()' (meaning, ChaCha20).
It's 'radical' because it can break code that depends upon the predictable nature of 'rand()', but it fixes all that code by naive programmers who assumed it was cryptographically secure.
Missing some Tweet in this thread?
You can try to force a refresh.

Like this thread? Get email updates or save it to PDF!

Subscribe to Robᵇᵉᵗᵒ Graham
Profile picture

Get real-time email alerts when new unrolls are available from this author!

This content may be removed anytime!

Twitter may remove this content at anytime, convert it as a PDF, save and print for later use!

Try unrolling a thread yourself!

how to unroll video

1) Follow Thread Reader App on Twitter so you can easily mention us!

2) Go to a Twitter thread (series of Tweets by the same owner) and mention us with a keyword "unroll" @threadreaderapp unroll

You can practice here first or read more on our help page!

Follow Us on Twitter!

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just three indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3.00/month or $30.00/year) and get exclusive features!

Become Premium

Too expensive? Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal Become our Patreon

Thank you for your support!