xref: /aosp_15_r20/system/nfc/src/adaptation/debug_lmrt.cc (revision 7eba2f3b06c51ae21384f6a4f14577b668a869b3)
1*7eba2f3bSAndroid Build Coastguard Worker /**
2*7eba2f3bSAndroid Build Coastguard Worker  * Copyright (C) 2021 The Android Open Source Project
3*7eba2f3bSAndroid Build Coastguard Worker  *
4*7eba2f3bSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*7eba2f3bSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*7eba2f3bSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*7eba2f3bSAndroid Build Coastguard Worker  *
8*7eba2f3bSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*7eba2f3bSAndroid Build Coastguard Worker  *
10*7eba2f3bSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*7eba2f3bSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*7eba2f3bSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*7eba2f3bSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*7eba2f3bSAndroid Build Coastguard Worker  * limitations under the License.
15*7eba2f3bSAndroid Build Coastguard Worker  */
16*7eba2f3bSAndroid Build Coastguard Worker #include "include/debug_lmrt.h"
17*7eba2f3bSAndroid Build Coastguard Worker 
18*7eba2f3bSAndroid Build Coastguard Worker #include <android-base/logging.h>
19*7eba2f3bSAndroid Build Coastguard Worker #include <android-base/stringprintf.h>
20*7eba2f3bSAndroid Build Coastguard Worker 
21*7eba2f3bSAndroid Build Coastguard Worker using android::base::StringPrintf;
22*7eba2f3bSAndroid Build Coastguard Worker 
23*7eba2f3bSAndroid Build Coastguard Worker /* The payload of each RF_SET_LISTEN_MODE_ROUTING_CMD when commit routing */
24*7eba2f3bSAndroid Build Coastguard Worker lmrt_payload_t lmrt_payloads;
25*7eba2f3bSAndroid Build Coastguard Worker 
26*7eba2f3bSAndroid Build Coastguard Worker /* The committed routing table stored in tlv form  */
27*7eba2f3bSAndroid Build Coastguard Worker std::vector<uint8_t> committed_lmrt_tlvs(0);
28*7eba2f3bSAndroid Build Coastguard Worker 
29*7eba2f3bSAndroid Build Coastguard Worker /*******************************************************************************
30*7eba2f3bSAndroid Build Coastguard Worker **
31*7eba2f3bSAndroid Build Coastguard Worker ** Function         debug_lmrt_init
32*7eba2f3bSAndroid Build Coastguard Worker **
33*7eba2f3bSAndroid Build Coastguard Worker ** Description      initialize the lmrt_payloads
34*7eba2f3bSAndroid Build Coastguard Worker **
35*7eba2f3bSAndroid Build Coastguard Worker ** Returns          None
36*7eba2f3bSAndroid Build Coastguard Worker **
37*7eba2f3bSAndroid Build Coastguard Worker *******************************************************************************/
debug_lmrt_init(void)38*7eba2f3bSAndroid Build Coastguard Worker void debug_lmrt_init(void) {
39*7eba2f3bSAndroid Build Coastguard Worker   std::vector<uint8_t> empty_more(0);
40*7eba2f3bSAndroid Build Coastguard Worker   std::vector<uint8_t> empty_entry_count(0);
41*7eba2f3bSAndroid Build Coastguard Worker   std::vector<std::vector<uint8_t>> empty_tlvs(0);
42*7eba2f3bSAndroid Build Coastguard Worker 
43*7eba2f3bSAndroid Build Coastguard Worker   lmrt_payloads.more.swap(empty_more);
44*7eba2f3bSAndroid Build Coastguard Worker   lmrt_payloads.entry_count.swap(empty_entry_count);
45*7eba2f3bSAndroid Build Coastguard Worker   lmrt_payloads.tlvs.swap(empty_tlvs);
46*7eba2f3bSAndroid Build Coastguard Worker }
47*7eba2f3bSAndroid Build Coastguard Worker 
48*7eba2f3bSAndroid Build Coastguard Worker /*******************************************************************************
49*7eba2f3bSAndroid Build Coastguard Worker **
50*7eba2f3bSAndroid Build Coastguard Worker ** Function         lmrt_log
51*7eba2f3bSAndroid Build Coastguard Worker **
52*7eba2f3bSAndroid Build Coastguard Worker ** Description      print the listen mode routing configuration for debug use
53*7eba2f3bSAndroid Build Coastguard Worker **
54*7eba2f3bSAndroid Build Coastguard Worker ** Returns          None
55*7eba2f3bSAndroid Build Coastguard Worker **
56*7eba2f3bSAndroid Build Coastguard Worker *******************************************************************************/
lmrt_log(void)57*7eba2f3bSAndroid Build Coastguard Worker void lmrt_log(void) {
58*7eba2f3bSAndroid Build Coastguard Worker   if (!WOULD_LOG(VERBOSE)) return;
59*7eba2f3bSAndroid Build Coastguard Worker 
60*7eba2f3bSAndroid Build Coastguard Worker   static const char hexmap[] = {'0', '1', '2', '3', '4', '5', '6', '7',
61*7eba2f3bSAndroid Build Coastguard Worker                                 '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
62*7eba2f3bSAndroid Build Coastguard Worker 
63*7eba2f3bSAndroid Build Coastguard Worker   for (int i = 0; i < lmrt_payloads.more.size(); i++) {
64*7eba2f3bSAndroid Build Coastguard Worker     std::string tlvs_str;
65*7eba2f3bSAndroid Build Coastguard Worker     for (uint8_t byte : lmrt_payloads.tlvs[i]) {
66*7eba2f3bSAndroid Build Coastguard Worker       tlvs_str.push_back(hexmap[byte >> 4]);
67*7eba2f3bSAndroid Build Coastguard Worker       tlvs_str.push_back(hexmap[byte & 0x0F]);
68*7eba2f3bSAndroid Build Coastguard Worker     }
69*7eba2f3bSAndroid Build Coastguard Worker 
70*7eba2f3bSAndroid Build Coastguard Worker     LOG(VERBOSE) << StringPrintf("lmrt_log: Packet %d/%d, %d more packet", i + 1,
71*7eba2f3bSAndroid Build Coastguard Worker                                (int)lmrt_payloads.more.size(),
72*7eba2f3bSAndroid Build Coastguard Worker                                lmrt_payloads.more[i]);
73*7eba2f3bSAndroid Build Coastguard Worker     LOG(VERBOSE) << StringPrintf("lmrt_log: %d entries in this packet",
74*7eba2f3bSAndroid Build Coastguard Worker                                lmrt_payloads.entry_count[i]);
75*7eba2f3bSAndroid Build Coastguard Worker 
76*7eba2f3bSAndroid Build Coastguard Worker     LOG(VERBOSE) << StringPrintf("lmrt_log: tlv: %s", tlvs_str.c_str());
77*7eba2f3bSAndroid Build Coastguard Worker   }
78*7eba2f3bSAndroid Build Coastguard Worker }
79*7eba2f3bSAndroid Build Coastguard Worker 
80*7eba2f3bSAndroid Build Coastguard Worker /*******************************************************************************
81*7eba2f3bSAndroid Build Coastguard Worker **
82*7eba2f3bSAndroid Build Coastguard Worker ** Function         lmrt_capture
83*7eba2f3bSAndroid Build Coastguard Worker **
84*7eba2f3bSAndroid Build Coastguard Worker ** Description      record the last RF_SET_LISTEN_MODE_ROUTING_CMD
85*7eba2f3bSAndroid Build Coastguard Worker **
86*7eba2f3bSAndroid Build Coastguard Worker ** Returns          None
87*7eba2f3bSAndroid Build Coastguard Worker **
88*7eba2f3bSAndroid Build Coastguard Worker *******************************************************************************/
lmrt_capture(uint8_t * buf,uint8_t buf_size)89*7eba2f3bSAndroid Build Coastguard Worker void lmrt_capture(uint8_t* buf, uint8_t buf_size) {
90*7eba2f3bSAndroid Build Coastguard Worker   if (buf == nullptr || buf_size < 5) return;
91*7eba2f3bSAndroid Build Coastguard Worker 
92*7eba2f3bSAndroid Build Coastguard Worker   if (lmrt_payloads.more.size() > 0) {
93*7eba2f3bSAndroid Build Coastguard Worker     if (lmrt_payloads.more.back() == 0) {
94*7eba2f3bSAndroid Build Coastguard Worker       /* if the MORE setting of the last lmrt command is 0x00,
95*7eba2f3bSAndroid Build Coastguard Worker        * that means the data in lmrt_payloads are obsolete, empty it */
96*7eba2f3bSAndroid Build Coastguard Worker       debug_lmrt_init();
97*7eba2f3bSAndroid Build Coastguard Worker     }
98*7eba2f3bSAndroid Build Coastguard Worker   }
99*7eba2f3bSAndroid Build Coastguard Worker 
100*7eba2f3bSAndroid Build Coastguard Worker   /* push_back the last lmrt command to lmrt_payloads */
101*7eba2f3bSAndroid Build Coastguard Worker   lmrt_payloads.more.push_back(buf[3]);
102*7eba2f3bSAndroid Build Coastguard Worker   lmrt_payloads.entry_count.push_back(buf[4]);
103*7eba2f3bSAndroid Build Coastguard Worker   if (buf_size == 5) {
104*7eba2f3bSAndroid Build Coastguard Worker     lmrt_payloads.tlvs.push_back(std::vector<uint8_t>(0));
105*7eba2f3bSAndroid Build Coastguard Worker   } else {
106*7eba2f3bSAndroid Build Coastguard Worker     lmrt_payloads.tlvs.push_back(std::vector<uint8_t>(buf + 5, buf + buf_size));
107*7eba2f3bSAndroid Build Coastguard Worker   }
108*7eba2f3bSAndroid Build Coastguard Worker }
109*7eba2f3bSAndroid Build Coastguard Worker 
110*7eba2f3bSAndroid Build Coastguard Worker /*******************************************************************************
111*7eba2f3bSAndroid Build Coastguard Worker **
112*7eba2f3bSAndroid Build Coastguard Worker ** Function         lmrt_update
113*7eba2f3bSAndroid Build Coastguard Worker **
114*7eba2f3bSAndroid Build Coastguard Worker ** Description      Update the committed tlvs to committed_lmrt_tlvs
115*7eba2f3bSAndroid Build Coastguard Worker **
116*7eba2f3bSAndroid Build Coastguard Worker ** Returns          None
117*7eba2f3bSAndroid Build Coastguard Worker **
118*7eba2f3bSAndroid Build Coastguard Worker *******************************************************************************/
lmrt_update(void)119*7eba2f3bSAndroid Build Coastguard Worker void lmrt_update(void) {
120*7eba2f3bSAndroid Build Coastguard Worker   lmrt_log();
121*7eba2f3bSAndroid Build Coastguard Worker   std::vector<uint8_t> temp(0);
122*7eba2f3bSAndroid Build Coastguard Worker 
123*7eba2f3bSAndroid Build Coastguard Worker   /* combine all tlvs in lmrt_payloads.tlvs */
124*7eba2f3bSAndroid Build Coastguard Worker   for (auto tlv : lmrt_payloads.tlvs) {
125*7eba2f3bSAndroid Build Coastguard Worker     temp.insert(temp.end(), tlv.begin(), tlv.end());
126*7eba2f3bSAndroid Build Coastguard Worker   }
127*7eba2f3bSAndroid Build Coastguard Worker 
128*7eba2f3bSAndroid Build Coastguard Worker   committed_lmrt_tlvs.swap(temp);
129*7eba2f3bSAndroid Build Coastguard Worker }
130*7eba2f3bSAndroid Build Coastguard Worker 
131*7eba2f3bSAndroid Build Coastguard Worker /*******************************************************************************
132*7eba2f3bSAndroid Build Coastguard Worker **
133*7eba2f3bSAndroid Build Coastguard Worker ** Function         lmrt_get_max_size
134*7eba2f3bSAndroid Build Coastguard Worker **
135*7eba2f3bSAndroid Build Coastguard Worker ** Description      This function is used to get the max size of the routing
136*7eba2f3bSAndroid Build Coastguard Worker **                  table from cache
137*7eba2f3bSAndroid Build Coastguard Worker **
138*7eba2f3bSAndroid Build Coastguard Worker ** Returns          Max Routing Table Size
139*7eba2f3bSAndroid Build Coastguard Worker **
140*7eba2f3bSAndroid Build Coastguard Worker *******************************************************************************/
lmrt_get_max_size(void)141*7eba2f3bSAndroid Build Coastguard Worker int lmrt_get_max_size(void) { return nfc_cb.max_ce_table; }
142*7eba2f3bSAndroid Build Coastguard Worker 
143*7eba2f3bSAndroid Build Coastguard Worker /*******************************************************************************
144*7eba2f3bSAndroid Build Coastguard Worker **
145*7eba2f3bSAndroid Build Coastguard Worker ** Function         lmrt_get_tlvs
146*7eba2f3bSAndroid Build Coastguard Worker **
147*7eba2f3bSAndroid Build Coastguard Worker ** Description      This function is used to get the committed listen mode
148*7eba2f3bSAndroid Build Coastguard Worker **                  routing configuration command
149*7eba2f3bSAndroid Build Coastguard Worker **
150*7eba2f3bSAndroid Build Coastguard Worker ** Returns          The committed listen mode routing configuration command
151*7eba2f3bSAndroid Build Coastguard Worker **
152*7eba2f3bSAndroid Build Coastguard Worker *******************************************************************************/
lmrt_get_tlvs()153*7eba2f3bSAndroid Build Coastguard Worker std::vector<uint8_t>* lmrt_get_tlvs() { return &committed_lmrt_tlvs; }
154