Coverage Report

Created: 2026-06-06 06:51

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/opensc/src/libopensc/card-sc-hsm.c
Line
Count
Source
1
/*
2
 * card-sc-hsm.c
3
 *
4
 * Driver for the SmartCard-HSM, a light-weight hardware security module
5
 *
6
 * Copyright (C) 2012 Andreas Schwier, CardContact, Minden, Germany, and others
7
 * Copyright (C) 2018-2019 GSMK - Gesellschaft für Sichere Mobile Kommunikation mbH
8
 *
9
 * This library is free software; you can redistribute it and/or
10
 * modify it under the terms of the GNU Lesser General Public
11
 * License as published by the Free Software Foundation; either
12
 * version 2.1 of the License, or (at your option) any later version.
13
 *
14
 * This library is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
17
 * Lesser General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU Lesser General Public
20
 * License along with this library; if not, write to the Free Software
21
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22
 */
23
24
#ifdef HAVE_CONFIG_H
25
#include "config.h"
26
#endif
27
28
#include <string.h>
29
#include <stdlib.h>
30
#include <ctype.h>
31
32
#include "internal.h"
33
#include "asn1.h"
34
#include "cardctl.h"
35
#include "types.h"
36
37
#include "card-sc-hsm.h"
38
39
#if defined(ENABLE_SM) && defined(ENABLE_OPENPACE)
40
#include "sm/sm-eac.h"
41
#include <eac/cv_cert.h>
42
#include <eac/eac.h>
43
#include <eac/ta.h>
44
#include <openssl/evp.h>
45
#endif
46
47
48
/* Static reference to ISO driver */
49
static const struct sc_card_operations *iso_ops = NULL;
50
51
/* Our operations */
52
static struct sc_card_operations sc_hsm_ops;
53
54
/* Our driver description */
55
static struct sc_card_driver sc_hsm_drv = {
56
  "SmartCard-HSM",
57
  "sc-hsm",
58
  &sc_hsm_ops,
59
  NULL,
60
  0,
61
  NULL
62
};
63
64
65
66
/* Our AID */
67
struct sc_aid sc_hsm_aid = { { 0xE8,0x2B,0x06,0x01,0x04,0x01,0x81,0xC3,0x1F,0x02,0x01 }, 11 };
68
69
70
71
/* Known ATRs for SmartCard-HSMs */
72
const struct sc_atr_table sc_hsm_atrs[] = {
73
  /* standard version */
74
  {"3B:FE:18:00:00:81:31:FE:45:80:31:81:54:48:53:4D:31:73:80:21:40:81:07:FA", NULL, NULL, SC_CARD_TYPE_SC_HSM, 0, NULL},
75
  {"3B:8E:80:01:80:31:81:54:48:53:4D:31:73:80:21:40:81:07:18", NULL, NULL, SC_CARD_TYPE_SC_HSM, 0, NULL},
76
  {"3B:DE:18:FF:81:91:FE:1F:C3:80:31:81:54:48:53:4D:31:73:80:21:40:81:07:1C", NULL, NULL, SC_CARD_TYPE_SC_HSM, 0, NULL},
77
  {"3B:DE:96:FF:81:91:FE:1F:C3:80:31:81:54:48:53:4D:31:73:80:21:40:81:07:92", NULL, NULL, SC_CARD_TYPE_SC_HSM, 0, NULL},
78
79
  {"3B:80:80:01:01", NULL, NULL, SC_CARD_TYPE_SC_HSM_SOC, 0, NULL}, // SoC Sample Card
80
  {
81
    "3B:84:80:01:47:6f:49:44:00",
82
    "FF:FF:FF:FF:FF:FF:FF:FF:00",
83
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
84
  },
85
  {
86
    "3B:85:80:01:47:6f:49:44:00:00",
87
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00",
88
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
89
  },
90
  {
91
    "3B:86:80:01:47:6f:49:44:00:00:00",
92
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00",
93
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
94
  },
95
  {
96
    "3B:87:80:01:47:6f:49:44:00:00:00:00",
97
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00",
98
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
99
  },
100
  {
101
    "3B:88:80:01:47:6f:49:44:00:00:00:00:00",
102
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00",
103
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
104
  },
105
  {
106
    "3B:89:80:01:47:6f:49:44:00:00:00:00:00:00",
107
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00",
108
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
109
  },
110
  {
111
    "3B:8a:80:01:47:6f:49:44:00:00:00:00:00:00:00",
112
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00:00",
113
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
114
  },
115
  {
116
    "3B:8b:80:01:47:6f:49:44:00:00:00:00:00:00:00:00",
117
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00:00:00",
118
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
119
  },
120
  {
121
    "3B:8c:80:01:47:6f:49:44:00:00:00:00:00:00:00:00:00",
122
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00:00:00:00",
123
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
124
  },
125
  {
126
    "3B:8d:80:01:47:6f:49:44:00:00:00:00:00:00:00:00:00:00",
127
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00:00:00:00:00",
128
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
129
  },
130
  {
131
    "3B:8e:80:01:47:6f:49:44:00:00:00:00:00:00:00:00:00:00:00",
132
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00:00:00:00:00:00",
133
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
134
  },
135
  {
136
    "3B:8f:80:01:47:6f:49:44:00:00:00:00:00:00:00:00:00:00:00:00",
137
    "FF:FF:FF:FF:FF:FF:FF:FF:00:00:00:00:00:00:00:00:00:00:00:00",
138
    "GoID", SC_CARD_TYPE_SC_HSM_GOID, 0, NULL
139
  },
140
  {NULL, NULL, NULL, 0, 0, NULL}
141
};
142
143
144
145
static int sc_hsm_select_file_ex(sc_card_t *card,
146
             const sc_path_t *in_path, int forceselect,
147
             sc_file_t **file_out)
148
6.37k
{
149
6.37k
  int rv;
150
6.37k
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
151
6.37k
  sc_file_t *file = NULL;
152
6.37k
  sc_path_t cpath;
153
6.37k
  size_t card_max_recv_size = card->max_recv_size;
154
6.37k
  size_t reader_max_recv_size = card->reader->max_recv_size;
155
156
6.37k
  if (file_out == NULL) {       // Versions before 0.16 of the SmartCard-HSM do not support P2='0C'
157
542
    rv = sc_hsm_select_file_ex(card, in_path, forceselect, &file);
158
542
    sc_file_free(file);
159
542
    return rv;
160
542
  }
161
162
5.83k
  if ((in_path->type == SC_PATH_TYPE_FILE_ID) && in_path->aid.len) {
163
    // Split applet selection and file selection into two separate calls
164
0
    cpath = *in_path;
165
0
    cpath.len = 0;
166
0
    cpath.type = SC_PATH_TYPE_DF_NAME;
167
0
    rv = sc_hsm_select_file_ex(card, &cpath, forceselect, NULL);
168
0
    LOG_TEST_RET(card->ctx, rv, "Could not select SmartCard-HSM application");
169
170
0
    if (in_path->len) {
171
0
      cpath = *in_path;
172
0
      cpath.aid.len = 0;
173
0
      rv = sc_hsm_select_file_ex(card, &cpath, forceselect, file_out);
174
0
    }
175
0
    return rv;
176
0
  }
177
178
  // Prevent selection of applet unless this is the first time, selection is forced or the device is not authenticated
179
5.83k
  if (in_path->type == SC_PATH_TYPE_DF_NAME
180
593
      || (in_path->type == SC_PATH_TYPE_PATH
181
530
        && in_path->len == sc_hsm_aid.len
182
0
        && !memcmp(in_path->value, sc_hsm_aid.value, sc_hsm_aid.len))
183
593
      || (in_path->type == SC_PATH_TYPE_PATH
184
530
        && in_path->len == 0
185
2
        && in_path->aid.len == sc_hsm_aid.len
186
5.23k
        && !memcmp(in_path->aid.value, sc_hsm_aid.value, sc_hsm_aid.len))) {
187
5.23k
    if (!priv || (priv->dffcp == NULL) || forceselect) {
188
      /* Force use of Le = 0x00 in iso7816_select_file as required by SC-HSM */
189
5.08k
      card->max_recv_size = card->reader->max_recv_size = SC_READER_SHORT_APDU_MAX_RECV_SIZE;
190
5.08k
      rv = (*iso_ops->select_file)(card, in_path, file_out);
191
5.08k
      card->max_recv_size = card_max_recv_size;
192
5.08k
      card->reader->max_recv_size = reader_max_recv_size;
193
5.08k
      LOG_TEST_RET(card->ctx, rv, "Could not select SmartCard-HSM application");
194
195
306
      if (priv) {
196
101
        sc_file_free(priv->dffcp);
197
        // Cache the FCP returned when selecting the applet
198
101
        sc_file_dup(&priv->dffcp, *file_out);
199
101
      }
200
306
    } else {
201
157
      sc_file_dup(file_out, priv->dffcp);
202
157
      rv = SC_SUCCESS;
203
157
    }
204
463
    return rv;
205
5.23k
  }
206
207
593
  if ((in_path->len >= 2) && (in_path->value[0] == 0x3F) && (in_path->value[1] == 0x00)) {
208
    // The SmartCard-HSM is an applet that is not default selected. Simulate selection of the MF
209
439
    if (in_path->len == 2) {
210
1
      file = sc_file_new();
211
1
      if (file == NULL)
212
1
        LOG_FUNC_RETURN(card->ctx, SC_ERROR_OUT_OF_MEMORY);
213
1
      file->path = *in_path;
214
1
      file->id = 0x3F00;
215
1
      file->type = SC_FILE_TYPE_DF;
216
1
      file->magic = SC_FILE_MAGIC;
217
218
1
      *file_out = file;
219
1
      return SC_SUCCESS;
220
438
    } else {
221
      /* Force use of Le = 0x00 in iso7816_select_file as required by SC-HSM */
222
438
      card->max_recv_size = card->reader->max_recv_size = SC_READER_SHORT_APDU_MAX_RECV_SIZE;
223
438
      sc_path_t truncated;
224
438
      memcpy(&truncated, in_path, sizeof truncated);
225
438
      truncated.len = in_path->len - 2;
226
438
      memcpy(truncated.value, in_path->value+2, truncated.len);
227
438
      rv = (*iso_ops->select_file)(card, &truncated, file_out);
228
438
      card->max_recv_size = card_max_recv_size;
229
438
      card->reader->max_recv_size = reader_max_recv_size;
230
438
      return rv;
231
438
    }
232
439
  }
233
  /* Force use of Le = 0x00 in iso7816_select_file as required by SC-HSM */
234
154
  card->max_recv_size = card->reader->max_recv_size = SC_READER_SHORT_APDU_MAX_RECV_SIZE;
235
154
  rv = (*iso_ops->select_file)(card, in_path, file_out);
236
154
  card->max_recv_size = card_max_recv_size;
237
154
  card->reader->max_recv_size = reader_max_recv_size;
238
154
  return rv;
239
593
}
240
241
242
243
static int sc_hsm_select_file(sc_card_t *card,
244
             const sc_path_t *in_path,
245
             sc_file_t **file_out)
