FreeCalypso > hg > freecalypso-tools
view miscutil/ti2arfcn.c @ 921:74d284add54d
fc-fsio: guard against bogus readdir results from the target
If the FFS being operated on contains SE K2x0 extended filenames,
readdir will return strings that are bad for printing. We need to
guard against this possibility, and also against possible other
bogosity that could be sent by other alien firmwares.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 31 Dec 2022 22:55:23 +0000 |
parents | d2fccd82a83e |
children |
line wrap: on
line source
/* * TI's TCS211 L1 does not use standard ARFCNs internally, instead it uses * its own non-standard radio_freq numbers in their place. Other firmware * components and all external interfaces do use standard ARFCNs, thus * conversion functions are invoked at appropriate points in the firmware. * However, L1-internal radio_freq numbers are emitted in L1 debug traces, * thus anyone looking at these traces needs to be able to convert between * standard ARFCNs and L1-internal radio_freq. * * The present utility converts TI's radio_freq numbers as seen in L1 traces * into standard ARFCNs. */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <strings.h> main(argc, argv) char **argv; { int ti_num; if (argc != 3) { usage: fprintf(stderr, "usage: %s {eu|us} L1_radio_freq\n", argv[0]); exit(1); } ti_num = atoi(argv[2]); if (!strcmp(argv[1], "eu")) ti2arfcn_eu(ti_num); else if (!strcmp(argv[1], "us")) ti2arfcn_us(ti_num); else goto usage; exit(0); } ti2arfcn_eu(radio_freq) { int arfcn; if (radio_freq < 1 || radio_freq > 548) { fprintf(stderr, "error: specified radio_freq is out of range for dual-EU\n"); exit(1); } if (radio_freq < 175) { if (radio_freq <= 124) arfcn = radio_freq; else if (radio_freq < 174) arfcn = radio_freq - 125 + 975; else arfcn = 0; } else arfcn = radio_freq - 175 + 512; printf("%d\n", arfcn); } ti2arfcn_us(radio_freq) { int arfcn; if (radio_freq < 1 || radio_freq > 423) { fprintf(stderr, "error: specified radio_freq is out of range for dual-US\n"); exit(1); } if (radio_freq < 125) arfcn = radio_freq - 1 + 128; else arfcn = radio_freq - 125 + 512; printf("%d\n", arfcn); }