\documentclass[12pt,a4paper]{article}
\usepackage[spanish]{babel}

\title{Cyclic Redundancy Check}
\author{Nicolás A. Ortega}

\begin{document}
\maketitle
La CRC es un código usado para detectar errores que se suele usar en redes
digitales y dispositivos de almacenamiento. Funciona cogiendo el resto de una
división polinómica. De esta manera, los cálculos se repiten y si la prueba no
concuerda con los anteriores, se hacen correcciones para prevenir corrupción de
datos.

Es muy popular ya que es simple de implementar en hardware binario y bastante
bueno en la detección de errores comunes causadas por ruido.

La CRC-32 es un variante del CRC que guarda el código CRC en un variable de 32
bits. En C se implementaría de la manera siguiente:

\begin{verbatim}
#include <inttypes.h>

uint32_t CRC32(const uint8_t data[], size_t data_length)
{
  uint32_t crc32 = 0xFFFFFFFFu;

  for (size_t i = 0; i < data_length; i++)
  {
    const uint32_t lookupIndex = (crc32 ^ data[i]) & 0xff;
    crc32 = (crc32 >> 8) ^ CRCTable[lookupIndex];
  }

  crc32 ^= 0xFFFFFFFFu;
  return crc32;
}
\end{verbatim}

\end{document}