246
5.66k
{
247
5.66k
  return sc_hsm_select_file_ex(card, in_path, 0, file_out);
248
5.66k
}
249
250
251
252
static int sc_hsm_get_challenge(struct sc_card *card, unsigned char *rnd, size_t len)
253
0
{
254
0
  LOG_FUNC_CALLED(card->ctx);
255
256
0
  if (len > 1024) {
257
0
    len = 1024;
258
0
  }
259
260
0
  LOG_FUNC_RETURN(card->ctx, iso_ops->get_challenge(card, rnd, len));
261
0
}
262
263
264
265
static int sc_hsm_match_card(struct sc_card *card)
266
4.74k
{
267
4.74k
  sc_path_t path;
268
4.74k
  int i, r, type = 0;
269
4.74k
  sc_file_t *file = NULL;
270
271
4.74k
  i = _sc_match_atr(card, sc_hsm_atrs, &type);
272
4.74k
  if (i >= 0 && type != SC_CARD_TYPE_SC_HSM_SOC) {
273
169
    card->type = type;
274
169
    return 1;
275
169
  }
276
277
4.57k
  sc_path_set(&path, SC_PATH_TYPE_DF_NAME, sc_hsm_aid.value, sc_hsm_aid.len, 0, 0);
278
4.57k
  r = sc_hsm_select_file(card, &path, &file);
279
4.57k
  LOG_TEST_RET(card->ctx, r, "Could not select SmartCard-HSM application");
280
281
  // Validate that card returns a FCP with a proprietary tag 85 with value longer than 2 byte (Fixes #1377)
282
205
  if (file != NULL) {
283
205
    size_t sz = file->prop_attr_len;
284
205
    sc_file_free(file);
285
205
    if (sz < 2) {
286
203
      return 0;
287
203
    }
288
205
  }
289
290
2
  if (type == SC_CARD_TYPE_SC_HSM_SOC) {
291
0
    card->type = SC_CARD_TYPE_SC_HSM_SOC;
292
2
  } else {
293
2
    card->type = SC_CARD_TYPE_SC_HSM;
294
2
  }
295
296
2
  return 1;
297
205
}
298
299
300
301
/*
302
 * Encode 16 hexadecimals of SO-PIN into binary form
303
 * Caller must check length of sopin and provide an 8 byte buffer
304
 */
305
static int sc_hsm_encode_sopin(const u8 *sopin, u8 *sopinbin)
306
0
{
307
0
  int i;
308
0
  unsigned char digit;
309
310
0
  memset(sopinbin, 0, 8);
311
0
  for (i = 0; i < 16; i++) {
312
0
    *sopinbin <<= 4;
313
0
    digit = *sopin++;
314
315
0
    if (!isxdigit(digit))
316
0
      return SC_ERROR_PIN_CODE_INCORRECT;
317
0
    digit = toupper(digit);
318
319
0
    if (digit >= 'A')
320
0
      digit = digit - 'A' + 10;
321
0
    else
322
0
      digit = digit & 0xF;
323
324
0
    *sopinbin |= digit & 0xf;
325
0
    if (i & 1)
326
0
      sopinbin++;
327
0
  }
328
0
  return SC_SUCCESS;
329
0
}
330
331
332
static int sc_hsm_soc_select_minbioclient(sc_card_t *card)
333
0
{
334
0
  static const struct sc_aid minBioClient_aid = {
335
0
      {0xFF, 'm', 'i', 'n', 'B', 'i', 'o', 'C', 'l', 'i', 'e', 'n', 't', 0x01},
336
0
      14
337
0
    };
338
339
  /* Select MinBioClient */
340
0
#ifdef ENABLE_SM
341
0
  sc_sm_stop(card);
342
0
#endif
343
0
  return iso7816_select_aid(card, minBioClient_aid.value, minBioClient_aid.len, NULL, NULL);
344
0
}
345
346
static int sc_hsm_soc_change(sc_card_t *card, struct sc_pin_cmd_data *data)
347
0
{
348
0
  sc_apdu_t apdu;
349
0
  sc_path_t path;
350
0
  int r;
351
352
0
  if (card->type == SC_CARD_TYPE_SC_HSM_SOC) {
353
    /* Select MinBioClient */
354
0
    r = sc_hsm_soc_select_minbioclient(card);
355
0
    LOG_TEST_RET(card->ctx, r, "Could not select MinBioClient application");
356
357
    /* verify PIN */
358
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x20, 0x00, 0x80);
359
0
    r = sc_transmit_apdu(card, &apdu);
360
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "APDU transmit failed");
361
0
    r = sc_check_sw(card, apdu.sw1, apdu.sw2);
362
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "Could not verify PIN");
363
364
    /* change PIN */
365
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x24, 0x01, 0x80);
366
0
    r = sc_transmit_apdu(card, &apdu);
367
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "APDU transmit failed");
368
0
    r = sc_check_sw(card, apdu.sw1, apdu.sw2);
369
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "Could not change PIN");
370
0
  } else {
371
0
#ifdef ENABLE_SM
372
0
    unsigned sm_mode = card->sm_ctx.sm_mode;
373
0
#endif
374
375
    /* verify PIN */
376
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x20, 0x00, 0x85);
377
0
    apdu.cla = 0x80;
378
0
    r = sc_transmit_apdu(card, &apdu);
379
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "APDU transmit failed");
380
381
0
#ifdef ENABLE_SM
382
    /* temporary disable SM, change reference data does not reach the applet */
383
0
    card->sm_ctx.sm_mode = SM_MODE_NONE;
384
0
#endif
385
386
    /* change PIN */
387
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x24, 0x01, 0x85);
388
0
    apdu.cla = 0x80;
389
0
    r = sc_transmit_apdu(card, &apdu);
390
0
#ifdef ENABLE_SM
391
    /* restore SM if possible */
392
0
    card->sm_ctx.sm_mode = sm_mode;
393
0
#endif
394
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "APDU transmit failed");
395
0
    r = sc_check_sw(card, apdu.sw1, apdu.sw2);
396
0
    LOG_TEST_GOTO_ERR(card->ctx, r, "Could not change PIN");
397
0
  }
398
399
0
err:
400
0
  if (card->type == SC_CARD_TYPE_SC_HSM_SOC) {
401
    /* Select SC-HSM */
402
0
    sc_path_set(&path, SC_PATH_TYPE_DF_NAME,
403
0
          sc_hsm_aid.value, sc_hsm_aid.len, 0, 0);
404
0
    LOG_TEST_RET(card->ctx,
405
0
        sc_hsm_select_file_ex(card, &path, 1, NULL),
406
0
        "Could not select SmartCard-HSM application");
407
0
  }
408
409
0
  return r;
410
0
}
411
412
static int sc_hsm_soc_unblock(sc_card_t *card, struct sc_pin_cmd_data *data)
413
0
{
414
0
  sc_apdu_t apdu;
415
0
  sc_path_t path;
416
0
  int r;
417
418
0
  if (card->type == SC_CARD_TYPE_SC_HSM_GOID) {
419
0
    return SC_ERROR_NOT_SUPPORTED;
420
0
  }
421
422
  /* Select MinBioClient */
423
0
  r = sc_hsm_soc_select_minbioclient(card);
424
0
  LOG_TEST_RET(card->ctx, r, "Could not select MinBioClient application");
425
426
  /* verify PUK */
427
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x20, 0x00, 0x81);
428
0
  r = sc_transmit_apdu(card, &apdu);
429
0
  LOG_TEST_GOTO_ERR(card->ctx, r, "APDU transmit failed");
430
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
431
0
  LOG_TEST_GOTO_ERR(card->ctx, r, "Could not verify PUK");
432
433
  /* reset retry counter */
434
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x2c, 0x03, 0x00);
435
0
  r = sc_transmit_apdu(card, &apdu);
436
0
  LOG_TEST_GOTO_ERR(card->ctx, r, "APDU transmit failed");
437
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
438
0
  LOG_TEST_GOTO_ERR(card->ctx, r, "Could not unblock PIN");
439
440
0
err:
441
  /* Select SC-HSM */
442
0
  sc_path_set(&path, SC_PATH_TYPE_DF_NAME, sc_hsm_aid.value, sc_hsm_aid.len, 0, 0);
443
0
  LOG_TEST_RET(card->ctx,
444
0
      sc_hsm_select_file_ex(card, &path, 1, NULL),
445
0
      "Could not select SmartCard-HSM application");
446
447
0
  return r;
448
0
}
449
450
static int sc_hsm_soc_biomatch(sc_card_t *card, struct sc_pin_cmd_data *data)
451
0
{
452
0
  sc_apdu_t apdu;
453
0
  u8 rbuf[SC_MAX_APDU_BUFFER_SIZE];
454
0
  int r;
455
456
0
  if (card->type == SC_CARD_TYPE_SC_HSM_SOC) {
457
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_3_SHORT, 0x20, 0x00, 0x85);
458
0
    apdu.cla = 0x80;
459
0
    apdu.data = (unsigned char*)"\x7F\x24\x00";
460
0
    apdu.datalen = 3;
461
0
    apdu.lc = 3;
462
0
    apdu.resplen = 0;
463
464
0
    r = sc_transmit_apdu(card, &apdu);
465
0
    LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
466
    /* ignore the actual status bytes */
467
0
  }
468
469
  /* JCOP's SM accelerator is incapable of using case 1 APDU in SM */
470
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_2, 0x20, 0x00, 0x81);
471
0
  if (card->type == SC_CARD_TYPE_SC_HSM_GOID) {
472
0
    apdu.cla = 0x80;
473
0
  }
474
0
  apdu.resp = rbuf;
475
0
  apdu.resplen = sizeof rbuf;
476
0
  r = sc_transmit_apdu(card, &apdu);
477
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
478
479
  /* now check the status bytes */
480
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
481
0
  if (r == SC_SUCCESS) {
482
0
    LOG_FUNC_RETURN(card->ctx, r);
483
0
  }
484
485
0
  LOG_FUNC_RETURN(card->ctx, SC_ERROR_PIN_CODE_INCORRECT);
