FreeCalypso > hg > fc-pcsc-tools
diff libutil/iccid_luhn.c @ 162:274bfd8bccd0
libutil: ICCID Luhn function implemented
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 26 Feb 2021 21:16:45 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libutil/iccid_luhn.c Fri Feb 26 21:16:45 2021 +0000 @@ -0,0 +1,27 @@ +/* + * 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; +}