Cycles: Make all #include statements relative to cycles source directory
[blender.git] / intern / cycles / util / util_hash.h
1 /*
2  * Copyright 2011-2013 Blender Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #ifndef __UTIL_HASH_H__
18 #define __UTIL_HASH_H__
19
20 #include "util/util_types.h"
21
22 CCL_NAMESPACE_BEGIN
23
24 ccl_device_inline uint hash_int_2d(uint kx, uint ky)
25 {
26 #define rot(x,k) (((x)<<(k)) | ((x)>>(32-(k))))
27
28         uint a, b, c;
29
30         a = b = c = 0xdeadbeef + (2 << 2) + 13;
31         a += kx;
32         b += ky;
33
34         c ^= b; c -= rot(b,14);
35         a ^= c; a -= rot(c,11);
36         b ^= a; b -= rot(a,25);
37         c ^= b; c -= rot(b,16);
38         a ^= c; a -= rot(c,4);
39         b ^= a; b -= rot(a,14);
40         c ^= b; c -= rot(b,24);
41
42         return c;
43
44 #undef rot
45 }
46
47 ccl_device_inline uint hash_int(uint k)
48 {
49         return hash_int_2d(k, 0);
50 }
51
52 #ifndef __KERNEL_GPU__
53 static inline uint hash_string(const char *str)
54 {
55         uint i = 0, c;
56
57         while((c = *str++))
58                 i = i * 37 + c;
59
60         return i;
61 }
62 #endif
63
64 CCL_NAMESPACE_END
65
66 #endif /* __UTIL_HASH_H__ */
67