486
0
}
487
488
#if defined(ENABLE_SM) && defined(ENABLE_OPENPACE)
489
490
static int sc_hsm_perform_chip_authentication(sc_card_t *card)
491
0
{
492
0
  int r, protocol;
493
0
  sc_path_t path;
494
0
  u8 all_certs[1024];
495
0
  EAC_CTX *ctx = NULL;
496
0
  size_t all_certs_len = sizeof all_certs, left, device_cert_len, issuer_cert_len;
497
0
  const unsigned char *cert = all_certs, *device_cert, *issuer_cert;
498
0
  BUF_MEM *comp_pub_key = NULL;
499
0
  sc_cvc_t cvc_device, cvc_issuer;
500
  /* this is only needed to call sc_pkcs15emu_sc_hsm_decode_cvc */
501
0
  sc_pkcs15_card_t p15card;
502
0
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
503
  /* we know that sc_pkcs15emu_sc_hsm_decode_cvc does not require anything
504
   * else to be initialized than p15card->card */
505
0
  p15card.card = card;
506
507
0
  memset(&cvc_device, 0, sizeof(cvc_device));
508
0
  memset(&cvc_issuer, 0, sizeof(cvc_issuer));
509
510
511
0
  if (priv->EF_C_DevAut && priv->EF_C_DevAut_len) {
512
0
    all_certs_len = priv->EF_C_DevAut_len;
513
0
    cert = priv->EF_C_DevAut;
514
0
  } else {
515
    /* get issuer and device certificate from the card */
516
0
    r = sc_path_set(&path, SC_PATH_TYPE_FILE_ID, (u8 *) "\x2F\x02", 2, 0, 0);
517
0
    if (r < 0)
518
0
      goto err;
519
0
    r = sc_select_file(card, &path, NULL);
520
0
    if (r < 0)
521
0
      goto err;
522
0
    r = sc_read_binary(card, 0, all_certs, all_certs_len, 0);
523
0
    if (r < 0)
524
0
      goto err;
525
0
    if (r == 0) {
526
0
      r = SC_ERROR_FILE_NOT_FOUND;
527
0
      goto err;
528
0
    }
529
530
0
    all_certs_len = r;
531
532
    /* save EF_C_DevAut for further use */
533
0
    cert = realloc(priv->EF_C_DevAut, all_certs_len);
534
0
    if (cert) {
535
0
      memcpy((unsigned char *) cert, all_certs, all_certs_len);
536
0
      priv->EF_C_DevAut = (unsigned char *) cert;
537
0
      priv->EF_C_DevAut_len = all_certs_len;
538
0
    }
539
540
0
    cert = all_certs;
541
0
  }
542
0
  left = all_certs_len;
543
544
0
  device_cert = cert;
545
0
  r = sc_pkcs15emu_sc_hsm_decode_cvc(&p15card, &cert, &left, &cvc_device);
546
0
  if (r < 0)
547
0
    goto err;
548
0
  device_cert_len = all_certs_len - left;
549
550
0
  issuer_cert = cert;
551
0
  r = sc_pkcs15emu_sc_hsm_decode_cvc(&p15card, &cert, &left, &cvc_issuer);
552
0
  if (r < 0)
553
0
    goto err;
554
0
  issuer_cert_len = all_certs_len - device_cert_len - left;
555
556
0
  ctx = EAC_CTX_new();
557
0
  if (!ctx) {
558
0
    r = SC_ERROR_INTERNAL;
559
0
    goto err;
560
0
  }
561
562
563
  /* check all CVCs given of the document's pki */
564
0
  if (!TA_STEP2_import_certificate(ctx, issuer_cert, issuer_cert_len)
565
0
      || !TA_STEP2_import_certificate(ctx, device_cert, device_cert_len)) {
566
0
    r = SC_ERROR_INTERNAL;
567
0
    goto err;
568
0
  }
569
570
  /* XXX on older JCOPs only NID_id_CA_ECDH_3DES_CBC_CBC may be
571
   * supported. The card does not export its capabilities. We hardcode
572
   * NID_id_CA_ECDH_AES_CBC_CMAC_128 here, because we don't have the older
573
   * cards in production. */
574
0
  protocol = NID_id_CA_ECDH_AES_CBC_CMAC_128;
575
576
  /* initialize CA domain parameter with the document's public key */
577
0
  if (!EAC_CTX_init_ca(ctx, protocol, 8)) {
578
0
    r = SC_ERROR_INTERNAL;
579
0
    goto err;
580
0
  }
581
0
  EVP_PKEY_free(ctx->ca_ctx->ka_ctx->key);
582
0
  if (!EVP_PKEY_up_ref(ctx->ta_ctx->pub_key)) {
583
0
    sc_log_openssl(card->ctx);
584
0
    r = SC_ERROR_INTERNAL;
585
0
    goto err;
586
0
  }
587
0
  ctx->ca_ctx->ka_ctx->key = ctx->ta_ctx->pub_key;
588
589
  /* generate keys for CA */
590
0
  comp_pub_key = TA_STEP3_generate_ephemeral_key(ctx);
591
0
  r = perform_chip_authentication_ex(card, ctx,
592
0
      cvc_device.publicPoint, cvc_device.publicPointlen);
593
594
0
err:
595
0
  if (r < 0)
596
0
    EAC_CTX_clear_free(ctx);
597
0
  if (comp_pub_key)
598
0
    BUF_MEM_free(comp_pub_key);
599
0
  sc_pkcs15emu_sc_hsm_free_cvc(&cvc_device);
600
0
  sc_pkcs15emu_sc_hsm_free_cvc(&cvc_issuer);
601
602
0
  return r;
603
0
}
604
605
#else
606
607
static int sc_hsm_perform_chip_authentication(sc_card_t *card)
608
{
609
  return SC_ERROR_NOT_SUPPORTED;
610
}
611
#endif
612
613
614
615
static int sc_hsm_pin_cmd(sc_card_t *card, struct sc_pin_cmd_data *data)
616
37
{
617
37
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
618
37
  sc_apdu_t apdu;
619
37
  u8 cmdbuff[16];
620
37
#ifdef ENABLE_SM
621
37
  u8 rbuf[SC_MAX_APDU_BUFFER_SIZE];
622
37
#endif
623
37
  int r;
624
37
  int cmd = data->cmd;
625
37
  size_t pin2_len = data->pin2.len;
626
627
37
  if (cmd == SC_PIN_CMD_GET_SESSION_PIN) {
628
    /* First, perform a standard VERIFY */
629
0
    data->cmd = SC_PIN_CMD_VERIFY;
630
    /* we assign pin2.len to 0 early on so that in case of an error we are
631
     * not exiting with an undefined session PIN */
632
0
    data->pin2.len = 0;
633
0
  }
634
635
37
  if ((card->caps & SC_CARD_CAP_PROTECTED_AUTHENTICATION_PATH)
636
0
        && (data->cmd == SC_PIN_CMD_CHANGE)
637
0
        && (data->pin_reference == 0x81)
638
0
      && (!data->pin1.data || data->pin1.len <= 0)) {
639
0
    return sc_hsm_soc_change(card, data);
640
37
  } else if ((card->caps & SC_CARD_CAP_PROTECTED_AUTHENTICATION_PATH)
641
0
        && (data->cmd == SC_PIN_CMD_UNBLOCK)
642
0
        && (data->pin_reference == 0x81)
643
0
      && (!data->pin1.data || data->pin1.len <= 0)) {
644
0
    return sc_hsm_soc_unblock(card, data);
645
0
  }
646
647
37
#ifdef ENABLE_SM
648
  /* For contactless cards always establish a secure channel before PIN
649
   * verification. Also, Session PIN generation requires SM. */
650
37
  if ((card->type == SC_CARD_TYPE_SC_HSM_SOC
651
37
        || card->type == SC_CARD_TYPE_SC_HSM_GOID
652
0
        || card->reader->uid.len || cmd == SC_PIN_CMD_GET_SESSION_PIN)
653
37
      && (data->cmd != SC_PIN_CMD_GET_INFO)) {
654
0
    struct sc_pin_cmd_data check_sm_pin_data;
655
0
    memset(&check_sm_pin_data, 0, sizeof(check_sm_pin_data));
656
0
    check_sm_pin_data.cmd = SC_PIN_CMD_GET_INFO;
657
0
    check_sm_pin_data.pin_type = data->pin_type;
658
0
    check_sm_pin_data.pin_reference = data->pin_reference;
659
660
0
    r = SC_ERROR_NOT_ALLOWED;
661
0
    if (card->sm_ctx.sm_mode == SM_MODE_TRANSMIT) {
662
      /* check if the existing SM channel is still valid */
663
0
      r = sc_pin_cmd(card, &check_sm_pin_data);
664
0
    }
665
0
    if (r == SC_ERROR_ASN1_OBJECT_NOT_FOUND || r == SC_ERROR_NOT_ALLOWED) {
666
      /* need to establish a new SM channel */
667
0
      LOG_TEST_RET(card->ctx,
668
0
          sc_hsm_perform_chip_authentication(card),
669
0
          "Could not perform chip authentication");
670
0
    }
671
0
  }
672
37
#endif
673
674
37
  if ((card->caps & SC_CARD_CAP_PROTECTED_AUTHENTICATION_PATH)
675
0
      && (data->cmd == SC_PIN_CMD_VERIFY)
676
0
      && (data->pin_reference == 0x81)
677
0
      && (!data->pin1.data || data->pin1.len <= 0)) {
678
0
    r = sc_hsm_soc_biomatch(card, data);
679
37
  } else {
680
37
    if ((data->cmd == SC_PIN_CMD_VERIFY) && (data->pin_reference == 0x88)) {
681
0
      if (data->pin1.len != 16)
682
0
        return SC_ERROR_INVALID_PIN_LENGTH;
683
684
      // Save SO PIN for later use in sc_hsm_init_pin()
685
0
      r = sc_hsm_encode_sopin(data->pin1.data, priv->sopin);
686
0
      LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
687
688
0
      LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
689
0
    }
690
691
37
    if ((data->cmd == SC_PIN_CMD_CHANGE) && (data->pin_reference == 0x88)) {
692
0
      if ((data->pin1.len != 16) || (data->pin2.len != 16))
693
0
        return SC_ERROR_INVALID_PIN_LENGTH;
694
695
0
      r = sc_hsm_encode_sopin(data->pin1.data, cmdbuff);
696
0
      LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
697
698
0
      r = sc_hsm_encode_sopin(data->pin2.data, cmdbuff + 8);
699
0
      LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
700
701
0
      sc_format_apdu(card, &apdu, SC_APDU_CASE_3_SHORT, 0x24, 0x00, data->pin_reference);
702
0
      apdu.data = cmdbuff;
703
0
      apdu.datalen = sizeof(cmdbuff);
704
0
      apdu.lc = 16;
705
0
      apdu.resplen = 0;
706
0
      data->apdu = &apdu;
707
0
    }
708
709
37
#ifdef ENABLE_SM
710
37
    if ((data->cmd == SC_PIN_CMD_GET_INFO)
711
37
        && (card->sm_ctx.sm_mode == SM_MODE_TRANSMIT)) {
712
      /* JCOP's SM accelerator is incapable of using case 1 APDU in SM */
713
0
      sc_format_apdu(card, &apdu, SC_APDU_CASE_2, 0x20, 0x00, data->pin_reference);
714
0
      apdu.resp = rbuf;
715
0
      apdu.resplen = sizeof rbuf;
716
0
      data->apdu = &apdu;
717
0
    }
718
37
#endif
719
720
37
    data->pin1.offset = 5;
721
37
    data->pin2.offset = 5;
722
723
37
    r = (*iso_ops->pin_cmd)(card, data);
724
37
    data->apdu = NULL;
725
37
  }
726
37
  LOG_TEST_RET(card->ctx, r, "Verification failed");
727
728
5
  if (cmd == SC_PIN_CMD_GET_SESSION_PIN) {
729
    /* reset data->cmd to its original value */
730
0
    data->cmd = SC_PIN_CMD_GET_SESSION_PIN;
731
0
    if (data->pin_reference == 0x81) {
732
0
      u8 recvbuf[SC_MAX_APDU_BUFFER_SIZE];
733
0
#ifdef ENABLE_SM
734
0
      if (card->sm_ctx.sm_mode != SM_MODE_TRANSMIT) {
735
0
        sc_log(card->ctx,
736
0
            "Session PIN generation only supported in SM");
737
0
        LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
738
0
      }
739
#else
740
      sc_log(card->ctx,
741
          "Session PIN generation only supported in SM");
742
      LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
743
#endif
744
0
      sc_format_apdu(card, &apdu, SC_APDU_CASE_2_SHORT, 0x5A, 0x01, data->pin_reference);
745
0
      apdu.cla = 0x80;
746
0
      apdu.resp = recvbuf;
747
0
      apdu.resplen = sizeof recvbuf;
748
0
      apdu.le = 0;
749
0
      if (sc_transmit_apdu(card, &apdu) != SC_SUCCESS
750
0
          || sc_check_sw(card, apdu.sw1, apdu.sw2) != SC_SUCCESS) {
751
0
        sc_log(card->ctx,
752
0
            "Generating session PIN failed");
753
0
        LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
754
0
      }
755
0
      if (data->pin2.data && pin2_len > 0) {
756
0
        if (pin2_len >= apdu.resplen) {
757
0
          memcpy((unsigned char *) data->pin2.data, apdu.resp,
758
0
              apdu.resplen);
759
0
          data->pin2.len = apdu.resplen;
760
0
        } else {
761
0
          sc_log(card->ctx,
762
0
              "Buffer too small for session PIN");
763
0
        }
764
0
      }
765
0
    } else {
766
0
      sc_log(card->ctx,
767
0
          "Session PIN not supported for this PIN (0x%02X)",
768
0
          data->pin_reference);
769
0
    }
770
0
  }
771
5
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
772
5
}
773
774
775
776
static int sc_hsm_logout(sc_card_t * card)
777
0
{
778
0
  sc_path_t path;
779
0
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
780
0
  memset(priv->sopin, 0, sizeof(priv->sopin));
781
0
#ifdef ENABLE_SM
782
0
  sc_sm_stop(card);
783
0
#endif
784
785
0
  sc_path_set(&path, SC_PATH_TYPE_DF_NAME, sc_hsm_aid.value, sc_hsm_aid.len, 0, 0);
786
787
0
  return sc_hsm_select_file_ex(card, &path, 1, NULL);
788
0
}
789
790
791
/* NOTE: idx is an offset into the card's file, not into buf */
792
static int sc_hsm_read_binary(sc_card_t *card,
793
             unsigned int idx, u8 *buf, size_t count,
794
             unsigned long *flags)
