0b6a16c1a4
Only because qemu's checkpatch complains about it. Signed-off-by: Alon Levy <alevy@redhat.com> Reviewed-by: Marc-André Lureau <mlureau@redhat.com>
41 lines
1.0 KiB
C
41 lines
1.0 KiB
C
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <glib.h>
|
|
|
|
#include "libcacard/vcardt.h"
|
|
|
|
#include "libcacard/vcardt_internal.h"
|
|
|
|
/* create an ATR with appropriate historical bytes */
|
|
#define ATR_TS_DIRECT_CONVENTION 0x3b
|
|
#define ATR_TA_PRESENT 0x10
|
|
#define ATR_TB_PRESENT 0x20
|
|
#define ATR_TC_PRESENT 0x40
|
|
#define ATR_TD_PRESENT 0x80
|
|
|
|
unsigned char *vcard_alloc_atr(const char *postfix, int *atr_len)
|
|
{
|
|
int postfix_len;
|
|
const char prefix[] = "VCARD_";
|
|
const char default_postfix[] = "DEFAULT";
|
|
const int prefix_len = sizeof(prefix) - 1;
|
|
int total_len;
|
|
unsigned char *atr;
|
|
|
|
if (postfix == NULL) {
|
|
postfix = default_postfix;
|
|
}
|
|
postfix_len = strlen(postfix);
|
|
total_len = 3 + prefix_len + postfix_len;
|
|
atr = g_malloc(total_len);
|
|
atr[0] = ATR_TS_DIRECT_CONVENTION;
|
|
atr[1] = ATR_TD_PRESENT + prefix_len + postfix_len;
|
|
atr[2] = 0x00;
|
|
memcpy(&atr[3], prefix, prefix_len);
|
|
memcpy(&atr[3 + prefix_len], postfix, postfix_len);
|
|
if (atr_len) {
|
|
*atr_len = total_len;
|
|
}
|
|
return atr;
|
|
}
|