]> git.zerfleddert.de Git - proxmark3-svn/blame_incremental - armsrc/emvdataels.c
ADD: T55XX_WRITE_TIMEOUT to make sure all WaitForResponseTimeout for t55xx behaves...
[proxmark3-svn] / armsrc / emvdataels.c
... / ...
CommitLineData
1//Data elements for EMV transactions.
2#include <stdint.h>
3#ifndef __EMVDATAELS_H
4#define __EMVDATAELS_H
5#include "emvdataels.h"
6//Known AIDs
7
8typedef struct{
9uint8_t tag[2];
10char description[255];
11}tagdescription;
12
13const uint8_t AID_VISA[] = {0xa0,0x00,0x00,0x00,0x03};
14const uint8_t AID_VISA_DB[] = {0xa0,0x00,0x00,0x00,0x03,0x10,0x10};
15const uint8_t AID_VISA_C[] = {0xa0,0x00,0x00,0x00,0x03,0x10,0x10,0x01};
16const uint8_t AID_VISA_D[] = {0xa0,0x00,0x00,0x00,0x03,0x10,0x10,0x02};
17const uint8_t AID_VISA_E[] = {0xa0,0x00,0x00,0x00,0x03,0x20,0x10};
18const uint8_t AID_VISA_I[] = {0xa0,0x00,0x00,0x00,0x03,0x30,0x10};
19const uint8_t AID_VISA_P[] = {0xa0,0x00,0x00,0x00,0x03,0x80,0x10};
20const uint8_t AID_VISA_ATM[]= {0xa0,0x00,0x00,0x00,0x03,0x99,0x99,0x10};
21const uint8_t AID_MASTERCARD[]= {0xa0,0x00,0x00,0x00,0x04,0x10,0x10};
22const uint8_t AID_MAESTRO[] = {0xa0,0x00,0x00,0x00,0x04,0x30,0x60};
23const uint8_t AID_MAESTRO_UK[]= {0xa0,0x00,0x00,0x00,0x05,0x00,0x01};
24const uint8_t AID_MAESTRO_TEST[]={0xb0,0x12,0x34,0x56,0x78};
25const uint8_t AID_SELF_SERVICE[]={0xa0,0x00,0x00,0x00,0x24,0x01};
26const uint8_t AID_AMEX[] = {0xa0,0x00,0x00,0x00,0x25};
27const uint8_t AID_EXPRESSPAY[]= {0xa0,0x00,0x00,0x00,0x25,0x01,0x07,0x01};
28const uint8_t AID_LINK[] = {0xa0,0x00,0x00,0x00,0x29,0x10,0x10};
29const uint8_t AID_ALIAS[] = {0xa0,0x00,0x00,0x00,0x29,0x10,0x10};
30
31//Master data file for PSE
32//const uint8_t DF_PSE[] = {0x32, 0x50, 0x41, 0x59, 0x2E, 0x53, 0x59, 0x53, 0x2E, 0x44, 0x44, 0x46, 0x30, 0x31};
33const uint8_t DF_PSE[] = {0x32, 0x50, 0x41, 0x59, 0x2E, 0x53, 0x59, 0x53, 0x2E, 0x44, 0x44, 0x46, 0x30, 0x31};
34
35//TAGS
36
37//SW1 return values
38const uint8_t SW1_RESPONSE_BYTES[] = {0x61};
39const uint8_t SW1_WRONG_LENGTH[] = {0x6c};
40const uint8_t SW12_OK[] = {0x90,0x00};
41const uint8_t SW12_NOT_SUPPORTED[] = {0x6a,0x81};
42const uint8_t SW12_NOT_FOUND[] = {0x6a,0x82};
43const uint8_t SW12_COND_NOT_SAT[] = {0x69,0x83};
44const uint8_t PIN_BLOCKED[] = {0x69,0x84};
45const uint8_t PIN_BLOCKED2[] = {0x69,0x84};
46const uint8_t PIN_WRONG[] = {0x63};
47
48const tagdescription EMV_TAG_LIST[] = {
49 {"\x4f\x00","Application Identifier (AID)"},
50 {"\x50\x00","Application Label"},
51 {"\x57\x00","Track 2 Equivalent Data"},
52 {"\x5a\x00","Application Primary Account Number (PAN)"},
53 {"\x6f\x00","File Control Information (FCI) Template"},
54 {"\x70\x00","Record Template"},
55 {"\x77\x00","response message template format 2"},
56 {"\x80\x00","response message template format 1"},
57 {"\x82\x00","application interchange profile"},
58 {"\x83\x00","command template"},
59 {"\x84\x00","df name"},
60 {"\x86\x00","issuer script command"},
61 {"\x87\x00","application priority indicator"},
62 {"\x88\x00","short file identifier"},
63 {"\x8a\x00","authorisation response code"},
64 {"\x8c\x00","card risk management data object list 1 (cdol1)"},
65 {"\x8d\x00","card risk management data object list 2 (cdol2)"},
66 {"\x8e\x00","cardholder verification method (cvm) list"},
67 {"\x8f\x00","certification authority public key index"},
68 {"\x93\x00","signed static application data"},
69 {"\x94\x00","application file locator"},
70 {"\x95\x00","terminal verification results"},
71 {"\x97\x00","transaction certificate data object list (tdol)",},
72 {"\x9c\x00","transaction type"},
73 {"\x9d\x00","directory definition file"},
74 {"\xa5\x00","proprietary information"},
75 {"\x5f\x20","cardholder name"},
76 {"\x5f\x24","application expiration date yymmdd"},
77 {"\x5f\x25","application effective date yymmdd"},
78 {"\x5f\x28","issuer country code"},
79 {"\x5f\x2a","transaction currency code"},
80 {"\x5f\x2d","language preference"},
81 {"\x5f\x30","service code"},
82 {"\x5f\x34","application primary account number (pan) sequence number"},
83 {"\x5f\x50","issuer url"},
84 {"\x92\x00","issuer public key remainder"},
85 {"\x9a\x00","transaction date"},
86 {"\x9f\x02","amount, authorised (numeric)"},
87 {"\x9f\x03","amount, other (numeric)"},
88 {"\x9f\x04","amount, other (binary)"},
89 {"\x9f\x05","application discretionary data"},
90 {"\x9f\x07","application usage control"},
91 {"\x9f\x08","application version number"},
92 {"\x9f\x0d","issuer action code - default"},
93 {"\x9f\x0e","issuer action code - denial"},
94 {"\x9f\x0f","issuer action code - online"},
95 {"\x9f\x11","issuer code table index"},
96 {"\x9f\x12","application preferred name"},
97 {"\x9f\x1a","terminal country code"},
98 {"\x9f\x1f","track 1 discretionary data"},
99 {"\x9f\x20","track 2 discretionary data"},
100 {"\x9f\x26","application cryptogram"},
101 {"\x9f\x32","issuer public key exponent"},
102 {"\x9f\x36","application transaction counter"},
103 {"\x9f\x37","unpredictable number"},
104 {"\x9f\x38","processing options data object list (pdol)"},
105 {"\x9f\x42","application currency code"},
106 {"\x9f\x44","application currency exponent"},
107 {"\x9f\x4a","static data authentication tag list"},
108 {"\x9f\x4d","log entry"},
109 {"\x9f\x66","card production life cycle"},
110 {"\xbf\x0c","file control information (fci) issuer discretionary data"}
111};
112
113//AIP bitmasks details
114#define AIP_CHIP_SUPPORTED 0x80
115#define AIP_MSR_SUPPORTED 0x40
116
117#define AIP_SDA_SUPPORTED 0x40
118#define AIP_DDA_SUPPORTED 0x20
119#define AIP_CARDHOLDER_VERIFICATION 0x10
120#define AIP_TERMINAL_RISK 0x08
121#define AIP_ISSUER_AUTH 0x04
122#define AIP_CDA_SUPPORTED 0x01
123
124//human readable error messages
125
126
127#endif //__EMVDATAELS_H
Impressum, Datenschutz