795
424
{
796
424
  sc_context_t *ctx = card->ctx;
797
424
  sc_apdu_t apdu;
798
424
  u8 cmdbuff[4];
799
424
  int r;
800
801
424
  if (idx > 0xffff) {
802
0
    sc_log(ctx,  "invalid EF offset: 0x%X > 0xFFFF", idx);
803
0
    return SC_ERROR_OFFSET_TOO_LARGE;
804
0
  }
805
806
424
  cmdbuff[0] = 0x54;
807
424
  cmdbuff[1] = 0x02;
808
424
  cmdbuff[2] = (idx >> 8) & 0xFF;
809
424
  cmdbuff[3] = idx & 0xFF;
810
811
424
  if (count > sc_get_max_recv_size(card))
812
0
    return SC_ERROR_INTERNAL;
813
424
  sc_format_apdu(card, &apdu, SC_APDU_CASE_4, 0xB1, 0x00, 0x00);
814
424
  apdu.data = cmdbuff;
815
424
  apdu.datalen = 4;
816
424
  apdu.lc = 4;
817
424
  apdu.le = count;
818
424
  apdu.resplen = count;
819
424
  apdu.resp = buf;
820
821
424
  r = sc_transmit_apdu(card, &apdu);
822
424
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
823
824
414
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
825
414
  if (r != SC_ERROR_FILE_END_REACHED) {
826
373
    LOG_TEST_RET(ctx, r, "Check SW error");
827
373
  }
828
829
327
  LOG_FUNC_RETURN(ctx, (int)apdu.resplen);
830
327
}
831
832
833
/* NOTE: idx is an offset into the card's file, not into buf */
834
static int sc_hsm_write_ef(sc_card_t *card,
835
             int fid,
836
             unsigned int idx, const u8 *buf, size_t count)
837
0
{
838
0
  sc_context_t *ctx = card->ctx;
839
0
  sc_apdu_t apdu;
840
0
  u8 *cmdbuff, *p;
841
0
  size_t len;
842
0
  int r;
843
844
0
  if (idx > 0xffff) {
845
0
    sc_log(ctx,  "invalid EF offset: 0x%X > 0xFFFF", idx);
846
0
    return SC_ERROR_OFFSET_TOO_LARGE;
847
0
  }
848
849
0
  cmdbuff = malloc(8 + count);
850
0
  if (!cmdbuff) {
851
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_OUT_OF_MEMORY);
852
0
  }
853
854
0
  size_t bytes_left = count;
855
  // 8 bytes are required for T54(4) and T53(4)
856
0
  size_t blk_size = card->max_send_size - 8;
857
0
  size_t to_send = 0;
858
0
  size_t file_offset = (size_t) idx;
859
0
  size_t offset = 0;
860
0
  do {
861
0
    to_send = bytes_left >= blk_size ? blk_size : bytes_left;
862
0
    p = cmdbuff;
863
    // ASN1 0x54 offset
864
0
    *p++ = 0x54;
865
0
    *p++ = 0x02;
866
0
    *p++ = (file_offset >> 8) & 0xFF;
867
0
    *p++ = file_offset & 0xFF;
868
    // ASN1 0x53 to_send
869
0
    *p++ = 0x53;
870
0
    if (to_send < 128) {
871
0
      *p++ = (u8)to_send;
872
0
      len = 6;
873
0
    } else if (to_send < 256) {
874
0
      *p++ = 0x81;
875
0
      *p++ = (u8)to_send;
876
0
      len = 7;
877
0
    } else {
878
0
      *p++ = 0x82;
879
0
      *p++ = (to_send >> 8) & 0xFF;
880
0
      *p++ = to_send & 0xFF;
881
0
      len = 8;
882
0
    }
883
884
0
    if (buf != NULL)
885
0
      memcpy(p, buf+offset, to_send);
886
0
    len += to_send;
887
888
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_3, 0xD7, fid >> 8, fid & 0xFF);
889
0
    apdu.data = cmdbuff;
890
0
    apdu.datalen = len;
891
0
    apdu.lc = len;
892
893
0
    r = sc_transmit_apdu(card, &apdu);
894
0
    LOG_TEST_GOTO_ERR(ctx, r, "APDU transmit failed");
895
0
    r = sc_check_sw(card, apdu.sw1, apdu.sw2);
896
0
    LOG_TEST_GOTO_ERR(ctx, r, "Check SW error");
897
898
0
    bytes_left -= to_send;
899
0
    offset += to_send;
900
0
    file_offset += to_send;
901
0
  } while (0 < bytes_left);
902
903
0
err:
904
0
  free(cmdbuff);
905
906
0
  LOG_FUNC_RETURN(ctx, (int)count);
907
0
}
908
909
910
static int sc_hsm_update_binary(sc_card_t *card,
911
             unsigned int idx, const u8 *buf, size_t count,
912
             unsigned long flags)
913
0
{
914
0
  return sc_hsm_write_ef(card, 0, idx, buf, count);
915
0
}
916
917
918
919
static int sc_hsm_list_files(sc_card_t *card, u8 * buf, size_t buflen)
920
0
{
921
0
  sc_apdu_t apdu;
922
0
  u8 recvbuf[MAX_EXT_APDU_LENGTH];
923
0
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
924
0
  int r;
925
926
0
  if (priv->noExtLength) {
927
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_2, 0x58, 0, 0);
928
0
  } else {
929
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_2_EXT, 0x58, 0, 0);
930
0
  }
931
0
  apdu.cla = 0x80;
932
0
  apdu.resp = recvbuf;
933
0
  apdu.resplen = sizeof(recvbuf);
934
0
  apdu.le = 0;
935
0
  r = sc_transmit_apdu(card, &apdu);
936
937
0
  if ((r == SC_ERROR_TRANSMIT_FAILED) && (!priv->noExtLength)) {
938
0
    sc_log(card->ctx, "No extended length support ? Trying fall-back to short APDUs, probably breaking support for RSA 2048 operations");
939
0
    priv->noExtLength = 1;
940
0
    card->max_send_size = 248;    // 255 - 7 because of TLV in odd ins UPDATE BINARY
941
0
    return sc_hsm_list_files(card, buf, buflen);
942
0
  }
943
0
  LOG_TEST_RET(card->ctx, r, "ENUMERATE OBJECTS APDU transmit failed");
944
945
0
  if (buflen < apdu.resplen)
946
0
    memcpy(buf, recvbuf, buflen);
947
0
  else
948
0
    memcpy(buf, recvbuf, apdu.resplen);
949
950
0
  LOG_FUNC_RETURN(card->ctx, (int)apdu.resplen);
951
0
}
952
953
954
955
static int sc_hsm_create_file(sc_card_t *card, sc_file_t *file)
956
0
{
957
0
  int r;
958
959
0
  r = sc_hsm_write_ef(card, file->id, 0, NULL, 0);
960
0
  LOG_TEST_RET(card->ctx, r, "Create file failed");
961
962
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
963
0
}
964
965
966
967
static int sc_hsm_delete_file(sc_card_t *card, const sc_path_t *path)
968
0
{
969
0
  sc_context_t *ctx = card->ctx;
970
0
  sc_apdu_t apdu;
971
0
  u8 sbuf[2];
972
0
  int r;
973
974
0
  if ((path->type != SC_PATH_TYPE_FILE_ID) || (path->len != 2)) {
975
0
    sc_log(card->ctx,  "File type has to be SC_PATH_TYPE_FILE_ID");
976
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_INVALID_ARGUMENTS);
977
0
  }
978
979
0
  sbuf[0] = path->value[0];
980
0
  sbuf[1] = path->value[1];
981
982
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_3_SHORT, 0xE4, 0x02, 0x00);
983
0
  apdu.data = sbuf;
984
0
  apdu.datalen = sizeof(sbuf);
985
0
  apdu.lc = sizeof(sbuf);
986
987
0
  r = sc_transmit_apdu(card, &apdu);
988
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
989
990
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
991
0
  LOG_TEST_RET(ctx, r, "Check SW error");
992
993
0
  LOG_FUNC_RETURN(ctx, SC_SUCCESS);
994
0
}
995
996
997
static int sc_hsm_set_security_env(sc_card_t *card,
998
           const sc_security_env_t *env,
999
           int se_num)
1000
0
{
1001
0
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
1002
1003
0
  priv->env = env;
1004
1005
0
  switch(env->algorithm) {
1006
0
  case SC_ALGORITHM_RSA:
1007
0
    if (env->algorithm_flags & SC_ALGORITHM_RSA_PAD_PKCS1) {
1008
0
      if (env->algorithm_flags & SC_ALGORITHM_RSA_HASH_SHA1) {
1009
0
        priv->algorithm = ALGO_RSA_PKCS1_SHA1;
1010
0
      } else if (env->algorithm_flags & SC_ALGORITHM_RSA_HASH_SHA256) {
1011
0
        priv->algorithm = ALGO_RSA_PKCS1_SHA256;
1012
0
      } else if (env->algorithm_flags & SC_ALGORITHM_RSA_HASH_SHA384) {
1013
0
        priv->algorithm = ALGO_RSA_PKCS1_SHA384;
1014
0
      } else if (env->algorithm_flags & SC_ALGORITHM_RSA_HASH_SHA512) {
1015
0
        priv->algorithm = ALGO_RSA_PKCS1_SHA512;
1016
0
      } else {
1017
0
        priv->algorithm = ALGO_RSA_PKCS1;
1018
0
      }
1019
0
    } else if (env->algorithm_flags & SC_ALGORITHM_RSA_PAD_PSS) {
1020
0
      if ((env->algorithm_flags & SC_ALGORITHM_RSA_HASHES) &&
1021
0
          (((env->algorithm_flags & SC_ALGORITHM_MGF1_HASHES) >> 8) != (env->algorithm_flags & SC_ALGORITHM_RSA_HASHES))) {
1022
0
        LOG_FUNC_RETURN(card->ctx, SC_ERROR_INVALID_ARGUMENTS);
1023
0
      }
1024
0
      priv->algorithm = ALGO_RSA_PSS;
1025
0
    } else {
1026
0
      if (env->operation == SC_SEC_OPERATION_DECIPHER) {
1027
0
        priv->algorithm = ALGO_RSA_DECRYPT;
1028
0
      } else {
1029
0
        priv->algorithm = ALGO_RSA_RAW;
1030
0
      }
1031
0
    }
1032
0
    break;
1033
0
  case SC_ALGORITHM_EC:
1034
0
    if (env->operation == SC_SEC_OPERATION_DERIVE) {
1035
0
      priv->algorithm = ALGO_EC_DH;
1036
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_HASH_NONE) {
1037
0
      priv->algorithm = ALGO_EC_RAW;
1038
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_HASH_SHA1) {
1039
0
      priv->algorithm = ALGO_EC_SHA1;
1040
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_HASH_SHA224) {
1041
0
      priv->algorithm = ALGO_EC_SHA224;
1042
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_HASH_SHA256) {
1043
0
      priv->algorithm = ALGO_EC_SHA256;
1044
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_HASH_SHA384) {
1045
0
      priv->algorithm = ALGO_EC_SHA384;
1046
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_HASH_SHA512) {
1047
0
      priv->algorithm = ALGO_EC_SHA512;
1048
0
    } else if (env->algorithm_flags & SC_ALGORITHM_ECDSA_RAW) {
1049
0
      priv->algorithm = ALGO_EC_RAW;
1050
0
    } else {
1051
0
      LOG_FUNC_RETURN(card->ctx, SC_ERROR_INVALID_ARGUMENTS);
1052
0
    }
1053
0
    break;
1054
0
  default:
1055
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_INVALID_ARGUMENTS);
1056
0
    break;
1057
0
  }
