[2885] | 1 |
|
---|
| 2 | #include "ifd_azbox.h"
|
---|
[2887] | 3 | #include"icc_async.h"
|
---|
[2885] | 4 |
|
---|
[2927] | 5 | int sc_mode;
|
---|
| 6 |
|
---|
[2887] | 7 | int _GetStatus(struct s_reader *reader, int *in)
|
---|
| 8 | {
|
---|
| 9 | unsigned char tmp[512];
|
---|
| 10 | memset (tmp, 0, sizeof(tmp));
|
---|
| 11 |
|
---|
| 12 | return ioctl(reader->handle, SCARD_IOC_CHECKCARD, &tmp);
|
---|
| 13 | }
|
---|
| 14 |
|
---|
[2885] | 15 | int Azbox_Init(struct s_reader *reader)
|
---|
| 16 | {
|
---|
[4141] | 17 | cs_debug_mask(D_DEVICE, "openxcas sc: init");
|
---|
[2885] | 18 |
|
---|
[2887] | 19 | if ((reader->handle = openxcas_get_smartcard_device(0)) < 0) {
|
---|
[4141] | 20 | cs_debug_mask(D_DEVICE, "openxcas sc: init failed (%d)", reader->handle);
|
---|
[2887] | 21 | return FALSE;
|
---|
| 22 | }
|
---|
| 23 |
|
---|
[4141] | 24 | cs_debug_mask(D_DEVICE, "openxcas sc: init succeeded");
|
---|
[2887] | 25 |
|
---|
| 26 | return OK;
|
---|
[2885] | 27 | }
|
---|
| 28 |
|
---|
[2927] | 29 | void Azbox_SetMode(int mode)
|
---|
| 30 | {
|
---|
| 31 | sc_mode = mode;
|
---|
[2928] | 32 | cs_log("openxcas sc: set mode %d", sc_mode);
|
---|
[2927] | 33 | }
|
---|
| 34 |
|
---|
[2885] | 35 | int Azbox_GetStatus(struct s_reader *reader, int *in)
|
---|
| 36 | {
|
---|
| 37 | unsigned char tmp[512];
|
---|
| 38 | memset (tmp, 0, sizeof(tmp));
|
---|
| 39 |
|
---|
[2887] | 40 | int status = _GetStatus(reader, in);
|
---|
[2885] | 41 |
|
---|
[2887] | 42 | if (in) {
|
---|
| 43 | if (status != 1 && status != 3)
|
---|
| 44 | *in = 0;
|
---|
| 45 | else
|
---|
| 46 | *in = 1;
|
---|
[2885] | 47 |
|
---|
[4141] | 48 | //cs_debug_mask(D_DEVICE, "openxcas sc: get status = %d", *in);
|
---|
[2887] | 49 | }
|
---|
| 50 |
|
---|
| 51 | return OK;
|
---|
[2885] | 52 | }
|
---|
| 53 |
|
---|
| 54 | int Azbox_Reset(struct s_reader *reader, ATR *atr)
|
---|
| 55 | {
|
---|
| 56 | int status, reset = -1, mode = 0;
|
---|
| 57 | unsigned char tmp[512];
|
---|
| 58 |
|
---|
| 59 | memset(tmp, 0, sizeof(tmp));
|
---|
| 60 | tmp[0] = 3;
|
---|
| 61 | tmp[1] = 1;
|
---|
| 62 |
|
---|
| 63 | ioctl(reader->handle, SCARD_IOC_WARMRESET, &tmp);
|
---|
| 64 |
|
---|
| 65 | cs_sleepms(500);
|
---|
| 66 |
|
---|
[2887] | 67 | while ((status = _GetStatus(reader, NULL)) != 3)
|
---|
[2885] | 68 | cs_sleepms(50);
|
---|
| 69 |
|
---|
[2921] | 70 | tmp[0] = 0x02;
|
---|
[2927] | 71 | tmp[1] = sc_mode;
|
---|
[2921] | 72 | status = ioctl(reader->handle, SCARD_IOC_CHECKCARD, &tmp);
|
---|
| 73 |
|
---|
[2885] | 74 | memset(tmp, 0, sizeof(tmp));
|
---|
| 75 | tmp[0] = 1;
|
---|
| 76 |
|
---|
| 77 | int atr_len = ioctl(reader->handle, SCARD_IOC_CHECKCARD, &tmp);
|
---|
| 78 | if (ATR_InitFromArray(atr, tmp, atr_len) != ATR_OK)
|
---|
[2887] | 79 | return FALSE;
|
---|
[2885] | 80 |
|
---|
| 81 | cs_sleepms(500);
|
---|
| 82 |
|
---|
[2887] | 83 | return OK;
|
---|
[2885] | 84 | }
|
---|
| 85 |
|
---|
| 86 | int Azbox_Transmit(struct s_reader *reader, BYTE *buffer, unsigned size)
|
---|
| 87 | {
|
---|
| 88 | if (write(reader->handle, buffer, size) != size)
|
---|
[2887] | 89 | return FALSE;
|
---|
[2885] | 90 |
|
---|
[2887] | 91 | return OK;
|
---|
[2885] | 92 | }
|
---|
| 93 |
|
---|
| 94 | int Azbox_Receive(struct s_reader *reader, BYTE *buffer, unsigned size)
|
---|
| 95 | {
|
---|
| 96 | if (read(reader->handle, buffer, size) != size)
|
---|
[2887] | 97 | return FALSE;
|
---|
[2885] | 98 |
|
---|
[2887] | 99 | return OK;
|
---|
[2885] | 100 | }
|
---|
| 101 |
|
---|
| 102 | int Azbox_Close(struct s_reader *reader)
|
---|
| 103 | {
|
---|
| 104 | openxcas_release_smartcard_device(0);
|
---|
| 105 |
|
---|
[2887] | 106 | return OK;
|
---|
[2885] | 107 | }
|
---|