xref: /aosp_15_r20/system/chre/chpp/common/wifi_utils.c (revision 84e339476a462649f82315436d70fd732297a399)
1*84e33947SAndroid Build Coastguard Worker /*
2*84e33947SAndroid Build Coastguard Worker  * Copyright (C) 2021 The Android Open Source Project
3*84e33947SAndroid Build Coastguard Worker  *
4*84e33947SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*84e33947SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*84e33947SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*84e33947SAndroid Build Coastguard Worker  *
8*84e33947SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*84e33947SAndroid Build Coastguard Worker  *
10*84e33947SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*84e33947SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*84e33947SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*84e33947SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*84e33947SAndroid Build Coastguard Worker  * limitations under the License.
15*84e33947SAndroid Build Coastguard Worker  */
16*84e33947SAndroid Build Coastguard Worker 
17*84e33947SAndroid Build Coastguard Worker #include "chpp/common/wifi_utils.h"
18*84e33947SAndroid Build Coastguard Worker 
19*84e33947SAndroid Build Coastguard Worker #include <inttypes.h>
20*84e33947SAndroid Build Coastguard Worker 
21*84e33947SAndroid Build Coastguard Worker #include "chpp/log.h"
22*84e33947SAndroid Build Coastguard Worker 
23*84e33947SAndroid Build Coastguard Worker static uint8_t gResultTotal = 0;
24*84e33947SAndroid Build Coastguard Worker static uint8_t gResultAcc = 0;
25*84e33947SAndroid Build Coastguard Worker static uint8_t gExpectedIndex = 0;
26*84e33947SAndroid Build Coastguard Worker 
chppCheckWifiScanEventNotificationReset(void)27*84e33947SAndroid Build Coastguard Worker void chppCheckWifiScanEventNotificationReset(void) {
28*84e33947SAndroid Build Coastguard Worker   gResultTotal = 0;
29*84e33947SAndroid Build Coastguard Worker   gResultAcc = 0;
30*84e33947SAndroid Build Coastguard Worker   gExpectedIndex = 0;
31*84e33947SAndroid Build Coastguard Worker }
32*84e33947SAndroid Build Coastguard Worker 
chppCheckWifiScanEventNotification(const struct chreWifiScanEvent * chre)33*84e33947SAndroid Build Coastguard Worker bool chppCheckWifiScanEventNotification(const struct chreWifiScanEvent *chre) {
34*84e33947SAndroid Build Coastguard Worker   bool success = true;
35*84e33947SAndroid Build Coastguard Worker 
36*84e33947SAndroid Build Coastguard Worker   if (chre->eventIndex != gExpectedIndex) {
37*84e33947SAndroid Build Coastguard Worker     CHPP_LOGE("Unexpected scan index %" PRIu8 " exp %" PRIu8, chre->eventIndex,
38*84e33947SAndroid Build Coastguard Worker               gExpectedIndex);
39*84e33947SAndroid Build Coastguard Worker     success = false;
40*84e33947SAndroid Build Coastguard Worker   }
41*84e33947SAndroid Build Coastguard Worker   if (chre->eventIndex == 0) {
42*84e33947SAndroid Build Coastguard Worker     if (gResultAcc < gResultTotal) {
43*84e33947SAndroid Build Coastguard Worker       CHPP_LOGE("Too few prev scan results (%" PRIu8 " missing)",
44*84e33947SAndroid Build Coastguard Worker                 gResultTotal - gResultAcc);
45*84e33947SAndroid Build Coastguard Worker       success = false;
46*84e33947SAndroid Build Coastguard Worker     }
47*84e33947SAndroid Build Coastguard Worker     gExpectedIndex = 0;
48*84e33947SAndroid Build Coastguard Worker     gResultAcc = 0;
49*84e33947SAndroid Build Coastguard Worker     gResultTotal = chre->resultTotal;
50*84e33947SAndroid Build Coastguard Worker   }
51*84e33947SAndroid Build Coastguard Worker 
52*84e33947SAndroid Build Coastguard Worker   if (gResultTotal != chre->resultTotal) {
53*84e33947SAndroid Build Coastguard Worker     CHPP_LOGE("Inconsistent result total %" PRIu8 " exp %" PRIu8,
54*84e33947SAndroid Build Coastguard Worker               chre->resultTotal, gResultTotal);
55*84e33947SAndroid Build Coastguard Worker     success = false;
56*84e33947SAndroid Build Coastguard Worker   }
57*84e33947SAndroid Build Coastguard Worker 
58*84e33947SAndroid Build Coastguard Worker   gResultAcc += chre->resultCount;
59*84e33947SAndroid Build Coastguard Worker 
60*84e33947SAndroid Build Coastguard Worker   if (gResultAcc >= gResultTotal) {
61*84e33947SAndroid Build Coastguard Worker     if (gResultAcc > gResultTotal) {
62*84e33947SAndroid Build Coastguard Worker       CHPP_LOGE("Too many scan results (%" PRIu8 " extra)",
63*84e33947SAndroid Build Coastguard Worker                 gResultAcc - gResultTotal);
64*84e33947SAndroid Build Coastguard Worker       success = false;
65*84e33947SAndroid Build Coastguard Worker     }
66*84e33947SAndroid Build Coastguard Worker     gExpectedIndex = 0;
67*84e33947SAndroid Build Coastguard Worker   } else {
68*84e33947SAndroid Build Coastguard Worker     gExpectedIndex++;
69*84e33947SAndroid Build Coastguard Worker   }
70*84e33947SAndroid Build Coastguard Worker 
71*84e33947SAndroid Build Coastguard Worker   return success;
72*84e33947SAndroid Build Coastguard Worker }
73