FreeCalypso > hg > freecalypso-sw
view miscutil/imei-luhn.c @ 884:353daaa6014d
gsm-fw/gpf/conf/gsmcomp.c: increased max partition in the voice-only config
The code we got from TCS211 had the maximum prim pool partition size set to
900 bytes in the voice-only config (no FAX_AND_DATA, no GPRS) and to 1600 bytes
in every other config. As it turns out, this "minimized" config breaks when
the AT command interface is used with %CPI enabled, as the responsible code in
ATI does an ACI_MALLOC of 1012 bytes. TI may have considered this case to be
unsupported usage (perhaps they didn't care about the combination of a
voice-only PS with AT command control), but we do want this use case to work
without crashing. Solution: I made the largest prim pool the same as it is
with FAX_AND_DATA: 3 partitions of 1600 bytes.
author | Space Falcon <falcon@ivan.Harhan.ORG> |
---|---|
date | Sat, 27 Jun 2015 07:31:30 +0000 |
parents | cd043e690621 |
children |
line wrap: on
line source
/* * This program computes the Luhn check digit for an IMEI number given * the first 14 digits, or verifies the correctness of this check digit * given a 15-digit number as input. * * The number given on the command line may optionally include punctuation, * which is skipped and ignored. */ #include <stdio.h> #include <ctype.h> #include <stdlib.h> char digits[15]; compute_cd() { int i, dig, sum; sum = 0; for (i = 0; i < 14; 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; } main(argc, argv) char **argv; { char *cp; int i; if (argc != 2) { usage: fprintf(stderr, "usage: %s number\n", argv[0]); exit(2); } cp = argv[1]; if (!isdigit(*cp)) goto usage; for (i = 0; *cp; ) { if (ispunct(*cp)) cp++; if (!isdigit(*cp)) goto usage; if (i >= 15) { wrong_len: fprintf(stderr, "error: argument must have 14 or 15 digits\n"); exit(2); } digits[i++] = *cp++ - '0'; } switch (i) { case 14: printf("%d\n", compute_cd()); exit(0); case 15: if (digits[14] == compute_cd()) { printf("IMEI OK\n"); exit(0); } else { printf("Check digit mismatch!\n"); exit(1); } default: goto wrong_len; } }