1058
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1059
0
}
1060
1061
1062
1063
static int sc_hsm_decode_ecdsa_signature(sc_card_t *card,
1064
          const u8 * data, size_t datalen,
1065
          u8 * out, size_t outlen,
1066
0
          size_t key_size) {
1067
1068
0
  int r;
1069
0
  size_t fieldsizebytes = (key_size + 7) >> 3;
1070
1071
0
  sc_log(card->ctx,
1072
0
         "Field size %"SC_FORMAT_LEN_SIZE_T"u, signature buffer size %"SC_FORMAT_LEN_SIZE_T"u",
1073
0
         fieldsizebytes, outlen);
1074
1075
0
  r = sc_asn1_decode_ecdsa_signature(card->ctx, data, datalen, fieldsizebytes, &out, outlen);
1076
0
  LOG_FUNC_RETURN(card->ctx, r);
1077
0
}
1078
1079
1080
1081
static int sc_hsm_compute_signature(sc_card_t *card,
1082
             const u8 * data, size_t datalen,
1083
             u8 * out, size_t outlen)
1084
0
{
1085
0
  int r;
1086
0
  sc_apdu_t apdu;
1087
0
  u8 rbuf[514];
1088
0
  sc_hsm_private_data_t *priv;
1089
1090
0
  if (card == NULL || data == NULL || out == NULL) {
1091
0
    return SC_ERROR_INVALID_ARGUMENTS;
1092
0
  }
1093
0
  priv = (sc_hsm_private_data_t *) card->drv_data;
1094
1095
0
  if (priv->env == NULL) {
1096
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_OBJECT_NOT_FOUND);
1097
0
  }
1098
1099
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_4_EXT, 0x68, priv->env->key_ref[0], priv->algorithm);
1100
0
  apdu.cla = 0x80;
1101
0
  apdu.resp = rbuf;
1102
0
  apdu.resplen = sizeof(rbuf);
1103
0
  apdu.le = 512;
1104
1105
0
  apdu.data = data;
1106
0
  apdu.lc = datalen;
1107
0
  apdu.datalen = datalen;
1108
0
  r = sc_transmit_apdu(card, &apdu);
1109
1110
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
1111
0
  if (apdu.sw1 == 0x90 && apdu.sw2 == 0x00) {
1112
0
    int len;
1113
1114
0
    if ((priv->algorithm & 0xF0) == ALGO_EC_RAW) {
1115
0
      len = sc_hsm_decode_ecdsa_signature(card, apdu.resp, apdu.resplen, out, outlen, priv->env->key_size_bits);
1116
0
      if (len < 0) {
1117
0
        LOG_FUNC_RETURN(card->ctx, len);
1118
0
      }
1119
0
    } else {
1120
0
      len = (int)(apdu.resplen > outlen ? outlen : apdu.resplen);
1121
0
      memcpy(out, apdu.resp, len);
1122
0
    }
1123
0
    LOG_FUNC_RETURN(card->ctx, len);
1124
0
  }
1125
0
  LOG_FUNC_RETURN(card->ctx, sc_check_sw(card, apdu.sw1, apdu.sw2));
1126
0
}
1127
1128
1129
1130
static int sc_hsm_decipher(sc_card_t *card, const u8 * crgram, size_t crgram_len, u8 * out, size_t outlen)
1131
0
{
1132
0
  int r;
1133
0
  size_t len;
1134
0
  sc_apdu_t apdu;
1135
0
  u8 rbuf[514];
1136
0
  sc_hsm_private_data_t *priv;
1137
1138
0
  if (card == NULL || crgram == NULL || out == NULL) {
1139
0
    return SC_ERROR_INVALID_ARGUMENTS;
1140
0
  }
1141
0
  LOG_FUNC_CALLED(card->ctx);
1142
0
  priv = (sc_hsm_private_data_t *) card->drv_data;
1143
1144
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_4_EXT, 0x62, priv->env->key_ref[0], priv->algorithm);
1145
0
  apdu.cla = 0x80;
1146
0
  apdu.resp = rbuf;
1147
0
  apdu.resplen = sizeof(rbuf);
1148
0
  apdu.le = 512;
1149
1150
0
  apdu.data = (u8 *)crgram;
1151
0
  apdu.lc = crgram_len;
1152
0
  apdu.datalen = crgram_len;
1153
1154
0
  r = sc_transmit_apdu(card, &apdu);
1155
1156
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
1157
0
  if (apdu.sw1 == 0x90 && apdu.sw2 == 0x00) {
1158
0
    if (priv->algorithm == ALGO_EC_DH) {
1159
      //
1160
      // The SmartCard-HSM returns the point result of the DH operation
1161
      // with a leading '04'
1162
0
      if (apdu.resplen <= 0)
1163
0
        return SC_ERROR_INTERNAL;
1164
0
      len = apdu.resplen - 1 > outlen ? outlen : apdu.resplen - 1;
1165
0
      memcpy(out, apdu.resp + 1, len);
1166
0
      LOG_FUNC_RETURN(card->ctx, (int)len);
1167
0
    } else {
1168
0
      len = apdu.resplen > outlen ? outlen : apdu.resplen;
1169
0
      memcpy(out, apdu.resp, len);
1170
0
      LOG_FUNC_RETURN(card->ctx, (int)len);
1171
0
    }
1172
0
  }
1173
0
  else
1174
0
    LOG_FUNC_RETURN(card->ctx, sc_check_sw(card, apdu.sw1, apdu.sw2));
1175
0
}
1176
1177
1178
1179
void sc_hsm_set_serialnr(sc_card_t *card, char *serial)
1180
0
{
1181
0
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
1182
1183
0
  if (priv->serialno) {
1184
0
    free(priv->serialno);
1185
0
  }
1186
1187
0
  priv->serialno = strdup(serial);
1188
0
}
1189
1190
1191
1192
static int sc_hsm_get_serialnr(sc_card_t *card, sc_serial_number_t *serial)
1193
37
{
1194
37
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
1195
1196
37
  LOG_FUNC_CALLED(card->ctx);
1197
1198
37
  if (!priv->serialno && 0 == strcmp(card->ctx->app_name, "opensc-tool")) {
1199
    /* sc-hsm initializes the serial number via its PKCS#15 layer.
1200
     * Create and destroy a dummy card to get this initialized.  Only do
1201
     * this for `opensc-tool --serial` to avoid unnecessary card commands
1202
     * in all other cases. */
1203
0
    sc_pkcs15_card_t *p15card = NULL;
1204
0
    (void)sc_pkcs15_bind(card, NULL, &p15card);
1205
0
    sc_pkcs15_unbind(p15card);
1206
0
  }
1207
1208
37
  if (!priv->serialno) {
1209
37
    return SC_ERROR_OBJECT_NOT_FOUND;
1210
37
  }
1211
1212
0
  serial->len = strlen(priv->serialno);
1213
0
  if (serial->len > sizeof(serial->value))
1214
0
    serial->len = sizeof(serial->value);
1215
1216
0
  memcpy(serial->value, priv->serialno, serial->len);
1217
1218
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1219
0
}
1220
1221
1222
1223
static int sc_hsm_initialize(sc_card_t *card, sc_cardctl_sc_hsm_init_param_t *params)
1224
0
{
1225
0
  sc_context_t *ctx = card->ctx;
1226
0
  sc_pkcs15_tokeninfo_t ti;
1227
0
  struct sc_pin_cmd_data pincmd;
1228
0
  int r;
1229
0
  size_t tilen;
1230
0
  sc_apdu_t apdu;
1231
0
  u8 ibuff[68+0xFF], *p;
1232
1233
0
  LOG_FUNC_CALLED(card->ctx);
1234
1235
0
  p = ibuff;
1236
0
  *p++ = 0x80;  // Options
1237
0
  *p++ = 0x02;
1238
0
  memcpy(p, params->options, 2);
1239
0
  p += 2;
1240
1241
0
  if (params->user_pin_len > 0xFF) {
1242
0
    return SC_ERROR_INVALID_ARGUMENTS;
1243
0
  }
1244
0
  *p++ = 0x81;  // User PIN
1245
0
  *p++ = (u8)params->user_pin_len;
1246
0
  memcpy(p, params->user_pin, params->user_pin_len);
1247
0
  p += params->user_pin_len;
1248
1249
0
  *p++ = 0x82;  // Initialization code
1250
0
  *p++ = 0x08;
1251
0
  memcpy(p, params->init_code, 8);
1252
0
  p += 8;
1253
1254
0
  *p++ = 0x91;  // User PIN retry counter
1255
0
  *p++ = 0x01;
1256
0
  *p++ = params->user_pin_retry_counter;
1257
1258
0
  if (params->dkek_shares >= 0) {
1259
0
    *p++ = 0x92;  // Number of DKEK shares
1260
0
    *p++ = 0x01;
1261
0
    *p++ = (u8)params->dkek_shares;
1262
0
  }
1263
1264
0
  if (params->num_of_pub_keys > 0) {
1265
0
    *p++ = 0x93;  // Use public key authentication
1266
0
    *p++ = 0x02;
1267
0
    *p++ = params->num_of_pub_keys; // Total number of public keys used for public authentication
1268
0
    *p++ = params->required_pub_keys; // Number of public keys required for authentication
1269
0
  }
1270
1271
0
  if (params->bio1.len) {
1272
0
    *p++ = 0x95;
1273
0
    *p++ = params->bio1.len;
1274
0
    memcpy(p, params->bio1.value, params->bio1.len);
1275
0
    p += params->bio1.len;
1276
0
  }
1277
0
  if (params->bio2.len) {
1278
0
    *p++ = 0x96;
1279
0
    *p++ = params->bio2.len;
1280
0
    memcpy(p, params->bio2.value, params->bio2.len);
1281
0
    p += params->bio2.len;
1282
0
  }
1283
1284
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_3_SHORT, 0x50, 0x00, 0x00);
1285
0
  apdu.cla = 0x80;
1286
0
  apdu.data = ibuff;
1287
0
  apdu.datalen = p - ibuff;
1288
0
  apdu.lc = apdu.datalen;
