/* * Copyright (C) 2015 Lucas Jenß * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @ingroup sys_ecc * @brief * @{ * * @brief Hamming Code implementation for 256byte data segments * @author Lucas Jenß <lucas@x3ro.de> */ #ifndef ECC_HAMMING256_H #define ECC_HAMMING256_H #include <stdint.h> #ifdef __cplusplus extern "C" { #endif /** No bit errors were detected in the message */ #define Hamming_ERROR_NONE 0 /** A single bit was incorrect but has been recovered. */ #define Hamming_ERROR_SINGLEBIT 1 /** The original code has been corrupted. */ #define Hamming_ERROR_ECC 2 /** Multiple bits are incorrect in the data and they cannot be corrected. */ #define Hamming_ERROR_MULTIPLEBITS 3 /** * @brief Computes 3-bytes hamming codes for a data block whose size is multiple of * 256 bytes. Each 256 bytes block gets its own code. * * @param[in] data Data to compute code for. * @param[in] size Data size in bytes. * @param[out] code Codes buffer. */ void hamming_compute256x( const uint8_t *data, uint32_t size, uint8_t *code ); /** * @brief Verifies 3-bytes hamming codes for a data block whose size is multiple of * 256 bytes. Each 256-bytes block is verified with its own code. * * @return Hamming_ERROR_NONE if the data is correct, Hamming_ERROR_SINGLEBIT if one or more * block(s) have had a single bit corrected, or either Hamming_ERROR_ECC * or Hamming_ERROR_MULTIPLEBITS. * * @param[in] data Data buffer to verify. * @param[in] size Size of the data in bytes. * @param[in] code Original codes. */ uint8_t hamming_verify256x( uint8_t *data, uint32_t size, const uint8_t *code ); #ifdef __cplusplus } #endif #endif /* ECC_HAMMING256_H */ /** @} */