Jump to content

SipHash: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m Usage: Add Node.js and V8 as prominent examples
m Usage: Sort implementations
Line 136: Line 136:
{{div col}}
{{div col}}
* [https://github.com/veorq/SipHash C] (Public domain reference implementation)
* [https://github.com/veorq/SipHash C] (Public domain reference implementation)
* [https://github.com/jedisct1/rust-siphash Rust]
* [[Crypto++]]
* [https://github.com/paya-cz/siphash C#]
* [https://github.com/paya-cz/siphash C#]
* [[Crypto++]]
* [https://github.com/dchest/siphash Go]
* [https://gist.github.com/ar-nelson/12bd5ea968c145045200 Haskell]
* [https://gist.github.com/ar-nelson/12bd5ea968c145045200 Haskell]
* [https://github.com/jedisct1/siphash-js JavaScript]
* [https://github.com/jedisct1/siphash-js JavaScript]
* [https://github.com/pemb/siphash VHDL]
* [https://github.com/secworks/siphash Verilog]
* [https://godoc.org/github.com/dchest/siphash Go]
* [https://github.com/attaswift/SipHash Swift]
* [https://web.archive.org/web/20180207062939if_/https://bitbucket.org/mihailp/tankfeeder/src/default/hash/siphash.l PicoLisp]
* [https://web.archive.org/web/20180207062939if_/https://bitbucket.org/mihailp/tankfeeder/src/default/hash/siphash.l PicoLisp]
* [https://github.com/jedisct1/rust-siphash Rust]
* [https://github.com/attaswift/SipHash Swift]
* [https://github.com/secworks/siphash Verilog]
* [https://github.com/pemb/siphash VHDL]
{{div col end}}
{{div col end}}



Revision as of 23:12, 21 October 2021

SipHash is an add–rotate–xor (ARX) based family of pseudorandom functions created by Jean-Philippe Aumasson and Daniel J. Bernstein in 2012,[1]: 165 [2] in response to a spate of "hash flooding" denial-of-service attacks in late 2011.[3]

Although designed for use as a hash function to ensure security, SipHash is fundamentally different from cryptographic hash functions like SHA in that it is only suitable as a message authentication code: a keyed hash function like HMAC. That is, SHA is designed so that it is difficult for an attacker to find two messages X and Y such that SHA(X) = SHA(Y), even though anyone may compute SHA(X). SipHash instead guarantees that, having seen Xi and SipHash(Xi, k), an attacker who does not know the key k cannot find (any information about) k or SipHash(Y, k) for any message Y ∉ {Xi} which they have not seen before.

Overview

SipHash computes a 64-bit message authentication code from a variable-length message and 128-bit secret key. It was designed to be efficient even for short inputs, with performance comparable to non-cryptographic hash functions, such as CityHash,[4]: 496 [2] this can be used to prevent denial-of-service attacks against hash tables ("hash flooding"),[5] or to authenticate network packets. A variant was later added which produces a 128-bit result.[6]

An unkeyed hash function such as SHA is only collision-resistant if the entire output is used. If used to generate a small output, such as an index into a hash table of practical size, then no algorithm can prevent collisions; an attacker need only make as many attempts as there are possible outputs.

For example, suppose a network server is designed to be able to handle up to a million requests at once. It keeps track of incoming requests in a hash table with two million entries, using a hash function to map identifying information from each request to one of the two million possible table entries. An attacker who knows the hash function need only feed it arbitrary inputs; one out of two million will have a specific hash value. If the attacker now sends a few hundred requests all chosen to have the same hash value to the server, that will produce a large number of hash collisions, slowing (or possibly stopping) the server with an effect similar to a packet flood of many million requests.[7]

By using a key unknown to the attacker, a keyed hash function like SipHash prevents this sort of attack. While it is possible to add a key to an unkeyed hash function (HMAC is a popular technique), SipHash is much more efficient.

Functions in SipHash family are specified as SipHash-c-d, where c is the number of rounds per message block and d is the number of finalization rounds. The recommended parameters are SipHash-2-4 for best performance, and SipHash-4-8 for conservative security. A few languages use Siphash-1-3 for performance at the risk of yet-unknown DoS attacks.

The reference implementation was released as public domain software under the CC0.[6]

Usage

SipHash is used in hash table implementations of various software:[8]

The following programs use SipHash in other ways:

Implementations

See also

References

  1. ^ Dobraunig, Christoph; Mendel, Florian; Schläffer, Martin (29 November 2014). Differential Cryptanalysis of SipHash. Lecture Notes in Computer Science. Vol. 8781. pp. 165–182. doi:10.1007/978-3-319-13051-4_10. ISBN 978-3-319-13050-7. Retrieved 28 February 2018. {{cite book}}: |journal= ignored (help)
  2. ^ a b Jean-Philippe Aumasson & Daniel J. Bernstein (2012-09-18). "SipHash: a fast short-input PRF".
  3. ^ Lennon, Mike (2011-12-28). "Hash Table Vulnerability Enables Wide-Scale DDoS Attacks". SecurityWeek.
  4. ^ So, Won; Narayanan, Ashok; Oran, David; Stapp, Mark (2013). Named data networking on a router: forwarding at 20gbps and beyond. p. 495. doi:10.1145/2486001.2491699. ISBN 9781450320566. S2CID 1457918. Retrieved 28 February 2018. The recently proposed SipHash [1] offers a good balance as it provides collision resistance and comparable performance to non-crypto hashes {{cite book}}: |journal= ignored (help)
  5. ^ Aumasson, Jean-Philippe; Bernstein, Daniel J.; Boßlet, Martin (2012-11-08). Hash-flooding DoS reloaded: attacks and defenses (PDF). Application Security Forum – Western Switzerland 2012.
  6. ^ a b "SipHash: a fast short-input PRF". 2016-08-01. Retrieved 2017-01-21. Intellectual property: We aren't aware of any patents or patent applications relevant to SipHash, and we aren't planning to apply for any. The reference code of SipHash is released under CC0 license, a public domain-like license.
  7. ^ Crosby, Scott A.; Wallach, Dan S. (2003-08-06). Denial of Service via Algorithmic Complexity Attacks. Usenix Security Symposium. Washington, D.C.
  8. ^ Aumasson, Jean-Philippe; Bernstein, Daniel J. (2016-08-01). "SipHash: a fast short-input PRF, Users". Retrieved 2017-01-21.
  9. ^ Vagg, Rod (2019-02-28). "build: enable v8's SipHash for hash seed creation". Node.js. Retrieved 2021-10-21 – via GitHub.
  10. ^ "Perl security – Algorithmic Complexity Attacks". Perldoc Browser. 2016-05-16. Retrieved 2021-10-21.
  11. ^ Heimes, Christian (2013-09-27). "PEP 456 – Secure and interchangeable hash algorithm". Retrieved 2017-01-21.
  12. ^ McVey, Samantha (2018-07-16). "Implement SipHash, use as our hashing function w/ 64bit hashvals". MoarVM. Retrieved 2018-07-16 – via GitHub.
  13. ^ Hoare, Graydon (2012-07-24). "Add core::hash containing SipHash-2-4 implementation. Re: #1616 and #859". Rust. Retrieved 2017-01-21 – via GitHub.
  14. ^ Poettering, Lennart (2013-12-22). "shared: switch our hash table implementation over to SipHash". systemd. Retrieved 2017-01-21 – via freedesktop.org.
  15. ^ Guo, Yang (2019-01-09). "Optionally use halfsiphash for integer hashing". V8. Retrieved 2021-10-21.
  16. ^ "Compact Block Relay". GitHub. Retrieved 2018-09-27.
  17. ^ bslh_siphashalgorithm.h