1289
1290
0
  r = sc_transmit_apdu(card, &apdu);
1291
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
1292
1293
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
1294
1295
0
  if (r == SC_ERROR_NOT_ALLOWED) {
1296
0
    r = SC_ERROR_PIN_CODE_INCORRECT;
1297
0
  }
1298
1299
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1300
1301
0
  if (params->label) {
1302
0
    memset(&ti, 0, sizeof(ti));
1303
1304
0
    ti.label = params->label;
1305
0
    ti.flags = SC_PKCS15_TOKEN_PRN_GENERATION;
1306
1307
0
    r = sc_pkcs15_encode_tokeninfo(ctx, &ti, &p, &tilen);
1308
0
    LOG_TEST_RET(ctx, r, "Error encoding tokeninfo");
1309
1310
0
    memset(&pincmd, 0, sizeof(pincmd));
1311
0
    pincmd.cmd = SC_PIN_CMD_VERIFY;
1312
0
    pincmd.pin_type = SC_AC_CHV;
1313
0
    pincmd.pin_reference = 0x81;
1314
0
    pincmd.pin1.data = params->user_pin;
1315
0
    pincmd.pin1.len = params->user_pin_len;
1316
1317
0
    r = (*iso_ops->pin_cmd)(card, &pincmd);
1318
0
    LOG_TEST_RET(ctx, r, "Could not verify PIN");
1319
1320
0
    r = sc_hsm_write_ef(card, 0x2F03, 0, p, tilen);
1321
0
    LOG_TEST_RET(ctx, r, "Could not write EF.TokenInfo");
1322
0
  }
1323
1324
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1325
0
}
1326
1327
1328
1329
static int sc_hsm_import_dkek_share(sc_card_t *card, sc_cardctl_sc_hsm_dkek_t *params)
1330
0
{
1331
0
  sc_context_t *ctx = card->ctx;
1332
0
  sc_apdu_t apdu;
1333
0
  u8 status[SC_MAX_APDU_BUFFER_SIZE];
1334
0
  int r;
1335
1336
0
  LOG_FUNC_CALLED(card->ctx);
1337
1338
0
  if (params->importShare) {
1339
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_4_SHORT, 0x52, 0x00, 0x00);
1340
0
    apdu.cla = 0x80;
1341
0
    apdu.data = params->dkek_share;
1342
0
    apdu.datalen = sizeof(params->dkek_share);
1343
0
    apdu.lc = apdu.datalen;
1344
0
  } else {
1345
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_2_SHORT, 0x52, 0x00, 0x00);
1346
0
  }
1347
0
  apdu.cla = 0x80;
1348
0
  apdu.le = 0;
1349
0
  apdu.resp = status;
1350
0
  apdu.resplen = sizeof(status);
1351
1352
0
  r = sc_transmit_apdu(card, &apdu);
1353
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
1354
1355
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
1356
1357
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1358
1359
0
  if (apdu.resplen < (sizeof(params->key_check_value) + 2))
1360
0
    return SC_ERROR_INTERNAL;
1361
1362
0
  params->dkek_shares = status[0];
1363
0
  params->outstanding_shares = status[1];
1364
0
  memcpy(params->key_check_value, status + 2, sizeof(params->key_check_value));
1365
1366
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1367
0
}
1368
1369
1370
1371
static int sc_hsm_wrap_key(sc_card_t *card, sc_cardctl_sc_hsm_wrapped_key_t *params)
1372
0
{
1373
0
  sc_context_t *ctx = card->ctx;
1374
0
  sc_apdu_t apdu;
1375
0
  u8 data[1500];
1376
0
  int r;
1377
1378
0
  LOG_FUNC_CALLED(card->ctx);
1379
1380
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_2_EXT, 0x72, params->key_id, 0x92);
1381
0
  apdu.cla = 0x80;
1382
0
  apdu.le = 0;
1383
0
  apdu.resp = data;
1384
0
  apdu.resplen = sizeof(data);
1385
1386
0
  r = sc_transmit_apdu(card, &apdu);
1387
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
1388
1389
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
1390
1391
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1392
1393
0
  if (params->wrapped_key == NULL) {
1394
0
    params->wrapped_key_length = apdu.resplen;
1395
0
    params->wrapped_key = malloc(apdu.resplen);
1396
0
    if (params->wrapped_key == NULL) {
1397
0
      LOG_FUNC_RETURN(card->ctx, SC_ERROR_OUT_OF_MEMORY);
1398
0
    }
1399
0
  } else {
1400
0
    if (apdu.resplen > params->wrapped_key_length) {
1401
0
      LOG_FUNC_RETURN(card->ctx, SC_ERROR_BUFFER_TOO_SMALL);
1402
0
    }
1403
0
    params->wrapped_key_length = apdu.resplen;
1404
0
  }
1405
0
  memcpy(params->wrapped_key, data, apdu.resplen);
1406
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1407
0
}
1408
1409
1410
1411
static int sc_hsm_unwrap_key(sc_card_t *card, sc_cardctl_sc_hsm_wrapped_key_t *params)
1412
0
{
1413
0
  sc_context_t *ctx = card->ctx;
1414
0
  sc_apdu_t apdu;
1415
0
  int r;
1416
1417
0
  LOG_FUNC_CALLED(card->ctx);
1418
1419
0
  r = sc_hsm_write_ef(card, 0x2F10, 0, params->wrapped_key, params->wrapped_key_length);
1420
0
  LOG_TEST_RET(card->ctx, r, "Create EF failed");
1421
1422
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_1, 0x74, params->key_id, 0x93);
1423
0
  apdu.cla = 0x80;
1424
0
  r = sc_transmit_apdu(card, &apdu);
1425
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
1426
1427
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1428
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1429
1430
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1431
0
}
1432
1433
static int verify_certificate(sc_card_t *card, sc_cvc_t *cvc,
1434
    const u8 *cvc_buf, size_t cvc_buf_len)
1435
0
{
1436
0
  u8 tag = SC_ASN1_TAG_CONTEXT | SC_ASN1_TAG_BIT_STRING; /* 0x83 */
1437
0
  size_t pukref_len;
1438
0
  u8 pukref[BUFSIZ];
1439
0
  sc_apdu_t apdu;
1440
0
  u8 *ptr;
1441
0
  int r;
1442
1443
0
  LOG_FUNC_CALLED(card->ctx);
1444
1445
  /* check if public key is already known */
1446
0
  if ((r = sc_asn1_put_tag(tag, (u8 *)cvc->chr, cvc->chrLen,
1447
0
          pukref, sizeof(pukref), &ptr)) < 0) {
1448
0
    sc_log(card->ctx, "Error formatting ASN.1 sequence: %s\n", sc_strerror(r));
1449
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_UNKNOWN);
1450
0
  }
1451
0
  pukref_len = ptr - pukref;
1452
1453
  /* MANAGE SECURITY ENVIRONMENT to query public key by chr */
1454
0
  sc_format_apdu_ex(&apdu, 0x00, 0x22, 0x81, 0xB6, pukref, pukref_len, NULL, 0);
1455
1456
0
  r = sc_transmit_apdu(card, &apdu);
1457
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
1458
1459
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1460
0
  if (!r) {
1461
    /* already known */
1462
0
    LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1463
0
  }
1464
0
  if (apdu.sw1 != 0x6A && apdu.sw2 != 0x88) {
1465
0
    LOG_TEST_RET(card->ctx, SC_ERROR_UNKNOWN, "Check SW error");
1466
0
  }
1467
1468
0
  if ((r = sc_asn1_put_tag(tag, (u8 *)cvc->car, cvc->carLen,
1469
0
          pukref, sizeof(pukref), &ptr)) < 0) {
1470
0
    sc_log(card->ctx, "Error formatting ASN.1 sequence: %s\n", sc_strerror(r));
1471
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_UNKNOWN);
1472
0
  }
1473
0
  pukref_len = ptr - pukref;
1474
1475
  /* MANAGE SECURITY ENVIRONMENT to set the CAR public key */
1476
0
  sc_format_apdu_ex(&apdu, 0x00, 0x22, 0x81, 0xB6, pukref, pukref_len, NULL, 0);
1477
1478
0
  r = sc_transmit_apdu(card, &apdu);
1479
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
1480
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1481
0
  LOG_TEST_RET(card->ctx, r, "Check SW error");
1482
1483
  /* PERFORM SECURITY OPERATION -> VERIFY CERTIFICATE */
1484
0
  sc_format_apdu_ex(&apdu, 0x00, 0x2A, 0x00, 0xBE, cvc_buf, cvc_buf_len, NULL, 0);
1485
1486
0
  r = sc_transmit_apdu(card, &apdu);
1487
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
1488
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1489
0
  LOG_TEST_RET(card->ctx, r, "Check SW error");
1490
1491
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1492
0
}
1493
1494
1495
1496
static int sc_hsm_register_public_key(sc_card_t *card,
1497
    sc_cardctl_sc_hsm_pka_register_t *pka_register)
1498
0
{
1499
0
  u8 tag = SC_ASN1_TAG_CONTEXT | SC_ASN1_TAG_BIT_STRING; /* 0x83 */
1500
0
  u8 recvbuf[4];
1501
0
  sc_context_t *ctx = card->ctx;
1502
0
  sc_apdu_t apdu;
1503
0
  u8 *ptr;
1504
0
  int r;
1505
0
  sc_pkcs15_card_t p15card;
1506
0
  const u8 *pka_buf;
1507
0
  size_t pka_buf_len;
1508
0
  sc_cvc_pka_t pka;
1509
  /* outer CAR in ASN.1 needs a byte for tag and a byte for length */
1510
0
  u8 asn1_outer_car[sizeof(pka.public_key_req.cvc.outer_car) + 2];
1511
1512
0
  LOG_FUNC_CALLED(ctx);
1513
1514
0
  memset(&pka, 0, sizeof(pka));
1515
0
  memset(&p15card, 0, sizeof(p15card));
1516
0
  p15card.card = card;
1517
1518
0
  pka_buf = pka_register->buf;
1519
0
  pka_buf_len = pka_register->buflen;
1520
0
  r = sc_pkcs15emu_sc_hsm_decode_pka(&p15card, &pka_buf, &pka_buf_len, &pka);
1521
0
  LOG_TEST_GOTO_ERR(ctx, r, "sc_pkcs15emu_sc_hsm_decode_pka failed");
1522
1523
  /* the DICA CVC must be verified first */
1524
0
  r = verify_certificate(card, &pka.dica.cvc, pka.dica.ptr, pka.dica.len);
1525
0
  LOG_TEST_GOTO_ERR(ctx, r, "Verify device issuer CA CVC failed");
1526
1527
  /* the device CVC must be verified before registering the public key */
1528
0
  r = verify_certificate(card, &pka.device.cvc, pka.device.ptr, pka.device.len);
1529
0
  LOG_TEST_GOTO_ERR(ctx, r, "Verify device CVC failed");
1530
1531
0
  r = sc_asn1_put_tag(tag,
1532
0
      (u8 *)pka.public_key_req.cvc.outer_car,
1533
0
      pka.public_key_req.cvc.outerCARLen,
1534
0
      asn1_outer_car, sizeof(asn1_outer_car), &ptr);
1535
0
  LOG_TEST_GOTO_ERR(ctx, r, "ASN.1 encode outer CAR failed");
1536
1537
  /* MANAGE SECURITY ENVIRONMENT with the outer CAR of the public key */
1538
0
  sc_format_apdu_ex(&apdu, 0x00, 0x22, 0x81, 0xB6,
1539
0
      asn1_outer_car, ptr - asn1_outer_car, NULL, 0);
1540
1541
0
  r = sc_transmit_apdu(card, &apdu);
1542
0
  LOG_TEST_GOTO_ERR(ctx, r, "APDU transmit failed");
1543
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1544
0
  LOG_TEST_GOTO_ERR(ctx, r, "Check SW error");
1545
1546
0
  sc_format_apdu_ex(&apdu, 0x80, 0x54, 0x00, 0x00,
1547
0
      pka.public_key_req.ptr, pka.public_key_req.len,
1548
0
      recvbuf, sizeof(recvbuf));
1549
1550
0
  r = sc_transmit_apdu(card, &apdu);
1551
0
  LOG_TEST_GOTO_ERR(ctx, r, "APDU transmit failed");
1552
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1553
0
  LOG_TEST_GOTO_ERR(ctx, r, "Check SW error");
1554
1555
0
  pka_register->new_status.num_total = recvbuf[0];
1556
0
  pka_register->new_status.num_missing = recvbuf[1];
1557
0
  pka_register->new_status.num_required = recvbuf[2];
1558
0
  pka_register->new_status.num_authenticated = recvbuf[3];
1559
1560
0
  r = 0;
1561
  /* fall-through */
1562
1563
0
err:
1564
0
  sc_pkcs15emu_sc_hsm_free_cvc_pka(&pka);
1565
0
  return r;
1566
0
}
1567
1568
1569
1570
static int sc_hsm_public_key_auth_status(sc_card_t *card,
1571
  sc_cardctl_sc_hsm_pka_status_t *status)
