1 #include "fuzz_cmn.h"
2 #include "nfa_api.h"
3 #include "nfa_nfcee_int.h"
4
5 // These are the functions implemented elsewhere in the NFC code. Our fuzzing
6 // doesn't need them. To avoid pulling into more source code we simply stub
7 // them out.
8
9 tNFA_PROPRIETARY_CFG nfa_proprietary_cfg = {
10 0x80, /* NCI_PROTOCOL_18092_ACTIVE */
11 0x81, /* NCI_PROTOCOL_B_PRIME */
12 0x82, /* NCI_PROTOCOL_DUAL */
13 0x83, /* NCI_PROTOCOL_15693 */
14 0x8A, /* NCI_PROTOCOL_KOVIO */
15 0xFF, /* NCI_PROTOCOL_MIFARE */
16 0x77, /* NCI_DISCOVERY_TYPE_POLL_KOVIO */
17 0x74, /* NCI_DISCOVERY_TYPE_POLL_B_PRIME */
18 0xF4, /* NCI_DISCOVERY_TYPE_LISTEN_B_PRIME */
19 };
20
21 tNFA_PROPRIETARY_CFG* p_nfa_proprietary_cfg =
22 (tNFA_PROPRIETARY_CFG*)&nfa_proprietary_cfg;
23
nfc_start_quick_timer(TIMER_LIST_ENT *,uint16_t,uint32_t)24 void nfc_start_quick_timer(TIMER_LIST_ENT*, uint16_t, uint32_t) {}
nfc_stop_timer(TIMER_LIST_ENT *)25 void nfc_stop_timer(TIMER_LIST_ENT*) {}
nfc_stop_quick_timer(TIMER_LIST_ENT *)26 void nfc_stop_quick_timer(TIMER_LIST_ENT*) {}
NFC_GetNCIVersion()27 uint8_t NFC_GetNCIVersion() { return NCI_VERSION_2_0; }
28
NFC_SendData(uint8_t conn_id,NFC_HDR * p_data)29 tNFC_STATUS NFC_SendData(uint8_t conn_id, NFC_HDR* p_data) {
30 uint8_t* p = (uint8_t*)(p_data + 1) + p_data->offset;
31 uint8_t len = (uint8_t)p_data->len;
32
33 FUZZLOG("conn_id=%d, data=%s", conn_id, BytesToHex(p, len).c_str());
34 GKI_freebuf(p_data);
35 return NFC_STATUS_OK;
36 }
37
NFC_SetStaticT4tNfceeCback(tNFC_CONN_CBACK *,uint8_t)38 void NFC_SetStaticT4tNfceeCback(tNFC_CONN_CBACK*, uint8_t) {}
39
NFA_T4tNfcEeIsProcessing()40 bool NFA_T4tNfcEeIsProcessing() { return NFC_STATUS_OK; }
41
42 tNFA_T4TNFCEE_CB nfa_t4tnfcee_cb;
43
nci_snd_t3t_polling(uint16_t system_code,uint8_t rc,uint8_t tsn)44 uint8_t nci_snd_t3t_polling(uint16_t system_code, uint8_t rc, uint8_t tsn) {
45 FUZZLOG("sc=%04X, rc=%02X, tsn=%02X", system_code, rc, tsn);
46 return NFC_STATUS_OK;
47 }
48
49 tNFC_CONN_CBACK* rf_cback = nullptr;
NFC_SetStaticRfCback(tNFC_CONN_CBACK * p_cback)50 void NFC_SetStaticRfCback(tNFC_CONN_CBACK* p_cback) { rf_cback = p_cback; }
51
NFC_ISODEPNakPresCheck()52 tNFC_STATUS NFC_ISODEPNakPresCheck() { return NFC_STATUS_OK; }
53
NFC_GetStatusName(tNFC_STATUS status)54 std::string NFC_GetStatusName(tNFC_STATUS status) {
55 switch (status) {
56 case NFC_STATUS_OK:
57 return "OK";
58 case NFC_STATUS_REJECTED:
59 return "REJECTED";
60 case NFC_STATUS_MSG_CORRUPTED:
61 return "CORRUPTED";
62 case NFC_STATUS_BUFFER_FULL:
63 return "BUFFER_FULL";
64 case NFC_STATUS_FAILED:
65 return "FAILED";
66 case NFC_STATUS_NOT_INITIALIZED:
67 return "NOT_INITIALIZED";
68 case NFC_STATUS_SYNTAX_ERROR:
69 return "SYNTAX_ERROR";
70 case NFC_STATUS_SEMANTIC_ERROR:
71 return "SEMANTIC_ERROR";
72 case NFC_STATUS_UNKNOWN_GID:
73 return "UNKNOWN_GID";
74 case NFC_STATUS_UNKNOWN_OID:
75 return "UNKNOWN_OID";
76 case NFC_STATUS_INVALID_PARAM:
77 return "INVALID_PARAM";
78 case NFC_STATUS_MSG_SIZE_TOO_BIG:
79 return "MSG_SIZE_TOO_BIG";
80 case NFC_STATUS_ALREADY_STARTED:
81 return "ALREADY_STARTED";
82 case NFC_STATUS_ACTIVATION_FAILED:
83 return "ACTIVATION_FAILED";
84 case NFC_STATUS_TEAR_DOWN:
85 return "TEAR_DOWN";
86 case NFC_STATUS_RF_TRANSMISSION_ERR:
87 return "RF_TRANSMISSION_ERR";
88 case NFC_STATUS_RF_PROTOCOL_ERR:
89 return "RF_PROTOCOL_ERR";
90 case NFC_STATUS_TIMEOUT:
91 return "TIMEOUT";
92 case NFC_STATUS_EE_INTF_ACTIVE_FAIL:
93 return "EE_INTF_ACTIVE_FAIL";
94 case NFC_STATUS_EE_TRANSMISSION_ERR:
95 return "EE_TRANSMISSION_ERR";
96 case NFC_STATUS_EE_PROTOCOL_ERR:
97 return "EE_PROTOCOL_ERR";
98 case NFC_STATUS_EE_TIMEOUT:
99 return "EE_TIMEOUT";
100 case NFC_STATUS_CMD_STARTED:
101 return "CMD_STARTED";
102 case NFC_STATUS_HW_TIMEOUT:
103 return "HW_TIMEOUT";
104 case NFC_STATUS_CONTINUE:
105 return "CONTINUE";
106 case NFC_STATUS_REFUSED:
107 return "REFUSED";
108 case NFC_STATUS_BAD_RESP:
109 return "BAD_RESP";
110 case NFC_STATUS_CMD_NOT_CMPLTD:
111 return "CMD_CMPLTD";
112 case NFC_STATUS_NO_BUFFERS:
113 return "NO_BUFFERS";
114 case NFC_STATUS_WRONG_PROTOCOL:
115 return "WRONG_PROTOCOL";
116 case NFC_STATUS_BUSY:
117 return "BUSY";
118 case NFC_STATUS_LINK_LOSS:
119 return "LINK_LOSS";
120 case NFC_STATUS_BAD_LENGTH:
121 return "BAD_LENGTH";
122 case NFC_STATUS_BAD_HANDLE:
123 return "BAD_HANDLE";
124 case NFC_STATUS_CONGESTED:
125 return "CONGESTED";
126 default:
127 return "UNKNOWN";
128 }
129 }