Adapt select_applet to new call.

Also fixes sex test.

Signed-off-by: Pol Henarejos <pol.henarejos@cttc.es>
This commit is contained in:
Pol Henarejos
2023-02-03 16:32:28 +01:00
parent 29b4aec24e
commit cf53fdd903

View File

@@ -28,7 +28,7 @@
#include "mbedtls/asn1.h" #include "mbedtls/asn1.h"
#include "asn1.h" #include "asn1.h"
#include "usb.h" #include "usb.h"
#include "ccid.h" #include "ccid/ccid.h"
bool has_pw1 = false; bool has_pw1 = false;
bool has_pw2 = false; bool has_pw2 = false;
@@ -256,6 +256,13 @@ void scan_files() {
flash_write_data_to_file(ef, def, sizeof(def)); flash_write_data_to_file(ef, def, sizeof(def));
} }
} }
if ((ef = search_by_fid(EF_SEX, NULL, SPECIFY_ANY))) {
if (!ef->data) {
printf("Sex is empty. Initializing to default\r\n");
const uint8_t def[] = { 0x30 };
flash_write_data_to_file(ef, def, sizeof(def));
}
}
low_flash_available(); low_flash_available();
} }
@@ -331,8 +338,8 @@ int heapLeft() {
return left; return left;
} }
app_t *openpgp_select_aid(app_t *a) { app_t *openpgp_select_aid(app_t *a, const uint8_t *aid, uint8_t aid_len) {
if (!memcmp(apdu.data, openpgp_aid+1, openpgp_aid[0])) { if (!memcmp(aid, openpgp_aid+1, MIN(aid_len,openpgp_aid[0]))) {
a->aid = openpgp_aid; a->aid = openpgp_aid;
a->process_apdu = openpgp_process_apdu; a->process_apdu = openpgp_process_apdu;
a->unload = openpgp_unload; a->unload = openpgp_unload;
@@ -371,7 +378,7 @@ int parse_do(uint16_t *fids, int mode) {
else else
data_len = 0; data_len = 0;
if (mode == 1) { if (mode == 1) {
if (fids[0] > 1 && res_APDU_size > 0) { if (fids[0] > 1 /*&& res_APDU_size > 0*/) {
if (fids[i+1] < 0x0100) { if (fids[i+1] < 0x0100) {
res_APDU[res_APDU_size++] = fids[i+1] & 0xff; res_APDU[res_APDU_size++] = fids[i+1] & 0xff;
} }
@@ -413,15 +420,16 @@ int parse_ch_data(const file_t *f, int mode) {
3, 3,
EF_CH_NAME, EF_LANG_PREF, EF_SEX, EF_CH_NAME, EF_LANG_PREF, EF_SEX,
}; };
res_APDU[res_APDU_size++] = EF_CH_DATA & 0xff; //res_APDU[res_APDU_size++] = EF_CH_DATA & 0xff;
res_APDU[res_APDU_size++] = 0x82; //res_APDU[res_APDU_size++] = 0x82;
uint8_t *lp = res_APDU+res_APDU_size; //uint8_t *lp = res_APDU+res_APDU_size;
res_APDU_size += 2; //res_APDU_size += 2;
parse_do(fids, mode); parse_do(fids, mode);
uint16_t lpdif = res_APDU+res_APDU_size-lp-2; //uint16_t lpdif = res_APDU+res_APDU_size-lp-2;
*lp++ = lpdif >> 8; //*lp++ = lpdif >> 8;
*lp++ = lpdif & 0xff; //*lp++ = lpdif & 0xff;
return lpdif+4; //return lpdif+4;
return res_APDU_size;
} }
int inc_sig_count() { int inc_sig_count() {
@@ -1755,12 +1763,6 @@ static int cmd_get_next_data() {
return cmd_get_data(); return cmd_get_data();
} }
typedef struct cmd
{
uint8_t ins;
int (*cmd_handler)();
} cmd_t;
#define INS_VERIFY 0x20 #define INS_VERIFY 0x20
#define INS_MSE 0x22 #define INS_MSE 0x22
#define INS_CHANGE_PIN 0x24 #define INS_CHANGE_PIN 0x24