1572
0
{
1573
0
  u8 recvbuf[4];
1574
0
  sc_context_t *ctx = card->ctx;
1575
0
  sc_apdu_t apdu;
1576
0
  int r;
1577
1578
0
  LOG_FUNC_CALLED(card->ctx);
1579
1580
  /* get status */
1581
0
  sc_format_apdu_ex(&apdu, 0x00, 0x54, 0x00, 0x00, NULL, 0, recvbuf, sizeof recvbuf);
1582
0
  apdu.cla = 0x80;
1583
1584
0
  r = sc_transmit_apdu(card, &apdu);
1585
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
1586
1587
0
  r = sc_check_sw(card, apdu.sw1, apdu.sw2);
1588
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1589
1590
0
  status->num_total = recvbuf[0];
1591
0
  status->num_missing = recvbuf[1];
1592
0
  status->num_required = recvbuf[2];
1593
0
  status->num_authenticated = recvbuf[3];
1594
1595
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1596
0
}
1597
1598
1599
1600
static int sc_hsm_init_token(sc_card_t *card, sc_cardctl_pkcs11_init_token_t *params)
1601
0
{
1602
0
  sc_context_t *ctx = card->ctx;
1603
0
  sc_cardctl_sc_hsm_init_param_t ip;
1604
0
  int r;
1605
0
  char label[33],*cpo;
1606
1607
0
  LOG_FUNC_CALLED(ctx);
1608
1609
0
  if (params->so_pin_len != 16) {
1610
0
    LOG_TEST_RET(ctx, SC_ERROR_INVALID_DATA, "SO PIN wrong length (!=16)");
1611
0
  }
1612
1613
0
  memset(&ip, 0, sizeof(ip));
1614
0
  ip.dkek_shares = -1;
1615
0
  ip.options[0] = 0x00;
1616
0
  ip.options[1] = 0x01;
1617
1618
0
  r = sc_hsm_encode_sopin(params->so_pin, ip.init_code);
1619
0
  LOG_TEST_RET(ctx, r, "SO PIN wrong format");
1620
1621
0
  ip.user_pin = ip.init_code;   // Use the first 6 bytes of the SO-PIN as initial User-PIN value
1622
0
  ip.user_pin_len = 6;
1623
0
  ip.user_pin_retry_counter = 3;
1624
1625
0
  if (params->label) {
1626
    // Strip trailing spaces
1627
0
    memcpy(label, params->label, 32);
1628
0
    label[32] = 0;
1629
0
    cpo = label + 31;
1630
0
    while ((cpo >= label) && (*cpo == ' ')) {
1631
0
      *cpo = 0;
1632
0
      cpo--;
1633
0
    }
1634
0
    ip.label = label;
1635
0
  }
1636
1637
0
  r = sc_hsm_initialize(card, &ip);
1638
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1639
1640
0
  LOG_FUNC_RETURN(ctx, SC_SUCCESS);
1641
0
}
1642
1643
1644
1645
static int sc_hsm_init_pin(sc_card_t *card, sc_cardctl_pkcs11_init_pin_t *params)
1646
0
{
1647
0
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
1648
0
  sc_context_t *ctx = card->ctx;
1649
0
  int r;
1650
0
  sc_apdu_t apdu;
1651
0
  u8 ibuff[50], *p;
1652
1653
0
  LOG_FUNC_CALLED(card->ctx);
1654
1655
0
  if (params->pin_len > 16) {
1656
0
    LOG_TEST_RET(card->ctx, SC_ERROR_INVALID_DATA, "User PIN too long");
1657
0
  }
1658
1659
0
  p = ibuff;
1660
1661
0
  memcpy(p, priv->sopin, sizeof(priv->sopin));
1662
0
  p += sizeof(priv->sopin);
1663
1664
0
  memcpy(p, params->pin, params->pin_len);
1665
0
  p += params->pin_len;
1666
1667
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_3_SHORT, 0x2C, 0x00, 0x81);
1668
0
  apdu.data = ibuff;
1669
0
  apdu.datalen = p - ibuff;
1670
0
  apdu.lc = apdu.datalen;
1671
1672
0
  r = sc_transmit_apdu(card, &apdu);
1673
0
  LOG_TEST_RET(ctx, r, "APDU transmit failed");
1674
1675
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
1676
1677
  // Cards before version 1.0 do not implement RESET_RETRY_COUNTER
1678
  // For those cards the CHANGE REFERENCE DATA command is used instead
1679
0
  if (r == SC_ERROR_INS_NOT_SUPPORTED) {
1680
0
    p = ibuff;
1681
0
    memcpy(p, priv->sopin, 6);
1682
0
    p += 6;
1683
1684
0
    memcpy(p, params->pin, params->pin_len);
1685
0
    p += params->pin_len;
1686
1687
0
    sc_format_apdu(card, &apdu, SC_APDU_CASE_3_SHORT, 0x24, 0x00, 0x81);
1688
0
    apdu.data = ibuff;
1689
0
    apdu.datalen = p - ibuff;
1690
0
    apdu.lc = apdu.datalen;
1691
1692
0
    r = sc_transmit_apdu(card, &apdu);
1693
0
    LOG_TEST_RET(ctx, r, "APDU transmit failed");
1694
1695
0
    r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
1696
0
  }
1697
1698
0
  LOG_TEST_RET(ctx, r, "Check SW error");
1699
1700
0
  memset(priv->sopin, 0, sizeof(priv->sopin));
