run make style

This commit is contained in:
Grayson Martin 2023-11-11 14:32:09 -06:00
parent db3c86958a
commit e65263c73b
No known key found for this signature in database
GPG key ID: 4914C62F2696A273
8 changed files with 79 additions and 62 deletions

View file

@ -1205,21 +1205,21 @@ static void atsToEmulatedAtr(uint8_t *ats, uint8_t *atr, int *atrLen) {
} }
static void atqbToEmulatedAtr(uint8_t *atqb, uint8_t cid, uint8_t *atr, int *atrLen) { static void atqbToEmulatedAtr(uint8_t *atqb, uint8_t cid, uint8_t *atr, int *atrLen) {
atr[0] = 0x3B; atr[0] = 0x3B;
atr[1] = 0x80 | 8; atr[1] = 0x80 | 8;
atr[2] = 0x80; atr[2] = 0x80;
atr[3] = 0x01; atr[3] = 0x01;
memcpy(atr + 4, atqb, 7); memcpy(atr + 4, atqb, 7);
atr[11] = cid >> 4; atr[11] = cid >> 4;
uint8_t tck = 0; uint8_t tck = 0;
for (int i = 1; i < 12; ++i) { for (int i = 1; i < 12; ++i) {
tck = tck ^ atr[i]; tck = tck ^ atr[i];
} }
atr[12] = tck; atr[12] = tck;
*atrLen = 13; *atrLen = 13;
} }
static int CmdRelay(const char *Cmd) { static int CmdRelay(const char *Cmd) {
@ -1263,9 +1263,9 @@ static int CmdRelay(const char *Cmd) {
uint8_t cmdbuf[512] = {0}; uint8_t cmdbuf[512] = {0};
iso14a_card_select_t selectedCard14a; iso14a_card_select_t selectedCard14a;
iso14b_card_select_t selectedCard14b; iso14b_card_select_t selectedCard14b;
isodep_state_t cardType = ISODEP_INACTIVE; isodep_state_t cardType = ISODEP_INACTIVE;
bool fieldActivated = false; bool fieldActivated = false;
do { do {
if (cardType != ISODEP_INACTIVE) { if (cardType != ISODEP_INACTIVE) {
@ -1280,11 +1280,11 @@ static int CmdRelay(const char *Cmd) {
uint8_t atr[20] = {0}; uint8_t atr[20] = {0};
int atrLen = 0; int atrLen = 0;
if (cardType == ISODEP_NFCA) { if (cardType == ISODEP_NFCA) {
atsToEmulatedAtr(selectedCard14a.ats, atr, &atrLen); atsToEmulatedAtr(selectedCard14a.ats, atr, &atrLen);
} else if (cardType == ISODEP_NFCB) { } else if (cardType == ISODEP_NFCB) {
atqbToEmulatedAtr(selectedCard14b.atqb, selectedCard14b.cid, atr, &atrLen); atqbToEmulatedAtr(selectedCard14b.atqb, selectedCard14b.cid, atr, &atrLen);
} }
uint8_t res[22] = {0}; uint8_t res[22] = {0};
res[1] = atrLen; res[1] = atrLen;
@ -1300,21 +1300,21 @@ static int CmdRelay(const char *Cmd) {
PrintAndLogEx(INFO, ">> %s", sprint_hex(cmdbuf + 2, apduLen)); PrintAndLogEx(INFO, ">> %s", sprint_hex(cmdbuf + 2, apduLen));
} }
if (cardType == ISODEP_NFCA) { if (cardType == ISODEP_NFCA) {
if (ExchangeAPDU14a(cmdbuf + 2, apduLen, !fieldActivated, true, apduRes, sizeof(apduRes), &apduResLen) != PM3_SUCCESS) { if (ExchangeAPDU14a(cmdbuf + 2, apduLen, !fieldActivated, true, apduRes, sizeof(apduRes), &apduResLen) != PM3_SUCCESS) {
cardType = ISODEP_INACTIVE; cardType = ISODEP_INACTIVE;
mbedtls_net_close(&netCtx); mbedtls_net_close(&netCtx);
continue; continue;
} }
} else if (cardType == ISODEP_NFCB) { } else if (cardType == ISODEP_NFCB) {
if (exchange_14b_apdu(cmdbuf + 2, apduLen, !fieldActivated, true, apduRes, sizeof(apduRes), &apduResLen, 0)) { if (exchange_14b_apdu(cmdbuf + 2, apduLen, !fieldActivated, true, apduRes, sizeof(apduRes), &apduResLen, 0)) {
cardType = ISODEP_INACTIVE; cardType = ISODEP_INACTIVE;
mbedtls_net_close(&netCtx); mbedtls_net_close(&netCtx);
continue; continue;
} }
} }
fieldActivated = true; fieldActivated = true;
if (verbose) { if (verbose) {
PrintAndLogEx(INFO, "<< %s", sprint_hex(apduRes, apduResLen)); PrintAndLogEx(INFO, "<< %s", sprint_hex(apduRes, apduResLen));
@ -1328,22 +1328,22 @@ static int CmdRelay(const char *Cmd) {
} }
} }
} else { } else {
if (IfPm3Iso14443a() && SelectCard14443A_4(false, false, &selectedCard14a) == PM3_SUCCESS) { if (IfPm3Iso14443a() && SelectCard14443A_4(false, false, &selectedCard14a) == PM3_SUCCESS) {
cardType = ISODEP_NFCA; cardType = ISODEP_NFCA;
} else if (IfPm3Iso14443b() && select_card_14443b_4(false, &selectedCard14b) == PM3_SUCCESS) { } else if (IfPm3Iso14443b() && select_card_14443b_4(false, &selectedCard14b) == PM3_SUCCESS) {
cardType = ISODEP_NFCB; cardType = ISODEP_NFCB;
} }
if (cardType != ISODEP_INACTIVE) { if (cardType != ISODEP_INACTIVE) {
fieldActivated = false; fieldActivated = false;
if (mbedtls_net_connect(&netCtx, (char *) host, (char *) port, MBEDTLS_NET_PROTO_TCP)) { if (mbedtls_net_connect(&netCtx, (char *) host, (char *) port, MBEDTLS_NET_PROTO_TCP)) {
PrintAndLogEx(FAILED, "Failed to connect to vpcd socket. Ensure you have vpcd installed and running"); PrintAndLogEx(FAILED, "Failed to connect to vpcd socket. Ensure you have vpcd installed and running");
mbedtls_net_close(&netCtx); mbedtls_net_close(&netCtx);
mbedtls_net_free(&netCtx); mbedtls_net_free(&netCtx);
DropField(); DropField();
return PM3_EINVARG; return PM3_EINVARG;
} }
} }
msleep(300); msleep(300);
} }
} while (!kbd_enter_pressed()); } while (!kbd_enter_pressed());

View file

@ -791,6 +791,7 @@ const static vocabulary_t vocabulary[] = {
{ 1, "smart help" }, { 1, "smart help" },
{ 1, "smart list" }, { 1, "smart list" },
{ 0, "smart info" }, { 0, "smart info" },
{ 0, "smart relay" },
{ 0, "smart reader" }, { 0, "smart reader" },
{ 0, "smart raw" }, { 0, "smart raw" },
{ 1, "smart upgrade" }, { 1, "smart upgrade" },

View file

@ -11790,6 +11790,21 @@
], ],
"usage": "smart reader [-hv]" "usage": "smart reader [-hv]"
}, },
"smart relay": {
"command": "smart relay",
"description": "Make pm3 available to host OS smartcard driver via vpcd to enable use with other software such as GlobalPlatform Pro",
"notes": [
"Requires the virtual smartcard daemon to be installed and running, see https://frankmorgner.github.io/vsmartcard/virtualsmartcard/README.html"
],
"offline": false,
"options": [
"-h, --help This help",
"--host <str> vpcd socket host (default: localhost)",
"-p, --port <int> vpcd socket port (default: 35963)",
"-v, --verbose display APDU transactions between OS and card"
],
"usage": "smart relay [-hv] [--host <str>] [-p <int>]"
},
"smart setclock": { "smart setclock": {
"command": "smart setclock", "command": "smart setclock",
"description": "Set clock speed for smart card interface.", "description": "Set clock speed for smart card interface.",
@ -12049,8 +12064,8 @@
} }
}, },
"metadata": { "metadata": {
"commands_extracted": 698, "commands_extracted": 699,
"extracted_by": "PM3Help2JSON v1.00", "extracted_by": "PM3Help2JSON v1.00",
"extracted_on": "2023-11-09T16:29:08" "extracted_on": "2023-11-11T20:31:02"
} }
} }

