Daniel J. Bernstein | |
Birth Date: | 29 October 1971 |
Birth Place: | East Patchogue, New York |
Citizenship: | American, German[1] |
Fields: | Mathematics, Cryptography, Computer Security |
Workplaces: | University of Illinois at Chicago, Eindhoven University of Technology |
Alma Mater: | University of California, Berkeley (PhD) New York University (BA) |
Doctoral Advisor: | Hendrik Lenstra |
Known For: | qmail, djbdns, Salsa20, ChaCha20, Poly1305, Curve25519 |
Daniel Julius Bernstein (sometimes known as djb; born October 29, 1971) is an American mathematician, cryptologist, and computer scientist. He was a visiting professor at CASA[2] at Ruhr University Bochum until 2024[3], as well as a research professor of Computer Science at the University of Illinois at Chicago. Before this, he was a visiting professor in the department of mathematics and computer science at the Eindhoven University of Technology.
Bernstein attended Bellport High School, a public high school on Long Island, graduating in 1987 at the age of 15.[4] The same year, he ranked fifth in the Westinghouse Science Talent Search.[5] In 1987 (at the age of 16), he achieved a Top 10 ranking in the William Lowell Putnam Mathematical Competition,[6] and was a member of the second-place team from Princeton University the following year.[7] Bernstein earned a B.A. in mathematics from New York University (1991) and a Ph.D. in mathematics from the University of California, Berkeley (1995), where he studied under Hendrik Lenstra.
The export of cryptography from the United States was controlled as a munition starting from the Cold War until recategorization in 1996, with further relaxation in the late 1990s.[8] In 1995, Bernstein brought the court case Bernstein v. United States. The ruling in the case declared that software was protected speech under the First Amendment, which contributed to regulatory changes reducing controls on encryption.[9] Bernstein was originally represented by the Electronic Frontier Foundation.[10] He later represented himself.[11]
Bernstein designed the Salsa20 stream cipher in 2005 and submitted it to eSTREAM for review and possible standardization. He later published the ChaCha20 variant of Salsa in 2008. In 2005, he proposed the elliptic curve Curve25519 as a basis for public-key schemes. He worked as the lead researcher on the Ed25519 version of EdDSA. The algorithms made their way into popular software. For example, since 2014, when OpenSSH is compiled without OpenSSL they power most of its operations, and OpenBSD package signing is based on Ed25519.[12] [13]
Nearly a decade later, Edward Snowden disclosed mass surveillance by the National Security Agency, and researchers discovered a backdoor in the Agency's Dual EC DRBG algorithm. These events raised suspicions of the elliptic curve parameters proposed by NSA and standardized by NIST.[14] Many researchers feared[15] that the NSA had chosen curves that gave them a cryptanalytic advantage.[16] [17] Google selected ChaCha20 along with Bernstein's Poly1305 message authentication code for use in TLS, which is widely used for Internet security.[18] Many protocols based on his works have been adopted by various standards organizations and are used in a variety of applications, such as Apple iOS,[19] the Linux kernel,[20] OpenSSH,[21] [22] and Tor.[23]
In spring 2005, Bernstein taught a course on "high speed cryptography."[24] He introduced new cache attacks against implementations of AES in the same time period.[25]
In April 2008,[26] Bernstein's stream cipher "Salsa20" was selected as a member of the final portfolio of the eSTREAM project, part of a European Union research directive.
In 2011, Bernstein published RFSB, a variant of the Fast Syndrome Based Hash function.
He is one of the editors of the 2009 book Post-Quantum Cryptography.[27]
Starting in the mid-1990s, Bernstein wrote a number of security-aware programs, including qmail, ezmlm, djbdns, ucspi-tcp, daemontools, and publicfile
.
Bernstein criticized the leading DNS package at the time, BIND, and wrote djbdns as a DNS package with security as a primary goal.[28] Bernstein offers "security guarantees" for qmail and djbdns in the form of monetary rewards for the identification of flaws.[29] [30] A purported exploit targeting qmail running on 64-bit platforms was published in 2005,[31] [32] but Bernstein believes that the exploit does not fall within the parameters of his qmail security guarantee. In March 2009, Bernstein awarded $1000 to Matthew Dempsky for finding a security flaw in djbdns.[33]
In August 2008, Bernstein announced[34] DNSCurve, a proposal to secure the Domain Name System. DNSCurve applies techniques from elliptic curve cryptography with the goal of providing a vast increase in performance over the RSA public-key algorithm used by DNSSEC. It uses the existing DNS hierarchy to propagate trust by embedding public keys into specially formatted, backward-compatible DNS records.
Bernstein proposed Internet Mail 2000, an alternative system for electronic mail, which he intended to replace the Simple Mail Transfer Protocol (SMTP), the Post Office Protocol (POP3) and the Internet Message Access Protocol (IMAP).[35]
Bernstein is also known for his string hashing function djb2[36] [37] and the cdb database library.[38]
Bernstein has published a number of papers on mathematics and computation. Many of his papers deal with algorithms or implementations.
In 2001, Bernstein circulated "Circuits for integer factorization: a proposal,"[39] which suggested that, if physical hardware implementations could be brought close to their theoretical efficiency, the then-popular estimates of adequate security parameters might be off by a factor of three. Since 512-bit RSA was breakable at the time, so might be 1536-bit RSA. Bernstein was careful not to make any actual predictions, and emphasized the importance of correctly interpreting asymptotic expressions. Several prominent researchers (among them Arjen Lenstra, Adi Shamir, Jim Tomlinson, and Eran Tromer) disagreed strongly with Bernstein's conclusions.[40] Bernstein has received funding to investigate whether this potential can be realized.
Bernstein is also the author of the mathematical libraries DJBFFT, a fast portable FFT library, and primegen
, an asymptotically fast small prime sieve with low memory footprint based on the sieve of Atkin (rather than the more usual sieve of Eratosthenes). Both have been used effectively in the search for large prime numbers.
In 2007, Bernstein proposed the use of a (twisted) Edwards curve, Curve25519, as a basis for elliptic curve cryptography; it is employed in Ed25519 implementation of EdDSA.
In February 2015, Bernstein and others published a paper on a stateless post-quantum hash-based signature scheme called SPHINCS.[41] In July 2022, SPHINCS+, a signature scheme adapted from SPHINCS by Bernstein and others, was one of four algorithms selected as winners of the NIST Post-Quantum Cryptography Standardization competition. It was the only hash-based algorithm of the four winners.[42] [43]
In April 2017, Bernstein and others published a paper on Post-Quantum RSA that includes an integer factorization algorithm claimed to be "often much faster than Shor's".[44]
In 2004, Bernstein taught a course on computer software security where he assigned each student to find ten vulnerabilities in published software.[45] The 25 students discovered 44 vulnerabilities, and the class published security advisories about the issues.