1701
1702
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1703
0
}
1704
1705
1706
1707
static int sc_hsm_generate_keypair(sc_card_t *card, sc_cardctl_sc_hsm_keygen_info_t *keyinfo)
1708
0
{
1709
0
  u8 rbuf[1200];
1710
0
  int r;
1711
0
  sc_apdu_t apdu;
1712
1713
0
  LOG_FUNC_CALLED(card->ctx);
1714
1715
0
  sc_format_apdu(card, &apdu, SC_APDU_CASE_4_EXT, 0x46, keyinfo->key_id, keyinfo->auth_key_id);
1716
0
  apdu.cla = 0x00;
1717
0
  apdu.resp = rbuf;
1718
0
  apdu.resplen = sizeof(rbuf);
1719
0
  apdu.le = 0;
1720
1721
0
  apdu.data = keyinfo->gakprequest;
1722
0
  apdu.lc = keyinfo->gakprequest_len;
1723
0
  apdu.datalen = keyinfo->gakprequest_len;
1724
1725
0
  r = sc_transmit_apdu(card, &apdu);
1726
0
  LOG_TEST_RET(card->ctx, r, "APDU transmit failed");
1727
1728
0
  r =  sc_check_sw(card, apdu.sw1, apdu.sw2);
1729
0
  LOG_TEST_RET(card->ctx, r, "Check SW error");
1730
1731
0
  keyinfo->gakpresponse_len = apdu.resplen;
1732
0
  keyinfo->gakpresponse = malloc(apdu.resplen);
1733
1734
0
  if (keyinfo->gakpresponse == NULL) {
1735
0
    LOG_FUNC_RETURN(card->ctx, SC_ERROR_OUT_OF_MEMORY);
1736
0
  }
1737
1738
0
  memcpy(keyinfo->gakpresponse, apdu.resp, apdu.resplen);
1739
1740
0
  LOG_FUNC_RETURN(card->ctx, SC_SUCCESS);
1741
0
}
1742
1743
1744
1745
static int sc_hsm_card_ctl(sc_card_t *card, unsigned long cmd, void *ptr)
1746
37
{
1747
37
  switch (cmd) {
1748
37
  case SC_CARDCTL_GET_SERIALNR:
1749
37
    return sc_hsm_get_serialnr(card, (sc_serial_number_t *)ptr);
1750
0
  case SC_CARDCTL_PKCS11_INIT_TOKEN:
1751
0
    return sc_hsm_init_token(card, (sc_cardctl_pkcs11_init_token_t *)ptr);
1752
0
  case SC_CARDCTL_PKCS11_INIT_PIN:
1753
0
    return sc_hsm_init_pin(card, (sc_cardctl_pkcs11_init_pin_t *)ptr);
1754
0
  case SC_CARDCTL_SC_HSM_GENERATE_KEY:
1755
0
    return sc_hsm_generate_keypair(card, (sc_cardctl_sc_hsm_keygen_info_t *)ptr);
1756
0
  case SC_CARDCTL_SC_HSM_INITIALIZE:
1757
0
    return sc_hsm_initialize(card, (sc_cardctl_sc_hsm_init_param_t *)ptr);
1758
0
  case SC_CARDCTL_SC_HSM_IMPORT_DKEK_SHARE:
1759
0
    return sc_hsm_import_dkek_share(card, (sc_cardctl_sc_hsm_dkek_t *)ptr);
1760
0
  case SC_CARDCTL_SC_HSM_WRAP_KEY:
1761
0
    return sc_hsm_wrap_key(card, (sc_cardctl_sc_hsm_wrapped_key_t *)ptr);
1762
0
  case SC_CARDCTL_SC_HSM_UNWRAP_KEY:
1763
0
    return sc_hsm_unwrap_key(card, (sc_cardctl_sc_hsm_wrapped_key_t *)ptr);
1764
0
  case SC_CARDCTL_SC_HSM_REGISTER_PUBLIC_KEY:
1765
0
    return sc_hsm_register_public_key(card, ptr);
1766
0
  case SC_CARDCTL_SC_HSM_PUBLIC_KEY_AUTH_STATUS:
1767
0
    return sc_hsm_public_key_auth_status(card, ptr);
1768
37
  }
1769
0
  return SC_ERROR_NOT_SUPPORTED;
1770
37
}
1771
1772
1773
1774
static int sc_hsm_init(struct sc_card *card)
1775
171
{
1776
#if defined(ENABLE_SM) && defined(ENABLE_OPENPACE) && defined(_WIN32)
1777
  char expanded_val[PATH_MAX];
1778
  size_t expanded_len = PATH_MAX;
1779
#endif
1780
171
  int flags,ext_flags;
1781
171
  sc_file_t *file = NULL;
1782
171
  sc_path_t path;
1783
171
  sc_hsm_private_data_t *priv = NULL;
1784
1785
171
  LOG_FUNC_CALLED(card->ctx);
1786
1787
171
  flags = SC_ALGORITHM_RSA_RAW|SC_ALGORITHM_RSA_PAD_PSS|SC_ALGORITHM_ONBOARD_KEY_GEN
1788
171
      |SC_ALGORITHM_RSA_HASH_SHA1|SC_ALGORITHM_RSA_HASH_SHA256|SC_ALGORITHM_RSA_HASH_SHA384|SC_ALGORITHM_RSA_HASH_SHA512
1789
171
      |SC_ALGORITHM_MGF1_SHA256|SC_ALGORITHM_MGF1_SHA384|SC_ALGORITHM_MGF1_SHA512;
1790
1791
171
  _sc_card_add_rsa_alg(card, 1024, flags, 0);
1792
171
  _sc_card_add_rsa_alg(card, 1536, flags, 0);
1793
171
  _sc_card_add_rsa_alg(card, 2048, flags, 0);
1794
171
  _sc_card_add_rsa_alg(card, 3072, flags, 0);
1795
171
  _sc_card_add_rsa_alg(card, 4096, flags, 0);
1796
1797
171
  flags = SC_ALGORITHM_ECDSA_RAW|
1798
171
    SC_ALGORITHM_ECDH_CDH_RAW|
1799
171
    SC_ALGORITHM_ECDSA_HASH_NONE|
1800
171
    SC_ALGORITHM_ECDSA_HASH_SHA1|
1801
171
    SC_ALGORITHM_ECDSA_HASH_SHA224|
1802
171
    SC_ALGORITHM_ECDSA_HASH_SHA256|
1803
171
    SC_ALGORITHM_ECDSA_HASH_SHA384|
1804
171
    SC_ALGORITHM_ECDSA_HASH_SHA512|
1805
171
    SC_ALGORITHM_ONBOARD_KEY_GEN;
1806
1807
171
  ext_flags = SC_ALGORITHM_EXT_EC_F_P|
1808
171
      SC_ALGORITHM_EXT_EC_ECPARAMETERS|
1809
171
      SC_ALGORITHM_EXT_EC_NAMEDCURVE|
1810
171
      SC_ALGORITHM_EXT_EC_UNCOMPRESES|
1811
171
      SC_ALGORITHM_ONBOARD_KEY_GEN;
1812
171
  _sc_card_add_ec_alg(card, 192, flags, ext_flags, NULL);
1813
171
  _sc_card_add_ec_alg(card, 224, flags, ext_flags, NULL);
1814
171
  _sc_card_add_ec_alg(card, 256, flags, ext_flags, NULL);
1815
171
  _sc_card_add_ec_alg(card, 320, flags, ext_flags, NULL);
1816
171
  _sc_card_add_ec_alg(card, 384, flags, ext_flags, NULL);
1817
171
  _sc_card_add_ec_alg(card, 512, flags, ext_flags, NULL);
1818
171
  _sc_card_add_ec_alg(card, 521, flags, ext_flags, NULL);
1819
1820
171
  card->caps |= SC_CARD_CAP_RNG|SC_CARD_CAP_APDU_EXT|SC_CARD_CAP_ISO7816_PIN_INFO;
1821
1822
  // APDU Size limits
1823
  //   JCOP 2.4.1r3           1462
1824
  //   JCOP 2.4.2r3           1454
1825
  //   JCOP 3                 1232
1826
  //   JCOP 4                 1454
1827
  //   MicroSD with JCOP 3    478 / 506 - handled in reader-pcsc.c
1828
  //   Reiner SCT             1014 - handled in reader-pcsc.c
1829
  //
1830
  // Note, that these are limits for the whole APDU, but the semantics of max_send_size
1831
  // is the size of the APDU send buffer so to get the right value from them, we need
1832
  // to subtract APDU headers (CLA, INS, P1, P2, Lc (3B)), 7 bytes altogether for
1833
  // class 3 APDU
1834
  // (or 9 bytes for case 4 when we pass in >255 B data and expect return of more than 255 B)
1835
1836
  // Use JCOP 3 (smallest unhandled by reader limitation) card limits for sending
1837
  // And make it 9 smaller to make sure we fit the rest of the APDU.
1838
171
  card->max_send_size = 1232 - 9;
1839
  // Assume that card supports sending with extended length APDU and without limit
1840
171
  card->max_recv_size = 0;
1841
1842
171
  if (card->type == SC_CARD_TYPE_SC_HSM_SOC
1843
171
      || card->type == SC_CARD_TYPE_SC_HSM_GOID) {
1844
169
    card->max_recv_size = 0x0630; // SoC Proxy forces this limit
1845
169
  } else {
1846
    // Adjust to the limits set by the reader
1847
2
    if (card->reader->max_send_size < card->max_send_size) {
1848
2
      if (18 >= card->reader->max_send_size)
1849
2
        LOG_FUNC_RETURN(card->ctx, SC_ERROR_INCONSISTENT_CONFIGURATION);
1850
1851
      // 17 byte header and TLV because of odd ins in UPDATE BINARY
1852
0
      card->max_send_size = card->reader->max_send_size - 17;
1853
0
    }
1854
1855
0
    if (0 < card->reader->max_recv_size) {
1856
0
      if (3 >= card->reader->max_recv_size)
1857
0
        LOG_FUNC_RETURN(card->ctx, SC_ERROR_INCONSISTENT_CONFIGURATION);
1858
0
      card->max_recv_size = card->reader->max_recv_size - 2;
1859
0
    }
1860
0
  }
1861
1862
169
  priv = card->drv_data;
1863
169
  if (!priv) {
1864
169
    priv = calloc(1, sizeof(sc_hsm_private_data_t));
1865
169
    if (!priv)
1866
169
      LOG_FUNC_RETURN(card->ctx, SC_ERROR_OUT_OF_MEMORY);
1867
169
    card->drv_data = priv;
1868
169
  }
1869
1870
169
  sc_path_set(&path, SC_PATH_TYPE_DF_NAME, sc_hsm_aid.value, sc_hsm_aid.len, 0, 0);
1871
169
  if (sc_hsm_select_file_ex(card, &path, 0, &file) == SC_SUCCESS
1872
55
      && file && file->prop_attr && file->prop_attr_len >= 2) {
1873
3
    static char card_name[SC_MAX_APDU_BUFFER_SIZE];
1874
3
    u8 type = 0xFF;
1875
3
    u8 major = file->prop_attr[file->prop_attr_len - 2];
1876
3
    u8 minor = file->prop_attr[file->prop_attr_len - 1];
1877
3
    char p00[] = "SmartCard-HSM Applet for JCOP";
1878
3
    char p01[] = "SmartCard-HSM Demo Applet for JCOP";
1879
3
    char *p = "SmartCard-HSM";
1880
3
    if (file->prop_attr_len >= 3) {
1881
2
      type = file->prop_attr[file->prop_attr_len - 3];
1882
2
    }
1883
3
    switch (type) {
1884
1
      case 0x00:
1885
1
        p = p00;
1886
1
        break;
1887
1
      case 0x01:
1888
1
        p = p01;
1889
1
        break;
1890
1
      default:
1891
1
        break;
1892
3
    }
1893
3
    snprintf(card_name, sizeof card_name, "%s version %u.%u", p, major, minor);
1894
3
    card->name = card_name;
1895
1896
3
    if (file->prop_attr[1] & 0x04) {
1897
1
      card->caps |= SC_CARD_CAP_SESSION_PIN;
1898
1
    }
1899
3
  }
1900
169
  sc_file_free(file);
1901
1902
169
  priv->EF_C_DevAut = NULL;
1903
169
  priv->EF_C_DevAut_len = 0;
1904
1905
169
#if defined(ENABLE_SM) && defined(ENABLE_OPENPACE)
1906
169
  EAC_init();
1907
#ifdef _WIN32
1908
  expanded_len = ExpandEnvironmentStringsA(CVCDIR, expanded_val, sizeof expanded_val);
1909
  if (0 < expanded_len && expanded_len < sizeof expanded_val)
1910
    EAC_set_cvc_default_dir(expanded_val);
1911
#else
1912
169
  EAC_set_cvc_default_dir(CVCDIR);
1913
169
#endif
1914
169
#endif
1915
1916
169
  return 0;
1917
169
}
1918
1919
1920
1921
static int sc_hsm_finish(sc_card_t * card)
1922
169
{
1923
169
  sc_hsm_private_data_t *priv = (sc_hsm_private_data_t *) card->drv_data;
1924
169
#ifdef ENABLE_SM
1925
169
  sc_sm_stop(card);
1926
169
#endif
1927
169
  if (priv) {
1928
169
    free(priv->serialno);
1929
169
    sc_file_free(priv->dffcp);
1930
169
    free(priv->EF_C_DevAut);
1931
169
  }
1932
169
  free(priv);
1933
1934
169
  return SC_SUCCESS;
1935
169
}
1936
1937
1938
1939
static struct sc_card_driver * sc_get_driver(void)
1940
12.6k
{
1941
12.6k
  struct sc_card_driver *iso_drv = sc_get_iso7816_driver();
1942
1943
12.6k
  if (iso_ops == NULL)
1944
1
    iso_ops = iso_drv->ops;
1945
1946
12.6k
  sc_hsm_ops                   = *iso_drv->ops;
1947
12.6k
  sc_hsm_ops.match_card        = sc_hsm_match_card;
1948
12.6k
  sc_hsm_ops.select_file       = sc_hsm_select_file;
1949
12.6k
  sc_hsm_ops.get_challenge     = sc_hsm_get_challenge;
1950
12.6k
  sc_hsm_ops.read_binary       = sc_hsm_read_binary;
1951
12.6k
  sc_hsm_ops.update_binary     = sc_hsm_update_binary;
1952
12.6k
  sc_hsm_ops.list_files        = sc_hsm_list_files;
1953
12.6k
  sc_hsm_ops.create_file       = sc_hsm_create_file;
1954
12.6k
  sc_hsm_ops.delete_file       = sc_hsm_delete_file;
1955
12.6k
  sc_hsm_ops.set_security_env  = sc_hsm_set_security_env;
1956
12.6k
  sc_hsm_ops.compute_signature = sc_hsm_compute_signature;
1957
12.6k
  sc_hsm_ops.decipher          = sc_hsm_decipher;
1958
12.6k
  sc_hsm_ops.init              = sc_hsm_init;
1959
12.6k
  sc_hsm_ops.finish            = sc_hsm_finish;
1960
12.6k
  sc_hsm_ops.card_ctl          = sc_hsm_card_ctl;
1961
12.6k
  sc_hsm_ops.pin_cmd           = sc_hsm_pin_cmd;
1962
12.6k
  sc_hsm_ops.logout            = sc_hsm_logout;
1963
1964
  /* no record oriented file services */
1965
12.6k
  sc_hsm_ops.read_record       = NULL;
1966
12.6k
  sc_hsm_ops.write_record      = NULL;
1967
12.6k
  sc_hsm_ops.append_record     = NULL;
1968
12.6k
  sc_hsm_ops.update_record     = NULL;
1969
1970
12.6k
  return &sc_hsm_drv;
1971
12.6k
}
1972
1973
1974
1975
struct sc_card_driver * sc_get_sc_hsm_driver(void)
1976
12.6k
{
1977
12.6k
  return sc_get_driver();
1978
12.6k
}
1979