View file

@ -1424,6 +1424,7 @@ Check column "offline" for their availability.
|`smart help `|Y |`This help` |`smart help `|Y |`This help`
|`smart list `|Y |`List ISO 7816 history` |`smart list `|Y |`List ISO 7816 history`
|`smart info `|N |`Tag information` |`smart info `|N |`Tag information`
|`smart relay `|N |`Turn pm3 into pcsc reader and relay to host OS via vpcd`
|`smart reader `|N |`Act like an IS07816 reader` |`smart reader `|N |`Act like an IS07816 reader`
|`smart raw `|N |`Send raw hex data to tag` |`smart raw `|N |`Send raw hex data to tag`
|`smart upgrade `|Y |`Upgrade sim module firmware` |`smart upgrade `|Y |`Upgrade sim module firmware`

View file

@ -525,7 +525,7 @@ static void *brute_thread(void *arguments) {
free(revstate); free(revstate);
continue; continue;
} }
// lock this section to avoid interlacing prints from different threats // lock this section to avoid interlacing prints from different threats
pthread_mutex_lock(&print_lock); pthread_mutex_lock(&print_lock);
if (args->ev1) { if (args->ev1) {
@ -533,11 +533,11 @@ static void *brute_thread(void *arguments) {
} }
#if 0 #if 0
printf("thread #%d idx %d %s\n", args->thread, args->idx, (args->ev1) ? "(Ev1)" : ""); printf("thread #%d idx %d %s\n", args->thread, args->idx, (args->ev1) ? "(Ev1)" : "");
printf("current nt(%08x) ar_enc(%08x) at_enc(%08x)\n", nt, ar_enc, at_enc); printf("current nt(%08x) ar_enc(%08x) at_enc(%08x)\n", nt, ar_enc, at_enc);
printf("ks2:%08x\n", ks2); printf("ks2:%08x\n", ks2);
printf("ks3:%08x\n", ks3); printf("ks3:%08x\n", ks3);
printf("ks4:%08x\n", ks4); printf("ks4:%08x\n", ks4);
#endif #endif
if (cmd_enc) { if (cmd_enc) {
uint32_t decrypted = ks4 ^ cmd_enc; uint32_t decrypted = ks4 ^ cmd_enc;
@ -681,7 +681,7 @@ int main(int argc, const char *argv[]) {
// next encrypted command + a full read/write // next encrypted command + a full read/write
int enc_len = 0; int enc_len = 0;
uint8_t enc[ENC_LEN] = {0}; uint8_t enc[ENC_LEN] = {0};
if (argc > 9) { if (argc > 9) {
param_gethex_to_eol(argv[9], 0, enc, sizeof(enc), &enc_len); param_gethex_to_eol(argv[9], 0, enc, sizeof(enc), &enc_len);
cmd_enc = (enc[0] << 24 | enc[1] << 16 | enc[2] << 8 | enc[3]); cmd_enc = (enc[0] << 24 | enc[1] << 16 | enc[2] << 8 | enc[3]);

View file

@ -235,7 +235,7 @@ uint64_t *nested(NtpKs1 *pNK, uint32_t sizePNK, uint32_t authuid, uint32_t *keyC
free(pRPs); free(pRPs);
return NULL; return NULL;
} }
for (i = 0; i < TRY_KEYS; i++) { for (i = 0; i < TRY_KEYS; i++) {
// We don't known this key, try to break it // We don't known this key, try to break it
// This key can be found here two or more times // This key can be found here two or more times

View file

@ -12,4 +12,4 @@ typedef struct {
uint8_t valid_nonce(uint32_t Nt, uint32_t NtEnc, uint32_t Ks1, uint8_t *parity); uint8_t valid_nonce(uint32_t Nt, uint32_t NtEnc, uint32_t Ks1, uint8_t *parity);
uint64_t *nested(NtpKs1 *pNK, uint32_t sizePNK, uint32_t authuid, uint32_t *keyCount); uint64_t *nested(NtpKs1 *pNK, uint32_t sizePNK, uint32_t authuid, uint32_t *keyCount);
#endif #endif

View file

@ -233,4 +233,4 @@ int main(int argc, char *const argv[]) {
exit(EXIT_SUCCESS); exit(EXIT_SUCCESS);
error: error:
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }