SUPL over WiFi changes in GNSS HIDL2.0
Change-Id: I20a2071fd748dea16cd55aa120bc307ebc0645a9 CRs-fixed: 2342192
This commit is contained in:
parent
c051c7d112
commit
e78728024d
3 changed files with 141 additions and 6 deletions
|
@ -40,33 +40,166 @@ AGnss::~AGnss() {
|
||||||
spAGnss = nullptr;
|
spAGnss = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AGnss::agnssStatusIpV4Cb(AGnssExtStatusIpV4 status){
|
void AGnss::agnssStatusIpV4Cb(AGnssExtStatusIpV4 status) {
|
||||||
|
if (nullptr != spAGnss) {
|
||||||
|
spAGnss->statusCb(status.type, status.status);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AGnss::statusIpV4Cb(AGnssExtStatusIpV4 status) {
|
void AGnss::statusCb(AGpsExtType type, LocAGpsStatusValue status) {
|
||||||
|
|
||||||
|
V2_0::IAGnssCallback::AGnssType aType;
|
||||||
|
IAGnssCallback::AGnssStatusValue aStatus;
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case LOC_AGPS_TYPE_SUPL:
|
||||||
|
aType = IAGnssCallback::AGnssType::SUPL;
|
||||||
|
break;
|
||||||
|
case LOC_AGPS_TYPE_SUPL_ES:
|
||||||
|
aType = IAGnssCallback::AGnssType::SUPL_EIMS;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
LOC_LOGE("invalid type: %d", type);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (status) {
|
||||||
|
case LOC_GPS_REQUEST_AGPS_DATA_CONN:
|
||||||
|
aStatus = IAGnssCallback::AGnssStatusValue::REQUEST_AGNSS_DATA_CONN;
|
||||||
|
break;
|
||||||
|
case LOC_GPS_RELEASE_AGPS_DATA_CONN:
|
||||||
|
aStatus = IAGnssCallback::AGnssStatusValue::RELEASE_AGNSS_DATA_CONN;
|
||||||
|
break;
|
||||||
|
case LOC_GPS_AGPS_DATA_CONNECTED:
|
||||||
|
aStatus = IAGnssCallback::AGnssStatusValue::AGNSS_DATA_CONNECTED;
|
||||||
|
break;
|
||||||
|
case LOC_GPS_AGPS_DATA_CONN_DONE:
|
||||||
|
aStatus = IAGnssCallback::AGnssStatusValue::AGNSS_DATA_CONN_DONE;
|
||||||
|
break;
|
||||||
|
case LOC_GPS_AGPS_DATA_CONN_FAILED:
|
||||||
|
aStatus = IAGnssCallback::AGnssStatusValue::AGNSS_DATA_CONN_FAILED;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
LOC_LOGE("invalid status: %d", status);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mAGnssCbIface != nullptr) {
|
||||||
|
auto r = mAGnssCbIface->agnssStatusCb(aType, aStatus);
|
||||||
|
if (!r.isOk()) {
|
||||||
|
LOC_LOGw("Error invoking AGNSS status cb %s", r.description().c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
LOC_LOGw("setCallback has not been called yet");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Return<void> AGnss::setCallback(const sp<V2_0::IAGnssCallback>& callback) {
|
Return<void> AGnss::setCallback(const sp<V2_0::IAGnssCallback>& callback) {
|
||||||
|
|
||||||
|
if(mGnss == nullptr || mGnss->getGnssInterface() == nullptr){
|
||||||
|
LOC_LOGE("Null GNSS interface");
|
||||||
|
return Void();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Save the interface
|
||||||
|
mAGnssCbIface = callback;
|
||||||
|
|
||||||
|
AgpsCbInfo cbInfo = {};
|
||||||
|
cbInfo.statusV4Cb = (void*)agnssStatusIpV4Cb;
|
||||||
|
cbInfo.cbPriority = AGPS_CB_PRIORITY_HIGH;
|
||||||
|
|
||||||
|
mGnss->getGnssInterface()->agpsInit(cbInfo);
|
||||||
return Void();
|
return Void();
|
||||||
}
|
}
|
||||||
|
|
||||||
Return<bool> AGnss::dataConnClosed() {
|
Return<bool> AGnss::dataConnClosed() {
|
||||||
|
|
||||||
|
if(mGnss == nullptr || mGnss->getGnssInterface() == nullptr){
|
||||||
|
LOC_LOGE("Null GNSS interface");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
mGnss->getGnssInterface()->agpsDataConnClosed(LOC_AGPS_TYPE_SUPL);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Return<bool> AGnss::dataConnFailed() {
|
Return<bool> AGnss::dataConnFailed() {
|
||||||
|
|
||||||
|
if(mGnss == nullptr || mGnss->getGnssInterface() == nullptr){
|
||||||
|
LOC_LOGE("Null GNSS interface");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
mGnss->getGnssInterface()->agpsDataConnFailed(LOC_AGPS_TYPE_SUPL);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Return<bool> AGnss::dataConnOpen(uint64_t networkHandle, const hidl_string& apn,
|
Return<bool> AGnss::dataConnOpen(uint64_t /*networkHandle*/, const hidl_string& apn,
|
||||||
V2_0::IAGnss::ApnIpType apnIpType) {
|
V2_0::IAGnss::ApnIpType apnIpType) {
|
||||||
|
|
||||||
|
if(mGnss == nullptr || mGnss->getGnssInterface() == nullptr){
|
||||||
|
LOC_LOGE("Null GNSS interface");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Validate */
|
||||||
|
if(apn.empty()){
|
||||||
|
LOC_LOGE("Invalid APN");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOC_LOGD("dataConnOpen APN name = [%s]", apn.c_str());
|
||||||
|
|
||||||
|
AGpsBearerType bearerType;
|
||||||
|
switch (apnIpType) {
|
||||||
|
case IAGnss::ApnIpType::IPV4:
|
||||||
|
bearerType = AGPS_APN_BEARER_IPV4;
|
||||||
|
break;
|
||||||
|
case IAGnss::ApnIpType::IPV6:
|
||||||
|
bearerType = AGPS_APN_BEARER_IPV6;
|
||||||
|
break;
|
||||||
|
case IAGnss::ApnIpType::IPV4V6:
|
||||||
|
bearerType = AGPS_APN_BEARER_IPV4V6;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
bearerType = AGPS_APN_BEARER_IPV4;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
mGnss->getGnssInterface()->agpsDataConnOpen(
|
||||||
|
LOC_AGPS_TYPE_SUPL, apn.c_str(), apn.size(), (int)bearerType);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Return<bool> AGnss::setServer(V2_0::IAGnssCallback::AGnssType type,
|
Return<bool> AGnss::setServer(V2_0::IAGnssCallback::AGnssType type,
|
||||||
const hidl_string& hostname,
|
const hidl_string& hostname,
|
||||||
int32_t port) {
|
int32_t port) {
|
||||||
return true;
|
if (mGnss == nullptr) {
|
||||||
|
LOC_LOGE("%s]: mGnss is nullptr", __FUNCTION__);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
GnssConfig config;
|
||||||
|
memset(&config, 0, sizeof(GnssConfig));
|
||||||
|
config.size = sizeof(GnssConfig);
|
||||||
|
config.flags = GNSS_CONFIG_FLAGS_SET_ASSISTANCE_DATA_VALID_BIT;
|
||||||
|
config.assistanceServer.size = sizeof(GnssConfigSetAssistanceServer);
|
||||||
|
if (type == IAGnssCallback::AGnssType::SUPL) {
|
||||||
|
config.assistanceServer.type = GNSS_ASSISTANCE_TYPE_SUPL;
|
||||||
|
} else if (type == IAGnssCallback::AGnssType::C2K) {
|
||||||
|
config.assistanceServer.type = GNSS_ASSISTANCE_TYPE_C2K;
|
||||||
|
} else if (type == IAGnssCallback::AGnssType::SUPL_EIMS) {
|
||||||
|
config.assistanceServer.type = GNSS_ASSISTANCE_TYPE_SUPL_EIMS;
|
||||||
|
} else if (type == IAGnssCallback::AGnssType::SUPL_IMS) {
|
||||||
|
config.assistanceServer.type = GNSS_ASSISTANCE_TYPE_SUPL_IMS;
|
||||||
|
} else {
|
||||||
|
LOC_LOGE("%s]: invalid AGnssType: %d", __FUNCTION__, static_cast<uint8_t>(type));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
config.assistanceServer.hostName = strdup(hostname.c_str());
|
||||||
|
config.assistanceServer.port = port;
|
||||||
|
return mGnss->updateConfiguration(config);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace implementation
|
} // namespace implementation
|
||||||
|
|
|
@ -58,7 +58,7 @@ struct AGnss : public V2_0::IAGnss {
|
||||||
Return<bool> setServer(V2_0::IAGnssCallback::AGnssType type,
|
Return<bool> setServer(V2_0::IAGnssCallback::AGnssType type,
|
||||||
const hidl_string& hostname, int32_t port) override;
|
const hidl_string& hostname, int32_t port) override;
|
||||||
|
|
||||||
void statusIpV4Cb(AGnssExtStatusIpV4 status);
|
void statusCb(AGpsExtType type, LocAGpsStatusValue status);
|
||||||
|
|
||||||
/* Data call setup callback passed down to GNSS HAL implementation */
|
/* Data call setup callback passed down to GNSS HAL implementation */
|
||||||
static void agnssStatusIpV4Cb(AGnssExtStatusIpV4 status);
|
static void agnssStatusIpV4Cb(AGnssExtStatusIpV4 status);
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* Copyright (c) 2018 The Linux Foundation. All rights reserved.
|
/* Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions are
|
* modification, are permitted provided that the following conditions are
|
||||||
|
@ -374,6 +374,8 @@ typedef enum {
|
||||||
typedef enum {
|
typedef enum {
|
||||||
GNSS_ASSISTANCE_TYPE_SUPL = 0,
|
GNSS_ASSISTANCE_TYPE_SUPL = 0,
|
||||||
GNSS_ASSISTANCE_TYPE_C2K,
|
GNSS_ASSISTANCE_TYPE_C2K,
|
||||||
|
GNSS_ASSISTANCE_TYPE_SUPL_EIMS,
|
||||||
|
GNSS_ASSISTANCE_TYPE_SUPL_IMS,
|
||||||
} GnssAssistanceType;
|
} GnssAssistanceType;
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
|
|
Loading…
Reference in a new issue