FreeCalypso > hg > fc-pcsc-tools
view simtool/sstdump.c @ 58:1861d9fb7751
fc-simtool dump-lnd command implemented
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 13 Feb 2021 21:40:38 +0000 |
parents | bbc2821288aa |
children | c56e63a8725d |
line wrap: on
line source
/* * This module implements the sst-dump command, * providing a more readable form of the SIM Service Table. */ #include <sys/types.h> #include <stdio.h> #include "simresp.h" #include "curfile.h" #include "file_id.h" cmd_sst_dump() { int rc; unsigned byte, pos, code, nserv, linelen; rc = select_op(DF_GSM); if (rc < 0) return(rc); rc = select_op(EF_SST); if (rc < 0) return(rc); rc = parse_ef_select_response(); if (rc < 0) return(rc); if (curfile_structure != 0x00) { fprintf(stderr, "error: EF_SST is not transparent\n"); return(-1); } if (curfile_total_size < 2) { fprintf(stderr, "error: EF_SST is shorter than spec minimum of 2 bytes\n"); return(-1); } if (curfile_total_size > 256) { fprintf(stderr, "error: EF_SST is longer than our 256 byte limit\n"); return(-1); } rc = readbin_op(0, curfile_total_size); if (rc < 0) return(rc); linelen = 0; for (byte = 0, nserv = 1; byte < curfile_total_size; byte++) { for (pos = 0; pos < 8; pos += 2, nserv++) { code = (sim_resp_data[byte] >> pos) & 3; if (!(code & 1)) continue; if (linelen > 73) { putchar('\n'); linelen = 0; } if (linelen) { putchar(' '); linelen++; } linelen += printf("%u", nserv); if (!(code & 2)) { putchar('^'); linelen++; } } } if (linelen) putchar('\n'); return(0); }