1*043036a2SApple OSS Distributions /*- 2*043036a2SApple OSS Distributions * Copyright (c) 2013 Andre Oppermann <[email protected]> 3*043036a2SApple OSS Distributions * All rights reserved. 4*043036a2SApple OSS Distributions * 5*043036a2SApple OSS Distributions * Redistribution and use in source and binary forms, with or without 6*043036a2SApple OSS Distributions * modification, are permitted provided that the following conditions 7*043036a2SApple OSS Distributions * are met: 8*043036a2SApple OSS Distributions * 1. Redistributions of source code must retain the above copyright 9*043036a2SApple OSS Distributions * notice, this list of conditions and the following disclaimer. 10*043036a2SApple OSS Distributions * 2. Redistributions in binary form must reproduce the above copyright 11*043036a2SApple OSS Distributions * notice, this list of conditions and the following disclaimer in the 12*043036a2SApple OSS Distributions * documentation and/or other materials provided with the distribution. 13*043036a2SApple OSS Distributions * 3. The name of the author may not be used to endorse or promote 14*043036a2SApple OSS Distributions * products derived from this software without specific prior written 15*043036a2SApple OSS Distributions * permission. 16*043036a2SApple OSS Distributions * 17*043036a2SApple OSS Distributions * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 18*043036a2SApple OSS Distributions * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19*043036a2SApple OSS Distributions * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20*043036a2SApple OSS Distributions * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 21*043036a2SApple OSS Distributions * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22*043036a2SApple OSS Distributions * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23*043036a2SApple OSS Distributions * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24*043036a2SApple OSS Distributions * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25*043036a2SApple OSS Distributions * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26*043036a2SApple OSS Distributions * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27*043036a2SApple OSS Distributions * SUCH DAMAGE. 28*043036a2SApple OSS Distributions */ 29*043036a2SApple OSS Distributions 30*043036a2SApple OSS Distributions /* 31*043036a2SApple OSS Distributions * SipHash is a family of pseudorandom functions (a.k.a. keyed hash functions) 32*043036a2SApple OSS Distributions * optimized for speed on short messages returning a 64bit hash/digest value. 33*043036a2SApple OSS Distributions * 34*043036a2SApple OSS Distributions * The number of rounds is defined during the initialization: 35*043036a2SApple OSS Distributions * SipHash24_Init() for the fast and resonable strong version 36*043036a2SApple OSS Distributions * SipHash48_Init() for the strong version (half as fast) 37*043036a2SApple OSS Distributions * 38*043036a2SApple OSS Distributions * struct SIPHASH_CTX ctx; 39*043036a2SApple OSS Distributions * SipHash24_Init(&ctx); 40*043036a2SApple OSS Distributions * SipHash_SetKey(&ctx, "16bytes long key"); 41*043036a2SApple OSS Distributions * SipHash_Update(&ctx, pointer_to_string, length_of_string); 42*043036a2SApple OSS Distributions * SipHash_Final(output, &ctx); 43*043036a2SApple OSS Distributions */ 44*043036a2SApple OSS Distributions 45*043036a2SApple OSS Distributions #ifndef _NET_SIPHASH_H_ 46*043036a2SApple OSS Distributions #define _NET_SIPHASH_H_ 47*043036a2SApple OSS Distributions 48*043036a2SApple OSS Distributions #include <sys/types.h> 49*043036a2SApple OSS Distributions #include <stdint.h> 50*043036a2SApple OSS Distributions 51*043036a2SApple OSS Distributions #define SIPHASH_BLOCK_LENGTH 8 52*043036a2SApple OSS Distributions #define SIPHASH_KEY_LENGTH 16 53*043036a2SApple OSS Distributions #define SIPHASH_DIGEST_LENGTH 8 54*043036a2SApple OSS Distributions 55*043036a2SApple OSS Distributions typedef struct _SIPHASH_CTX { 56*043036a2SApple OSS Distributions uint64_t v[4]; 57*043036a2SApple OSS Distributions union { 58*043036a2SApple OSS Distributions uint64_t b64; 59*043036a2SApple OSS Distributions uint8_t b8[8]; 60*043036a2SApple OSS Distributions } buf; 61*043036a2SApple OSS Distributions uint64_t bytes; 62*043036a2SApple OSS Distributions uint8_t buflen; 63*043036a2SApple OSS Distributions uint8_t rounds_compr; 64*043036a2SApple OSS Distributions uint8_t rounds_final; 65*043036a2SApple OSS Distributions uint8_t initialized; 66*043036a2SApple OSS Distributions } SIPHASH_CTX; 67*043036a2SApple OSS Distributions 68*043036a2SApple OSS Distributions 69*043036a2SApple OSS Distributions #define SipHash24_Init(x) SipHash_InitX((x), 2, 4) 70*043036a2SApple OSS Distributions #define SipHash48_Init(x) SipHash_InitX((x), 4, 8) 71*043036a2SApple OSS Distributions void SipHash_InitX(SIPHASH_CTX *, uint8_t, uint8_t); 72*043036a2SApple OSS Distributions void SipHash_SetKey(SIPHASH_CTX *, 73*043036a2SApple OSS Distributions const uint8_t[SIPHASH_KEY_LENGTH]); 74*043036a2SApple OSS Distributions void SipHash_Update(SIPHASH_CTX *ctx, const void *src __sized_by(len0), size_t len0); 75*043036a2SApple OSS Distributions void SipHash_Final(uint8_t[SIPHASH_DIGEST_LENGTH], SIPHASH_CTX *); 76*043036a2SApple OSS Distributions uint64_t SipHash_End(SIPHASH_CTX *); 77*043036a2SApple OSS Distributions 78*043036a2SApple OSS Distributions #define SipHash24(x, y, z, i) SipHashX((x), 2, 4, (y), (z), (i)); 79*043036a2SApple OSS Distributions #define SipHash48(x, y, z, i) SipHashX((x), 4, 8, (y), (z), (i)); 80*043036a2SApple OSS Distributions uint64_t SipHashX(SIPHASH_CTX *ctx, uint8_t rc, uint8_t rf, 81*043036a2SApple OSS Distributions const uint8_t key[SIPHASH_KEY_LENGTH], const void *src __sized_by(len), size_t len); 82*043036a2SApple OSS Distributions 83*043036a2SApple OSS Distributions int SipHash24_TestVectors(void); 84*043036a2SApple OSS Distributions 85*043036a2SApple OSS Distributions #endif /* _SIPHASH_H_ */ 86