1*6dbdd20aSAndroid Build Coastguard Worker /* 2*6dbdd20aSAndroid Build Coastguard Worker * Copyright (C) 2021 The Android Open Source Project 3*6dbdd20aSAndroid Build Coastguard Worker * 4*6dbdd20aSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*6dbdd20aSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*6dbdd20aSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*6dbdd20aSAndroid Build Coastguard Worker * 8*6dbdd20aSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*6dbdd20aSAndroid Build Coastguard Worker * 10*6dbdd20aSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*6dbdd20aSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*6dbdd20aSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*6dbdd20aSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*6dbdd20aSAndroid Build Coastguard Worker * limitations under the License. 15*6dbdd20aSAndroid Build Coastguard Worker */ 16*6dbdd20aSAndroid Build Coastguard Worker 17*6dbdd20aSAndroid Build Coastguard Worker #ifndef INCLUDE_PERFETTO_TRACING_INTERNAL_FNV1A_H_ 18*6dbdd20aSAndroid Build Coastguard Worker #define INCLUDE_PERFETTO_TRACING_INTERNAL_FNV1A_H_ 19*6dbdd20aSAndroid Build Coastguard Worker 20*6dbdd20aSAndroid Build Coastguard Worker #include <cstddef> 21*6dbdd20aSAndroid Build Coastguard Worker #include <cstdint> 22*6dbdd20aSAndroid Build Coastguard Worker 23*6dbdd20aSAndroid Build Coastguard Worker namespace perfetto { 24*6dbdd20aSAndroid Build Coastguard Worker namespace internal { 25*6dbdd20aSAndroid Build Coastguard Worker 26*6dbdd20aSAndroid Build Coastguard Worker // Constexpr functions to compute a 64-bit hash of the input data. The algorithm 27*6dbdd20aSAndroid Build Coastguard Worker // used is FNV-1a as it is fast and easy to implement and has relatively few 28*6dbdd20aSAndroid Build Coastguard Worker // collisions. 29*6dbdd20aSAndroid Build Coastguard Worker // 30*6dbdd20aSAndroid Build Coastguard Worker // WARNING: This hash function should not be used for any cryptographic purpose. 31*6dbdd20aSAndroid Build Coastguard Worker 32*6dbdd20aSAndroid Build Coastguard Worker static constexpr uint64_t kFnv1a64OffsetBasis = 0xcbf29ce484222325; 33*6dbdd20aSAndroid Build Coastguard Worker static constexpr uint64_t kFnv1a64Prime = 0x100000001b3; 34*6dbdd20aSAndroid Build Coastguard Worker Fnv1a(const char * s)35*6dbdd20aSAndroid Build Coastguard Workerstatic constexpr inline uint64_t Fnv1a(const char* s) { 36*6dbdd20aSAndroid Build Coastguard Worker uint64_t ret = kFnv1a64OffsetBasis; 37*6dbdd20aSAndroid Build Coastguard Worker for (; *s; s++) { 38*6dbdd20aSAndroid Build Coastguard Worker ret = ret ^ static_cast<uint8_t>(*s); 39*6dbdd20aSAndroid Build Coastguard Worker ret *= kFnv1a64Prime; 40*6dbdd20aSAndroid Build Coastguard Worker } 41*6dbdd20aSAndroid Build Coastguard Worker return ret; 42*6dbdd20aSAndroid Build Coastguard Worker } 43*6dbdd20aSAndroid Build Coastguard Worker Fnv1a(const void * data,size_t size)44*6dbdd20aSAndroid Build Coastguard Workerstatic constexpr inline uint64_t Fnv1a(const void* data, size_t size) { 45*6dbdd20aSAndroid Build Coastguard Worker uint64_t ret = kFnv1a64OffsetBasis; 46*6dbdd20aSAndroid Build Coastguard Worker const uint8_t* s = static_cast<const uint8_t*>(data); 47*6dbdd20aSAndroid Build Coastguard Worker for (size_t i = 0; i < size; i++) { 48*6dbdd20aSAndroid Build Coastguard Worker ret = ret ^ s[i]; 49*6dbdd20aSAndroid Build Coastguard Worker ret *= kFnv1a64Prime; 50*6dbdd20aSAndroid Build Coastguard Worker } 51*6dbdd20aSAndroid Build Coastguard Worker return ret; 52*6dbdd20aSAndroid Build Coastguard Worker } 53*6dbdd20aSAndroid Build Coastguard Worker 54*6dbdd20aSAndroid Build Coastguard Worker } // namespace internal 55*6dbdd20aSAndroid Build Coastguard Worker } // namespace perfetto 56*6dbdd20aSAndroid Build Coastguard Worker 57*6dbdd20aSAndroid Build Coastguard Worker #endif // INCLUDE_PERFETTO_TRACING_INTERNAL_FNV1A_H_ 58