1 /*
2 * Copyright (c) 2017-2019, The Linux Foundation. All rights reserved.
3 * Not a Contribution
4 */
5 /*
6 * Copyright (C) 2016 The Android Open Source Project
7 *
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
11 *
12 * http://www.apache.org/licenses/LICENSE-2.0
13 *
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 */
20
21 #define LOG_TAG "LocSvc_GnssMeasurementInterface"
22
23 #include <log_util.h>
24 #include "GnssMeasurement.h"
25 #include "MeasurementAPIClient.h"
26
27 namespace android {
28 namespace hardware {
29 namespace gnss {
30 namespace V2_0 {
31 namespace implementation {
32
serviceDied(uint64_t cookie,const wp<IBase> & who)33 void GnssMeasurement::GnssMeasurementDeathRecipient::serviceDied(
34 uint64_t cookie, const wp<IBase>& who) {
35 LOC_LOGE("%s] service died. cookie: %llu, who: %p",
36 __FUNCTION__, static_cast<unsigned long long>(cookie), &who);
37 if (mGnssMeasurement != nullptr) {
38 mGnssMeasurement->close();
39 }
40 }
41
GnssMeasurement()42 GnssMeasurement::GnssMeasurement() {
43 mGnssMeasurementDeathRecipient = new GnssMeasurementDeathRecipient(this);
44 mApi = new MeasurementAPIClient();
45 }
46
~GnssMeasurement()47 GnssMeasurement::~GnssMeasurement() {
48 if (mApi) {
49 delete mApi;
50 mApi = nullptr;
51 }
52 }
53
54 // Methods from ::android::hardware::gnss::V1_0::IGnssMeasurement follow.
setCallback(const sp<V1_0::IGnssMeasurementCallback> & callback)55 Return<GnssMeasurement::GnssMeasurementStatus> GnssMeasurement::setCallback(
56 const sp<V1_0::IGnssMeasurementCallback>& callback) {
57
58 Return<GnssMeasurement::GnssMeasurementStatus> ret =
59 IGnssMeasurement::GnssMeasurementStatus::ERROR_GENERIC;
60 if (mGnssMeasurementCbIface != nullptr) {
61 LOC_LOGE("%s]: GnssMeasurementCallback is already set", __FUNCTION__);
62 return IGnssMeasurement::GnssMeasurementStatus::ERROR_ALREADY_INIT;
63 }
64
65 if (callback == nullptr) {
66 LOC_LOGE("%s]: callback is nullptr", __FUNCTION__);
67 return ret;
68 }
69 if (mApi == nullptr) {
70 LOC_LOGE("%s]: mApi is nullptr", __FUNCTION__);
71 return ret;
72 }
73
74 mGnssMeasurementCbIface = callback;
75 mGnssMeasurementCbIface->linkToDeath(mGnssMeasurementDeathRecipient, 0);
76
77 return mApi->measurementSetCallback(callback);
78 }
79
close()80 Return<void> GnssMeasurement::close() {
81 if (mApi == nullptr) {
82 LOC_LOGE("%s]: mApi is nullptr", __FUNCTION__);
83 return Void();
84 }
85
86 if (mGnssMeasurementCbIface != nullptr) {
87 mGnssMeasurementCbIface->unlinkToDeath(mGnssMeasurementDeathRecipient);
88 mGnssMeasurementCbIface = nullptr;
89 }
90 if (mGnssMeasurementCbIface_1_1 != nullptr) {
91 mGnssMeasurementCbIface_1_1->unlinkToDeath(mGnssMeasurementDeathRecipient);
92 mGnssMeasurementCbIface_1_1 = nullptr;
93 }
94 if (mGnssMeasurementCbIface_2_0 != nullptr) {
95 mGnssMeasurementCbIface_2_0->unlinkToDeath(mGnssMeasurementDeathRecipient);
96 mGnssMeasurementCbIface_2_0 = nullptr;
97 }
98 mApi->measurementClose();
99
100 return Void();
101 }
102
103 // Methods from ::android::hardware::gnss::V1_1::IGnssMeasurement follow.
setCallback_1_1(const sp<V1_1::IGnssMeasurementCallback> & callback,bool enableFullTracking)104 Return<GnssMeasurement::GnssMeasurementStatus> GnssMeasurement::setCallback_1_1(
105 const sp<V1_1::IGnssMeasurementCallback>& callback, bool enableFullTracking) {
106
107 Return<GnssMeasurement::GnssMeasurementStatus> ret =
108 IGnssMeasurement::GnssMeasurementStatus::ERROR_GENERIC;
109 if (mGnssMeasurementCbIface_1_1 != nullptr) {
110 LOC_LOGE("%s]: GnssMeasurementCallback is already set", __FUNCTION__);
111 return IGnssMeasurement::GnssMeasurementStatus::ERROR_ALREADY_INIT;
112 }
113
114 if (callback == nullptr) {
115 LOC_LOGE("%s]: callback is nullptr", __FUNCTION__);
116 return ret;
117 }
118 if (nullptr == mApi) {
119 LOC_LOGE("%s]: mApi is nullptr", __FUNCTION__);
120 return ret;
121 }
122
123 mGnssMeasurementCbIface_1_1 = callback;
124 mGnssMeasurementCbIface_1_1->linkToDeath(mGnssMeasurementDeathRecipient, 0);
125
126 GnssPowerMode powerMode = enableFullTracking?
127 GNSS_POWER_MODE_M1 : GNSS_POWER_MODE_M2;
128
129 return mApi->measurementSetCallback_1_1(callback, powerMode);
130 }
131 // Methods from ::android::hardware::gnss::V2_0::IGnssMeasurement follow.
setCallback_2_0(const sp<V2_0::IGnssMeasurementCallback> & callback,bool enableFullTracking)132 Return<V1_0::IGnssMeasurement::GnssMeasurementStatus> GnssMeasurement::setCallback_2_0(
133 const sp<V2_0::IGnssMeasurementCallback>& callback,
134 bool enableFullTracking) {
135
136 Return<GnssMeasurement::GnssMeasurementStatus> ret =
137 IGnssMeasurement::GnssMeasurementStatus::ERROR_GENERIC;
138 if (mGnssMeasurementCbIface_2_0 != nullptr) {
139 LOC_LOGE("%s]: GnssMeasurementCallback is already set", __FUNCTION__);
140 return IGnssMeasurement::GnssMeasurementStatus::ERROR_ALREADY_INIT;
141 }
142
143 if (callback == nullptr) {
144 LOC_LOGE("%s]: callback is nullptr", __FUNCTION__);
145 return ret;
146 }
147 if (nullptr == mApi) {
148 LOC_LOGE("%s]: mApi is nullptr", __FUNCTION__);
149 return ret;
150 }
151
152 mGnssMeasurementCbIface_2_0 = callback;
153 mGnssMeasurementCbIface_2_0->linkToDeath(mGnssMeasurementDeathRecipient, 0);
154
155 GnssPowerMode powerMode = enableFullTracking ?
156 GNSS_POWER_MODE_M1 : GNSS_POWER_MODE_M2;
157
158 return mApi->measurementSetCallback_2_0(callback, powerMode);
159 }
160
161 } // namespace implementation
162 } // namespace V2_0
163 } // namespace gnss
164 } // namespace hardware
165 } // namespace android
166