# HG changeset patch # User Mychaela Falconia # Date 1614374205 0 # Node ID 274bfd8bccd01d6f1091be282aeaeb81f3501c38 # Parent 884b933624498ab5a34e939ae9325fd20c5463fe libutil: ICCID Luhn function implemented diff -r 884b93362449 -r 274bfd8bccd0 libutil/Makefile --- a/libutil/Makefile Fri Feb 26 21:10:26 2021 +0000 +++ b/libutil/Makefile Fri Feb 26 21:16:45 2021 +0000 @@ -2,7 +2,7 @@ CFLAGS= -O2 OBJS= alpha_decode.o alpha_fromfile.o alpha_valid.o decimal_str.o \ filesearch.o gsm7_decode.o gsm7_encode.o gsm7_encode_table.o \ - gsm7_unpack.o hexdigits.o hexread.o hexstr.o nibbles2asc.o \ + gsm7_unpack.o hexdigits.o hexread.o hexstr.o iccid_luhn.o nibbles2asc.o\ number_decode.o number_encode.o pinentry.o plmncodes.o revnibbles.o \ shorthand.o LIB= libutil.a diff -r 884b93362449 -r 274bfd8bccd0 libutil/iccid_luhn.c --- /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 + +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; +}