/* * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Copyright 2011 Danny Robson */ #include "crc.hpp" #include "debug.hpp" #include "endian.hpp" uint32_t crc32 (const void *restrict, size_t) { not_implemented (); /* const uint8_t *restrict data = static_cast (_data); static const uint32_t POLYNOMIAL = hton (static_cast(0x04C11DB7)); uint64_t bits = 0; unsigned int i = 0; if (size == 0) return POLYNOMIAL; switch (size) { default: bits |= static_cast(data[3]) << 32U; case 3: bits |= static_cast(data[2]) << 40U; case 2: bits |= static_cast(data[1]) << 48U; case 1: bits |= static_cast(data[0]) << 56U; } for (size_t i = 0; i < size; ++i) { for (unsigned j = 0; j < 32; ++j) { bool mix = bits 0x7000000000000000ULL; bits <<= 1; if (mix) bits ^= POLYNOMIAL << 32; } } */ }