xref: /aosp_15_r20/system/chre/host/common/time_syncer.cc (revision 84e339476a462649f82315436d70fd732297a399)
1*84e33947SAndroid Build Coastguard Worker /*
2*84e33947SAndroid Build Coastguard Worker  * Copyright (C) 2022 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 "chre_host/time_syncer.h"
18*84e33947SAndroid Build Coastguard Worker #include <chre_host/host_protocol_host.h>
19*84e33947SAndroid Build Coastguard Worker #include "chre_host/log.h"
20*84e33947SAndroid Build Coastguard Worker 
21*84e33947SAndroid Build Coastguard Worker namespace android::chre {
22*84e33947SAndroid Build Coastguard Worker // TODO(b/247124878): Can we add a static assert to make sure these functions
23*84e33947SAndroid Build Coastguard Worker //  are not called when connection->isTimeSyncNeeded() returns false?
sendTimeSync(ChreConnection * connection)24*84e33947SAndroid Build Coastguard Worker bool TimeSyncer::sendTimeSync(ChreConnection *connection) {
25*84e33947SAndroid Build Coastguard Worker   if (!connection->isTimeSyncNeeded()) {
26*84e33947SAndroid Build Coastguard Worker     LOGW("Platform doesn't require time sync. Ignore the request.");
27*84e33947SAndroid Build Coastguard Worker     return true;
28*84e33947SAndroid Build Coastguard Worker   }
29*84e33947SAndroid Build Coastguard Worker   int64_t timeOffsetUs = 0;
30*84e33947SAndroid Build Coastguard Worker   if (!connection->getTimeOffset(&timeOffsetUs)) {
31*84e33947SAndroid Build Coastguard Worker     LOGE("Failed to get time offset.");
32*84e33947SAndroid Build Coastguard Worker     return false;
33*84e33947SAndroid Build Coastguard Worker   }
34*84e33947SAndroid Build Coastguard Worker   flatbuffers::FlatBufferBuilder builder(64);
35*84e33947SAndroid Build Coastguard Worker   // clientId doesn't matter for time sync request so the default id is used.
36*84e33947SAndroid Build Coastguard Worker   HostProtocolHost::encodeTimeSyncMessage(builder, timeOffsetUs);
37*84e33947SAndroid Build Coastguard Worker   return connection->sendMessage(builder.GetBufferPointer(), builder.GetSize());
38*84e33947SAndroid Build Coastguard Worker }
39*84e33947SAndroid Build Coastguard Worker 
sendTimeSyncWithRetry(ChreConnection * connection,size_t numOfRetries,useconds_t retryDelayUs)40*84e33947SAndroid Build Coastguard Worker bool TimeSyncer::sendTimeSyncWithRetry(ChreConnection *connection,
41*84e33947SAndroid Build Coastguard Worker                                        size_t numOfRetries,
42*84e33947SAndroid Build Coastguard Worker                                        useconds_t retryDelayUs) {
43*84e33947SAndroid Build Coastguard Worker   if (!connection->isTimeSyncNeeded()) {
44*84e33947SAndroid Build Coastguard Worker     LOGW("Platform doesn't require time sync. Ignore the request.");
45*84e33947SAndroid Build Coastguard Worker     return true;
46*84e33947SAndroid Build Coastguard Worker   }
47*84e33947SAndroid Build Coastguard Worker   bool success = false;
48*84e33947SAndroid Build Coastguard Worker   while (!success && (numOfRetries-- > 0)) {
49*84e33947SAndroid Build Coastguard Worker     success = sendTimeSync(connection);
50*84e33947SAndroid Build Coastguard Worker     if (!success) {
51*84e33947SAndroid Build Coastguard Worker       usleep(retryDelayUs);
52*84e33947SAndroid Build Coastguard Worker     }
53*84e33947SAndroid Build Coastguard Worker   }
54*84e33947SAndroid Build Coastguard Worker   return success;
55*84e33947SAndroid Build Coastguard Worker }
56*84e33947SAndroid Build Coastguard Worker }  // namespace android::chre