FreeCalypso > hg > fc-pcsc-tools
view libutil/iccid_luhn.c @ 226:0f96b5136541
sws-email2db program written
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Wed, 10 Mar 2021 20:34:03 +0000 |
parents | 274bfd8bccd0 |
children |
line wrap: on
line source
/* * This module implements a function for computing the Luhn check digit * for ICCIDs that follow the 18+1 convention. */ #include <sys/types.h> compute_iccid_luhn(digits) u_char *digits; { int i, dig, sum; sum = 0; for (i = 0; i < 18; i++) { dig = digits[i]; if (i & 1) { dig *= 2; if (dig > 9) dig -= 9; } sum += dig; } dig = sum % 10; if (dig) dig = 10 - dig; return dig; }