blob: d3be41437a0c73f5db45b03435da408383f0d55d [file] [log] [blame]
Yu-Han Yang1e1a6762020-09-30 17:01:53 -07001/*
2 * Copyright (C) 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080017#define LOG_TAG "GnssCallbackAidl"
18
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070019#include "GnssCallbackAidl.h"
20#include <log/log.h>
21
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080022using android::binder::Status;
23using android::hardware::gnss::GnssLocation;
24using GnssSvInfo = android::hardware::gnss::IGnssCallback::GnssSvInfo;
25using GnssSystemInfo = android::hardware::gnss::IGnssCallback::GnssSystemInfo;
Yu-Han Yangd2377442022-10-12 23:54:51 +000026using GnssSignalType = android::hardware::gnss::GnssSignalType;
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080027
28Status GnssCallbackAidl::gnssSetCapabilitiesCb(const int capabilities) {
29 ALOGI("Capabilities received %#08x", capabilities);
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070030 capabilities_cbq_.store(capabilities);
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080031 return Status::ok();
32}
33
Yu-Han Yangd2377442022-10-12 23:54:51 +000034Status GnssCallbackAidl::gnssSetSignalTypeCapabilitiesCb(
35 const std::vector<GnssSignalType>& signalTypes) {
36 ALOGI("SignalTypeCapabilities received");
37 std::ostringstream ss;
38 for (auto& signalType : signalTypes) {
39 ss << "[constellation=" << (int)signalType.constellation
40 << ", carrierFrequencyHz=" << signalType.carrierFrequencyHz
41 << ", codeType=" << signalType.codeType << "], ";
42 }
43 ALOGI("%s", ss.str().c_str());
44 signal_type_capabilities_cbq_.store(signalTypes);
45 return Status::ok();
46}
47
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080048Status GnssCallbackAidl::gnssStatusCb(const GnssStatusValue /* status */) {
Yu-Han Yang19a32b62022-04-27 09:57:01 -070049 ALOGI("gnssStatusCb");
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080050 return Status::ok();
51}
52
53Status GnssCallbackAidl::gnssSvStatusCb(const std::vector<GnssSvInfo>& svInfoList) {
54 ALOGI("gnssSvStatusCb. Size = %d", (int)svInfoList.size());
55 sv_info_list_cbq_.store(svInfoList);
56 return Status::ok();
57}
58
59Status GnssCallbackAidl::gnssLocationCb(const GnssLocation& location) {
60 ALOGI("Location received");
61 location_cbq_.store(location);
62 return Status::ok();
63}
64
Yu-Han Yang19a32b62022-04-27 09:57:01 -070065Status GnssCallbackAidl::gnssNmeaCb(const int64_t timestamp, const std::string& nmea) {
66 nmea_cbq_.store(std::make_pair(timestamp, nmea));
Yu-Han Yang1afbd5f2021-11-24 16:39:13 -080067 return Status::ok();
68}
69
70Status GnssCallbackAidl::gnssAcquireWakelockCb() {
71 return Status::ok();
72}
73
74Status GnssCallbackAidl::gnssReleaseWakelockCb() {
75 return Status::ok();
76}
77
78Status GnssCallbackAidl::gnssSetSystemInfoCb(const GnssSystemInfo& info) {
79 ALOGI("gnssSetSystemInfoCb, year=%d, name=%s", info.yearOfHw, info.name.c_str());
80 info_cbq_.store(info);
81 return Status::ok();
82}
83
84Status GnssCallbackAidl::gnssRequestTimeCb() {
85 return Status::ok();
86}
87
88Status GnssCallbackAidl::gnssRequestLocationCb(const bool /* independentFromGnss */,
89 const bool /* isUserEmergency */) {
90 return Status::ok();
Yu-Han Yang1e1a6762020-09-30 17:01:53 -070091}