summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile.am10
-rw-r--r--configure.ac85
-rwxr-xr-xetc/gps.conf1
-rw-r--r--loc-api.pc.in10
-rw-r--r--loc_api/ds_api/Android.mk49
-rw-r--r--loc_api/ds_api/ds_client.c704
-rw-r--r--loc_api/ds_api/ds_client.h142
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/Makefile.am46
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/rpc_inc/loc_api_rpc_glue.h4
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/LocApiRpcAdapter.cpp10
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_log.c1
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_rpc_glue.c5
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_sync_call.c2
-rw-r--r--loc_api/libloc_api-rpc-50001/libloc_api-rpc-stub/Makefile.am42
-rw-r--r--loc_api/libloc_api_50001/LocApiAdapter.cpp27
-rw-r--r--loc_api/libloc_api_50001/LocApiAdapter.h15
-rw-r--r--loc_api/libloc_api_50001/Makefile.am79
-rw-r--r--loc_api/libloc_api_50001/loc.cpp5
-rw-r--r--loc_api/libloc_api_50001/loc.h3
-rw-r--r--loc_api/libloc_api_50001/loc_eng.cpp157
-rw-r--r--loc_api/libloc_api_50001/loc_eng.h2
-rw-r--r--loc_api/libloc_api_50001/loc_eng_agps.cpp269
-rw-r--r--loc_api/libloc_api_50001/loc_eng_agps.h117
-rw-r--r--loc_api/libloc_api_50001/loc_eng_dmn_conn.cpp2
-rw-r--r--loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_msg.c2
-rw-r--r--loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_pipe.c2
-rw-r--r--loc_api/libloc_api_50001/loc_eng_dmn_conn_handler.cpp1
-rw-r--r--loc_api/libloc_api_50001/loc_eng_dmn_conn_thread_helper.c1
-rw-r--r--loc_api/libloc_api_50001/loc_eng_log.cpp4
-rw-r--r--loc_api/libloc_api_50001/loc_eng_msg.h38
-rw-r--r--loc_api/libloc_api_50001/loc_eng_msg_id.h6
-rw-r--r--loc_api/libloc_api_50001/loc_eng_ni.cpp2
-rw-r--r--loc_api/libloc_api_50001/loc_eng_nmea.cpp702
-rw-r--r--loc_api/libloc_api_50001/loc_eng_nmea.h2
-rw-r--r--loc_api/libloc_api_50001/loc_eng_xtra.cpp6
-rw-r--r--loc_api/loc_api_v02/Android.mk52
-rw-r--r--loc_api/loc_api_v02/LocApiV02Adapter.cpp2365
-rw-r--r--loc_api/loc_api_v02/LocApiV02Adapter.h182
-rw-r--r--loc_api/loc_api_v02/Makefile.am42
-rw-r--r--loc_api/loc_api_v02/loc_api_sync_req.c547
-rw-r--r--loc_api/loc_api_v02/loc_api_v02_client.c2211
-rw-r--r--loc_api/loc_api_v02/loc_api_v02_client.h1437
-rw-r--r--loc_api/loc_api_v02/loc_api_v02_log.c295
-rw-r--r--loc_api/loc_api_v02/loc_util_log.h75
-rw-r--r--loc_api/loc_api_v02/location_service_v02.c3346
-rw-r--r--loc_api/loc_api_v02/location_service_v02.h8862
-rw-r--r--platform_lib_abstractions/elapsed_millis_since_boot.cpp46
-rw-r--r--platform_lib_abstractions/platform_lib_includes.h35
-rw-r--r--platform_lib_abstractions/platform_lib_macros.h81
-rw-r--r--platform_lib_abstractions/platform_lib_time.h35
-rw-r--r--utils/Android.mk15
-rw-r--r--utils/Makefile.am44
-rw-r--r--utils/linked_list.c2
-rw-r--r--utils/loc_cfg.cpp6
-rw-r--r--utils/loc_log.cpp5
-rw-r--r--utils/loc_timer.c157
-rw-r--r--utils/loc_timer.h54
-rw-r--r--utils/log_util.h44
-rw-r--r--utils/msg_q.c2
59 files changed, 22067 insertions, 426 deletions
diff --git a/Makefile.am b/Makefile.am
new file mode 100644
index 0000000..f374a5c
--- /dev/null
+++ b/Makefile.am
@@ -0,0 +1,10 @@
+# Makefile.am - Automake script for gps loc_api
+#
+
+ACLOCAL_AMFLAGS = -I m4
+
+SUBDIRS = utils loc_api/libloc_api_50001 loc_api/loc_api_v02
+
+pkgconfigdir = $(libdir)/pkgconfig
+pkgconfig_DATA = loc-api.pc
+EXTRA_DIST = $(pkgconfig_DATA)
diff --git a/configure.ac b/configure.ac
new file mode 100644
index 0000000..dca18a1
--- /dev/null
+++ b/configure.ac
@@ -0,0 +1,85 @@
+# configure.ac -- Autoconf script for gps loc_api
+#
+# Process this file with autoconf to produce a configure script
+
+# Requires autoconf tool later than 2.61
+AC_PREREQ(2.61)
+# Initialize the gps loc_api package version 1.0.0
+AC_INIT([loc-api],1.0.0)
+# Does not strictly follow GNU Coding standards
+AM_INIT_AUTOMAKE([foreign])
+# Disables auto rebuilding of configure, Makefile.ins
+AM_MAINTAINER_MODE
+# Verifies the --srcdir is correct by checking for the path
+AC_CONFIG_SRCDIR([utils/loc_cfg.cpp])
+# defines some macros variable to be included by source
+AC_CONFIG_HEADERS([config.h])
+AC_CONFIG_MACRO_DIR([m4])
+
+# Checks for programs.
+AC_PROG_LIBTOOL
+AC_PROG_CXX
+AC_PROG_CC
+AM_PROG_CC_C_O
+AC_PROG_AWK
+AC_PROG_CPP
+AC_PROG_INSTALL
+AC_PROG_LN_S
+AC_PROG_MAKE_SET
+PKG_PROG_PKG_CONFIG
+
+# Checks for libraries.
+PKG_CHECK_MODULES([QMIF], [qmi-framework])
+AC_SUBST([QMIF_CFLAGS])
+AC_SUBST([QMIF_LIBS])
+
+AC_ARG_WITH([libhardware_includes],
+ AC_HELP_STRING([--with-libhardware-includes=@<:@dir@:>@],
+ [Specify the location of the libhardware headers]),
+ [libhardware_incdir=$withval],
+ with_libhardware_includes=no)
+
+if test "x$with_libhardware_includes" != "xno"; then
+ CPPFLAGS="${CPPFLAGS} -I${libhardware_incdir}"
+fi
+
+AC_ARG_WITH([core_includes],
+ AC_HELP_STRING([--with-core-includes=@<:@dir@:>@],
+ [Specify the location of the core headers]),
+ [core_incdir=$withval],
+ with_core_includes=no)
+
+if test "x$with_core_includes" != "xno"; then
+ CPPFLAGS="${CPPFLAGS} -I${core_incdir}"
+fi
+
+AC_SUBST([CPPFLAGS])
+
+AC_ARG_WITH([glib],
+ AC_HELP_STRING([--with-glib],
+ [enable glib, building HLOS systems which use glib]))
+
+if (test "x${with_glib}" = "xyes"); then
+ AC_DEFINE(ENABLE_USEGLIB, 1, [Define if HLOS systems uses glib])
+ PKG_CHECK_MODULES(GTHREAD, gthread-2.0 >= 2.16, dummy=yes,
+ AC_MSG_ERROR(GThread >= 2.16 is required))
+ PKG_CHECK_MODULES(GLIB, glib-2.0 >= 2.16, dummy=yes,
+ AC_MSG_ERROR(GLib >= 2.16 is required))
+ GLIB_CFLAGS="$GLIB_CFLAGS $GTHREAD_CFLAGS"
+ GLIB_LIBS="$GLIB_LIBS $GTHREAD_LIBS"
+
+ AC_SUBST(GLIB_CFLAGS)
+ AC_SUBST(GLIB_LIBS)
+fi
+
+AM_CONDITIONAL(USE_GLIB, test "x${with_glib}" = "xyes")
+
+AC_CONFIG_FILES([ \
+ Makefile \
+ utils/Makefile \
+ loc_api/libloc_api_50001/Makefile \
+ loc_api/loc_api_v02/Makefile \
+ loc-api.pc \
+ ])
+
+AC_OUTPUT
diff --git a/etc/gps.conf b/etc/gps.conf
index 977e7b3..c0943da 100755
--- a/etc/gps.conf
+++ b/etc/gps.conf
@@ -25,6 +25,7 @@ NTP_SERVER=time.gpsonextra.net
# DEBUG LEVELS: 0 - none, 1 - Error, 2 - Warning, 3 - Info
# 4 - Debug, 5 - Verbose
+# If DEBUG_LEVEL is commented, Android's logging levels will be used
DEBUG_LEVEL = 3
# Intermediate position report, 1=enable, 0=disable
diff --git a/loc-api.pc.in b/loc-api.pc.in
new file mode 100644
index 0000000..3b4f81b
--- /dev/null
+++ b/loc-api.pc.in
@@ -0,0 +1,10 @@
+prefix=@prefix@
+exec_prefix=@exec_prefix@
+libdir=@libdir@
+includedir=@includedir@
+
+Name: loc-api
+Description: Qualcomm GPS Location API
+Version: @VERSION@
+Libs: -L${libdir} -lgps_utils_so -lloc_adapter_so -lloc_eng_so -lgps_default_so -lloc_api
+Cflags: -I${includedir}/loc-api/libloc_api_50001 -I${includedir}/loc-api/utils -I${includedir}/ -I${includedir}/loc-api
diff --git a/loc_api/ds_api/Android.mk b/loc_api/ds_api/Android.mk
new file mode 100644
index 0000000..ca04f51
--- /dev/null
+++ b/loc_api/ds_api/Android.mk
@@ -0,0 +1,49 @@
+ifneq ($(BUILD_TINY_ANDROID),true)
+
+LOCAL_PATH := $(call my-dir)
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := libds_api
+
+LOCAL_MODULE_TAGS := optional
+
+LOCAL_SHARED_LIBRARIES := \
+ libutils \
+ libcutils \
+ libqmi_cci \
+ libqmi_csi \
+ libqmi_common_so \
+ libgps.utils \
+ libdsi_netctrl \
+ libqmiservices
+
+
+LOCAL_SRC_FILES += \
+ ds_client.c
+
+LOCAL_CFLAGS += \
+ -fno-short-enums \
+ -D_ANDROID_
+
+LOCAL_COPY_HEADERS_TO:= ds_api/
+
+LOCAL_COPY_HEADERS:= \
+ ds_client.h
+
+LOCAL_LDFLAGS += -Wl,--export-dynamic
+
+## Includes
+LOCAL_C_INCLUDES := \
+ $(TARGET_OUT_HEADERS)/libloc_eng \
+ $(TARGET_OUT_HEADERS)/qmi-framework/inc \
+ $(TARGET_OUT_HEADERS)/qmi/inc \
+ $(TARGET_OUT_HEADERS)/gps.utils \
+ $(TARGET_OUT_HEADERS)/data/inc
+
+
+LOCAL_PRELINK_MODULE := false
+
+include $(BUILD_SHARED_LIBRARY)
+
+endif # not BUILD_TINY_ANDROID
diff --git a/loc_api/ds_api/ds_client.c b/loc_api/ds_api/ds_client.c
new file mode 100644
index 0000000..2dcf063
--- /dev/null
+++ b/loc_api/ds_api/ds_client.c
@@ -0,0 +1,704 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#define LOG_NDEBUG 0
+#define LOG_TAG "LocSvc_ds_client"
+
+#include <stdlib.h>
+#include <string.h>
+#include <stdint.h>
+#include <stdbool.h>
+#include <stddef.h>
+#include <wireless_data_service_v01.h>
+#include <utils/Log.h>
+#include <log_util.h>
+#include <loc_log.h>
+#include <qmi_client.h>
+#include <qmi_idl_lib.h>
+#include <qmi_cci_target_ext.h>
+#include <qmi_cci_target.h>
+#include <qmi_cci_common.h>
+#include <dsi_netctrl.h>
+#include <ds_client.h>
+
+#include<sys/time.h>
+
+//Timeout to wait for wds service notification from qmi
+#define DS_CLIENT_SERVICE_TIMEOUT (4000)
+//Max timeout for the service to come up
+#define DS_CLIENT_SERVICE_TIMEOUT_TOTAL (40000)
+//Timeout for the service to respond to sync msg
+#define DS_CLIENT_SYNC_MSG_TIMEOUT (5000)
+/*Request messages the WDS client can send to the WDS service*/
+typedef union
+{
+ /*Requests the service for a list of all profiles present*/
+ wds_get_profile_list_req_msg_v01 *p_get_profile_list_req;
+ /*Requests the service for a profile's settings*/
+ wds_get_profile_settings_req_msg_v01 *p_get_profile_settings_req;
+}ds_client_req_union_type;
+
+/*Response indications that are sent by the WDS service*/
+typedef union
+{
+ wds_get_profile_list_resp_msg_v01 *p_get_profile_list_resp;
+ wds_get_profile_settings_resp_msg_v01 *p_get_profile_setting_resp;
+}ds_client_resp_union_type;
+
+struct event_strings_s
+{
+ char * str;
+ dsi_net_evt_t evt;
+};
+
+struct event_strings_s event_string_tbl[DSI_EVT_MAX] =
+{
+ NAME_VAL(DSI_EVT_INVALID),
+ NAME_VAL(DSI_EVT_NET_IS_CONN),
+ NAME_VAL(DSI_EVT_NET_NO_NET),
+ NAME_VAL(DSI_EVT_PHYSLINK_DOWN_STATE),
+ NAME_VAL(DSI_EVT_PHYSLINK_UP_STATE),
+ NAME_VAL(DSI_EVT_NET_RECONFIGURED),
+};
+
+typedef struct
+{
+ ds_client_event_ind_cb_type event_cb;
+ void *caller_cookie;
+}ds_caller_data;
+
+typedef struct {
+ //Global dsi handle
+ dsi_hndl_t dsi_net_handle;
+ //Handle to caller's data
+ ds_caller_data caller_data;
+} ds_client_session_data;
+
+void net_ev_cb(dsi_hndl_t handle, void* user_data,
+ dsi_net_evt_t evt, dsi_evt_payload_t *payload_ptr)
+{
+ int i;
+ (void)handle;
+ (void)user_data;
+ (void)payload_ptr;
+ ds_caller_data *callback_data = (ds_caller_data *)user_data;
+
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+
+ if(evt > DSI_EVT_INVALID && evt < DSI_EVT_MAX)
+ {
+ for(i=0;i<DSI_EVT_MAX;i++)
+ {
+ if(event_string_tbl[i].evt == evt)
+ LOC_LOGE("%s:%d]: Callback received: %s",
+ __func__, __LINE__, event_string_tbl[i].str);
+ }
+ switch(evt) {
+ case DSI_EVT_NET_IS_CONN:
+ {
+ LOC_LOGD("%s:%d]: Emergency call started\n", __func__, __LINE__);
+ callback_data->event_cb(E_DS_CLIENT_DATA_CALL_CONNECTED,
+ callback_data->caller_cookie);
+ break;
+ }
+ case DSI_EVT_NET_NO_NET:
+ {
+ LOC_LOGD("%s:%d]: Emergency call stopped\n", __func__, __LINE__);
+ callback_data->event_cb(E_DS_CLIENT_DATA_CALL_DISCONNECTED,
+ callback_data->caller_cookie);
+ break;
+ }
+ default:
+ LOC_LOGD("%s:%d]: uninteresting event\n", __func__, __LINE__);
+ }
+ }
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+}
+
+/*This function is called to obtain a handle to the QMI WDS service*/
+static ds_client_status_enum_type
+ds_client_qmi_ctrl_point_init(qmi_client_type *p_wds_qmi_client)
+{
+ qmi_client_type wds_qmi_client, notifier = NULL;
+ ds_client_status_enum_type status = E_DS_CLIENT_SUCCESS;
+ qmi_service_info *p_service_info = NULL;
+ uint32_t num_services = 0, num_entries = 0;
+ qmi_client_error_type ret = QMI_NO_ERR;
+ unsigned char no_signal = 0;
+ qmi_client_os_params os_params;
+ int timeout = 0;
+
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+
+ //Get service object for QMI_WDS service
+ qmi_idl_service_object_type ds_client_service_object =
+ wds_get_service_object_v01();
+ if(ds_client_service_object == NULL) {
+ LOC_LOGE("%s:%d]: wds_get_service_object_v01 failed\n" ,
+ __func__, __LINE__);
+ status = E_DS_CLIENT_FAILURE_INTERNAL;
+ goto err;
+ }
+
+ //get service addressing information
+ ret = qmi_client_get_service_list(ds_client_service_object, NULL, NULL,
+ &num_services);
+ LOC_LOGD("%s:%d]: qmi_client_get_service_list() first try ret %d, "
+ "num_services %d]\n", __func__, __LINE__, ret, num_services);
+ if(ret != QMI_NO_ERR) {
+ //Register for service notification
+ ret = qmi_client_notifier_init(ds_client_service_object, &os_params, &notifier);
+ if (ret != QMI_NO_ERR) {
+ LOC_LOGE("%s:%d]: qmi_client_notifier_init failed %d\n",
+ __func__, __LINE__, ret);
+ status = E_DS_CLIENT_FAILURE_INTERNAL;
+ goto err;
+ }
+
+ do {
+ QMI_CCI_OS_SIGNAL_CLEAR(&os_params);
+ ret = qmi_client_get_service_list(ds_client_service_object, NULL,
+ NULL, &num_services);
+ if(ret != QMI_NO_ERR) {
+ QMI_CCI_OS_SIGNAL_WAIT(&os_params, DS_CLIENT_SERVICE_TIMEOUT);
+ no_signal = QMI_CCI_OS_SIGNAL_TIMED_OUT(&os_params);
+ if(!no_signal)
+ ret = qmi_client_get_service_list(ds_client_service_object, NULL,
+ NULL, &num_services);
+ }
+ timeout += DS_CLIENT_SERVICE_TIMEOUT;
+ LOC_LOGV("%s:%d]: qmi_client_get_service_list() returned ret: %d,"
+ "no_signal: %d, total timeout: %d\n", __func__, __LINE__,
+ ret, no_signal, timeout);
+ } while( (timeout < DS_CLIENT_SERVICE_TIMEOUT_TOTAL) &&
+ no_signal &&
+ (ret != QMI_NO_ERR) );
+ }
+
+ //Handle failure cases
+ if(num_services == 0 || ret != QMI_NO_ERR) {
+ if(!no_signal) {
+ LOC_LOGE("%s:%d]: qmi_client_get_service_list failed even though"
+ "service is up! Error: %d \n", __func__, __LINE__, ret);
+ status = E_DS_CLIENT_FAILURE_INTERNAL;
+ }
+ else {
+ LOC_LOGE("%s:%d]: qmi_client_get_service_list failed after retries"
+ "Error: %d \n", __func__, __LINE__, ret);
+ status = E_DS_CLIENT_FAILURE_TIMEOUT;
+ }
+ goto err;
+ }
+
+ LOC_LOGD("%s:%d]: qmi_client_get_service_list succeeded\n", __func__, __LINE__);
+
+ //Success
+ p_service_info = (qmi_service_info *)malloc(num_services * sizeof(qmi_service_info));
+ if(p_service_info == NULL) {
+ LOC_LOGE("%s:%d]: could not allocate memory for serviceInfo !!\n",
+ __func__, __LINE__);
+ status = E_DS_CLIENT_FAILURE_INTERNAL;
+ goto err;
+ }
+ num_entries = num_services;
+
+ //Populate service info
+ ret = qmi_client_get_service_list(ds_client_service_object, p_service_info,
+ &num_entries, &num_services);
+ if(ret != QMI_NO_ERR) {
+ LOC_LOGE("%s:%d]: qmi_client_get_service_list failed. ret: %d \n",
+ __func__, __LINE__, ret);
+ status = E_DS_CLIENT_FAILURE_INTERNAL;
+ goto err;
+ }
+
+ //Initialize wds_qmi_client
+ LOC_LOGD("%s:%d]: Initializing WDS client with qmi_client_init\n", __func__,
+ __LINE__);
+ ret = qmi_client_init(&p_service_info[0], ds_client_service_object,
+ NULL, NULL, NULL, &wds_qmi_client);
+ if(ret != QMI_NO_ERR) {
+ LOC_LOGE("%s:%d]: qmi_client_init Error. ret: %d\n", __func__, __LINE__, ret);
+ status = E_DS_CLIENT_FAILURE_INTERNAL;
+ goto err;
+ }
+ LOC_LOGD("%s:%d]: WDS client initialized with qmi_client_init\n", __func__,
+ __LINE__);
+
+ //Store WDS QMI client handle in the parameter passed in
+ *p_wds_qmi_client = wds_qmi_client;
+
+ status = E_DS_CLIENT_SUCCESS;
+ LOC_LOGD("%s:%d]: init success\n", __func__, __LINE__);
+
+ if(notifier)
+ qmi_client_release(notifier);
+
+err:
+ if(p_service_info)
+ free(p_service_info);
+
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return status;
+}
+
+/*This function reads the error code from within the response struct*/
+static ds_client_status_enum_type ds_client_convert_qmi_response(
+ uint32_t req_id,
+ ds_client_resp_union_type *resp_union)
+{
+ ds_client_status_enum_type ret = E_DS_CLIENT_FAILURE_GENERAL;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ switch(req_id)
+ {
+ case QMI_WDS_GET_PROFILE_LIST_REQ_V01 :
+ {
+ if(resp_union->p_get_profile_list_resp->resp.error !=
+ QMI_ERR_NONE_V01) {
+ LOC_LOGE("%s:%d]: Response error: %d", __func__, __LINE__,
+ resp_union->p_get_profile_list_resp->resp.error);
+ }
+ else
+ ret = E_DS_CLIENT_SUCCESS;
+ }
+ break;
+
+ case QMI_WDS_GET_PROFILE_SETTINGS_REQ_V01 :
+ {
+ if(resp_union->p_get_profile_setting_resp->resp.error !=
+ QMI_ERR_NONE_V01) {
+ LOC_LOGE("%s:%d]: Response error: %d", __func__, __LINE__,
+ resp_union->p_get_profile_setting_resp->resp.error);
+ }
+ else
+ ret = E_DS_CLIENT_SUCCESS;
+ }
+ break;
+
+ default:
+ LOC_LOGE("%s:%d]: Unknown request ID\n", __func__, __LINE__);
+ }
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+}
+
+
+static ds_client_status_enum_type ds_client_send_qmi_sync_req(
+ qmi_client_type *ds_client_handle,
+ uint32_t req_id,
+ ds_client_resp_union_type *resp_union,
+ ds_client_req_union_type *req_union)
+{
+ uint32_t req_len = 0;
+ uint32_t resp_len = 0;
+ ds_client_status_enum_type ret = E_DS_CLIENT_SUCCESS;
+ qmi_client_error_type qmi_ret = QMI_NO_ERR;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ switch(req_id)
+ {
+ case QMI_WDS_GET_PROFILE_LIST_REQ_V01 :
+ {
+ req_len = sizeof(wds_get_profile_list_req_msg_v01);
+ resp_len = sizeof(wds_get_profile_list_resp_msg_v01);
+ LOC_LOGD("%s:%d]: req_id = GET_PROFILE_LIST_REQ\n",
+ __func__, __LINE__);
+ }
+ break;
+
+ case QMI_WDS_GET_PROFILE_SETTINGS_REQ_V01 :
+ {
+ req_len = sizeof(wds_get_profile_settings_req_msg_v01);
+ resp_len = sizeof(wds_get_profile_settings_resp_msg_v01);
+ LOC_LOGD("%s:%d]: req_id = GET_PROFILE_SETTINGS_REQ\n",
+ __func__, __LINE__);
+ }
+ break;
+
+ default:
+ LOC_LOGE("%s:%d]: Error unknown req_id=%d\n", __func__, __LINE__,
+ req_id);
+ ret = E_DS_CLIENT_FAILURE_INVALID_PARAMETER;
+ goto err;
+ }
+
+ LOC_LOGD("%s:%d]: req_id=%d, len = %d; resp_len= %d\n", __func__, __LINE__,
+ req_id, req_len, resp_len);
+ //Send msg through QCCI
+ qmi_ret = qmi_client_send_msg_sync(
+ *ds_client_handle,
+ req_id,
+ (void *)req_union->p_get_profile_list_req,
+ req_len,
+ (void *)resp_union->p_get_profile_list_resp,
+ resp_len,
+ DS_CLIENT_SYNC_MSG_TIMEOUT);
+ LOC_LOGD("%s:%d]: qmi_client_send_msg_sync returned: %d", __func__, __LINE__, qmi_ret);
+
+ if(qmi_ret != QMI_NO_ERR) {
+ ret = E_DS_CLIENT_FAILURE_INTERNAL;
+ goto err;
+ }
+
+ ret = ds_client_convert_qmi_response(req_id, resp_union);
+
+err:
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+}
+
+/*This function obtains the list of supported profiles*/
+static ds_client_status_enum_type ds_client_get_profile_list(
+ qmi_client_type *ds_client_handle,
+ ds_client_resp_union_type *profile_list_resp_msg,
+ wds_profile_type_enum_v01 profile_type)
+{
+ ds_client_status_enum_type ret = E_DS_CLIENT_SUCCESS;
+ ds_client_req_union_type req_union;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+
+ req_union.p_get_profile_list_req = NULL;
+ req_union.p_get_profile_list_req = (wds_get_profile_list_req_msg_v01 *)
+ calloc(1, sizeof(wds_get_profile_list_req_msg_v01));
+ if(req_union.p_get_profile_list_req == NULL) {
+ LOC_LOGE("%s:%d]: Could not allocate memory for"
+ "wds_get_profile_list_req_msg_v01\n", __func__, __LINE__);
+ goto err;
+ }
+ //Populate required members of the request structure
+ req_union.p_get_profile_list_req->profile_type_valid = 1;
+ req_union.p_get_profile_list_req->profile_type = profile_type;
+ ret = ds_client_send_qmi_sync_req(ds_client_handle,
+ QMI_WDS_GET_PROFILE_LIST_REQ_V01,
+ profile_list_resp_msg, &req_union);
+ if(ret != E_DS_CLIENT_SUCCESS) {
+ LOC_LOGE("%s:%d]: ds_client_send_qmi_req failed. ret: %d\n",
+ __func__, __LINE__, ret);
+ goto err;
+ }
+err:
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ if(req_union.p_get_profile_list_req)
+ free(req_union.p_get_profile_list_req);
+ return ret;
+}
+
+/*This function obtains settings for the profile specified by
+ the profile_identifier*/
+static ds_client_status_enum_type ds_client_get_profile_settings(
+ qmi_client_type *ds_client_handle,
+ ds_client_resp_union_type *profile_settings_resp_msg,
+ wds_profile_identifier_type_v01 *profile_identifier)
+{
+ ds_client_status_enum_type ret = E_DS_CLIENT_SUCCESS;
+ ds_client_req_union_type req_union;
+
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ //Since it's a union containing a pointer to a structure,
+ //following entities have the same address
+ //- req_union
+ //- req_union.p_get_profile_settings_req
+ //- req_union.p_get_profile_settings_req->profile
+ //so we can very well assign req_union = profile_identifier
+ req_union.p_get_profile_settings_req =
+ (wds_get_profile_settings_req_msg_v01 *)profile_identifier;
+ ret = ds_client_send_qmi_sync_req(ds_client_handle,
+ QMI_WDS_GET_PROFILE_SETTINGS_REQ_V01,
+ profile_settings_resp_msg, &req_union);
+ if(ret != E_DS_CLIENT_SUCCESS) {
+ LOC_LOGE("%s:%d]: ds_client_send_qmi_req failed. ret: %d\n",
+ __func__, __LINE__, ret);
+ goto err;
+ }
+err:
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+}
+
+/*
+ Starts data call using the handle and the profile index
+*/
+ds_client_status_enum_type
+ds_client_start_call(dsClientHandleType client_handle, int profile_index)
+{
+ ds_client_status_enum_type ret = E_DS_CLIENT_FAILURE_GENERAL;
+ dsi_call_param_value_t param_info;
+ dsi_hndl_t dsi_handle;
+ ds_client_session_data *ds_global_data = (ds_client_session_data *)client_handle;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ if(ds_global_data == NULL) {
+ LOC_LOGE("%s:%d]: Null callback parameter\n", __func__, __LINE__);
+ goto err;
+ }
+ dsi_handle = ds_global_data->dsi_net_handle;
+ //Set profile index as call parameter
+ param_info.buf_val = NULL;
+ param_info.num_val = profile_index;
+ dsi_set_data_call_param(dsi_handle,
+ DSI_CALL_INFO_UMTS_PROFILE_IDX,
+ &param_info);
+ LOC_LOGD("%s:%d]: Starting emergency call with profile index %d\n",
+ __func__, __LINE__, param_info.num_val);
+ if(dsi_start_data_call(dsi_handle) == DSI_SUCCESS) {
+ LOC_LOGD("%s:%d]: Sent request to start data call\n",
+ __func__, __LINE__);
+ ret = E_DS_CLIENT_SUCCESS;
+ }
+ else {
+ LOC_LOGE("%s:%d]: Could not send req to start data call \n", __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_GENERAL;
+ goto err;
+ }
+
+err:
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+
+}
+
+/*Function to open an emergency call. Does the following things:
+ - Obtains a handle to the WDS service
+ - Obtains a list of profiles configured in the modem
+ - Queries each profile and obtains settings to check if emergency calls
+ are supported
+ - Returns the profile index that supports emergency calls
+ - Returns handle to dsi_netctrl*/
+ds_client_status_enum_type
+ds_client_open_call(dsClientHandleType *client_handle,
+ ds_client_cb_data *callback,
+ void *caller_cookie,
+ int *profile_index)
+{
+ ds_client_status_enum_type ret = E_DS_CLIENT_FAILURE_GENERAL;
+ ds_client_resp_union_type profile_list_resp_msg;
+ ds_client_resp_union_type profile_settings_resp_msg;
+ wds_profile_identifier_type_v01 profile_identifier;
+ uint32_t i=0;
+ dsi_hndl_t dsi_handle;
+ ds_client_session_data **ds_global_data = (ds_client_session_data **)client_handle;
+ unsigned char call_profile_index_found = 0;
+ uint32_t emergency_profile_index=0;
+ qmi_client_type wds_qmi_client;
+
+ profile_list_resp_msg.p_get_profile_list_resp = NULL;
+ profile_settings_resp_msg.p_get_profile_setting_resp = NULL;
+
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ if(callback == NULL || ds_global_data == NULL) {
+ LOC_LOGE("%s:%d]: Null callback parameter\n", __func__, __LINE__);
+ goto err;
+ }
+
+ ret = ds_client_qmi_ctrl_point_init(&wds_qmi_client);
+ if(ret != E_DS_CLIENT_SUCCESS) {
+ LOC_LOGE("%s:%d]: ds_client_qmi_ctrl_point_init failed. ret: %d\n",
+ __func__, __LINE__, ret);
+ goto err;
+ }
+
+ //Allocate memory for the response msg to obtain a list of profiles
+ profile_list_resp_msg.p_get_profile_list_resp = (wds_get_profile_list_resp_msg_v01 *)
+ calloc(1, sizeof(wds_get_profile_list_resp_msg_v01));
+ if(profile_list_resp_msg.p_get_profile_list_resp == NULL) {
+ LOC_LOGE("%s:%d]: Could not allocate memory for"
+ "p_get_profile_list_resp\n", __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_NOT_ENOUGH_MEMORY;
+ goto err;
+ }
+
+ LOC_LOGD("%s:%d]: Getting profile list\n", __func__, __LINE__);
+ ret = ds_client_get_profile_list(&wds_qmi_client,
+ &profile_list_resp_msg,
+ WDS_PROFILE_TYPE_3GPP_V01);
+ if(ret != E_DS_CLIENT_SUCCESS) {
+ LOC_LOGE("%s:%d]: ds_client_get_profile_list failed. ret: %d\n",
+ __func__, __LINE__, ret);
+ goto err;
+ }
+ LOC_LOGD("%s:%d]: Got profile list; length = %d\n", __func__, __LINE__,
+ profile_list_resp_msg.p_get_profile_list_resp->profile_list_len);
+
+ //Allocate memory for the response msg to obtain profile settings
+ //We allocate memory for only one response msg and keep re-using it
+ profile_settings_resp_msg.p_get_profile_setting_resp =
+ (wds_get_profile_settings_resp_msg_v01 *)
+ calloc(1, sizeof(wds_get_profile_settings_resp_msg_v01));
+ if(profile_settings_resp_msg.p_get_profile_setting_resp == NULL) {
+ LOC_LOGE("%s:%d]: Could not allocate memory for"
+ "p_get_profile_setting_resp\n", __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_NOT_ENOUGH_MEMORY;
+ goto err;
+ }
+
+ //Loop over the list of profiles to find a profile that supports
+ //emergency calls
+ for(i=0; i < profile_list_resp_msg.p_get_profile_list_resp->profile_list_len; i++) {
+ /*QMI_WDS_GET_PROFILE_SETTINGS_REQ requires an input data
+ structure that is of type wds_profile_identifier_type_v01
+ We have to fill that structure for each profile from the
+ info obtained from the profile list*/
+ //copy profile type
+ profile_identifier.profile_type =
+ profile_list_resp_msg.p_get_profile_list_resp->profile_list[i].profile_type;
+ //copy profile index
+ profile_identifier.profile_index =
+ profile_list_resp_msg.p_get_profile_list_resp->profile_list[i].profile_index;
+
+ ret = ds_client_get_profile_settings(&wds_qmi_client,
+ &profile_settings_resp_msg,
+ &profile_identifier);
+ if(ret != E_DS_CLIENT_SUCCESS) {
+ LOC_LOGE("%s:%d]: ds_client_get_profile_settings failed. ret: %d\n",
+ __func__, __LINE__, ret);
+ goto err;
+ }
+ LOC_LOGD("%s:%d]: Got profile setting for profile %d\n", __func__, __LINE__, i);
+ LOC_LOGD("%s:%d]: Profile name: %s\n", __func__, __LINE__,
+ profile_settings_resp_msg.p_get_profile_setting_resp->profile_name);
+
+ if(profile_settings_resp_msg.p_get_profile_setting_resp->support_emergency_calls_valid) {
+ if(profile_settings_resp_msg.p_get_profile_setting_resp->support_emergency_calls) {
+ LOC_LOGD("%s:%d]: Found emergency profile in profile %d"
+ , __func__, __LINE__, i);
+ call_profile_index_found = 1;
+ emergency_profile_index = profile_identifier.profile_index;
+ break;
+ }
+ else
+ LOC_LOGE("%s:%d]: Emergency profile valid but not supported in profile: %d "
+ , __func__, __LINE__, i);
+ }
+ //Since this struct is loaded with settings for the next profile,
+ //it is important to clear out the memory to avoid values/flags
+ //from being carried over
+ memset((void *)profile_settings_resp_msg.p_get_profile_setting_resp,
+ 0, sizeof(wds_get_profile_settings_resp_msg_v01));
+ }
+
+ //Release qmi client handle
+ if(qmi_client_release(wds_qmi_client) != QMI_NO_ERR) {
+ LOC_LOGE("%s:%d]: Could not release qmi client handle\n",
+ __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_GENERAL;
+ }
+
+ if(call_profile_index_found) {
+ *profile_index = emergency_profile_index;
+ *ds_global_data = (ds_client_session_data *)calloc(1, sizeof(ds_client_session_data));
+ if(*ds_global_data == NULL) {
+ LOC_LOGE("%s:%d]: Could not allocate memory for ds_global_data. Failing\n",
+ __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_NOT_ENOUGH_MEMORY;
+ goto err;
+ }
+
+ (*ds_global_data)->caller_data.event_cb = callback->event_cb;
+ (*ds_global_data)->caller_data.caller_cookie = caller_cookie;
+ dsi_handle = dsi_get_data_srvc_hndl(net_ev_cb, &(*ds_global_data)->caller_data);
+ if(dsi_handle == NULL) {
+ LOC_LOGE("%s:%d]: Could not get data handle. Retry Later\n",
+ __func__, __LINE__);
+ ret = E_DS_CLIENT_RETRY_LATER;
+ goto err;
+ }
+ else
+ (*ds_global_data)->dsi_net_handle = dsi_handle;
+ }
+ else {
+ LOC_LOGE("%s:%d]: Could not find a profile that supports emergency calls",
+ __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_GENERAL;
+ }
+err:
+ if(profile_list_resp_msg.p_get_profile_list_resp)
+ free(profile_list_resp_msg.p_get_profile_list_resp);
+ if(profile_settings_resp_msg.p_get_profile_setting_resp)
+ free(profile_settings_resp_msg.p_get_profile_setting_resp);
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+}
+
+ds_client_status_enum_type ds_client_stop_call(dsClientHandleType client_handle)
+{
+ ds_client_status_enum_type ret = E_DS_CLIENT_SUCCESS;
+ ds_client_session_data *p_ds_global_data = (ds_client_session_data *)client_handle;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+
+ if(client_handle == NULL) {
+ LOC_LOGE("%s:%d]: Null argument received. Failing\n", __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_GENERAL;
+ goto err;
+ }
+
+ if(dsi_stop_data_call(p_ds_global_data->dsi_net_handle) == DSI_SUCCESS) {
+ LOC_LOGD("%s:%d]: Sent request to stop data call\n", __func__, __LINE__);
+ }
+ else {
+ LOC_LOGE("%s:%d]: Could not send request to stop data call\n",
+ __func__, __LINE__);
+ ret = E_DS_CLIENT_FAILURE_GENERAL;
+ goto err;
+ }
+
+err:
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+}
+
+/*
+ Stops data call associated with the data handle
+*/
+void ds_client_close_call(dsClientHandleType *client_handle)
+{
+ ds_client_session_data **ds_global_data = (ds_client_session_data **)client_handle;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ if(client_handle == NULL || *client_handle == NULL) {
+ LOC_LOGE("%s:%d]: Null argument received. Failing\n", __func__, __LINE__);
+ goto err;
+ }
+ dsi_rel_data_srvc_hndl((*ds_global_data)->dsi_net_handle);
+ (*ds_global_data)->dsi_net_handle = NULL;
+ free(*ds_global_data);
+ *ds_global_data = NULL;
+ LOC_LOGD("%s:%d]: Released Data handle\n", __func__, __LINE__);
+err:
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return;
+}
+
+int ds_client_init()
+{
+ int ret = 0;
+ LOC_LOGD("%s:%d]:Enter\n", __func__, __LINE__);
+ if(DSI_SUCCESS != dsi_init(DSI_MODE_GENERAL))
+ {
+ LOC_LOGE("%s:%d]:dsi_init failed\n", __func__, __LINE__);
+ ret = -1;
+ }
+ LOC_LOGD("%s:%d]:Exit\n", __func__, __LINE__);
+ return ret;
+}
diff --git a/loc_api/ds_api/ds_client.h b/loc_api/ds_api/ds_client.h
new file mode 100644
index 0000000..044f96a
--- /dev/null
+++ b/loc_api/ds_api/ds_client.h
@@ -0,0 +1,142 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _DS_CLIENT_H_
+#define _DS_CLIENT_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+typedef void* dsClientHandleType;
+
+typedef enum
+{
+ E_DS_CLIENT_SUCCESS = 0,
+ /**< Request was successful. */
+
+ E_DS_CLIENT_FAILURE_GENERAL = 1,
+ /**< Failed because of a general failure. */
+
+ E_DS_CLIENT_FAILURE_UNSUPPORTED = 2,
+ /**< Failed because the service does not support the command. */
+
+ E_DS_CLIENT_FAILURE_INVALID_PARAMETER = 3,
+ /**< Failed because the request contained invalid parameters. */
+
+ E_DS_CLIENT_FAILURE_ENGINE_BUSY = 4,
+ /**< Failed because the engine is busy. */
+
+ E_DS_CLIENT_FAILURE_PHONE_OFFLINE = 5,
+ /**< Failed because the phone is offline. */
+
+ E_DS_CLIENT_FAILURE_TIMEOUT = 6,
+ /**< Failed because of a timeout. */
+
+ E_DS_CLIENT_FAILURE_SERVICE_NOT_PRESENT = 7,
+ /**< Failed because the service is not present. */
+
+ E_DS_CLIENT_FAILURE_SERVICE_VERSION_UNSUPPORTED = 8,
+ /**< Failed because the service version is unsupported. */
+
+ E_DS_CLIENT_FAILURE_CLIENT_VERSION_UNSUPPORTED = 9,
+ /**< Failed because the service does not support client version. */
+
+ E_DS_CLIENT_FAILURE_INVALID_HANDLE = 10,
+ /**< Failed because an invalid handle was specified. */
+
+ E_DS_CLIENT_FAILURE_INTERNAL = 11,
+ /**< Failed because of an internal error in the service. */
+
+ E_DS_CLIENT_FAILURE_NOT_INITIALIZED = 12,
+ /**< Failed because the service has not been initialized. */
+
+ E_DS_CLIENT_FAILURE_NOT_ENOUGH_MEMORY = 13,
+ /**< Failed because not rnough memory to do the operation.*/
+
+ E_DS_CLIENT_SERVICE_ALREADY_STARTED = 14,
+ /*Service is already started*/
+
+ E_DS_CLIENT_DATA_CALL_CONNECTED = 15,
+
+ E_DS_CLIENT_DATA_CALL_DISCONNECTED = 16,
+
+ E_DS_CLIENT_RETRY_LATER = 17
+}ds_client_status_enum_type;
+
+typedef enum {
+ DATA_CALL_NONE = 0,
+ DATA_CALL_OPEN,
+ DATA_CALL_CLOSE
+}data_call_request_enum_type;
+
+typedef void (*ds_client_event_ind_cb_type)(ds_client_status_enum_type result,
+ void* loc_adapter_cookie);
+typedef struct {
+ ds_client_event_ind_cb_type event_cb;
+}ds_client_cb_data;
+
+/*
+ This function is to be called as a first step by each process that
+ needs to use data services. This call internally calls dsi_init()
+ and prepares the module for making data calls.
+ Needs to be called once for every process
+*/
+int ds_client_init();
+
+/*
+ Obtains a handle to the dsi_netctrl layer and looks up the profile
+ to make the call. As of now. It only searches for profiles that
+ support emergency calls
+ */
+ds_client_status_enum_type ds_client_open_call(dsClientHandleType *client_handle,
+ ds_client_cb_data *callback,
+ void *loc_adapter_cookie,
+ int *profile_index);
+
+/*
+ Starts a data call using the profile number provided
+ */
+ds_client_status_enum_type ds_client_start_call(dsClientHandleType client_handle,
+ int profile_index);
+
+/*
+ Stops a data call associated with the handle
+*/
+ds_client_status_enum_type ds_client_stop_call(dsClientHandleType client_handle);
+
+/*
+ Releases the handle used for making data calls
+*/
+void ds_client_close_call(dsClientHandleType *client_handle);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/Makefile.am b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/Makefile.am
new file mode 100644
index 0000000..f5c5136
--- /dev/null
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/Makefile.am
@@ -0,0 +1,46 @@
+AM_CFLAGS = \
+ -I../../../utils \
+ -I../../../platform_lib_abstractions \
+ -I./rpc_inc \
+ -I../libloc_api-rpc-stub/inc \
+ -I../../libloc_api_50001 \
+ $(MSM7K_CFLAGS) \
+ -DUSE_QCOM_AUTO_RPC
+
+requiredlibs = \
+ ../../../utils/libgps_utils_so.la \
+ $(MSM7K_LIBS)
+
+h_sources = \
+ rpc_inc/loc_api_rpc_glue.h \
+ rpc_inc/loc_api_fixup.h \
+ rpc_inc/loc_api_sync_call.h \
+ rpc_inc/loc_apicb_appinit.h \
+
+c_sources = \
+ src/loc_api_rpc_glue.c \
+ src/loc_api_sync_call.c \
+ src/loc_apicb_appinit.c \
+ src/loc_api_fixup.c \
+ src/loc_api_log.c \
+ src/LocApiRpcAdapter.cpp \
+
+
+library_includedir = $(pkgincludedir)/libloc_api-rpc-50001/libloc_api-rpc-glue/rpc_inc
+library_include_HEADERS = $(h_sources)
+libloc_api_rpc_qc_la_SOURCES = $(c_sources) $(h_sources)
+
+if USE_GLIB
+libloc_api_rpc_qc_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libloc_api_rpc_qc_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libloc_api_rpc_qc_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libloc_api_rpc_qc_la_CFLAGS = $(AM_CFLAGS)
+libloc_api_rpc_qc_la_LDFLAGS = -lpthread -shared -version-info 1:0:0
+libloc_api_rpc_qc_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+
+libloc_api_rpc_qc_la_LIBADD = $(requiredlibs) -lstdc++
+
+#Create and Install Libraries
+lib_LTLIBRARIES = libloc_api_rpc_qc.la
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/rpc_inc/loc_api_rpc_glue.h b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/rpc_inc/loc_api_rpc_glue.h
index 010e147..6df33ae 100644
--- a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/rpc_inc/loc_api_rpc_glue.h
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/rpc_inc/loc_api_rpc_glue.h
@@ -48,8 +48,8 @@ typedef unsigned char boolean;
#define TRUE 1
#define FALSE 0
-#include "rpc_inc/loc_api_fixup.h"
-#include "rpc_inc/loc_api_sync_call.h"
+#include "loc_api_fixup.h"
+#include "loc_api_sync_call.h"
#include <rpc/clnt.h>
#ifdef __cplusplus
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/LocApiRpcAdapter.cpp b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/LocApiRpcAdapter.cpp
index 22e4f7e..e836f10 100644
--- a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/LocApiRpcAdapter.cpp
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/LocApiRpcAdapter.cpp
@@ -31,12 +31,20 @@
#include <unistd.h>
#include <math.h>
+#ifndef USE_GLIB
#include <utils/SystemClock.h>
+#endif /* USE_GLIB */
#include "LocApiRpcAdapter.h"
#include "loc_api_rpcgen_common_rpc.h"
#include "log_util.h"
#include "loc_log.h"
#include "loc_api_log.h"
+#ifdef USE_GLIB
+#include <glib.h>
+#endif
+#include "librpc.h"
+#include "platform_lib_includes.h"
+
#define LOC_XTRA_INJECT_DEFAULT_TIMEOUT (3100)
#define XTRA_BLOCK_SIZE (3072)
@@ -390,7 +398,7 @@ LocApiRpcAdapter::setTime(GpsUtcTime time, int64_t timeReference, int uncertaint
time_info_ptr = &ioctl_data.rpc_loc_ioctl_data_u_type_u.assistance_data_time;
time_info_ptr->time_utc = time;
- time_info_ptr->time_utc += (int64_t)(android::elapsedRealtime() - timeReference);
+ time_info_ptr->time_utc += (int64_t)(ELAPSED_MILLIS_SINCE_BOOT_PLATFORM_LIB_ABSTRACTION - timeReference);
time_info_ptr->uncertainty = uncertainty; // Uncertainty in ms
ioctl_data.disc = ioctl_type;
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_log.c b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_log.c
index 256545a..1c48232 100644
--- a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_log.c
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_log.c
@@ -33,6 +33,7 @@
#include "loc_api_log.h"
#include "loc_log.h"
#include "log_util.h"
+#include "platform_lib_includes.h"
#include "rpc/rpc.h"
#include "loc_api_fixup.h"
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_rpc_glue.c b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_rpc_glue.c
index c047cb3..e0f400c 100644
--- a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_rpc_glue.c
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_rpc_glue.c
@@ -57,10 +57,15 @@
/* Logging */
#define LOG_TAG "LocSvc_api_rpc_glue"
#define LOG_NDDEBUG 0
+#ifndef USE_GLIB
#include <utils/Log.h>
+#endif /* USE_GLIB */
/* Logging Improvement */
#include "log_util.h"
+#include "platform_lib_includes.h"
+/*Maximum number of Modem init*/
+#define RPC_TRY_NUM 10
/*Maximum number of Modem init*/
#define RPC_TRY_NUM 10
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_sync_call.c b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_sync_call.c
index 9541a40..ae629d7 100644
--- a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_sync_call.c
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-glue/src/loc_api_sync_call.c
@@ -40,7 +40,9 @@
/* Logging */
#define LOG_TAG "LocSvc_api_rpc_glue"
// #define LOG_NDDEBUG 0
+#ifndef USE_GLIB
#include <utils/Log.h>
+#endif /* USE_GLIB */
/***************************************************************************
* DATA FOR ASYNCHRONOUS RPC PROCESSING
diff --git a/loc_api/libloc_api-rpc-50001/libloc_api-rpc-stub/Makefile.am b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-stub/Makefile.am
new file mode 100644
index 0000000..4ac8c8a
--- /dev/null
+++ b/loc_api/libloc_api-rpc-50001/libloc_api-rpc-stub/Makefile.am
@@ -0,0 +1,42 @@
+AM_CFLAGS = \
+ -I../../../utils \
+ -I./inc \
+ $(MSM7K_CFLAGS)
+
+requiredlibs = \
+ ../../../utils/libgps_utils_so.la \
+ $(MSM7K_LIBS)
+
+h_sources = \
+ inc/loc_api_rpcgen_rpc.h \
+ inc/loc_api_rpcgen_common_rpc.h \
+ inc/loc_api_rpcgen_cb_rpc.h \
+ inc/loc_apicb_appinit.h
+
+c_sources = \
+ src/loc_api_rpcgen_cb_xdr.c \
+ src/loc_api_rpcgen_common_xdr.c \
+ src/loc_api_rpcgen_cb_svc.c \
+ src/loc_api_rpcgen_clnt.c \
+ src/loc_api_rpcgen_xdr.c
+
+
+
+library_includedir = $(pkgincludedir)/libloc_api-rpc-50001/libloc_api-rpc-stub/inc
+library_include_HEADERS = $(h_sources)
+libloc_api_rpcgen_la_SOURCES = $(c_sources) $(h_sources)
+
+if USE_GLIB
+libloc_api_rpcgen_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libloc_api_rpcgen_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libloc_api_rpcgen_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libloc_api_rpcgen_la_CFLAGS = $(AM_CFLAGS)
+libloc_api_rpcgen_la_LDFLAGS = -lpthread -shared -version-info 1:0:0
+libloc_api_rpcgen_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+
+libloc_api_rpcgen_la_LIBADD = $(requiredlibs) -lstdc++
+
+#Create and Install Libraries
+lib_LTLIBRARIES = libloc_api_rpcgen.la
diff --git a/loc_api/libloc_api_50001/LocApiAdapter.cpp b/loc_api/libloc_api_50001/LocApiAdapter.cpp
index f5a498d..b26a400 100644
--- a/loc_api/libloc_api_50001/LocApiAdapter.cpp
+++ b/loc_api/libloc_api_50001/LocApiAdapter.cpp
@@ -192,6 +192,18 @@ void LocApiAdapter::requestATL(int connHandle, AGpsType agps_type)
locEngHandle.sendMsge(locEngHandle.owner, msg);
}
+void LocApiAdapter::requestSuplES(int connHandle)
+{
+ loc_eng_msg_request_supl_es *msg(new loc_eng_msg_request_supl_es(locEngHandle.owner, connHandle));
+ locEngHandle.sendMsge(locEngHandle.owner, msg);
+}
+
+void LocApiAdapter::releaseDataHandle(void)
+{
+ loc_eng_msg_close_data_call *msg(new loc_eng_msg_close_data_call(locEngHandle.owner));
+ locEngHandle.sendMsge(locEngHandle.owner, msg);
+}
+
void LocApiAdapter::releaseATL(int connHandle)
{
loc_eng_msg_release_atl *msg(new loc_eng_msg_release_atl(locEngHandle.owner, connHandle));
@@ -240,3 +252,18 @@ void LocApiAdapter::handleEngineUpEvent()
loc_eng_msg *msg(new loc_eng_msg(locEngHandle.owner, LOC_ENG_MSG_ENGINE_UP));
locEngHandle.sendMsge(locEngHandle.owner, msg);
}
+
+void LocApiAdapter::reportDataCallOpened()
+{
+ loc_eng_msg_atl_open_success *msg(new loc_eng_msg_atl_open_success(locEngHandle.owner,
+ AGPS_TYPE_INVALID,
+ NULL, 0, 0));
+ locEngHandle.sendMsge(locEngHandle.owner, msg);
+}
+
+void LocApiAdapter::reportDataCallClosed()
+{
+ loc_eng_msg_atl_closed *msg(new loc_eng_msg_atl_closed(locEngHandle.owner,
+ AGPS_TYPE_INVALID));
+ locEngHandle.sendMsge(locEngHandle.owner, msg);
+}
diff --git a/loc_api/libloc_api_50001/LocApiAdapter.h b/loc_api/libloc_api_50001/LocApiAdapter.h
index 0cfdb35..ace934e 100644
--- a/loc_api/libloc_api_50001/LocApiAdapter.h
+++ b/loc_api/libloc_api_50001/LocApiAdapter.h
@@ -35,6 +35,7 @@
#include <loc_eng_log.h>
#include <log_util.h>
#include <loc_eng_msg.h>
+#include "platform_lib_includes.h"
#define MAX_APN_LEN 100
#define MAX_URL_LEN 256
@@ -142,7 +143,10 @@ public:
void requestNiNotify(GpsNiNotification &notify, const void* data);
void handleEngineDownEvent();
void handleEngineUpEvent();
-
+ void requestSuplES(int connHandle);
+ void releaseDataHandle(void);
+ void reportDataCallOpened(void);
+ void reportDataCallClosed(void);
// All below functions are to be defined by adapter specific modules:
// RPC, QMI, etc. The default implementation is empty.
inline virtual enum loc_api_adapter_err
@@ -228,6 +232,15 @@ public:
inline bool isInSession() { return navigating; }
inline virtual void setInSession(bool inSession) { navigating = inSession; }
+ inline virtual int openAndStartDataCall()
+ {LOC_LOGW("%s: default implementation invoked", __func__); return -1;}
+ inline virtual void stopDataCall()
+ {LOC_LOGW("%s: default implementation invoked", __func__);}
+ inline virtual void closeDataCall()
+ {LOC_LOGW("%s: default implementation invoked", __func__);}
+ inline virtual int initDataServiceClient()
+ {LOC_LOGW("%s: default implementation invoked", __func__); return -1;}
+
};
extern "C" LocApiAdapter* getLocApiAdapter(LocEng &locEng);
diff --git a/loc_api/libloc_api_50001/Makefile.am b/loc_api/libloc_api_50001/Makefile.am
new file mode 100644
index 0000000..93e633f
--- /dev/null
+++ b/loc_api/libloc_api_50001/Makefile.am
@@ -0,0 +1,79 @@
+AM_CFLAGS = \
+ -I../../utils \
+ -I../../platform_lib_abstractions \
+ -I../ulp/inc \
+ -fno-short-enums \
+ -DFEATURE_GNSS_BIT_API
+
+libloc_adapter_so_la_SOURCES = loc_eng_log.cpp LocApiAdapter.cpp
+
+if USE_GLIB
+libloc_adapter_so_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libloc_adapter_so_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libloc_adapter_so_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libloc_adapter_so_la_CFLAGS = $(AM_CFLAGS)
+libloc_adapter_so_la_LDFLAGS = -lpthread -shared -version-info 1:0:0
+libloc_adapter_so_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+libloc_adapter_so_la_LIBADD = -lstdc++ -lcutils ../../utils/libgps_utils_so.la
+
+
+libloc_eng_so_la_SOURCES = \
+ loc_eng.cpp \
+ loc_eng_agps.cpp \
+ loc_eng_xtra.cpp \
+ loc_eng_ni.cpp \
+ loc_eng_log.cpp \
+ loc_eng_dmn_conn.cpp \
+ loc_eng_dmn_conn_handler.cpp \
+ loc_eng_dmn_conn_thread_helper.c \
+ loc_eng_dmn_conn_glue_msg.c \
+ loc_eng_dmn_conn_glue_pipe.c
+
+
+if USE_GLIB
+libloc_eng_so_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libloc_eng_so_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libloc_eng_so_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libloc_eng_so_la_CFLAGS = $(AM_CFLAGS)
+libloc_eng_so_la_LDFLAGS = -lpthread -shared -version-info 1:0:0
+libloc_eng_so_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+
+libloc_eng_so_la_LIBADD = -lstdc++ -lcutils -ldl ../../utils/libgps_utils_so.la libloc_adapter_so.la
+
+
+libgps_default_so_la_SOURCES = \
+ loc.cpp \
+ gps.c
+
+if USE_GLIB
+libgps_default_so_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libgps_default_so_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libgps_default_so_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libgps_default_so_la_CFLAGS = $(AM_CFLAGS)
+libgps_default_so_la_LDFLAGS = -lpthread -shared -version-info 1:0:0
+libgps_default_so_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+
+libgps_default_so_la_LIBADD = -lstdc++ -lcutils ../../utils/libgps_utils_so.la -ldl libloc_eng_so.la
+
+library_include_HEADERS = \
+ LocApiAdapter.h \
+ loc.h \
+ loc_eng.h \
+ loc_eng_xtra.h \
+ loc_eng_ni.h \
+ loc_eng_agps.h \
+ loc_eng_msg.h \
+ loc_eng_msg_id.h \
+ loc_eng_log.h \
+ ../ulp/inc/ulp.h
+
+library_includedir = $(pkgincludedir)/libloc_api_50001
+
+#Create and Install libraries
+lib_LTLIBRARIES = libloc_adapter_so.la libloc_eng_so.la libgps_default_so.la
diff --git a/loc_api/libloc_api_50001/loc.cpp b/loc_api/libloc_api_50001/loc.cpp
index 34a0f8c..35a9979 100644
--- a/loc_api/libloc_api_50001/loc.cpp
+++ b/loc_api/libloc_api_50001/loc.cpp
@@ -174,6 +174,8 @@ const GpsInterface* gps_get_hardware_interface ()
char propBuf[PROPERTY_VALUE_MAX];
+ loc_eng_read_config();
+
// check to see if GPS should be disabled
property_get("gps.disable", propBuf, "");
if (propBuf[0] == '1')
@@ -216,8 +218,9 @@ extern "C" const GpsInterface* get_gps_interface()
if((target == TARGET_APQ8064_STANDALONE) || (target == TARGET_APQ8030_STANDALONE)) {
gps_conf.CAPABILITIES &= ~(GPS_CAPABILITY_MSA | GPS_CAPABILITY_MSB);
gss_fd = open("/dev/gss", O_RDONLY);
- if (gss_fd < 0)
+ if (gss_fd < 0) {
LOC_LOGE("GSS open failed: %s\n", strerror(errno));
+ }
else {
LOC_LOGD("GSS open success! CAPABILITIES %0lx\n", gps_conf.CAPABILITIES);
}
diff --git a/loc_api/libloc_api_50001/loc.h b/loc_api/libloc_api_50001/loc.h
index 9b1195b..146063a 100644
--- a/loc_api/libloc_api_50001/loc.h
+++ b/loc_api/libloc_api_50001/loc.h
@@ -92,7 +92,8 @@ typedef uint32_t LocPosTechMask;
#define LOC_POS_TECH_MASK_SENSORS ((LocPosTechMask)0x00000008)
#define LOC_POS_TECH_MASK_REFERENCE_LOCATION ((LocPosTechMask)0x00000010)
#define LOC_POS_TECH_MASK_INJECTED_COARSE_POSITION ((LocPosTechMask)0x00000020)
-
+#define LOC_POS_TECH_MASK_AFLT ((LocPosTechMask)0x00000040)
+#define LOC_POS_TECH_MASK_HYBRID ((LocPosTechMask)0x00000080)
void loc_ulp_msg_sender(void* loc_eng_data_p, void* msg);
#ifdef __cplusplus
diff --git a/loc_api/libloc_api_50001/loc_eng.cpp b/loc_api/libloc_api_50001/loc_eng.cpp
index 91367ca..db3cb3f 100644
--- a/loc_api/libloc_api_50001/loc_eng.cpp
+++ b/loc_api/libloc_api_50001/loc_eng.cpp
@@ -47,8 +47,16 @@
#include "LocApiAdapter.h"
#include <cutils/sched_policy.h>
+#ifndef USE_GLIB
#include <utils/SystemClock.h>
#include <utils/Log.h>
+#endif /* USE_GLIB */
+
+#ifdef USE_GLIB
+#include <glib.h>
+#include <sys/syscall.h>
+#endif /* USE_GLIB */
+
#include <string.h>
#include <loc_eng.h>
@@ -60,8 +68,8 @@
#include <loc_eng_nmea.h>
#include <msg_q.h>
#include <loc.h>
-
#include "log_util.h"
+#include "platform_lib_includes.h"
#include "loc_eng_log.h"
#define SUCCESS TRUE
@@ -171,7 +179,7 @@ LocEngContext::LocEngContext(gps_create_thread threadCreator) :
counter(0)
{
LOC_LOGV("LocEngContext %d : %d pthread_id %ld\n",
- getpid(), gettid(),
+ getpid(), GETTID_PLATFORM_LIB_ABSTRACTION,
deferred_action_thread);
}
@@ -523,8 +531,8 @@ int loc_eng_start(loc_eng_data_s_type &loc_eng_data)
ENTRY_LOG_CALLFLOW();
INIT_CHECK(loc_eng_data.context, return -1);
- void* target_q = loc_eng_data.ulp_initialized?
- (void*)((LocEngContext*)(loc_eng_data.context))->ulp_q:
+ void* target_q = loc_eng_data.ulp_initialized ?
+ (void*)((LocEngContext*)(loc_eng_data.context))->ulp_q :
(void*)((LocEngContext*)(loc_eng_data.context))->deferred_q;
//Pass the start messgage to ULP if present & activated
@@ -575,8 +583,8 @@ int loc_eng_stop(loc_eng_data_s_type &loc_eng_data)
ENTRY_LOG_CALLFLOW();
INIT_CHECK(loc_eng_data.context, return -1);
- void* target_q = loc_eng_data.ulp_initialized?
- (void*)((LocEngContext*)(loc_eng_data.context))->ulp_q:
+ void* target_q = loc_eng_data.ulp_initialized ?
+ (void*)((LocEngContext*)(loc_eng_data.context))->ulp_q :
(void*)((LocEngContext*)(loc_eng_data.context))->deferred_q;
//Pass the start messgage to ULP if present & activated
@@ -802,6 +810,38 @@ static void loc_inform_gps_status(loc_eng_data_s_type &loc_eng_data, GpsStatusVa
EXIT_LOG(%s, VOID_RET);
}
+/*
+ Callback function passed to Data Services State Machine
+ This becomes part of the state machine's servicer and
+ is used to send requests to the data services client
+*/
+static int dataCallCb(void *cb_data)
+{
+ LOC_LOGD("Enter dataCallCb\n");
+ int ret=0;
+ if(cb_data != NULL) {
+ dsCbData *cbData = (dsCbData *)cb_data;
+ LocApiAdapter *locAdapter = (LocApiAdapter *)cbData->mAdapter;
+ if(cbData->action == GPS_REQUEST_AGPS_DATA_CONN) {
+ LOC_LOGD("dataCallCb GPS_REQUEST_AGPS_DATA_CONN\n");
+ ret = locAdapter->openAndStartDataCall();
+ }
+ else if(cbData->action == GPS_RELEASE_AGPS_DATA_CONN) {
+ LOC_LOGD("dataCallCb GPS_RELEASE_AGPS_DATA_CONN\n");
+ locAdapter->stopDataCall();
+ }
+ }
+ else {
+ LOC_LOGE("NULL argument received. Failing.\n");
+ ret = -1;
+ goto err;
+ }
+
+err:
+ LOC_LOGD("Exit dataCallCb ret = %d\n", ret);
+ return ret;
+}
+
/*===========================================================================
FUNCTION loc_eng_agps_reinit
@@ -868,15 +908,25 @@ void loc_eng_agps_init(loc_eng_data_s_type &loc_eng_data, AGpsExtCallbacks* call
}
loc_eng_data.agps_status_cb = callbacks->status_cb;
- loc_eng_data.agnss_nif = new AgpsStateMachine(loc_eng_data.agps_status_cb,
+ loc_eng_data.agnss_nif = new AgpsStateMachine(servicerTypeAgps,
+ (void *)loc_eng_data.agps_status_cb,
AGPS_TYPE_SUPL,
false);
- loc_eng_data.internet_nif = new AgpsStateMachine(loc_eng_data.agps_status_cb,
+ loc_eng_data.internet_nif = new AgpsStateMachine(servicerTypeAgps,
+ (void *)loc_eng_data.agps_status_cb,
AGPS_TYPE_WWAN_ANY,
false);
- loc_eng_data.wifi_nif = new AgpsStateMachine(loc_eng_data.agps_status_cb,
+ loc_eng_data.wifi_nif = new AgpsStateMachine(servicerTypeAgps,
+ (void *)loc_eng_data.agps_status_cb,
AGPS_TYPE_WIFI,
true);
+ if(!loc_eng_data.client_handle->initDataServiceClient()) {
+ LOC_LOGD("%s:%d]: Creating new ds state machine\n", __func__, __LINE__);
+ loc_eng_data.ds_nif = new DSStateMachine(servicerTypeExt,
+ (void *)dataCallCb,
+ loc_eng_data.client_handle);
+ LOC_LOGD("%s:%d]: Created new ds state machine\n", __func__, __LINE__);
+ }
loc_eng_dmn_conn_loc_api_server_launch(callbacks->create_thread_cb,
NULL, NULL, &loc_eng_data);
@@ -1305,6 +1355,29 @@ void loc_eng_handle_engine_up(loc_eng_data_s_type &loc_eng_data)
EXIT_LOG(%s, VOID_RET);
}
+#ifdef USE_GLIB
+/*===========================================================================
+FUNCTION set_sched_policy
+
+DESCRIPTION
+ Local copy of this function which bypasses android set_sched_policy
+
+DEPENDENCIES
+ None
+
+RETURN VALUE
+ 0
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+static int set_sched_policy(int tid, SchedPolicy policy)
+{
+ return 0;
+}
+#endif /* USE_GLIB */
+
/*===========================================================================
FUNCTION loc_eng_deferred_action_thread
@@ -1329,7 +1402,7 @@ static void loc_eng_deferred_action_thread(void* arg)
LocEngContext* context = (LocEngContext*)arg;
// make sure we do not run in background scheduling group
- set_sched_policy(gettid(), SP_FOREGROUND);
+ set_sched_policy(GETTID_PLATFORM_LIB_ABSTRACTION, SP_FOREGROUND);
while (1)
{
@@ -1544,7 +1617,10 @@ static void loc_eng_deferred_action_thread(void* arg)
if (loc_eng_data_p->generateNmea && rpMsg->location.position_source == ULP_LOCATION_IS_FROM_GNSS)
{
- loc_eng_nmea_generate_pos(loc_eng_data_p, rpMsg->location, rpMsg->locationExtended);
+ unsigned char generate_nmea = reported && (rpMsg->status != LOC_SESS_FAILURE);
+ loc_eng_nmea_generate_pos(loc_eng_data_p, rpMsg->location,
+ rpMsg->locationExtended,
+ generate_nmea);
}
// Free the allocated memory for rawData
@@ -1660,13 +1736,32 @@ static void loc_eng_deferred_action_thread(void* arg)
loc_eng_data_p->client_handle,
false);
// attempt to unsubscribe from agnss_nif first
- if (! loc_eng_data_p->agnss_nif->unsubscribeRsrc((Subscriber*)&s1)) {
+ if (loc_eng_data_p->agnss_nif->unsubscribeRsrc((Subscriber*)&s1)) {
+ LOC_LOGD("%s:%d]: Unsubscribed from agnss_nif", __func__, __LINE__);
+ }
+ else {
ATLSubscriber s2(arlMsg->handle,
loc_eng_data_p->internet_nif,
loc_eng_data_p->client_handle,
false);
// if unsuccessful, try internet_nif
- loc_eng_data_p->internet_nif->unsubscribeRsrc((Subscriber*)&s2);
+ if(loc_eng_data_p->internet_nif->unsubscribeRsrc((Subscriber*)&s2)) {
+ LOC_LOGD("%s:%d]: Unsubscribed from internet_nif", __func__, __LINE__);
+ }
+ else {
+ DSSubscriber s3(loc_eng_data_p->ds_nif,
+ arlMsg->handle);
+ LOC_LOGD("%s:%d]: Request to stop Emergency call. Handle: %d\n",
+ __func__, __LINE__, arlMsg->handle);
+ if(loc_eng_data_p->ds_nif->unsubscribeRsrc((Subscriber*)&s3)) {
+ LOC_LOGD("%s:%d]: Unsubscribed from ds_nif", __func__, __LINE__);
+ }
+ else {
+ LOC_LOGE("%s:%d]: Could not release ATL. No subscribers found\n",
+ __func__, __LINE__);
+ loc_eng_data_p->client_handle->atlCloseStatus(arlMsg->handle, 0);
+ }
+ }
}
}
break;
@@ -1747,17 +1842,25 @@ static void loc_eng_deferred_action_thread(void* arg)
{
loc_eng_msg_atl_open_success *aosMsg = (loc_eng_msg_atl_open_success*)msg;
AgpsStateMachine* stateMachine;
-
+ LOC_LOGD("%s:%d]: AGPS_TYPE: %d\n", __func__, __LINE__, (int)aosMsg->agpsType);
switch (aosMsg->agpsType) {
case AGPS_TYPE_WIFI: {
+ LOC_LOGD("%s:%d]: AGPS Type wifi\n", __func__, __LINE__);
stateMachine = loc_eng_data_p->wifi_nif;
break;
}
case AGPS_TYPE_SUPL: {
+ LOC_LOGD("%s:%d]: AGPS Type supl\n", __func__, __LINE__);
stateMachine = loc_eng_data_p->agnss_nif;
break;
}
+ case AGPS_TYPE_INVALID: {
+ stateMachine = loc_eng_data_p->ds_nif;
+ LOC_LOGD("%s:%d]: AGPS Type invalid\n", __func__, __LINE__);
+ }
+ break;
default: {
+ LOC_LOGD("%s:%d]: AGPS Type default internet\n", __func__, __LINE__);
stateMachine = loc_eng_data_p->internet_nif;
}
}
@@ -1782,7 +1885,11 @@ static void loc_eng_deferred_action_thread(void* arg)
stateMachine = loc_eng_data_p->agnss_nif;
break;
}
- default: {
+ case AGPS_TYPE_INVALID: {
+ stateMachine = loc_eng_data_p->ds_nif;
+ break;
+ }
+ default: {
stateMachine = loc_eng_data_p->internet_nif;
}
}
@@ -1826,6 +1933,25 @@ static void loc_eng_deferred_action_thread(void* arg)
}
break;
+ case LOC_ENG_MSG_REQUEST_SUPL_ES:
+ {
+ loc_eng_msg_request_supl_es *reqMsg =
+ (loc_eng_msg_request_supl_es *)msg;
+ AgpsStateMachine *stateMachine = loc_eng_data_p->ds_nif;
+ DSSubscriber subscriber(stateMachine, reqMsg->handle);
+ LOC_LOGD("%s:%d]: Starting data call\n", __func__, __LINE__);
+ stateMachine->subscribeRsrc((Subscriber *)&subscriber);
+ }
+ break;
+
+ case LOC_ENG_MSG_CLOSE_DATA_CALL:
+ {
+ loc_eng_data_p->client_handle->closeDataCall();
+ LOC_LOGD("%s:%d]: Request to close data call\n",
+ __func__, __LINE__);
+ }
+ break;
+
default:
LOC_LOGE("unsupported msgid = %d\n", msg->msgid);
break;
@@ -1926,4 +2052,3 @@ int loc_eng_read_config(void)
EXIT_LOG(%d, 0);
return 0;
}
-
diff --git a/loc_api/libloc_api_50001/loc_eng.h b/loc_api/libloc_api_50001/loc_eng.h
index 52a1d77..f956619 100644
--- a/loc_api/libloc_api_50001/loc_eng.h
+++ b/loc_api/libloc_api_50001/loc_eng.h
@@ -119,6 +119,8 @@ typedef struct loc_eng_data_s
AgpsStateMachine* agnss_nif;
AgpsStateMachine* internet_nif;
AgpsStateMachine* wifi_nif;
+ //State machine for Data Services
+ AgpsStateMachine* ds_nif;
// GPS engine status
GpsStatusValue engine_status;
diff --git a/loc_api/libloc_api_50001/loc_eng_agps.cpp b/loc_api/libloc_api_50001/loc_eng_agps.cpp
index 1f7d1ab..b7821c9 100644
--- a/loc_api/libloc_api_50001/loc_eng_agps.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_agps.cpp
@@ -33,8 +33,10 @@
#include <loc_eng_agps.h>
#include <loc_eng_log.h>
#include <log_util.h>
+#include "platform_lib_includes.h"
#include <loc_eng_dmn_conn_handler.h>
#include <loc_eng_dmn_conn.h>
+#include<sys/time.h>
//======================================================================
// C callbacks
@@ -84,8 +86,8 @@ static bool notifySubscriber(void* fromCaller, void* fromList)
const int Notification::BROADCAST_ALL = 0x80000000;
const int Notification::BROADCAST_ACTIVE = 0x80000001;
const int Notification::BROADCAST_INACTIVE = 0x80000002;
-
-
+const unsigned char DSStateMachine::MAX_START_DATA_CALL_RETRIES = 4;
+const unsigned int DSStateMachine::DATA_CALL_RETRY_DELAY_MSEC = 500;
//======================================================================
// Subscriber: BITSubscriber / ATLSubscriber / WIFISubscriber
//======================================================================
@@ -211,7 +213,29 @@ bool WIFISubscriber::notifyRsrcStatus(Notification &notification)
return notify;
}
-
+bool DSSubscriber::notifyRsrcStatus(Notification &notification)
+{
+ bool notify = forMe(notification);
+ LOC_LOGD("DSSubscriber::notifyRsrcStatus. notify:%d \n",(int)(notify));
+ if(notify) {
+ switch(notification.rsrcStatus) {
+ case RSRC_UNSUBSCRIBE:
+ case RSRC_RELEASED:
+ case RSRC_DENIED:
+ case RSRC_GRANTED:
+ ((DSStateMachine *)mStateMachine)->informStatus(notification.rsrcStatus, ID);
+ break;
+ default:
+ notify = false;
+ }
+ }
+ return notify;
+}
+void DSSubscriber :: setInactive()
+{
+ mIsInactive = true;
+ ((DSStateMachine *)mStateMachine)->informStatus(RSRC_UNSUBSCRIBE, ID);
+}
//======================================================================
// AgpsState: AgpsReleasedState / AgpsPendingState / AgpsAcquiredState
//======================================================================
@@ -233,13 +257,14 @@ public:
AgpsState* AgpsReleasedState::onRsrcEvent(AgpsRsrcStatus event, void* data)
{
+ LOC_LOGD("AgpsReleasedState::onRsrcEvent; event:%d\n", (int)event);
if (mStateMachine->hasSubscribers()) {
LOC_LOGE("Error: %s subscriber list not empty!!!", whoami());
// I don't know how to recover from it. I am adding this rather
// for debugging purpose.
}
- AgpsState* nextState = this;;
+ AgpsState* nextState = this;
switch (event)
{
case RSRC_SUBSCRIBE:
@@ -247,13 +272,16 @@ AgpsState* AgpsReleasedState::onRsrcEvent(AgpsRsrcStatus event, void* data)
// no notification until we get RSRC_GRANTED
// but we need to add subscriber to the list
mStateMachine->addSubscriber((Subscriber*)data);
- // move the state to PENDING
- nextState = mPendingState;
-
// request from connecivity service for NIF
- mStateMachine->sendRsrcRequest(GPS_REQUEST_AGPS_DATA_CONN);
+ //The if condition is added so that if the data call setup fails
+ //for DS State Machine, we want to retry in released state.
+ //for AGps State Machine, sendRsrcRequest() will always return success
+ if(!mStateMachine->sendRsrcRequest(GPS_REQUEST_AGPS_DATA_CONN)) {
+ // move the state to PENDING
+ nextState = mPendingState;
+ }
}
- break;
+ break;
case RSRC_UNSUBSCRIBE:
{
@@ -297,6 +325,7 @@ public:
AgpsState* AgpsPendingState::onRsrcEvent(AgpsRsrcStatus event, void* data)
{
AgpsState* nextState = this;;
+ LOC_LOGD("AgpsPendingState::onRsrcEvent; event:%d\n", (int)event);
switch (event)
{
case RSRC_SUBSCRIBE:
@@ -335,7 +364,7 @@ AgpsState* AgpsPendingState::onRsrcEvent(AgpsRsrcStatus event, void* data)
mStateMachine->sendRsrcRequest(GPS_RELEASE_AGPS_DATA_CONN);
}
}
- break;
+ break;
case RSRC_GRANTED:
{
@@ -392,6 +421,7 @@ public:
AgpsState* AgpsAcquiredState::onRsrcEvent(AgpsRsrcStatus event, void* data)
{
AgpsState* nextState = this;
+ LOC_LOGD("AgpsAcquiredState::onRsrcEvent; event:%d\n", (int)event);
switch (event)
{
case RSRC_SUBSCRIBE:
@@ -484,7 +514,9 @@ public:
AgpsState* AgpsReleasingState::onRsrcEvent(AgpsRsrcStatus event, void* data)
{
AgpsState* nextState = this;;
- switch (event)
+ LOC_LOGD("AgpsReleasingState::onRsrcEvent; event:%d\n", (int)event);
+
+ switch (event)
{
case RSRC_SUBSCRIBE:
{
@@ -525,7 +557,7 @@ AgpsState* AgpsReleasingState::onRsrcEvent(AgpsRsrcStatus event, void* data)
// by setting false, we keep subscribers on the linked list
mStateMachine->notifySubscribers(notification);
- if (mStateMachine->hasSubscribers()) {
+ if (mStateMachine->hasActiveSubscribers()) {
nextState = mPendingState;
// request from connecivity service for NIF
mStateMachine->sendRsrcRequest(GPS_REQUEST_AGPS_DATA_CONN);
@@ -545,20 +577,58 @@ AgpsState* AgpsReleasingState::onRsrcEvent(AgpsRsrcStatus event, void* data)
whoami(), nextState->whoami(), event);
return nextState;
}
+//======================================================================
+//Servicer
+//======================================================================
+Servicer* Servicer :: getServicer(servicerType type, void *cb_func)
+{
+ LOC_LOGD(" Enter getServicer type:%d\n", (int)type);
+ switch(type) {
+ case servicerTypeNoCbParam:
+ return (new Servicer(cb_func));
+ case servicerTypeExt:
+ return (new ExtServicer(cb_func));
+ case servicerTypeAgps:
+ return (new AGpsServicer(cb_func));
+ default:
+ return NULL;
+ }
+}
+
+int Servicer :: requestRsrc(void *cb_data)
+{
+ callback();
+ return 0;
+}
+
+int ExtServicer :: requestRsrc(void *cb_data)
+{
+ int ret=-1;
+ LOC_LOGD("Enter ExtServicer :: requestRsrc\n");
+ ret = callbackExt(cb_data);
+ LOC_LOGD("Exit ExtServicer :: requestRsrc\n");
+ return(ret);
+}
+int AGpsServicer :: requestRsrc(void *cb_data)
+{
+ callbackAGps((AGpsStatus *)cb_data);
+ return 0;
+}
//======================================================================
// AgpsStateMachine
//======================================================================
-AgpsStateMachine::AgpsStateMachine(void (*servicer)(AGpsExtStatus* status),
+AgpsStateMachine::AgpsStateMachine(servicerType servType,
+ void *cb_func,
AGpsExtType type,
bool enforceSingleSubscriber) :
- mServicer(servicer), mType(type),
- mStatePtr(new AgpsReleasedState(this)),
+ mStatePtr(new AgpsReleasedState(this)),mType(type),
mAPN(NULL),
mAPNLen(0),
- mEnforceSingleSubscriber(enforceSingleSubscriber)
+ mEnforceSingleSubscriber(enforceSingleSubscriber),
+ mServicer(Servicer :: getServicer(servType, (void *)cb_func))
{
linked_list_init(&mSubscribers);
@@ -599,6 +669,7 @@ AgpsStateMachine::~AgpsStateMachine()
delete releasedState;
delete pendindState;
delete releasingState;
+ delete mServicer;
linked_list_destroy(&mSubscribers);
if (NULL != mAPN) {
@@ -653,6 +724,7 @@ void AgpsStateMachine::notifySubscribers(Notification& notification) const
// rest of the list unprocessed. So we need a loop.
linked_list_search(mSubscribers, (void**)&s, notifySubscriber,
(void*)&notification, true);
+ delete s;
}
} else {
// no loop needed if it the last param sets to false, which
@@ -674,7 +746,7 @@ void AgpsStateMachine::addSubscriber(Subscriber* subscriber) const
}
}
-void AgpsStateMachine::sendRsrcRequest(AGpsStatusValue action) const
+int AgpsStateMachine::sendRsrcRequest(AGpsStatusValue action) const
{
Subscriber* s = NULL;
Notification notification(Notification::BROADCAST_ACTIVE);
@@ -698,8 +770,9 @@ void AgpsStateMachine::sendRsrcRequest(AGpsStatusValue action) const
}
CALLBACK_LOG_CALLFLOW("agps_cb", %s, loc_get_agps_status_name(action));
- (*mServicer)(&nifRequest);
+ mServicer->requestRsrc((void *)&nifRequest);
}
+ return 0;
}
void AgpsStateMachine::subscribeRsrc(Subscriber *subscriber)
@@ -734,3 +807,163 @@ bool AgpsStateMachine::hasActiveSubscribers() const
hasSubscriber, (void*)&notification, false);
return NULL != s;
}
+
+//======================================================================
+// DSStateMachine
+//======================================================================
+void delay_callback(void *callbackData, int result)
+{
+ if(callbackData) {
+ DSStateMachine *DSSMInstance = (DSStateMachine *)callbackData;
+ DSSMInstance->retryCallback();
+ }
+ else {
+ LOC_LOGE(" NULL argument received. Failing.\n");
+ goto err;
+ }
+err:
+ return;
+}
+
+DSStateMachine :: DSStateMachine(servicerType type, void *cb_func,
+ LocApiAdapter* adapterHandle):
+ AgpsStateMachine(type, cb_func, AGPS_TYPE_INVALID,false),
+ mLocAdapter(adapterHandle)
+{
+ LOC_LOGD("%s:%d]: New DSStateMachine\n", __func__, __LINE__);
+ mRetries = 0;
+}
+
+void DSStateMachine :: retryCallback(void)
+{
+ DSSubscriber *subscriber = NULL;
+ Notification notification(Notification::BROADCAST_ACTIVE);
+ linked_list_search(mSubscribers, (void**)&subscriber, hasSubscriber,
+ (void*)&notification, false);
+ if(subscriber)
+ mLocAdapter->requestSuplES(subscriber->ID);
+ else
+ LOC_LOGE("DSStateMachine :: retryCallback: No subscriber found." \
+ "Cannot retry data call\n");
+ return;
+}
+
+int DSStateMachine :: sendRsrcRequest(AGpsStatusValue action) const
+{
+ DSSubscriber* s = NULL;
+ dsCbData cbData;
+ int ret=-1;
+ int connHandle=-1;
+ LOC_LOGD("Enter DSStateMachine :: sendRsrcRequest\n");
+ Notification notification(Notification::BROADCAST_ACTIVE);
+ linked_list_search(mSubscribers, (void**)&s, hasSubscriber,
+ (void*)&notification, false);
+ if(s) {
+ connHandle = s->ID;
+ LOC_LOGD("DSStateMachine :: sendRsrcRequest - subscriber found\n");
+ }
+ else
+ LOC_LOGD("DSStateMachine :: sendRsrcRequest - No subscriber found\n");
+
+ cbData.action = action;
+ cbData.mAdapter = mLocAdapter;
+ ret = mServicer->requestRsrc((void *)&cbData);
+ //Only the request to start data call returns a success/failure
+ //The request to stop data call will always succeed
+ //Hence, the below block will only be executed when the
+ //request to start the data call fails
+ switch(ret) {
+ case LOC_API_ADAPTER_ERR_ENGINE_BUSY:
+ LOC_LOGD("DSStateMachine :: sendRsrcRequest - Failure returned: %d\n",ret);
+ ((DSStateMachine *)this)->incRetries();
+ if(mRetries > MAX_START_DATA_CALL_RETRIES) {
+ LOC_LOGE(" Failed to start Data call. Fallback to normal ATL SUPL\n");
+ informStatus(RSRC_DENIED, connHandle);
+ }
+ else {
+ if(loc_timer_start(DATA_CALL_RETRY_DELAY_MSEC, delay_callback, (void *)this)) {
+ LOC_LOGE("Error: Could not start delay thread\n");
+ ret = -1;
+ goto err;
+ }
+ }
+ break;
+ case LOC_API_ADAPTER_ERR_UNSUPPORTED:
+ LOC_LOGE("No profile found for emergency call. Fallback to normal SUPL ATL\n");
+ informStatus(RSRC_DENIED, connHandle);
+ break;
+ case LOC_API_ADAPTER_ERR_SUCCESS:
+ LOC_LOGD("%s:%d]: Request to start data call sent\n", __func__, __LINE__);
+ break;
+ case -1:
+ //One of the ways this case can be encountered is if the callback function
+ //receives a null argument, it just exits with -1 error
+ LOC_LOGE("Error: Something went wrong somewhere. Falling back to normal SUPL ATL\n");
+ informStatus(RSRC_DENIED, connHandle);
+ break;
+ default:
+ LOC_LOGE("%s:%d]: Unrecognized return value\n", __func__, __LINE__);
+ }
+err:
+ LOC_LOGD("EXIT DSStateMachine :: sendRsrcRequest; ret = %d\n", ret);
+ return ret;
+}
+
+void DSStateMachine :: onRsrcEvent(AgpsRsrcStatus event)
+{
+ void* currState = (void *)mStatePtr;
+ LOC_LOGD("Enter DSStateMachine :: onRsrcEvent. event = %d\n", (int)event);
+ switch (event)
+ {
+ case RSRC_GRANTED:
+ LOC_LOGD("DSStateMachine :: onRsrcEvent RSRC_GRANTED\n");
+ mStatePtr = mStatePtr->onRsrcEvent(event, NULL);
+ break;
+ case RSRC_RELEASED:
+ LOC_LOGD("DSStateMachine :: onRsrcEvent RSRC_RELEASED\n");
+ mStatePtr = mStatePtr->onRsrcEvent(event, NULL);
+ //To handle the case where we get a RSRC_RELEASED in
+ //pending state, we translate that to a RSRC_DENIED state
+ //since the callback from DSI is either RSRC_GRANTED or RSRC_RELEASED
+ //for when the call is connected or disconnected respectively.
+ if((void *)mStatePtr != currState)
+ break;
+ else {
+ event = RSRC_DENIED;
+ LOC_LOGE(" Switching event to RSRC_DENIED\n");
+ }
+ case RSRC_DENIED:
+ mStatePtr = mStatePtr->onRsrcEvent(event, NULL);
+ break;
+ default:
+ LOC_LOGW("AgpsStateMachine: unrecognized event %d", event);
+ break;
+ }
+ LOC_LOGD("Exit DSStateMachine :: onRsrcEvent. event = %d\n", (int)event);
+}
+
+void DSStateMachine :: informStatus(AgpsRsrcStatus status, int ID) const
+{
+ LOC_LOGD("DSStateMachine :: informStatus. Status=%d\n",(int)status);
+ switch(status) {
+ case RSRC_UNSUBSCRIBE:
+ ((LocApiAdapter*)mLocAdapter)->atlCloseStatus(ID, 1);
+ break;
+ case RSRC_RELEASED:
+ ((LocApiAdapter*)mLocAdapter)->releaseDataHandle();
+ break;
+ case RSRC_DENIED:
+ ((DSStateMachine *)this)->mRetries = 0;
+ mLocAdapter->requestATL(ID, AGPS_TYPE_SUPL);
+ break;
+ case RSRC_GRANTED:
+ ((LocApiAdapter*)mLocAdapter)->atlOpenStatus(ID, 1,
+ NULL,
+ AGPS_APN_BEARER_INVALID,
+ AGPS_TYPE_INVALID);
+ break;
+ default:
+ LOC_LOGW("DSStateMachine :: informStatus - unknown status");
+ }
+ return;
+}
diff --git a/loc_api/libloc_api_50001/loc_eng_agps.h b/loc_api/libloc_api_50001/loc_eng_agps.h
index ff5a92a..93980f3 100644
--- a/loc_api/libloc_api_50001/loc_eng_agps.h
+++ b/loc_api/libloc_api_50001/loc_eng_agps.h
@@ -38,6 +38,7 @@
#include <linked_list.h>
#include <LocApiAdapter.h>
#include "loc_eng_msg.h"
+#include <loc_timer.h>
// forward declaration
class AgpsStateMachine;
@@ -53,6 +54,18 @@ typedef enum {
RSRC_STATUS_MAX
} AgpsRsrcStatus;
+typedef enum {
+ servicerTypeNoCbParam,
+ servicerTypeAgps,
+ servicerTypeExt
+}servicerType;
+
+//DS Callback struct
+typedef struct {
+ LocApiAdapter *mAdapter;
+ AGpsStatusValue action;
+}dsCbData;
+
// information bundle for subscribers
struct Notification {
// goes to every subscriber
@@ -101,7 +114,7 @@ class AgpsState {
// no class members are public. We don't want
// anyone but state machine to use state.
friend class AgpsStateMachine;
-
+ friend class DSStateMachine;
// state transitions are done here.
// Each state implements its own transitions (of course).
inline virtual AgpsState* onRsrcEvent(AgpsRsrcStatus event, void* data) = 0;
@@ -129,21 +142,56 @@ public:
inline virtual char* whoami() = 0;
};
+class Servicer {
+ void (*callback)(void);
+public:
+ static Servicer* getServicer(servicerType type, void *cb_func);
+ virtual int requestRsrc(void *cb_data);
+ Servicer() {}
+ Servicer(void *cb_func)
+ { callback = (void(*)(void))(cb_func); }
+ virtual ~Servicer(){}
+ inline virtual char *whoami() {return (char*)"Servicer";}
+};
+
+class ExtServicer : public Servicer {
+ int (*callbackExt)(void *cb_data);
+public:
+ int requestRsrc(void *cb_data);
+ ExtServicer() {}
+ ExtServicer(void *cb_func)
+ { callbackExt = (int(*)(void *))(cb_func); }
+ virtual ~ExtServicer(){}
+ inline virtual char *whoami() {return (char*)"ExtServicer";}
+};
+
+class AGpsServicer : public Servicer {
+ void (*callbackAGps)(AGpsStatus* status);
+public:
+ int requestRsrc(void *cb_data);
+ AGpsServicer() {}
+ AGpsServicer(void *cb_func)
+ { callbackAGps = (void(*)(AGpsStatus *))(cb_func); }
+ virtual ~AGpsServicer(){}
+ inline virtual char *whoami() {return (char*)"AGpsServicer";}
+};
+
class AgpsStateMachine {
+protected:
+ // a linked list of subscribers.
+ void* mSubscribers;
+ //handle to whoever provides the service
+ Servicer *mServicer;
// allows AgpsState to access private data
// each state is really internal data to the
// state machine, so it should be able to
// access anything within the state machine.
friend class AgpsState;
-
- // handle to whoever provides the service
- void (* const mServicer)(AGpsExtStatus* status);
- // NIF type: AGNSS or INTERNET.
- const AGpsExtType mType;
// pointer to the current state.
AgpsState* mStatePtr;
- // a linked list of subscribers.
- void* mSubscribers;
+private:
+ // NIF type: AGNSS or INTERNET.
+ const AGpsExtType mType;
// apn to the NIF. Each state machine tracks
// resource state of a particular NIF. For each
// NIF, there is also an active APN.
@@ -156,7 +204,8 @@ class AgpsStateMachine {
bool mEnforceSingleSubscriber;
public:
- AgpsStateMachine(void (*servicer)(AGpsExtStatus* status), AGpsExtType type, bool enforceSingleSubscriber);
+ AgpsStateMachine(servicerType servType, void *cb_func,
+ AGpsExtType type, bool enforceSingleSubscriber);
virtual ~AgpsStateMachine();
// self explanatory methods below
@@ -175,11 +224,15 @@ public:
// add a subscriber in the linked list, if not already there.
void addSubscriber(Subscriber* subscriber) const;
- void onRsrcEvent(AgpsRsrcStatus event);
+ virtual void onRsrcEvent(AgpsRsrcStatus event);
// put the data together and send the FW
- void sendRsrcRequest(AGpsStatusValue action) const;
+ virtual int sendRsrcRequest(AGpsStatusValue action) const;
+ //if list is empty, linked_list_empty returns 1
+ //else if list is not empty, returns 0
+ //so hasSubscribers() returns 1 if list is not empty
+ //and returns 0 if list is empty
inline bool hasSubscribers() const
{ return !linked_list_empty(mSubscribers); }
@@ -190,6 +243,24 @@ public:
// private. Only a state gets to call this.
void notifySubscribers(Notification& notification) const;
+
+};
+
+class DSStateMachine : public AgpsStateMachine {
+ static const unsigned char MAX_START_DATA_CALL_RETRIES;
+ static const unsigned int DATA_CALL_RETRY_DELAY_MSEC;
+ LocApiAdapter* mLocAdapter;
+ unsigned char mRetries;
+public:
+ DSStateMachine(servicerType type,
+ void *cb_func,
+ LocApiAdapter* adapterHandle);
+ int sendRsrcRequest(AGpsStatusValue action) const;
+ void onRsrcEvent(AgpsRsrcStatus event);
+ void retryCallback();
+ void informStatus(AgpsRsrcStatus status, int ID) const;
+ inline void incRetries() {mRetries++;}
+ inline virtual char *whoami() {return (char*)"DSStateMachine";}
};
// each subscriber is a AGPS client. In the case of ATL, there could be
@@ -248,7 +319,7 @@ struct BITSubscriber : public Subscriber {
}
virtual bool equals(const Subscriber *s) const;
-
+ inline virtual ~BITSubscriber(){}
private:
char ipv6Addr[16];
};
@@ -273,6 +344,7 @@ struct ATLSubscriber : public Subscriber {
return new ATLSubscriber(ID, mStateMachine, mLocAdapter,
mBackwardCompatibleMode);
}
+ inline virtual ~ATLSubscriber(){}
};
// WIFISubscriber, created with requests from MSAPM or QuIPC
@@ -320,6 +392,27 @@ struct WIFISubscriber : public Subscriber {
{
return new WIFISubscriber(mStateMachine, mSSID, mPassword, senderId);
}
+ inline virtual ~WIFISubscriber(){}
+};
+
+struct DSSubscriber : public Subscriber {
+ bool mIsInactive;
+ inline DSSubscriber(const AgpsStateMachine *stateMachine,
+ const int id) :
+ Subscriber(id, stateMachine)
+ {
+ mIsInactive = false;
+ }
+ inline virtual void setIPAddresses(uint32_t &v4, char* v6) {}
+ virtual Subscriber* clone()
+ {return new DSSubscriber(mStateMachine, ID);}
+ virtual bool notifyRsrcStatus(Notification &notification);
+ inline virtual bool waitForCloseComplete() { return true; }
+ virtual void setInactive();
+ inline virtual bool isInactive()
+ { return mIsInactive; }
+ inline virtual ~DSSubscriber(){}
+ inline virtual char *whoami() {return (char*)"DSSubscriber";}
};
#endif //__LOC_ENG_AGPS_H__
diff --git a/loc_api/libloc_api_50001/loc_eng_dmn_conn.cpp b/loc_api/libloc_api_50001/loc_eng_dmn_conn.cpp
index 8648908..918ae22 100644
--- a/loc_api/libloc_api_50001/loc_eng_dmn_conn.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_dmn_conn.cpp
@@ -38,7 +38,7 @@
#include <sys/stat.h>
#include "log_util.h"
-
+#include "platform_lib_includes.h"
#include "loc_eng_dmn_conn_glue_msg.h"
#include "loc_eng_dmn_conn_handler.h"
#include "loc_eng_dmn_conn.h"
diff --git a/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_msg.c b/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_msg.c
index 6b97a23..a1076ff 100644
--- a/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_msg.c
+++ b/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_msg.c
@@ -32,7 +32,7 @@
#include <linux/types.h>
#include "log_util.h"
-
+#include "platform_lib_includes.h"
#include "loc_eng_dmn_conn_glue_msg.h"
#include "loc_eng_dmn_conn_handler.h"
diff --git a/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_pipe.c b/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_pipe.c
index d0bee29..dffcad0 100644
--- a/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_pipe.c
+++ b/loc_api/libloc_api_50001/loc_eng_dmn_conn_glue_pipe.c
@@ -38,7 +38,7 @@
#include "loc_eng_dmn_conn_glue_pipe.h"
#include "log_util.h"
-
+#include "platform_lib_includes.h"
/*===========================================================================
FUNCTION loc_eng_dmn_conn_glue_pipeget
diff --git a/loc_api/libloc_api_50001/loc_eng_dmn_conn_handler.cpp b/loc_api/libloc_api_50001/loc_eng_dmn_conn_handler.cpp
index 6c060f6..8176ab4 100644
--- a/loc_api/libloc_api_50001/loc_eng_dmn_conn_handler.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_dmn_conn_handler.cpp
@@ -32,6 +32,7 @@
#include <unistd.h>
#include "log_util.h"
+#include "platform_lib_includes.h"
#include "loc_eng_msg.h"
#include "loc_eng_dmn_conn.h"
#include "loc_eng_dmn_conn_handler.h"
diff --git a/loc_api/libloc_api_50001/loc_eng_dmn_conn_thread_helper.c b/loc_api/libloc_api_50001/loc_eng_dmn_conn_thread_helper.c
index 67e3187..9fed9d4 100644
--- a/loc_api/libloc_api_50001/loc_eng_dmn_conn_thread_helper.c
+++ b/loc_api/libloc_api_50001/loc_eng_dmn_conn_thread_helper.c
@@ -29,6 +29,7 @@
#include <stdio.h>
#include "log_util.h"
+#include "platform_lib_includes.h"
#include "loc_eng_dmn_conn_thread_helper.h"
/*===========================================================================
diff --git a/loc_api/libloc_api_50001/loc_eng_log.cpp b/loc_api/libloc_api_50001/loc_eng_log.cpp
index 6667ecb..877566e 100644
--- a/loc_api/libloc_api_50001/loc_eng_log.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_log.cpp
@@ -97,7 +97,9 @@ static loc_name_val_s_type loc_eng_msgs[] =
NAME_VAL( LOC_ENG_MSG_REQUEST_POSITION ),
NAME_VAL( LOC_ENG_MSG_LPP_CONFIG ),
NAME_VAL( LOC_ENG_MSG_A_GLONASS_PROTOCOL ),
- NAME_VAL( LOC_ENG_MSG_LOC_INIT )
+ NAME_VAL( LOC_ENG_MSG_LOC_INIT ),
+ NAME_VAL( LOC_ENG_MSG_REQUEST_SUPL_ES ),
+ NAME_VAL( LOC_ENG_MSG_CLOSE_DATA_CALL)
};
static int loc_eng_msgs_num = sizeof(loc_eng_msgs) / sizeof(loc_name_val_s_type);
diff --git a/loc_api/libloc_api_50001/loc_eng_msg.h b/loc_api/libloc_api_50001/loc_eng_msg.h
index 2228677..709f65c 100644
--- a/loc_api/libloc_api_50001/loc_eng_msg.h
+++ b/loc_api/libloc_api_50001/loc_eng_msg.h
@@ -35,9 +35,20 @@
#include <stdlib.h>
#include <string.h>
#include "log_util.h"
+#include "loc.h"
#include <loc_eng_log.h>
#include "loc_eng_msg_id.h"
+#ifndef SSID_BUF_SIZE
+ #define SSID_BUF_SIZE (32+1)
+#endif
+#ifdef USE_GLIB
+
+#include <glib.h>
+
+#endif /* USE_GLIB */
+#include "platform_lib_includes.h"
+
#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */
@@ -619,6 +630,23 @@ struct loc_eng_msg_request_atl : public loc_eng_msg {
}
};
+struct loc_eng_msg_request_supl_es : public loc_eng_msg {
+ const int handle;
+ inline loc_eng_msg_request_supl_es(void* instance, int hndl) :
+ loc_eng_msg(instance, LOC_ENG_MSG_REQUEST_SUPL_ES),
+ handle(hndl)
+ {
+ LOC_LOGV("handle: %d\n", handle);
+ }
+};
+
+struct loc_eng_msg_close_data_call: public loc_eng_msg {
+ inline loc_eng_msg_close_data_call(void *instance) :
+ loc_eng_msg(instance, LOC_ENG_MSG_CLOSE_DATA_CALL)
+ {
+ LOC_LOGV("%s:%d]Close data call: ", __func__, __LINE__);
+ }
+};
struct loc_eng_msg_release_atl : public loc_eng_msg {
const int handle;
inline loc_eng_msg_release_atl(void* instance, int hndl) :
@@ -751,12 +779,12 @@ struct loc_eng_msg_request_xtra_server : public loc_eng_msg {
};
struct loc_eng_msg_atl_open_success : public loc_eng_msg {
- const AGpsStatusValue agpsType;
+ const AGpsType agpsType;
const int length;
char* const apn;
const AGpsBearerType bearerType;
inline loc_eng_msg_atl_open_success(void* instance,
- AGpsStatusValue atype,
+ AGpsType atype,
const char* name,
int len,
AGpsBearerType btype) :
@@ -777,7 +805,6 @@ struct loc_eng_msg_atl_open_success : public loc_eng_msg {
}
};
-
struct loc_eng_msg_atl_open_failed : public loc_eng_msg {
const AGpsStatusValue agpsType;
inline loc_eng_msg_atl_open_failed(void* instance,
@@ -790,11 +817,10 @@ struct loc_eng_msg_atl_open_failed : public loc_eng_msg {
}
};
-
struct loc_eng_msg_atl_closed : public loc_eng_msg {
- const AGpsStatusValue agpsType;
+ const AGpsType agpsType;
inline loc_eng_msg_atl_closed(void* instance,
- AGpsStatusValue atype) :
+ AGpsType atype) :
loc_eng_msg(instance, LOC_ENG_MSG_ATL_CLOSED),
agpsType(atype)
{
diff --git a/loc_api/libloc_api_50001/loc_eng_msg_id.h b/loc_api/libloc_api_50001/loc_eng_msg_id.h
index 6e35312..186b53c 100644
--- a/loc_api/libloc_api_50001/loc_eng_msg_id.h
+++ b/loc_api/libloc_api_50001/loc_eng_msg_id.h
@@ -99,6 +99,12 @@ enum loc_eng_msg_ids_t {
//Message is sent by LOC to do LOC INIT
LOC_ENG_MSG_LOC_INIT,
+
+ /*Message is sent by modem to request emergency call setup*/
+ LOC_ENG_MSG_REQUEST_SUPL_ES,
+
+ /*Ask the DS client to close the data call by releasing the handle*/
+ LOC_ENG_MSG_CLOSE_DATA_CALL,
};
#ifdef __cplusplus
diff --git a/loc_api/libloc_api_50001/loc_eng_ni.cpp b/loc_api/libloc_api_50001/loc_eng_ni.cpp
index 2990003..e9ba91d 100644
--- a/loc_api/libloc_api_50001/loc_eng_ni.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_ni.cpp
@@ -43,7 +43,7 @@
#include <loc_eng.h>
#include "log_util.h"
-
+#include "platform_lib_includes.h"
/*=============================================================================
*
* DATA DECLARATION
diff --git a/loc_api/libloc_api_50001/loc_eng_nmea.cpp b/loc_api/libloc_api_50001/loc_eng_nmea.cpp
index 9f087ca..c4be2ab 100644
--- a/loc_api/libloc_api_50001/loc_eng_nmea.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_nmea.cpp
@@ -110,7 +110,9 @@ SIDE EFFECTS
===========================================================================*/
void loc_eng_nmea_generate_pos(loc_eng_data_s_type *loc_eng_data_p,
- const UlpLocation &location, const GpsLocationExtended &locationExtended)
+ const UlpLocation &location,
+ const GpsLocationExtended &locationExtended,
+ unsigned char generate_nmea)
{
ENTRY_LOG();
@@ -128,46 +130,32 @@ void loc_eng_nmea_generate_pos(loc_eng_data_s_type *loc_eng_data_p,
int utcMinutes = pTm->tm_min;
int utcSeconds = pTm->tm_sec;
- // ------------------
- // ------$GPGSA------
- // ------------------
-
- uint32_t svUsedCount = 0;
- uint32_t svUsedList[32] = {0};
- uint32_t mask = loc_eng_data_p->sv_used_mask;
- for (uint8_t i = 1; mask > 0 && svUsedCount < 32; i++)
- {
- if (mask & 1)
- svUsedList[svUsedCount++] = i;
- mask = mask >> 1;
- }
- // clear the cache so they can't be used again
- loc_eng_data_p->sv_used_mask = 0;
-
- char fixType;
- if (svUsedCount == 0)
- fixType = '1'; // no fix
- else if (svUsedCount <= 3)
- fixType = '2'; // 2D fix
- else
- fixType = '3'; // 3D fix
-
- length = snprintf(pMarker, lengthRemaining, "$GPGSA,A,%c,", fixType);
-
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (generate_nmea) {
+ // ------------------
+ // ------$GPGSA------
+ // ------------------
- for (uint8_t i = 0; i < 12; i++) // only the first 12 sv go in sentence
- {
- if (i < svUsedCount)
- length = snprintf(pMarker, lengthRemaining, "%02d,", svUsedList[i]);
+ uint32_t svUsedCount = 0;
+ uint32_t svUsedList[32] = {0};
+ uint32_t mask = loc_eng_data_p->sv_used_mask;
+ for (uint8_t i = 1; mask > 0 && svUsedCount < 32; i++)
+ {
+ if (mask & 1)
+ svUsedList[svUsedCount++] = i;
+ mask = mask >> 1;
+ }
+ // clear the cache so they can't be used again
+ loc_eng_data_p->sv_used_mask = 0;
+
+ char fixType;
+ if (svUsedCount == 0)
+ fixType = '1'; // no fix
+ else if (svUsedCount <= 3)
+ fixType = '2'; // 2D fix
else
- length = snprintf(pMarker, lengthRemaining, ",");
+ fixType = '3'; // 3D fix
+
+ length = snprintf(pMarker, lengthRemaining, "$GPGSA,A,%c,", fixType);
if (length < 0 || length >= lengthRemaining)
{
@@ -176,378 +164,412 @@ void loc_eng_nmea_generate_pos(loc_eng_data_s_type *loc_eng_data_p,
}
pMarker += length;
lengthRemaining -= length;
- }
- if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_DOP)
- { // dop is in locationExtended, (QMI)
- length = snprintf(pMarker, lengthRemaining, "%.1f,%.1f,%.1f",
- locationExtended.pdop,
- locationExtended.hdop,
- locationExtended.vdop);
- }
- else if (loc_eng_data_p->pdop > 0 && loc_eng_data_p->hdop > 0 && loc_eng_data_p->vdop > 0)
- { // dop was cached from sv report (RPC)
- length = snprintf(pMarker, lengthRemaining, "%.1f,%.1f,%.1f",
- loc_eng_data_p->pdop,
- loc_eng_data_p->hdop,
- loc_eng_data_p->vdop);
- }
- else
- { // no dop
- length = snprintf(pMarker, lengthRemaining, ",,");
- }
+ for (uint8_t i = 0; i < 12; i++) // only the first 12 sv go in sentence
+ {
+ if (i < svUsedCount)
+ length = snprintf(pMarker, lengthRemaining, "%02d,", svUsedList[i]);
+ else
+ length = snprintf(pMarker, lengthRemaining, ",");
- length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
- loc_eng_nmea_send(sentence, length, loc_eng_data_p);
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
+ }
- // ------------------
- // ------$GPVTG------
- // ------------------
+ if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_DOP)
+ { // dop is in locationExtended, (QMI)
+ length = snprintf(pMarker, lengthRemaining, "%.1f,%.1f,%.1f",
+ locationExtended.pdop,
+ locationExtended.hdop,
+ locationExtended.vdop);
+ }
+ else if (loc_eng_data_p->pdop > 0 && loc_eng_data_p->hdop > 0 && loc_eng_data_p->vdop > 0)
+ { // dop was cached from sv report (RPC)
+ length = snprintf(pMarker, lengthRemaining, "%.1f,%.1f,%.1f",
+ loc_eng_data_p->pdop,
+ loc_eng_data_p->hdop,
+ loc_eng_data_p->vdop);
+ }
+ else
+ { // no dop
+ length = snprintf(pMarker, lengthRemaining, ",,");
+ }
- pMarker = sentence;
- lengthRemaining = sizeof(sentence);
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- if (location.gpsLocation.flags & GPS_LOCATION_HAS_BEARING)
- {
- float magTrack = location.gpsLocation.bearing;
- if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_MAG_DEV)
+ // ------------------
+ // ------$GPVTG------
+ // ------------------
+
+ pMarker = sentence;
+ lengthRemaining = sizeof(sentence);
+
+ if (location.gpsLocation.flags & GPS_LOCATION_HAS_BEARING)
+ {
+ float magTrack = location.gpsLocation.bearing;
+ if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_MAG_DEV)
+ {
+ float magTrack = location.gpsLocation.bearing - locationExtended.magneticDeviation;
+ if (magTrack < 0.0)
+ magTrack += 360.0;
+ else if (magTrack > 360.0)
+ magTrack -= 360.0;
+ }
+
+ length = snprintf(pMarker, lengthRemaining, "$GPVTG,%.1lf,T,%.1lf,M,", location.gpsLocation.bearing, magTrack);
+ }
+ else
{
- float magTrack = location.gpsLocation.bearing - locationExtended.magneticDeviation;
- if (magTrack < 0.0)
- magTrack += 360.0;
- else if (magTrack > 360.0)
- magTrack -= 360.0;
+ length = snprintf(pMarker, lengthRemaining, "$GPVTG,,T,,M,");
}
- length = snprintf(pMarker, lengthRemaining, "$GPVTG,%.1lf,T,%.1lf,M,", location.gpsLocation.bearing, magTrack);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining, "$GPVTG,,T,,M,");
- }
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (location.gpsLocation.flags & GPS_LOCATION_HAS_SPEED)
+ {
+ float speedKnots = location.gpsLocation.speed * (3600.0/1852.0);
+ float speedKmPerHour = location.gpsLocation.speed * 3.6;
- if (location.gpsLocation.flags & GPS_LOCATION_HAS_SPEED)
- {
- float speedKnots = location.gpsLocation.speed * (3600.0/1852.0);
- float speedKmPerHour = location.gpsLocation.speed * 3.6;
+ length = snprintf(pMarker, lengthRemaining, "%.1lf,N,%.1lf,K,", speedKnots, speedKmPerHour);
+ }
+ else
+ {
+ length = snprintf(pMarker, lengthRemaining, ",N,,K,");
+ }
- length = snprintf(pMarker, lengthRemaining, "%.1lf,N,%.1lf,K,", speedKnots, speedKmPerHour);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining, ",N,,K,");
- }
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (!(location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG))
+ length = snprintf(pMarker, lengthRemaining, "%c", 'N'); // N means no fix
+ else if (LOC_POSITION_MODE_STANDALONE == loc_eng_data_p->client_handle->getPositionMode().mode)
+ length = snprintf(pMarker, lengthRemaining, "%c", 'A'); // A means autonomous
+ else
+ length = snprintf(pMarker, lengthRemaining, "%c", 'D'); // D means differential
- if (!(location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG))
- length = snprintf(pMarker, lengthRemaining, "%c", 'N'); // N means no fix
- else if (LOC_POSITION_MODE_STANDALONE == loc_eng_data_p->client_handle->getPositionMode().mode)
- length = snprintf(pMarker, lengthRemaining, "%c", 'A'); // A means autonomous
- else
- length = snprintf(pMarker, lengthRemaining, "%c", 'D'); // D means differential
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
- loc_eng_nmea_send(sentence, length, loc_eng_data_p);
+ // ------------------
+ // ------$GPRMC------
+ // ------------------
- // ------------------
- // ------$GPRMC------
- // ------------------
+ pMarker = sentence;
+ lengthRemaining = sizeof(sentence);
+
+ length = snprintf(pMarker, lengthRemaining, "$GPRMC,%02d%02d%02d,A," ,
+ utcHours, utcMinutes, utcSeconds);
- pMarker = sentence;
- lengthRemaining = sizeof(sentence);
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- length = snprintf(pMarker, lengthRemaining, "$GPRMC,%02d%02d%02d,A," ,
- utcHours, utcMinutes, utcSeconds);
+ if (location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG)
+ {
+ double latitude = location.gpsLocation.latitude;
+ double longitude = location.gpsLocation.longitude;
+ char latHemisphere;
+ char lonHemisphere;
+ double latMinutes;
+ double lonMinutes;
+
+ if (latitude > 0)
+ {
+ latHemisphere = 'N';
+ }
+ else
+ {
+ latHemisphere = 'S';
+ latitude *= -1.0;
+ }
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (longitude < 0)
+ {
+ lonHemisphere = 'W';
+ longitude *= -1.0;
+ }
+ else
+ {
+ lonHemisphere = 'E';
+ }
- if (location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG)
- {
- double latitude = location.gpsLocation.latitude;
- double longitude = location.gpsLocation.longitude;
- char latHemisphere;
- char lonHemisphere;
- double latMinutes;
- double lonMinutes;
+ latMinutes = fmod(latitude * 60.0 , 60.0);
+ lonMinutes = fmod(longitude * 60.0 , 60.0);
- if (latitude > 0)
- {
- latHemisphere = 'N';
+ length = snprintf(pMarker, lengthRemaining, "%02d%09.6lf,%c,%03d%09.6lf,%c,",
+ (uint8_t)floor(latitude), latMinutes, latHemisphere,
+ (uint8_t)floor(longitude),lonMinutes, lonHemisphere);
}
else
{
- latHemisphere = 'S';
- latitude *= -1.0;
+ length = snprintf(pMarker, lengthRemaining,",,,,");
+ }
+
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
}
+ pMarker += length;
+ lengthRemaining -= length;
- if (longitude < 0)
+ if (location.gpsLocation.flags & GPS_LOCATION_HAS_SPEED)
{
- lonHemisphere = 'W';
- longitude *= -1.0;
+ float speedKnots = location.gpsLocation.speed * (3600.0/1852.0);
+ length = snprintf(pMarker, lengthRemaining, "%.1lf,", speedKnots);
}
else
{
- lonHemisphere = 'E';
+ length = snprintf(pMarker, lengthRemaining, ",");
}
- latMinutes = fmod(latitude * 60.0 , 60.0);
- lonMinutes = fmod(longitude * 60.0 , 60.0);
-
- length = snprintf(pMarker, lengthRemaining, "%02d%09.6lf,%c,%03d%09.6lf,%c,",
- (uint8_t)floor(latitude), latMinutes, latHemisphere,
- (uint8_t)floor(longitude),lonMinutes, lonHemisphere);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining,",,,,");
- }
-
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
-
- if (location.gpsLocation.flags & GPS_LOCATION_HAS_SPEED)
- {
- float speedKnots = location.gpsLocation.speed * (3600.0/1852.0);
- length = snprintf(pMarker, lengthRemaining, "%.1lf,", speedKnots);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining, ",");
- }
-
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- if (location.gpsLocation.flags & GPS_LOCATION_HAS_BEARING)
- {
- length = snprintf(pMarker, lengthRemaining, "%.1lf,", location.gpsLocation.bearing);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining, ",");
- }
+ if (location.gpsLocation.flags & GPS_LOCATION_HAS_BEARING)
+ {
+ length = snprintf(pMarker, lengthRemaining, "%.1lf,", location.gpsLocation.bearing);
+ }
+ else
+ {
+ length = snprintf(pMarker, lengthRemaining, ",");
+ }
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- length = snprintf(pMarker, lengthRemaining, "%2.2d%2.2d%2.2d,",
- utcDay, utcMonth, utcYear);
+ length = snprintf(pMarker, lengthRemaining, "%2.2d%2.2d%2.2d,",
+ utcDay, utcMonth, utcYear);
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_MAG_DEV)
- {
- float magneticVariation = locationExtended.magneticDeviation;
- char direction;
- if (magneticVariation < 0.0)
+ if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_MAG_DEV)
{
- direction = 'W';
- magneticVariation *= -1.0;
+ float magneticVariation = locationExtended.magneticDeviation;
+ char direction;
+ if (magneticVariation < 0.0)
+ {
+ direction = 'W';
+ magneticVariation *= -1.0;
+ }
+ else
+ {
+ direction = 'E';
+ }
+
+ length = snprintf(pMarker, lengthRemaining, "%.1lf,%c,",
+ magneticVariation, direction);
}
else
{
- direction = 'E';
+ length = snprintf(pMarker, lengthRemaining, ",,");
}
- length = snprintf(pMarker, lengthRemaining, "%.1lf,%c,",
- magneticVariation, direction);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining, ",,");
- }
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (!(location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG))
+ length = snprintf(pMarker, lengthRemaining, "%c", 'N'); // N means no fix
+ else if (LOC_POSITION_MODE_STANDALONE == loc_eng_data_p->client_handle->getPositionMode().mode)
+ length = snprintf(pMarker, lengthRemaining, "%c", 'A'); // A means autonomous
+ else
+ length = snprintf(pMarker, lengthRemaining, "%c", 'D'); // D means differential
- if (!(location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG))
- length = snprintf(pMarker, lengthRemaining, "%c", 'N'); // N means no fix
- else if (LOC_POSITION_MODE_STANDALONE == loc_eng_data_p->client_handle->getPositionMode().mode)
- length = snprintf(pMarker, lengthRemaining, "%c", 'A'); // A means autonomous
- else
- length = snprintf(pMarker, lengthRemaining, "%c", 'D'); // D means differential
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
- loc_eng_nmea_send(sentence, length, loc_eng_data_p);
+ // ------------------
+ // ------$GPGGA------
+ // ------------------
- // ------------------
- // ------$GPGGA------
- // ------------------
+ pMarker = sentence;
+ lengthRemaining = sizeof(sentence);
+
+ length = snprintf(pMarker, lengthRemaining, "$GPGGA,%02d%02d%02d," ,
+ utcHours, utcMinutes, utcSeconds);
- pMarker = sentence;
- lengthRemaining = sizeof(sentence);
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- length = snprintf(pMarker, lengthRemaining, "$GPGGA,%02d%02d%02d," ,
- utcHours, utcMinutes, utcSeconds);
+ if (location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG)
+ {
+ double latitude = location.gpsLocation.latitude;
+ double longitude = location.gpsLocation.longitude;
+ char latHemisphere;
+ char lonHemisphere;
+ double latMinutes;
+ double lonMinutes;
+
+ if (latitude > 0)
+ {
+ latHemisphere = 'N';
+ }
+ else
+ {
+ latHemisphere = 'S';
+ latitude *= -1.0;
+ }
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ if (longitude < 0)
+ {
+ lonHemisphere = 'W';
+ longitude *= -1.0;
+ }
+ else
+ {
+ lonHemisphere = 'E';
+ }
- if (location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG)
- {
- double latitude = location.gpsLocation.latitude;
- double longitude = location.gpsLocation.longitude;
- char latHemisphere;
- char lonHemisphere;
- double latMinutes;
- double lonMinutes;
+ latMinutes = fmod(latitude * 60.0 , 60.0);
+ lonMinutes = fmod(longitude * 60.0 , 60.0);
- if (latitude > 0)
- {
- latHemisphere = 'N';
+ length = snprintf(pMarker, lengthRemaining, "%02d%09.6lf,%c,%03d%09.6lf,%c,",
+ (uint8_t)floor(latitude), latMinutes, latHemisphere,
+ (uint8_t)floor(longitude),lonMinutes, lonHemisphere);
}
else
{
- latHemisphere = 'S';
- latitude *= -1.0;
+ length = snprintf(pMarker, lengthRemaining,",,,,");
}
- if (longitude < 0)
+ if (length < 0 || length >= lengthRemaining)
{
- lonHemisphere = 'W';
- longitude *= -1.0;
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
+
+ char gpsQuality;
+ if (!(location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG))
+ gpsQuality = '0'; // 0 means no fix
+ else if (LOC_POSITION_MODE_STANDALONE == loc_eng_data_p->client_handle->getPositionMode().mode)
+ gpsQuality = '1'; // 1 means GPS fix
+ else
+ gpsQuality = '2'; // 2 means DGPS fix
+
+ if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_DOP)
+ { // dop is in locationExtended, (QMI)
+ length = snprintf(pMarker, lengthRemaining, "%c,%02d,%.1f,",
+ gpsQuality, svUsedCount, locationExtended.hdop);
+ }
+ else if (loc_eng_data_p->pdop > 0 && loc_eng_data_p->hdop > 0 && loc_eng_data_p->vdop > 0)
+ { // dop was cached from sv report (RPC)
+ length = snprintf(pMarker, lengthRemaining, "%c,%02d,%.1f,",
+ gpsQuality, svUsedCount, loc_eng_data_p->hdop);
}
else
+ { // no hdop
+ length = snprintf(pMarker, lengthRemaining, "%c,%02d,,",
+ gpsQuality, svUsedCount);
+ }
+
+ if (length < 0 || length >= lengthRemaining)
{
- lonHemisphere = 'E';
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
}
+ pMarker += length;
+ lengthRemaining -= length;
- latMinutes = fmod(latitude * 60.0 , 60.0);
- lonMinutes = fmod(longitude * 60.0 , 60.0);
+ if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_ALTITUDE_MEAN_SEA_LEVEL)
+ {
+ length = snprintf(pMarker, lengthRemaining, "%.1lf,M,",
+ locationExtended.altitudeMeanSeaLevel);
+ }
+ else
+ {
+ length = snprintf(pMarker, lengthRemaining,",,");
+ }
- length = snprintf(pMarker, lengthRemaining, "%02d%09.6lf,%c,%03d%09.6lf,%c,",
- (uint8_t)floor(latitude), latMinutes, latHemisphere,
- (uint8_t)floor(longitude),lonMinutes, lonHemisphere);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining,",,,,");
- }
+ if (length < 0 || length >= lengthRemaining)
+ {
+ LOC_LOGE("NMEA Error in string formatting");
+ return;
+ }
+ pMarker += length;
+ lengthRemaining -= length;
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
-
- char gpsQuality;
- if (!(location.gpsLocation.flags & GPS_LOCATION_HAS_LAT_LONG))
- gpsQuality = '0'; // 0 means no fix
- else if (LOC_POSITION_MODE_STANDALONE == loc_eng_data_p->client_handle->getPositionMode().mode)
- gpsQuality = '1'; // 1 means GPS fix
- else
- gpsQuality = '2'; // 2 means DGPS fix
+ if ((location.gpsLocation.flags & GPS_LOCATION_HAS_ALTITUDE) &&
+ (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_ALTITUDE_MEAN_SEA_LEVEL))
+ {
+ length = snprintf(pMarker, lengthRemaining, "%.1lf,M,,",
+ location.gpsLocation.altitude - locationExtended.altitudeMeanSeaLevel);
+ }
+ else
+ {
+ length = snprintf(pMarker, lengthRemaining,",,,");
+ }
- if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_DOP)
- { // dop is in locationExtended, (QMI)
- length = snprintf(pMarker, lengthRemaining, "%c,%02d,%.1f,",
- gpsQuality, svUsedCount, locationExtended.hdop);
- }
- else if (loc_eng_data_p->pdop > 0 && loc_eng_data_p->hdop > 0 && loc_eng_data_p->vdop > 0)
- { // dop was cached from sv report (RPC)
- length = snprintf(pMarker, lengthRemaining, "%c,%02d,%.1f,",
- gpsQuality, svUsedCount, loc_eng_data_p->hdop);
- }
- else
- { // no hdop
- length = snprintf(pMarker, lengthRemaining, "%c,%02d,,",
- gpsQuality, svUsedCount);
- }
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
}
- pMarker += length;
- lengthRemaining -= length;
+ //Send blank NMEA reports for non-final fixes
+ else {
+ strlcpy(sentence, "$GPGSA,A,1,,,,,,,,,,,,,,,", sizeof(sentence));
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- if (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_ALTITUDE_MEAN_SEA_LEVEL)
- {
- length = snprintf(pMarker, lengthRemaining, "%.1lf,M,",
- locationExtended.altitudeMeanSeaLevel);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining,",,");
- }
+ strlcpy(sentence, "$GPVTG,,T,,M,,N,,K,N", sizeof(sentence));
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- if (length < 0 || length >= lengthRemaining)
- {
- LOC_LOGE("NMEA Error in string formatting");
- return;
- }
- pMarker += length;
- lengthRemaining -= length;
+ strlcpy(sentence, "$GPRMC,,V,,,,,,,,,,N", sizeof(sentence));
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
- if ((location.gpsLocation.flags & GPS_LOCATION_HAS_ALTITUDE) &&
- (locationExtended.flags & GPS_LOCATION_EXTENDED_HAS_ALTITUDE_MEAN_SEA_LEVEL))
- {
- length = snprintf(pMarker, lengthRemaining, "%.1lf,M,,",
- location.gpsLocation.altitude - locationExtended.altitudeMeanSeaLevel);
- }
- else
- {
- length = snprintf(pMarker, lengthRemaining,",,,");
+ strlcpy(sentence, "$GPGGA,,,,,,0,,,,,,,,", sizeof(sentence));
+ length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
+ loc_eng_nmea_send(sentence, length, loc_eng_data_p);
}
-
- length = loc_eng_nmea_put_checksum(sentence, sizeof(sentence));
- loc_eng_nmea_send(sentence, length, loc_eng_data_p);
-
// clear the dop cache so they can't be used again
loc_eng_data_p->pdop = 0;
loc_eng_data_p->hdop = 0;
diff --git a/loc_api/libloc_api_50001/loc_eng_nmea.h b/loc_api/libloc_api_50001/loc_eng_nmea.h
index 6930593..40c6dbb 100644
--- a/loc_api/libloc_api_50001/loc_eng_nmea.h
+++ b/loc_api/libloc_api_50001/loc_eng_nmea.h
@@ -37,6 +37,6 @@
void loc_eng_nmea_send(char *pNmea, int length, loc_eng_data_s_type *loc_eng_data_p);
int loc_eng_nmea_put_checksum(char *pNmea, int maxSize);
void loc_eng_nmea_generate_sv(loc_eng_data_s_type *loc_eng_data_p, const GpsSvStatus &svStatus, const GpsLocationExtended &locationExtended);
-void loc_eng_nmea_generate_pos(loc_eng_data_s_type *loc_eng_data_p, const UlpLocation &location, const GpsLocationExtended &locationExtended);
+void loc_eng_nmea_generate_pos(loc_eng_data_s_type *loc_eng_data_p, const UlpLocation &location, const GpsLocationExtended &locationExtended, unsigned char generate_nmea);
#endif // LOC_ENG_NMEA_H
diff --git a/loc_api/libloc_api_50001/loc_eng_xtra.cpp b/loc_api/libloc_api_50001/loc_eng_xtra.cpp
index 4443373..5c030b0 100644
--- a/loc_api/libloc_api_50001/loc_eng_xtra.cpp
+++ b/loc_api/libloc_api_50001/loc_eng_xtra.cpp
@@ -33,7 +33,7 @@
#include <loc_eng.h>
#include <loc_eng_msg.h>
#include "log_util.h"
-
+#include "platform_lib_includes.h"
/*===========================================================================
FUNCTION loc_eng_xtra_init
@@ -57,9 +57,9 @@ int loc_eng_xtra_init (loc_eng_data_s_type &loc_eng_data,
int ret_val = -1;
loc_eng_xtra_data_s_type *xtra_module_data_ptr;
- if(callbacks == NULL)
+ if(callbacks == NULL) {
LOC_LOGE("loc_eng_xtra_init: failed, cb is NULL");
- else {
+ } else {
xtra_module_data_ptr = &loc_eng_data.xtra_module_data;
xtra_module_data_ptr->download_request_cb = callbacks->download_request_cb;
xtra_module_data_ptr->report_xtra_server_cb = callbacks->report_xtra_server_cb;
diff --git a/loc_api/loc_api_v02/Android.mk b/loc_api/loc_api_v02/Android.mk
new file mode 100644
index 0000000..1835dc5
--- /dev/null
+++ b/loc_api/loc_api_v02/Android.mk
@@ -0,0 +1,52 @@
+ifneq ($(BUILD_TINY_ANDROID),true)
+
+LOCAL_PATH := $(call my-dir)
+
+include $(CLEAR_VARS)
+
+LOCAL_MODULE := libloc_api_v02
+
+LOCAL_MODULE_TAGS := optional
+
+LOCAL_SHARED_LIBRARIES := \
+ libutils \
+ libcutils \
+ libqmi_cci \
+ libqmi_csi \
+ libqmi_common_so \
+ libloc_adapter \
+ libgps.utils \
+ libds_api
+
+LOCAL_SRC_FILES += \
+ LocApiV02Adapter.cpp \
+ loc_api_v02_log.c \
+ loc_api_v02_client.c \
+ loc_api_sync_req.c \
+ location_service_v02.c
+
+LOCAL_CFLAGS += \
+ -fno-short-enums \
+ -D_ANDROID_
+
+ifeq ($(FEATURE_IPV6), true)
+LOCAL_CFLAGS += -DFEATURE_IPV6
+endif #FEATURE_IPV6
+
+ifeq ($(FEATURE_DELEXT), true)
+LOCAL_CFLAGS += -DFEATURE_DELEXT
+endif #FEATURE_DELEXT
+
+## Includes
+LOCAL_C_INCLUDES := \
+ $(TARGET_OUT_HEADERS)/libloc_eng \
+ $(TARGET_OUT_HEADERS)/qmi-framework/inc \
+ $(TARGET_OUT_HEADERS)/qmi/inc \
+ $(TARGET_OUT_HEADERS)/gps.utils \
+ $(TARGET_OUT_HEADERS)/ds_api
+
+LOCAL_PRELINK_MODULE := false
+
+include $(BUILD_SHARED_LIBRARY)
+
+endif # not BUILD_TINY_ANDROID
diff --git a/loc_api/loc_api_v02/LocApiV02Adapter.cpp b/loc_api/loc_api_v02/LocApiV02Adapter.cpp
new file mode 100644
index 0000000..21e9386
--- /dev/null
+++ b/loc_api/loc_api_v02/LocApiV02Adapter.cpp
@@ -0,0 +1,2365 @@
+/* Copyright (c) 2011-2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundatoin, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#define LOG_NDEBUG 0
+#define LOG_TAG "LocSvc_adapter"
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <math.h>
+#include <stdint.h>
+#include <stdbool.h>
+
+#include <hardware/gps.h>
+
+#ifndef USE_GLIB
+#include <utils/SystemClock.h>
+#endif /* USE_GLIB */
+#include "LocApiV02Adapter.h"
+#include "loc_api_v02_client.h"
+#include "loc_api_v02_log.h"
+#include "loc_api_sync_req.h"
+#include "LocApiAdapter.h"
+#include "loc_util_log.h"
+#include "platform_lib_includes.h"
+
+/* Default session id ; TBD needs incrementing for each */
+#define LOC_API_V02_DEF_SESSION_ID (1)
+
+/* Default minimium interval in ms */
+#define LOC_API_V02_DEF_MIN_INTERVAL (1000)
+
+/* Default horizontal accuracy in meters*/
+#define LOC_API_V02_DEF_HORZ_ACCURACY (50)
+
+/* Default timeout in ms; TBD: needs implementing */
+#define LOC_API_V02_DEF_TIMEOUT (120000)
+
+/* UMTS CP Address key*/
+#define LOC_NI_NOTIF_KEY_ADDRESS "Address"
+
+/* GPS SV Id offset */
+#define GPS_SV_ID_OFFSET (1)
+
+/* GLONASS SV Id offset */
+#define GLONASS_SV_ID_OFFSET (65)
+
+/* SV ID range */
+#define SV_ID_RANGE (32)
+
+
+
+/* static event callbacks that call the LocApiV02Adapter callbacks*/
+
+/* global event callback, call the eventCb function in loc api adapter v02
+ instance */
+static void globalEventCb(locClientHandleType clientHandle,
+ uint32_t eventId,
+ const locClientEventIndUnionType eventPayload,
+ void* pClientCookie)
+{
+ MODEM_LOG_CALLFLOW(%s, loc_get_v02_event_name(eventId));
+ LocApiV02Adapter *locApiV02AdapterInstance =
+ (LocApiV02Adapter *)pClientCookie;
+
+ LOC_LOGV ("%s:%d] client = %p, event id = %d, client cookie ptr = %p\n",
+ __func__, __LINE__, clientHandle, eventId, pClientCookie);
+
+ // return if null is passed
+ if( NULL == locApiV02AdapterInstance)
+ {
+ LOC_LOGE ("%s:%d] NULL object passed : client = %p, event id = %d\n",
+ __func__, __LINE__, clientHandle, eventId);
+ return;
+ }
+ locApiV02AdapterInstance->eventCb(clientHandle,
+ eventId,
+ eventPayload);
+}
+
+/* global response callback, it calls the sync request process
+ indication function to unblock the request that is waiting on this
+ response indication*/
+static void globalRespCb(locClientHandleType clientHandle,
+ uint32_t respId,
+ const locClientRespIndUnionType respPayload,
+ void* pClientCookie)
+{
+ MODEM_LOG_CALLFLOW(%s, loc_get_v02_event_name(respId));
+ LocApiV02Adapter *locApiV02AdapterInstance =
+ (LocApiV02Adapter *)pClientCookie;
+
+
+ LOC_LOGV ("%s:%d] client = %p, resp id = %d, client cookie ptr = %p\n",
+ __func__, __LINE__, clientHandle, respId, pClientCookie);
+
+ if( NULL == locApiV02AdapterInstance)
+ {
+ LOC_LOGE ("%s:%d] NULL object passed : client = %p, resp id = %d\n",
+ __func__, __LINE__, clientHandle, respId);
+ return;
+ }
+ // process the sync call
+ // use pDeleteAssistDataInd as a dummy pointer
+ loc_sync_process_ind(clientHandle, respId,
+ (void *)respPayload.pDeleteAssistDataInd);
+}
+
+/* global error callback, it will call the handle service down
+ function in the loc api adapter instance. */
+static void globalErrorCb (locClientHandleType clientHandle,
+ locClientErrorEnumType errorId,
+ void *pClientCookie)
+{
+ LocApiV02Adapter *locApiV02AdapterInstance =
+ (LocApiV02Adapter *)pClientCookie;
+
+ LOC_LOGV ("%s:%d] client = %p, error id = %d\n, client cookie ptr = %p\n",
+ __func__, __LINE__, clientHandle, errorId, pClientCookie);
+ if( NULL == locApiV02AdapterInstance)
+ {
+ LOC_LOGE ("%s:%d] NULL object passed : client = %p, error id = %d\n",
+ __func__, __LINE__, clientHandle, errorId);
+ return;
+ }
+ locApiV02AdapterInstance->errorCb(clientHandle,
+ errorId);
+}
+
+/* global structure containing the callbacks */
+locClientCallbacksType globalCallbacks =
+{
+ sizeof(locClientCallbacksType),
+ globalEventCb,
+ globalRespCb,
+ globalErrorCb
+};
+
+/* Constructor for LocApiV02Adapter */
+LocApiV02Adapter :: LocApiV02Adapter(LocEng &locEng):
+ dsClientHandle(NULL),
+ LocApiAdapter(locEng), clientHandle( LOC_CLIENT_INVALID_HANDLE_VALUE),
+ eventMask(convertMask(locEng.eventMask))
+{
+ // initialize loc_sync_req interface
+ loc_sync_req_init();
+}
+
+/* Destructor for LocApiV02Adapter */
+LocApiV02Adapter :: ~LocApiV02Adapter()
+{
+ deInitLocClient();
+}
+
+/* close Loc API V02 client */
+int LocApiV02Adapter :: deInitLocClient()
+{
+ return ( eLOC_CLIENT_SUCCESS == locClientClose(&clientHandle)) ? 0 : -1 ;
+}
+
+/* Initialize a loc api v02 client */
+enum loc_api_adapter_err LocApiV02Adapter :: reinit()
+{
+ locClientStatusEnumType status;
+ /* If the client is already open close it first */
+ if(LOC_CLIENT_INVALID_HANDLE_VALUE != clientHandle)
+ {
+ status = locClientClose(&clientHandle);
+ if( eLOC_CLIENT_SUCCESS != status)
+ {
+ LOC_LOGE ("%s:%d]: locClientClose failed, status = %d\n", __func__,
+ __LINE__, status);
+ return (LOC_API_ADAPTER_ERR_FAILURE);
+ }
+ }
+
+ LOC_LOGV ("%s:%d]: reference to this = %p passed in \n", __func__,
+ __LINE__, this);
+ /* initialize the loc api v02 interface, note that
+ the locClientOpen() function will block if the
+ service is unavailable for a fixed time out */
+
+ status = locClientOpen(
+ eventMask, &globalCallbacks, &clientHandle, (void *)this);
+
+ if (eLOC_CLIENT_SUCCESS != status ||
+ clientHandle == LOC_CLIENT_INVALID_HANDLE_VALUE )
+ {
+ LOC_LOGE ("%s:%d]: locClientOpen failed, status = %s\n", __func__,
+ __LINE__, loc_get_v02_client_status_name(status));
+ return (LOC_API_ADAPTER_ERR_FAILURE);
+ }
+
+ // return SUCCESS
+ return (LOC_API_ADAPTER_ERR_SUCCESS);
+}
+
+/* start positioning session */
+enum loc_api_adapter_err LocApiV02Adapter :: startFix()
+{
+ locClientStatusEnumType status;
+ locClientReqUnionType req_union;
+
+ qmiLocStartReqMsgT_v02 start_msg;
+
+ qmiLocSetOperationModeReqMsgT_v02 set_mode_msg;
+ qmiLocSetOperationModeIndMsgT_v02 set_mode_ind;
+
+ // clear all fields, validity masks
+ memset (&start_msg, 0, sizeof(start_msg));
+ memset (&set_mode_msg, 0, sizeof(set_mode_msg));
+ memset (&set_mode_ind, 0, sizeof(set_mode_ind));
+
+ LOC_LOGV("%s:%d]: start \n", __func__, __LINE__);
+ fixCriteria.logv();
+
+ // fill in the start request
+ switch(fixCriteria.mode)
+ {
+ case LOC_POSITION_MODE_MS_BASED:
+ set_mode_msg.operationMode = eQMI_LOC_OPER_MODE_MSB_V02;
+ break;
+
+ case LOC_POSITION_MODE_MS_ASSISTED:
+ set_mode_msg.operationMode = eQMI_LOC_OPER_MODE_MSA_V02;
+ break;
+
+ case LOC_POSITION_MODE_RESERVED_4:
+ set_mode_msg.operationMode = eQMI_LOC_OPER_MODE_CELL_ID_V02;
+ break;
+
+ case LOC_POSITION_MODE_RESERVED_5:
+ set_mode_msg.operationMode = eQMI_LOC_OPER_MODE_WWAN_V02;
+ break;
+
+ default:
+ set_mode_msg.operationMode = eQMI_LOC_OPER_MODE_STANDALONE_V02;
+ break;
+ }
+
+ req_union.pSetOperationModeReq = &set_mode_msg;
+
+ // send the mode first, before the start message.
+ status = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_OPERATION_MODE_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_OPERATION_MODE_IND_V02,
+ &set_mode_ind); // NULL?
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != set_mode_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: set opertion mode failed status = %s, "
+ "ind..status = %s\n", __func__, __LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(set_mode_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE; // error
+ }
+
+ start_msg.minInterval_valid = 1;
+ start_msg.minInterval = fixCriteria.min_interval;
+
+ if (fixCriteria.preferred_accuracy >= 0) {
+ start_msg.horizontalAccuracyLevel_valid = 1;
+
+ if (fixCriteria.preferred_accuracy <= 100)
+ {
+ // fix needs high accuracy
+ start_msg.horizontalAccuracyLevel = eQMI_LOC_ACCURACY_HIGH_V02;
+ }
+ else if (fixCriteria.preferred_accuracy <= 1000)
+ {
+ //fix needs med accuracy
+ start_msg.horizontalAccuracyLevel = eQMI_LOC_ACCURACY_MED_V02;
+ }
+ else
+ {
+ //fix needs low accuracy
+ start_msg.horizontalAccuracyLevel = eQMI_LOC_ACCURACY_LOW_V02;
+ }
+ }
+
+ start_msg.fixRecurrence_valid = 1;
+ if(GPS_POSITION_RECURRENCE_SINGLE == fixCriteria.recurrence)
+ {
+ start_msg.fixRecurrence = eQMI_LOC_RECURRENCE_SINGLE_V02;
+ }
+ else
+ {
+ start_msg.fixRecurrence = eQMI_LOC_RECURRENCE_PERIODIC_V02;
+ }
+
+ //dummy session id
+ // TBD: store session ID, check for session id in pos reports.
+ start_msg.sessionId = LOC_API_V02_DEF_SESSION_ID;
+
+ if (fixCriteria.credentials[0] != 0) {
+ int size1 = sizeof(start_msg.applicationId.applicationName);
+ int size2 = sizeof(fixCriteria.credentials);
+ int len = ((size1 < size2) ? size1 : size2) - 1;
+ memcpy(start_msg.applicationId.applicationName,
+ fixCriteria.credentials,
+ len);
+
+ size1 = sizeof(start_msg.applicationId.applicationProvider);
+ size2 = sizeof(fixCriteria.provider);
+ len = ((size1 < size2) ? size1 : size2) - 1;
+ memcpy(start_msg.applicationId.applicationProvider,
+ fixCriteria.provider,
+ len);
+
+ start_msg.applicationId_valid = 1;
+ }
+
+ req_union.pStartReq = &start_msg;
+
+ status = locClientSendReq (clientHandle, QMI_LOC_START_REQ_V02,
+ req_union );
+
+ if( eLOC_CLIENT_SUCCESS == status)
+ {
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+ }
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+}
+
+/* stop a positioning session */
+enum loc_api_adapter_err LocApiV02Adapter :: stopFix()
+{
+ locClientStatusEnumType status;
+ locClientReqUnionType req_union;
+
+ qmiLocStopReqMsgT_v02 stop_msg;
+
+ LOC_LOGD(" %s:%d]: stop called \n", __func__, __LINE__);
+
+ memset(&stop_msg, 0, sizeof(stop_msg));
+
+ // dummy session id
+ stop_msg.sessionId = LOC_API_V02_DEF_SESSION_ID;
+
+ req_union.pStopReq = &stop_msg;
+
+ status = locClientSendReq(clientHandle,
+ QMI_LOC_STOP_REQ_V02,
+ req_union);
+
+ if( eLOC_CLIENT_SUCCESS == status)
+ {
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+ }
+
+ LOC_LOGE("%s:%d]: error = %s\n",__func__, __LINE__,
+ loc_get_v02_client_status_name(status));
+ return (LOC_API_ADAPTER_ERR_GENERAL_FAILURE);
+}
+
+/* set the positioning fix criteria */
+enum loc_api_adapter_err LocApiV02Adapter :: setPositionMode(
+ const LocPosMode *posMode)
+{
+ LOC_LOGV ("%s:%d]: posMode %p",__func__, __LINE__, posMode);
+
+ if (NULL != posMode &&
+ !fixCriteria.equals(*posMode)) {
+ //making a copy of the fix criteria
+ fixCriteria = *posMode;
+
+ LOC_LOGD ("%s:%d]: new fix criteria", __func__, __LINE__);
+
+ if(true == navigating)
+ {
+ //fix is in progress, send a restart
+ LOC_LOGD ("%s:%d]: fix is in progress restarting the fix with new "
+ "criteria\n", __func__, __LINE__);
+
+ return( startFix());
+ }
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* inject time into the position engine */
+enum loc_api_adapter_err LocApiV02Adapter ::
+ setTime(GpsUtcTime time, int64_t timeReference, int uncertainty)
+{
+ locClientReqUnionType req_union;
+ locClientStatusEnumType status;
+ qmiLocInjectUtcTimeReqMsgT_v02 inject_time_msg;
+ qmiLocInjectUtcTimeIndMsgT_v02 inject_time_ind;
+
+ memset(&inject_time_msg, 0, sizeof(inject_time_msg));
+
+ inject_time_ind.status = eQMI_LOC_GENERAL_FAILURE_V02;
+
+ inject_time_msg.timeUtc = time;
+
+ inject_time_msg.timeUtc += (int64_t)(ELAPSED_MILLIS_SINCE_BOOT_PLATFORM_LIB_ABSTRACTION - timeReference);
+
+ inject_time_msg.timeUnc = uncertainty;
+
+ req_union.pInjectUtcTimeReq = &inject_time_msg;
+
+ LOC_LOGV ("%s:%d]: uncertainty = %d\n", __func__, __LINE__,
+ uncertainty);
+
+ status = loc_sync_send_req(clientHandle,
+ QMI_LOC_INJECT_UTC_TIME_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_INJECT_UTC_TIME_IND_V02,
+ &inject_time_ind);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != inject_time_ind.status)
+ {
+ LOC_LOGE ("%s:%d] status = %s, ind..status = %s\n", __func__, __LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(inject_time_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* inject position into the position engine */
+enum loc_api_adapter_err LocApiV02Adapter ::
+ injectPosition(double latitude, double longitude, float accuracy)
+{
+ locClientReqUnionType req_union;
+ locClientStatusEnumType status;
+ qmiLocInjectPositionReqMsgT_v02 inject_pos_msg;
+ qmiLocInjectPositionIndMsgT_v02 inject_pos_ind;
+
+ memset(&inject_pos_msg, 0, sizeof(inject_pos_msg));
+
+ inject_pos_msg.latitude_valid = 1;
+ inject_pos_msg.latitude = latitude;
+
+ inject_pos_msg.longitude_valid = 1;
+ inject_pos_msg.longitude = longitude;
+
+ inject_pos_msg.horUncCircular_valid = 1;
+
+ inject_pos_msg.horUncCircular = accuracy; //meters assumed
+
+ inject_pos_msg.horConfidence_valid = 1;
+
+ inject_pos_msg.horConfidence = 63; // 63% (1 std dev assumed)
+
+ /* Log */
+ LOC_LOGD("%s:%d]: Lat=%lf, Lon=%lf, Acc=%.2lf\n", __func__, __LINE__,
+ inject_pos_msg.latitude, inject_pos_msg.longitude,
+ inject_pos_msg.horUncCircular);
+
+ req_union.pInjectPositionReq = &inject_pos_msg;
+
+ status = loc_sync_send_req(clientHandle,
+ QMI_LOC_INJECT_POSITION_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_INJECT_POSITION_IND_V02,
+ &inject_pos_ind);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != inject_pos_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: error! status = %s, inject_pos_ind.status = %s\n",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(inject_pos_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* delete assistance date */
+enum loc_api_adapter_err LocApiV02Adapter :: deleteAidingData(GpsAidingData f)
+{
+ locClientReqUnionType req_union;
+ locClientStatusEnumType status;
+ qmiLocDeleteAssistDataReqMsgT_v02 delete_req;
+ qmiLocDeleteAssistDataIndMsgT_v02 delete_resp;
+
+ memset(&delete_req, 0, sizeof(delete_req));
+ memset(&delete_resp, 0, sizeof(delete_resp));
+
+ if( f == GPS_DELETE_ALL )
+ {
+ delete_req.deleteAllFlag = true;
+ }
+
+ else
+ {
+ /* to keep track of svInfoList for GPS and GLO*/
+ uint32_t curr_sv_len = 0;
+ uint32_t curr_sv_idx = 0;
+ uint32_t sv_id = 0;
+
+ if((f & GPS_DELETE_EPHEMERIS ) || ( f & GPS_DELETE_ALMANAC ))
+ {
+ /* do delete for all GPS SV's */
+
+ curr_sv_len += SV_ID_RANGE;
+
+ sv_id = GPS_SV_ID_OFFSET;
+
+ delete_req.deleteSvInfoList_valid = 1;
+
+ delete_req.deleteSvInfoList_len = curr_sv_len;
+
+ LOC_LOGV("%s:%d]: Delete GPS SV info for index %d to %d"
+ "and sv id %d to %d \n",
+ __func__, __LINE__, curr_sv_idx, curr_sv_len - 1,
+ sv_id, sv_id+SV_ID_RANGE);
+
+ for( uint32_t i = curr_sv_idx; i< curr_sv_len ; i++, sv_id++ )
+ {
+ delete_req.deleteSvInfoList[i].gnssSvId = sv_id;
+
+ delete_req.deleteSvInfoList[i].system = eQMI_LOC_SV_SYSTEM_GPS_V02;
+
+ if(f & GPS_DELETE_EPHEMERIS )
+ {
+ // set ephemeris mask for all GPS SV's
+ delete_req.deleteSvInfoList[i].deleteSvInfoMask |=
+ QMI_LOC_MASK_DELETE_EPHEMERIS_V02;
+ }
+
+ if( f & GPS_DELETE_ALMANAC )
+ {
+ delete_req.deleteSvInfoList[i].deleteSvInfoMask |=
+ QMI_LOC_MASK_DELETE_ALMANAC_V02;
+ }
+ }
+ // increment the current index
+ curr_sv_idx += SV_ID_RANGE;
+
+ }
+
+#ifdef FEATURE_DELEXT
+ if( f & GPS_DELETE_TIME_GPS )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GPS_TIME_V02;
+ }
+#endif
+
+ if(f & GPS_DELETE_POSITION )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_POSITION_V02;
+ }
+
+ if(f & GPS_DELETE_TIME )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_TIME_V02;
+ }
+
+ if(f & GPS_DELETE_IONO )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_IONO_V02;
+ }
+
+ if(f & GPS_DELETE_UTC )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_UTC_V02;
+ }
+
+ if(f & GPS_DELETE_HEALTH )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_HEALTH_V02;
+ }
+
+ if(f & GPS_DELETE_SVDIR )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GPS_SVDIR_V02;
+ }
+ if(f & GPS_DELETE_SADATA )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_SADATA_V02;
+ }
+ if(f & GPS_DELETE_RTI )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_RTI_V02;
+ }
+ if(f & GPS_DELETE_CELLDB_INFO )
+ {
+ delete_req.deleteCellDbDataMask_valid = 1;
+ delete_req.deleteCellDbDataMask =
+ ( QMI_LOC_MASK_DELETE_CELLDB_POS_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_LATEST_GPS_POS_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_OTA_POS_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_EXT_REF_POS_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_TIMETAG_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_CELLID_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_CACHED_CELLID_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_LAST_SRV_CELL_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_CUR_SRV_CELL_V02 |
+ QMI_LOC_MASK_DELETE_CELLDB_NEIGHBOR_INFO_V02) ;
+
+ }
+#ifdef FEATURE_DELEXT
+ if(f & GPS_DELETE_ALMANAC_CORR )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GPS_ALM_CORR_V02;
+ }
+ if(f & GPS_DELETE_FREQ_BIAS_EST )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_FREQ_BIAS_EST_V02;
+ }
+ if ( (f & GPS_DELETE_EPHEMERIS_GLO ) || (f & GPS_DELETE_ALMANAC_GLO ))
+ {
+ /* do delete for all GLONASS SV's (65 - 96)
+ */
+ curr_sv_len += SV_ID_RANGE;
+
+ sv_id = GLONASS_SV_ID_OFFSET;
+
+ delete_req.deleteSvInfoList_valid = 1;
+
+ delete_req.deleteSvInfoList_len = curr_sv_len;
+
+ LOC_LOGV("%s:%d]: Delete GLO SV info for index %d to %d"
+ "and sv id %d to %d \n",
+ __func__, __LINE__, curr_sv_idx, curr_sv_len - 1,
+ sv_id, sv_id+SV_ID_RANGE);
+
+
+ for( uint32_t i = curr_sv_idx; i< curr_sv_len ; i++, sv_id++ )
+ {
+ delete_req.deleteSvInfoList[i].gnssSvId = sv_id;
+
+ delete_req.deleteSvInfoList[i].system = eQMI_LOC_SV_SYSTEM_GLONASS_V02;
+
+ if(f & GPS_DELETE_EPHEMERIS )
+ {
+ // set ephemeris mask for all GPS SV's
+ delete_req.deleteSvInfoList[i].deleteSvInfoMask |=
+ QMI_LOC_MASK_DELETE_EPHEMERIS_V02;
+ }
+
+ if( f & GPS_DELETE_ALMANAC )
+ {
+ delete_req.deleteSvInfoList[i].deleteSvInfoMask |=
+ QMI_LOC_MASK_DELETE_ALMANAC_V02;
+ }
+ }
+ curr_sv_idx += SV_ID_RANGE;
+ }
+
+ if(f & GPS_DELETE_SVDIR_GLO )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GLO_SVDIR_V02;
+ }
+
+ if(f & GPS_DELETE_SVSTEER_GLO )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GLO_SVSTEER_V02;
+ }
+
+ if(f & GPS_DELETE_ALMANAC_CORR_GLO )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GLO_ALM_CORR_V02;
+ }
+
+ if(f & GPS_DELETE_TIME_GLO )
+ {
+ delete_req.deleteGnssDataMask_valid = 1;
+ delete_req.deleteGnssDataMask |= QMI_LOC_MASK_DELETE_GLO_TIME_V02;
+ }
+#endif
+ }
+
+ req_union.pDeleteAssistDataReq = &delete_req;
+
+ status = loc_sync_send_req(clientHandle,
+ QMI_LOC_DELETE_ASSIST_DATA_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_DELETE_ASSIST_DATA_IND_V02,
+ &delete_resp);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != delete_resp.status)
+ {
+ LOC_LOGE ("%s:%d]: error! status = %s, delete_resp.status = %s\n",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(delete_resp.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* send NI user repsonse to the engine */
+enum loc_api_adapter_err LocApiV02Adapter ::
+ informNiResponse(GpsUserResponseType userResponse,
+ const void* passThroughData)
+{
+ locClientReqUnionType req_union;
+ locClientStatusEnumType status;
+
+ qmiLocNiUserRespReqMsgT_v02 ni_resp;
+ qmiLocNiUserRespIndMsgT_v02 ni_resp_ind;
+
+ qmiLocEventNiNotifyVerifyReqIndMsgT_v02 *request_pass_back =
+ (qmiLocEventNiNotifyVerifyReqIndMsgT_v02 *)passThroughData;
+
+ memset(&ni_resp,0, sizeof(ni_resp));
+
+ memset(&ni_resp_ind,0, sizeof(ni_resp_ind));
+
+ switch (userResponse)
+ {
+ case GPS_NI_RESPONSE_ACCEPT:
+ ni_resp.userResp = eQMI_LOC_NI_LCS_NOTIFY_VERIFY_ACCEPT_V02;
+ break;
+ case GPS_NI_RESPONSE_DENY:
+ ni_resp.userResp = eQMI_LOC_NI_LCS_NOTIFY_VERIFY_DENY_V02;
+ break;
+ case GPS_NI_RESPONSE_NORESP:
+ ni_resp.userResp = eQMI_LOC_NI_LCS_NOTIFY_VERIFY_NORESP_V02;
+ break;
+ default:
+ return LOC_API_ADAPTER_ERR_INVALID_PARAMETER;
+ }
+
+ LOC_LOGV(" %s:%d]: NI response: %d\n", __func__, __LINE__,
+ ni_resp.userResp);
+
+ ni_resp.notificationType = request_pass_back->notificationType;
+
+ // copy SUPL payload from request
+ if(request_pass_back->NiSuplInd_valid == 1)
+ {
+ ni_resp.NiSuplPayload_valid = 1;
+ memcpy(&(ni_resp.NiSuplPayload), &(request_pass_back->NiSuplInd),
+ sizeof(qmiLocNiSuplNotifyVerifyStructT_v02));
+
+ }
+ // should this be an "else if"?? we don't need to decide
+
+ // copy UMTS-CP payload from request
+ if( request_pass_back->NiUmtsCpInd_valid == 1 )
+ {
+ ni_resp.NiUmtsCpPayload_valid = 1;
+ memcpy(&(ni_resp.NiUmtsCpPayload), &(request_pass_back->NiUmtsCpInd),
+ sizeof(qmiLocNiUmtsCpNotifyVerifyStructT_v02));
+ }
+
+ //copy Vx payload from the request
+ if( request_pass_back->NiVxInd_valid == 1)
+ {
+ ni_resp.NiVxPayload_valid = 1;
+ memcpy(&(ni_resp.NiVxPayload), &(request_pass_back->NiVxInd),
+ sizeof(qmiLocNiVxNotifyVerifyStructT_v02));
+ }
+
+ // copy Vx service interaction payload from the request
+ if(request_pass_back->NiVxServiceInteractionInd_valid == 1)
+ {
+ ni_resp.NiVxServiceInteractionPayload_valid = 1;
+ memcpy(&(ni_resp.NiVxServiceInteractionPayload),
+ &(request_pass_back->NiVxServiceInteractionInd),
+ sizeof(qmiLocNiVxServiceInteractionStructT_v02));
+ }
+
+ // copy Network Initiated SUPL Version 2 Extension
+ if (request_pass_back->NiSuplVer2ExtInd_valid == 1)
+ {
+ ni_resp.NiSuplVer2ExtPayload_valid = 1;
+ memcpy(&(ni_resp.NiSuplVer2ExtPayload),
+ &(request_pass_back->NiSuplVer2ExtInd),
+ sizeof(qmiLocNiSuplVer2ExtStructT_v02));
+ }
+
+ // copy SUPL Emergency Notification
+ if(request_pass_back->suplEmergencyNotification_valid)
+ {
+ ni_resp.suplEmergencyNotification_valid = 1;
+ memcpy(&(ni_resp.suplEmergencyNotification),
+ &(request_pass_back->suplEmergencyNotification),
+ sizeof(qmiLocEmergencyNotificationStructT_v02));
+ }
+
+ req_union.pNiUserRespReq = &ni_resp;
+
+ status = loc_sync_send_req (
+ clientHandle, QMI_LOC_NI_USER_RESPONSE_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_NI_USER_RESPONSE_IND_V02, &ni_resp_ind);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != ni_resp_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: error! status = %s, ni_resp_ind.status = %s\n",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(ni_resp_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* Set UMTs SLP server URL */
+enum loc_api_adapter_err LocApiV02Adapter :: setServer(
+ const char* url, int len)
+{
+ locClientReqUnionType req_union;
+ locClientStatusEnumType status;
+ qmiLocSetServerReqMsgT_v02 set_server_req;
+ qmiLocSetServerIndMsgT_v02 set_server_ind;
+
+ if(len <=0 || len > sizeof(set_server_req.urlAddr))
+ {
+ LOC_LOGE("%s:%d]: len = %d greater than max allowed url length\n",
+ __func__, __LINE__, len);
+
+ return LOC_API_ADAPTER_ERR_INVALID_PARAMETER;
+ }
+
+ memset(&set_server_req, 0, sizeof(set_server_req));
+
+ LOC_LOGD("%s:%d]:, url = %s, len = %d\n", __func__, __LINE__, url, len);
+
+ set_server_req.serverType = eQMI_LOC_SERVER_TYPE_UMTS_SLP_V02;
+
+ set_server_req.urlAddr_valid = 1;
+
+ strlcpy(set_server_req.urlAddr, url, sizeof(set_server_req.urlAddr));
+
+ req_union.pSetServerReq = &set_server_req;
+
+ status = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_SERVER_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_SERVER_IND_V02,
+ &set_server_ind);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != set_server_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: error status = %s, set_server_ind.status = %s\n",
+ __func__,__LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(set_server_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+enum loc_api_adapter_err LocApiV02Adapter ::
+ setServer(unsigned int ip, int port, LocServerType type)
+{
+ locClientReqUnionType req_union;
+ locClientStatusEnumType status;
+ qmiLocSetServerReqMsgT_v02 set_server_req;
+ qmiLocSetServerIndMsgT_v02 set_server_ind;
+ qmiLocServerTypeEnumT_v02 set_server_cmd;
+
+ switch (type) {
+ case LOC_AGPS_MPC_SERVER:
+ set_server_cmd = eQMI_LOC_SERVER_TYPE_CDMA_MPC_V02;
+ break;
+ case LOC_AGPS_CUSTOM_PDE_SERVER:
+ set_server_cmd = eQMI_LOC_SERVER_TYPE_CUSTOM_PDE_V02;
+ break;
+ default:
+ set_server_cmd = eQMI_LOC_SERVER_TYPE_CDMA_PDE_V02;
+ break;
+ }
+
+ memset(&set_server_req, 0, sizeof(set_server_req));
+
+ LOC_LOGD("%s:%d]:, ip = %u, port = %d\n", __func__, __LINE__, ip, port);
+
+ set_server_req.serverType = set_server_cmd;
+ set_server_req.ipv4Addr_valid = 1;
+ set_server_req.ipv4Addr.addr = ip;
+ set_server_req.ipv4Addr.port = port;
+
+ req_union.pSetServerReq = &set_server_req;
+
+ status = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_SERVER_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_SERVER_IND_V02,
+ &set_server_ind);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != set_server_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: error status = %s, set_server_ind.status = %s\n",
+ __func__,__LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(set_server_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* Inject XTRA data, this module breaks down the XTRA
+ file into "chunks" and injects them one at a time */
+enum loc_api_adapter_err LocApiV02Adapter :: setXtraData(
+ char* data, int length)
+{
+ locClientStatusEnumType status = eLOC_CLIENT_SUCCESS;
+ int total_parts;
+ uint8_t part;
+ uint16_t len_injected;
+
+ locClientReqUnionType req_union;
+ qmiLocInjectPredictedOrbitsDataReqMsgT_v02 inject_xtra;
+ qmiLocInjectPredictedOrbitsDataIndMsgT_v02 inject_xtra_ind;
+
+ req_union.pInjectPredictedOrbitsDataReq = &inject_xtra;
+
+ LOC_LOGD("%s:%d]: xtra size = %d\n", __func__, __LINE__, length);
+
+ inject_xtra.formatType_valid = 1;
+ inject_xtra.formatType = eQMI_LOC_PREDICTED_ORBITS_XTRA_V02;
+ inject_xtra.totalSize = length;
+
+ total_parts = ((length - 1) / QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02) + 1;
+
+ inject_xtra.totalParts = total_parts;
+
+ len_injected = 0; // O bytes injected
+
+ // XTRA injection starts with part 1
+ for (part = 1; part <= total_parts; part++)
+ {
+ inject_xtra.partNum = part;
+
+ if (QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02 > (length - len_injected))
+ {
+ inject_xtra.partData_len = length - len_injected;
+ }
+ else
+ {
+ inject_xtra.partData_len = QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02;
+ }
+
+ // copy data into the message
+ memcpy(inject_xtra.partData, data+len_injected, inject_xtra.partData_len);
+
+ LOC_LOGD("[%s:%d] part %d/%d, len = %d, total injected = %d\n",
+ __func__, __LINE__,
+ inject_xtra.partNum, total_parts, inject_xtra.partData_len,
+ len_injected);
+
+ status = loc_sync_send_req( clientHandle,
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02,
+ &inject_xtra_ind);
+
+ if (status != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != inject_xtra_ind.status ||
+ inject_xtra.partNum != inject_xtra_ind.partNum)
+ {
+ LOC_LOGE ("%s:%d]: failed status = %s, inject_pos_ind.status = %s,"
+ " part num = %d, ind.partNum = %d\n", __func__, __LINE__,
+ loc_get_v02_client_status_name(status),
+ loc_get_v02_qmi_status_name(inject_xtra_ind.status),
+ inject_xtra.partNum, inject_xtra_ind.partNum);
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ break;
+ }
+
+ len_injected += inject_xtra.partData_len;
+ LOC_LOGD("%s:%d]: XTRA injected length: %d\n", __func__, __LINE__,
+ len_injected);
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+#ifdef FEATURE_IPV6
+enum loc_api_adapter_err LocApiV02Adapter :: atlOpenStatus(
+ int handle, int is_succ, char* apn, AGpsBearerType bear,
+ AGpsType agpsType)
+#else
+enum loc_api_adapter_err LocApiV02Adapter :: atlOpenStatus(
+ int handle, int is_succ, char* apn,
+ AGpsType agpsType)
+#endif
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+ qmiLocInformLocationServerConnStatusReqMsgT_v02 conn_status_req;
+ qmiLocInformLocationServerConnStatusIndMsgT_v02 conn_status_ind;
+
+#ifdef FEATURE_IPV6
+ LOC_LOGD("%s:%d]: ATL open handle = %d, is_succ = %d, "
+ "APN = [%s], bearer = %d \n", __func__, __LINE__,
+ handle, is_succ, apn, bear);
+#else
+ LOC_LOGD("%s:%d]: ATL open handle = %d, is_succ = %d, "
+ "APN = [%s] \n", __func__, __LINE__,
+ handle, is_succ, apn);
+#endif
+
+ memset(&conn_status_req, 0, sizeof(conn_status_req));
+ memset(&conn_status_ind, 0, sizeof(conn_status_ind));
+
+ // Fill in data
+ conn_status_req.connHandle = handle;
+
+ conn_status_req.requestType = eQMI_LOC_SERVER_REQUEST_OPEN_V02;
+
+ if(is_succ)
+ {
+ conn_status_req.statusType = eQMI_LOC_SERVER_REQ_STATUS_SUCCESS_V02;
+
+ if(apn != NULL)
+ strlcpy(conn_status_req.apnProfile.apnName, apn,
+ sizeof(conn_status_req.apnProfile.apnName) );
+
+#ifdef FEATURE_IPV6
+ switch(bear)
+ {
+ case AGPS_APN_BEARER_IPV4:
+ conn_status_req.apnProfile.pdnType =
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV4_V02;
+ conn_status_req.apnProfile_valid = 1;
+ break;
+
+ case AGPS_APN_BEARER_IPV6:
+ conn_status_req.apnProfile.pdnType =
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV6_V02;
+ conn_status_req.apnProfile_valid = 1;
+ break;
+
+ case AGPS_APN_BEARER_IPV4V6:
+ conn_status_req.apnProfile.pdnType =
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV4V6_V02;
+ conn_status_req.apnProfile_valid = 1;
+ break;
+
+ case AGPS_APN_BEARER_INVALID:
+ conn_status_req.apnProfile_valid = 0;
+ break;
+
+ default:
+ LOC_LOGE("%s:%d]:invalid bearer type\n",__func__,__LINE__);
+ return LOC_API_ADAPTER_ERR_INVALID_HANDLE;
+ }
+#else
+ conn_status_req.apnProfile.pdnType =
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV4_V02;
+#endif
+
+ }
+ else
+ {
+ conn_status_req.statusType = eQMI_LOC_SERVER_REQ_STATUS_FAILURE_V02;
+ }
+
+ req_union.pInformLocationServerConnStatusReq = &conn_status_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02,
+ &conn_status_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != conn_status_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(conn_status_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+
+}
+
+
+/* close atl connection */
+enum loc_api_adapter_err LocApiV02Adapter :: atlCloseStatus(
+ int handle, int is_succ)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+ qmiLocInformLocationServerConnStatusReqMsgT_v02 conn_status_req;
+ qmiLocInformLocationServerConnStatusIndMsgT_v02 conn_status_ind;
+
+ LOC_LOGD("%s:%d]: ATL close handle = %d, is_succ = %d\n",
+ __func__, __LINE__, handle, is_succ);
+
+ memset(&conn_status_req, 0, sizeof(conn_status_req));
+ memset(&conn_status_ind, 0, sizeof(conn_status_ind));
+
+ // Fill in data
+ conn_status_req.connHandle = handle;
+
+ conn_status_req.requestType = eQMI_LOC_SERVER_REQUEST_CLOSE_V02;
+
+ if(is_succ)
+ {
+ conn_status_req.statusType = eQMI_LOC_SERVER_REQ_STATUS_SUCCESS_V02;
+ }
+ else
+ {
+ conn_status_req.statusType = eQMI_LOC_SERVER_REQ_STATUS_FAILURE_V02;
+ }
+
+ req_union.pInformLocationServerConnStatusReq = &conn_status_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02,
+ &conn_status_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != conn_status_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(conn_status_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the SUPL version */
+enum loc_api_adapter_err LocApiV02Adapter :: setSUPLVersion(uint32_t version)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+
+ qmiLocSetProtocolConfigParametersReqMsgT_v02 supl_config_req;
+ qmiLocSetProtocolConfigParametersIndMsgT_v02 supl_config_ind;
+
+ LOC_LOGD("%s:%d]: supl version = %d\n", __func__, __LINE__, version);
+
+
+ memset(&supl_config_req, 0, sizeof(supl_config_req));
+ memset(&supl_config_ind, 0, sizeof(supl_config_ind));
+
+ supl_config_req.suplVersion_valid = 1;
+ // SUPL version from MSByte to LSByte:
+ // (reserved)(major version)(minor version)(serviceIndicator)
+
+ supl_config_req.suplVersion = (version == 0x00020000)?
+ eQMI_LOC_SUPL_VERSION_2_0_V02 : eQMI_LOC_SUPL_VERSION_1_0_V02;
+
+ req_union.pSetProtocolConfigParametersReq = &supl_config_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02,
+ &supl_config_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != supl_config_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(supl_config_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the configuration for LTE positioning profile (LPP) */
+enum loc_api_adapter_err LocApiV02Adapter :: setLPPConfig(uint32_t profile)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+ qmiLocSetProtocolConfigParametersReqMsgT_v02 lpp_config_req;
+ qmiLocSetProtocolConfigParametersIndMsgT_v02 lpp_config_ind;
+
+ LOC_LOGD("%s:%d]: lpp profile = %d\n", __func__, __LINE__, profile);
+
+ memset(&lpp_config_req, 0, sizeof(lpp_config_req));
+ memset(&lpp_config_ind, 0, sizeof(lpp_config_ind));
+
+ lpp_config_req.lppConfig_valid = 1;
+
+ lpp_config_req.lppConfig = profile;
+
+ req_union.pSetProtocolConfigParametersReq = &lpp_config_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02,
+ &lpp_config_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != lpp_config_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(lpp_config_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the Sensor Configuration */
+enum loc_api_adapter_err LocApiV02Adapter :: setSensorControlConfig(int sensorsDisabled)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+
+ qmiLocSetSensorControlConfigReqMsgT_v02 sensor_config_req;
+ qmiLocSetSensorControlConfigIndMsgT_v02 sensor_config_ind;
+
+ LOC_LOGD("%s:%d]: sensors disabled = %d\n", __func__, __LINE__, sensorsDisabled);
+
+ memset(&sensor_config_req, 0, sizeof(sensor_config_req));
+ memset(&sensor_config_ind, 0, sizeof(sensor_config_ind));
+
+ sensor_config_req.sensorsUsage_valid = 1;
+ sensor_config_req.sensorsUsage = (sensorsDisabled == 1) ? eQMI_LOC_SENSOR_CONFIG_SENSOR_USE_DISABLE_V02
+ : eQMI_LOC_SENSOR_CONFIG_SENSOR_USE_ENABLE_V02;
+
+ req_union.pSetSensorControlConfigReq = &sensor_config_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02,
+ &sensor_config_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != sensor_config_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(sensor_config_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the Sensor Properties */
+enum loc_api_adapter_err LocApiV02Adapter :: setSensorProperties(bool gyroBiasVarianceRandomWalk_valid, float gyroBiasVarianceRandomWalk,
+ bool accelBiasVarianceRandomWalk_valid, float accelBiasVarianceRandomWalk,
+ bool angleBiasVarianceRandomWalk_valid, float angleBiasVarianceRandomWalk,
+ bool rateBiasVarianceRandomWalk_valid, float rateBiasVarianceRandomWalk,
+ bool velocityBiasVarianceRandomWalk_valid, float velocityBiasVarianceRandomWalk)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+
+ qmiLocSetSensorPropertiesReqMsgT_v02 sensor_prop_req;
+ qmiLocSetSensorPropertiesIndMsgT_v02 sensor_prop_ind;
+
+ LOC_LOGI("%s:%d]: sensors prop: gyroBiasRandomWalk = %f, accelRandomWalk = %f, "
+ "angleRandomWalk = %f, rateRandomWalk = %f, velocityRandomWalk = %f\n",
+ __func__, __LINE__, gyroBiasVarianceRandomWalk, accelBiasVarianceRandomWalk,
+ angleBiasVarianceRandomWalk, rateBiasVarianceRandomWalk, velocityBiasVarianceRandomWalk);
+
+ memset(&sensor_prop_req, 0, sizeof(sensor_prop_req));
+ memset(&sensor_prop_ind, 0, sizeof(sensor_prop_ind));
+
+ /* Set the validity bit and value for each sensor property */
+ sensor_prop_req.gyroBiasVarianceRandomWalk_valid = gyroBiasVarianceRandomWalk_valid;
+ sensor_prop_req.gyroBiasVarianceRandomWalk = gyroBiasVarianceRandomWalk;
+
+ sensor_prop_req.accelerationRandomWalkSpectralDensity_valid = accelBiasVarianceRandomWalk_valid;
+ sensor_prop_req.accelerationRandomWalkSpectralDensity = accelBiasVarianceRandomWalk;
+
+ sensor_prop_req.angleRandomWalkSpectralDensity_valid = angleBiasVarianceRandomWalk_valid;
+ sensor_prop_req.angleRandomWalkSpectralDensity = angleBiasVarianceRandomWalk;
+
+ sensor_prop_req.rateRandomWalkSpectralDensity_valid = rateBiasVarianceRandomWalk_valid;
+ sensor_prop_req.rateRandomWalkSpectralDensity = rateBiasVarianceRandomWalk;
+
+ sensor_prop_req.velocityRandomWalkSpectralDensity_valid = velocityBiasVarianceRandomWalk_valid;
+ sensor_prop_req.velocityRandomWalkSpectralDensity = velocityBiasVarianceRandomWalk;
+
+ req_union.pSetSensorPropertiesReq = &sensor_prop_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02,
+ &sensor_prop_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != sensor_prop_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(sensor_prop_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the Sensor Performance Config */
+enum loc_api_adapter_err LocApiV02Adapter :: setSensorPerfControlConfig(int controlMode,
+ int accelSamplesPerBatch, int accelBatchesPerSec,
+ int gyroSamplesPerBatch, int gyroBatchesPerSec,
+ int accelSamplesPerBatchHigh, int accelBatchesPerSecHigh,
+ int gyroSamplesPerBatchHigh, int gyroBatchesPerSecHigh,
+ int algorithmConfig)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+
+ qmiLocSetSensorPerformanceControlConfigReqMsgT_v02 sensor_perf_config_req;
+ qmiLocSetSensorPerformanceControlConfigIndMsgT_v02 sensor_perf_config_ind;
+
+ LOC_LOGD("%s:%d]: Sensor Perf Control Config (performanceControlMode)(%u) "
+ "accel(#smp,#batches) (%u,%u) gyro(#smp,#batches) (%u,%u) "
+ "accel_high(#smp,#batches) (%u,%u) gyro_high(#smp,#batches) (%u,%u) "
+ "algorithmConfig(%u)\n",
+ __FUNCTION__,
+ __LINE__,
+ controlMode,
+ accelSamplesPerBatch,
+ accelBatchesPerSec,
+ gyroSamplesPerBatch,
+ gyroBatchesPerSec,
+ accelSamplesPerBatchHigh,
+ accelBatchesPerSecHigh,
+ gyroSamplesPerBatchHigh,
+ gyroBatchesPerSecHigh,
+ algorithmConfig
+ );
+
+ memset(&sensor_perf_config_req, 0, sizeof(sensor_perf_config_req));
+ memset(&sensor_perf_config_ind, 0, sizeof(sensor_perf_config_ind));
+
+ sensor_perf_config_req.performanceControlMode_valid = 1;
+ sensor_perf_config_req.performanceControlMode = (qmiLocSensorPerformanceControlModeEnumT_v02)controlMode;
+ sensor_perf_config_req.accelSamplingSpec_valid = 1;
+ sensor_perf_config_req.accelSamplingSpec.batchesPerSecond = accelBatchesPerSec;
+ sensor_perf_config_req.accelSamplingSpec.samplesPerBatch = accelSamplesPerBatch;
+ sensor_perf_config_req.gyroSamplingSpec_valid = 1;
+ sensor_perf_config_req.gyroSamplingSpec.batchesPerSecond = gyroBatchesPerSec;
+ sensor_perf_config_req.gyroSamplingSpec.samplesPerBatch = gyroSamplesPerBatch;
+ sensor_perf_config_req.accelSamplingSpecHigh_valid = 1;
+ sensor_perf_config_req.accelSamplingSpecHigh.batchesPerSecond = accelBatchesPerSecHigh;
+ sensor_perf_config_req.accelSamplingSpecHigh.samplesPerBatch = accelSamplesPerBatchHigh;
+ sensor_perf_config_req.gyroSamplingSpecHigh_valid = 1;
+ sensor_perf_config_req.gyroSamplingSpecHigh.batchesPerSecond = gyroBatchesPerSecHigh;
+ sensor_perf_config_req.gyroSamplingSpecHigh.samplesPerBatch = gyroSamplesPerBatchHigh;
+ sensor_perf_config_req.algorithmConfig_valid = 1;
+ sensor_perf_config_req.algorithmConfig = algorithmConfig;
+
+ req_union.pSetSensorPerformanceControlConfigReq = &sensor_perf_config_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02,
+ &sensor_perf_config_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != sensor_perf_config_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(sensor_perf_config_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the External Power Config */
+enum loc_api_adapter_err LocApiV02Adapter :: setExtPowerConfig(int isBatteryCharging)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+
+ qmiLocSetExternalPowerConfigReqMsgT_v02 ext_pwr_req;
+ qmiLocGetExternalPowerConfigIndMsgT_v02 ext_pwr_ind;
+
+ LOC_LOGI("%s:%d]: Ext Pwr Config (isBatteryCharging)(%u)",
+ __FUNCTION__,
+ __LINE__,
+ isBatteryCharging
+ );
+
+ memset(&ext_pwr_req, 0, sizeof(ext_pwr_req));
+ memset(&ext_pwr_ind, 0, sizeof(ext_pwr_ind));
+
+ switch(isBatteryCharging)
+ {
+ /* Charging */
+ case 1:
+ ext_pwr_req.externalPowerState = eQMI_LOC_EXTERNAL_POWER_CONNECTED_V02;
+ break;
+
+ /* Not charging */
+ case 0:
+ ext_pwr_req.externalPowerState = eQMI_LOC_EXTERNAL_POWER_NOT_CONNECTED_V02;
+ break;
+
+ default:
+ LOC_LOGE("%s:%d]: Invalid ext power state = %d!",
+ __FUNCTION__,
+ __LINE__,
+ isBatteryCharging);
+ return LOC_API_ADAPTER_ERR_INVALID_PARAMETER;
+ break;
+ }
+
+ req_union.pSetExternalPowerConfigReq = &ext_pwr_req;
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02,
+ &ext_pwr_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != ext_pwr_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %d, ind..status = %d ",
+ __func__, __LINE__, result, ext_pwr_ind.status);
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* set the Positioning Protocol on A-GLONASS system */
+enum loc_api_adapter_err LocApiV02Adapter :: setAGLONASSProtocol(unsigned long aGlonassProtocol)
+{
+ locClientStatusEnumType result = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType req_union;
+ qmiLocSetProtocolConfigParametersReqMsgT_v02 aGlonassProtocol_req;
+ qmiLocSetProtocolConfigParametersIndMsgT_v02 aGlonassProtocol_ind;
+
+ memset(&aGlonassProtocol_req, 0, sizeof(aGlonassProtocol_req));
+ memset(&aGlonassProtocol_ind, 0, sizeof(aGlonassProtocol_ind));
+
+ aGlonassProtocol_req.assistedGlonassProtocolMask_valid = 1;
+ aGlonassProtocol_req.assistedGlonassProtocolMask = aGlonassProtocol;
+
+ req_union.pSetProtocolConfigParametersReq = &aGlonassProtocol_req;
+
+ LOC_LOGD("%s:%d]: aGlonassProtocolMask = 0x%lx\n", __func__, __LINE__,
+ aGlonassProtocol_req.assistedGlonassProtocolMask);
+
+ result = loc_sync_send_req(clientHandle,
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02,
+ req_union, LOC_ENGINE_SYNC_REQUEST_TIMEOUT,
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02,
+ &aGlonassProtocol_ind);
+
+ if(result != eLOC_CLIENT_SUCCESS ||
+ eQMI_LOC_SUCCESS_V02 != aGlonassProtocol_ind.status)
+ {
+ LOC_LOGE ("%s:%d]: Error status = %s, ind..status = %s ",
+ __func__, __LINE__,
+ loc_get_v02_client_status_name(result),
+ loc_get_v02_qmi_status_name(aGlonassProtocol_ind.status));
+
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+ }
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+}
+
+/* Convert event mask from loc eng to loc_api_v02 format */
+locClientEventMaskType LocApiV02Adapter :: convertMask(
+ LOC_API_ADAPTER_EVENT_MASK_T mask)
+{
+ locClientEventMaskType eventMask = 0;
+ LOC_LOGD("%s:%d]: adapter mask = %u\n", __func__, __LINE__, mask);
+
+ if(mask & LOC_API_ADAPTER_BIT_PARSED_POSITION_REPORT)
+ eventMask |= QMI_LOC_EVENT_MASK_POSITION_REPORT_V02;
+
+ if(mask & LOC_API_ADAPTER_BIT_SATELLITE_REPORT)
+ eventMask |= QMI_LOC_EVENT_MASK_GNSS_SV_INFO_V02;
+
+ /* treat NMEA_1Hz and NMEA_POSITION_REPORT the same*/
+ if( (mask & LOC_API_ADAPTER_BIT_NMEA_POSITION_REPORT) ||
+ (mask & LOC_API_ADAPTER_BIT_NMEA_1HZ_REPORT) )
+ eventMask |= QMI_LOC_EVENT_MASK_NMEA_V02;
+
+ if(mask & LOC_API_ADAPTER_BIT_NI_NOTIFY_VERIFY_REQUEST)
+ eventMask |= QMI_LOC_EVENT_MASK_NI_NOTIFY_VERIFY_REQ_V02;
+
+ if(mask & LOC_API_ADAPTER_BIT_ASSISTANCE_DATA_REQUEST)
+ {
+ // TBD: This needs to be decoupled in the HAL
+ eventMask |= QMI_LOC_EVENT_MASK_INJECT_PREDICTED_ORBITS_REQ_V02;
+ eventMask |= QMI_LOC_EVENT_MASK_INJECT_TIME_REQ_V02;
+ eventMask |= QMI_LOC_EVENT_MASK_INJECT_POSITION_REQ_V02;
+ }
+
+ if(mask & LOC_API_ADAPTER_BIT_STATUS_REPORT)
+ {
+ eventMask |= (QMI_LOC_EVENT_MASK_ENGINE_STATE_V02);
+ }
+
+ if(mask & LOC_API_ADAPTER_BIT_LOCATION_SERVER_REQUEST)
+ eventMask |= QMI_LOC_EVENT_MASK_LOCATION_SERVER_CONNECTION_REQ_V02;
+
+ return eventMask;
+}
+
+/* Convert error from loc_api_v02 to loc eng format*/
+enum loc_api_adapter_err LocApiV02Adapter :: convertErr(
+ locClientStatusEnumType status)
+{
+ switch( status)
+ {
+ case LOC_API_ADAPTER_ERR_SUCCESS:
+ return LOC_API_ADAPTER_ERR_SUCCESS;
+
+ case eLOC_CLIENT_FAILURE_GENERAL:
+ return LOC_API_ADAPTER_ERR_GENERAL_FAILURE;
+
+ case eLOC_CLIENT_FAILURE_UNSUPPORTED:
+ return LOC_API_ADAPTER_ERR_UNSUPPORTED;
+
+ case eLOC_CLIENT_FAILURE_INVALID_PARAMETER:
+ return LOC_API_ADAPTER_ERR_INVALID_PARAMETER;
+
+ case eLOC_CLIENT_FAILURE_ENGINE_BUSY:
+ return LOC_API_ADAPTER_ERR_ENGINE_BUSY;
+
+ case eLOC_CLIENT_FAILURE_PHONE_OFFLINE:
+ return LOC_API_ADAPTER_ERR_PHONE_OFFLINE;
+
+ case eLOC_CLIENT_FAILURE_TIMEOUT:
+ return LOC_API_ADAPTER_ERR_TIMEOUT;
+
+ case eLOC_CLIENT_FAILURE_INVALID_HANDLE:
+ return LOC_API_ADAPTER_ERR_INVALID_HANDLE;
+
+ case eLOC_CLIENT_FAILURE_SERVICE_NOT_PRESENT:
+ return LOC_API_ADAPTER_ERR_SERVICE_NOT_PRESENT;
+
+ default:
+ return LOC_API_ADAPTER_ERR_FAILURE;
+ }
+}
+
+/* convert position report to loc eng format and send the converted
+ position to loc eng */
+
+void LocApiV02Adapter :: reportPosition (
+ const qmiLocEventPositionReportIndMsgT_v02 *location_report_ptr)
+{
+ UlpLocation location;
+ LocPosTechMask tech_Mask = LOC_POS_TECH_MASK_DEFAULT;
+ LOC_LOGD("Reporting postion from V2 Adapter\n");
+ memset(&location, 0, sizeof (UlpLocation));
+ location.size = sizeof(location);
+ GpsLocationExtended locationExtended;
+ memset(&locationExtended, 0, sizeof (GpsLocationExtended));
+ locationExtended.size = sizeof(locationExtended);
+ // Process the position from final and intermediate reports
+
+ if( (location_report_ptr->sessionStatus == eQMI_LOC_SESS_STATUS_SUCCESS_V02) ||
+ (location_report_ptr->sessionStatus == eQMI_LOC_SESS_STATUS_IN_PROGRESS_V02)
+ )
+ {
+ // Latitude & Longitude
+ if( (location_report_ptr->latitude_valid == 1 ) &&
+ (location_report_ptr->longitude_valid == 1) &&
+ (location_report_ptr->latitude != 0 ||
+ location_report_ptr->longitude!= 0))
+ {
+ location.gpsLocation.flags |= GPS_LOCATION_HAS_LAT_LONG;
+ location.gpsLocation.latitude = location_report_ptr->latitude;
+ location.gpsLocation.longitude = location_report_ptr->longitude;
+
+ // Time stamp (UTC)
+ if(location_report_ptr->timestampUtc_valid == 1)
+ {
+ location.gpsLocation.timestamp = location_report_ptr->timestampUtc;
+ }
+
+ // Altitude
+ if(location_report_ptr->altitudeWrtEllipsoid_valid == 1 )
+ {
+ location.gpsLocation.flags |= GPS_LOCATION_HAS_ALTITUDE;
+ location.gpsLocation.altitude = location_report_ptr->altitudeWrtEllipsoid;
+ }
+
+ // Speed
+ if((location_report_ptr->speedHorizontal_valid == 1) &&
+ (location_report_ptr->speedVertical_valid ==1 ) )
+ {
+ location.gpsLocation.flags |= GPS_LOCATION_HAS_SPEED;
+ location.gpsLocation.speed = sqrt(
+ (location_report_ptr->speedHorizontal *
+ location_report_ptr->speedHorizontal) +
+ (location_report_ptr->speedVertical *
+ location_report_ptr->speedVertical) );
+ }
+
+ // Heading
+ if(location_report_ptr->heading_valid == 1)
+ {
+ location.gpsLocation.flags |= GPS_LOCATION_HAS_BEARING;
+ location.gpsLocation.bearing = location_report_ptr->heading;
+ }
+
+ // Uncertainty (circular)
+ if( (location_report_ptr->horUncCircular_valid ) )
+ {
+ location.gpsLocation.flags |= GPS_LOCATION_HAS_ACCURACY;
+ location.gpsLocation.accuracy = location_report_ptr->horUncCircular;
+ }
+
+ // Technology Mask
+ tech_Mask |= location_report_ptr->technologyMask;
+
+ //Mark the location source as from GNSS
+ location.gpsLocation.flags |= LOCATION_HAS_SOURCE_INFO;
+ location.position_source = ULP_LOCATION_IS_FROM_GNSS;
+ if (location_report_ptr->magneticDeviation_valid)
+ {
+ locationExtended.flags |= GPS_LOCATION_EXTENDED_HAS_MAG_DEV;
+ locationExtended.magneticDeviation = location_report_ptr->magneticDeviation;
+ }
+
+ if (location_report_ptr->DOP_valid)
+ {
+ locationExtended.flags |= GPS_LOCATION_EXTENDED_HAS_DOP;
+ locationExtended.pdop = location_report_ptr->DOP.PDOP;
+ locationExtended.hdop = location_report_ptr->DOP.HDOP;
+ locationExtended.vdop = location_report_ptr->DOP.VDOP;
+ }
+
+ if (location_report_ptr->altitudeWrtMeanSeaLevel_valid)
+ {
+ locationExtended.flags |= GPS_LOCATION_EXTENDED_HAS_ALTITUDE_MEAN_SEA_LEVEL;
+ locationExtended.altitudeMeanSeaLevel = location_report_ptr->altitudeWrtMeanSeaLevel;
+ }
+
+ if (location_report_ptr->vertUnc_valid)
+ {
+ locationExtended.flags |= GPS_LOCATION_EXTENDED_HAS_VERT_UNC;
+ locationExtended.vert_unc = location_report_ptr->vertUnc;
+ }
+
+ if (location_report_ptr->speedUnc_valid )
+ {
+ locationExtended.flags |= GPS_LOCATION_EXTENDED_HAS_SPEED_UNC;
+ locationExtended.speed_unc = location_report_ptr->speedUnc;
+ }
+
+ LocApiAdapter::reportPosition( location,
+ locationExtended,
+ locEngHandle.extPosInfo((void*)location_report_ptr),
+ (location_report_ptr->sessionStatus
+ == eQMI_LOC_SESS_STATUS_IN_PROGRESS_V02 ?
+ LOC_SESS_INTERMEDIATE : LOC_SESS_SUCCESS),
+ tech_Mask);
+ }
+ }
+ else
+ {
+ LocApiAdapter::reportPosition(location,
+ locationExtended,
+ NULL,
+ LOC_SESS_FAILURE);
+
+ LOC_LOGD("%s:%d]: Ignoring position report with sess status = %d, "
+ "fix id = %u\n", __func__, __LINE__,
+ location_report_ptr->sessionStatus,
+ location_report_ptr->fixId );
+ }
+}
+
+/* convert satellite report to loc eng format and send the converted
+ report to loc eng */
+void LocApiV02Adapter :: reportSv (
+ const qmiLocEventGnssSvInfoIndMsgT_v02 *gnss_report_ptr)
+{
+ GpsSvStatus SvStatus;
+ GpsLocationExtended locationExtended;
+ int num_svs_max, i;
+ const qmiLocSvInfoStructT_v02 *sv_info_ptr;
+
+ LOC_LOGV ("%s:%d]: num of sv = %d\n", __func__, __LINE__,
+ gnss_report_ptr->svList_len);
+
+ num_svs_max = 0;
+ memset (&SvStatus, 0, sizeof (GpsSvStatus));
+ memset(&locationExtended, 0, sizeof (GpsLocationExtended));
+ locationExtended.size = sizeof(locationExtended);
+ if(gnss_report_ptr->svList_valid == 1)
+ {
+ num_svs_max = gnss_report_ptr->svList_len;
+ if(num_svs_max > GPS_MAX_SVS)
+ {
+ num_svs_max = GPS_MAX_SVS;
+ }
+ SvStatus.num_svs = 0;
+ for(i = 0; i < num_svs_max; i++)
+ {
+ sv_info_ptr = &(gnss_report_ptr->svList[i]);
+ if((sv_info_ptr->validMask & QMI_LOC_SV_INFO_MASK_VALID_SYSTEM_V02) &&
+ (sv_info_ptr->validMask & QMI_LOC_SV_INFO_MASK_VALID_GNSS_SVID_V02)
+ && (sv_info_ptr->gnssSvId != 0 ))
+ {
+ if(sv_info_ptr->system == eQMI_LOC_SV_SYSTEM_GPS_V02)
+ {
+ SvStatus.sv_list[SvStatus.num_svs].size = sizeof(GpsSvStatus);
+ SvStatus.sv_list[SvStatus.num_svs].prn = (int)sv_info_ptr->gnssSvId;
+
+ // We only have the data field to report gps eph and alm mask
+ if(sv_info_ptr->validMask &
+ QMI_LOC_SV_INFO_MASK_VALID_SVINFO_MASK_V02)
+ {
+ if(sv_info_ptr->svInfoMask &
+ QMI_LOC_SVINFO_MASK_HAS_EPHEMERIS_V02)
+ {
+ SvStatus.ephemeris_mask |= (1 << (sv_info_ptr->gnssSvId-1));
+ }
+ if(sv_info_ptr->svInfoMask &
+ QMI_LOC_SVINFO_MASK_HAS_ALMANAC_V02)
+ {
+ SvStatus.almanac_mask |= (1 << (sv_info_ptr->gnssSvId-1));
+ }
+ }
+
+ if((sv_info_ptr->validMask &
+ QMI_LOC_SV_INFO_MASK_VALID_PROCESS_STATUS_V02)
+ &&
+ (sv_info_ptr->svStatus == eQMI_LOC_SV_STATUS_TRACK_V02))
+ {
+ SvStatus.used_in_fix_mask |= (1 << (sv_info_ptr->gnssSvId-1));
+ }
+ }
+ // SBAS: GPS RPN: 120-151,
+ // In exteneded measurement report, we follow nmea standard,
+ // which is from 33-64.
+ else if(sv_info_ptr->system == eQMI_LOC_SV_SYSTEM_SBAS_V02)
+ {
+ SvStatus.sv_list[SvStatus.num_svs].prn =
+ sv_info_ptr->gnssSvId + 33 - 120;
+ }
+ // Gloness: Slot id: 1-32
+ // In extended measurement report, we follow nmea standard,
+ // which is 65-96
+ else if(sv_info_ptr->system == eQMI_LOC_SV_SYSTEM_GLONASS_V02)
+ {
+ SvStatus.sv_list[SvStatus.num_svs].prn =
+ sv_info_ptr->gnssSvId + (65-1);
+ }
+ // Unsupported SV system
+ else
+ {
+ continue;
+ }
+ }
+
+ if(sv_info_ptr->validMask & QMI_LOC_SV_INFO_MASK_VALID_SNR_V02 )
+ {
+ SvStatus.sv_list[SvStatus.num_svs].snr = sv_info_ptr->snr;
+ }
+
+ if(sv_info_ptr->validMask & QMI_LOC_SV_INFO_MASK_VALID_ELEVATION_V02)
+ {
+ SvStatus.sv_list[SvStatus.num_svs].elevation = sv_info_ptr->elevation;
+ }
+
+ if(sv_info_ptr->validMask & QMI_LOC_SV_INFO_MASK_VALID_AZIMUTH_V02)
+ {
+ SvStatus.sv_list[SvStatus.num_svs].azimuth = sv_info_ptr->azimuth;
+ }
+
+ SvStatus.num_svs++;
+ }
+ }
+
+ if (SvStatus.num_svs >= 0)
+ {
+ LOC_LOGV ("%s:%d]: firing SV callback\n", __func__, __LINE__);
+ LocApiAdapter::reportSv(SvStatus,
+ locationExtended,
+ locEngHandle.extSvInfo((void*)gnss_report_ptr));
+ }
+}
+
+/* convert engine state report to loc eng format and send the converted
+ report to loc eng */
+void LocApiV02Adapter :: reportEngineState (
+ const qmiLocEventEngineStateIndMsgT_v02 *engine_state_ptr)
+{
+
+ LOC_LOGV("%s:%d]: state = %d\n", __func__, __LINE__,
+ engine_state_ptr->engineState);
+
+ if (engine_state_ptr->engineState == eQMI_LOC_ENGINE_STATE_ON_V02)
+ {
+ LocApiAdapter::reportStatus(GPS_STATUS_ENGINE_ON);
+ LocApiAdapter::reportStatus(GPS_STATUS_SESSION_BEGIN);
+ }
+ else if (engine_state_ptr->engineState == eQMI_LOC_ENGINE_STATE_OFF_V02)
+ {
+ LocApiAdapter::reportStatus(GPS_STATUS_SESSION_END);
+ LocApiAdapter::reportStatus(GPS_STATUS_ENGINE_OFF);
+ }
+ else
+ {
+ LocApiAdapter::reportStatus(GPS_STATUS_NONE);
+ }
+
+}
+
+/* convert fix session state report to loc eng format and send the converted
+ report to loc eng */
+void LocApiV02Adapter :: reportFixSessionState (
+ const qmiLocEventFixSessionStateIndMsgT_v02 *fix_session_state_ptr)
+{
+ GpsStatusValue status;
+ LOC_LOGD("%s:%d]: state = %d\n", __func__, __LINE__,
+ fix_session_state_ptr->sessionState);
+
+ status = GPS_STATUS_NONE;
+ if (fix_session_state_ptr->sessionState == eQMI_LOC_FIX_SESSION_STARTED_V02)
+ {
+ status = GPS_STATUS_SESSION_BEGIN;
+ }
+ else if (fix_session_state_ptr->sessionState
+ == eQMI_LOC_FIX_SESSION_FINISHED_V02)
+ {
+ status = GPS_STATUS_SESSION_END;
+ }
+ LocApiAdapter::reportStatus(status);
+}
+
+/* convert NMEA report to loc eng format and send the converted
+ report to loc eng */
+void LocApiV02Adapter :: reportNmea (
+ const qmiLocEventNmeaIndMsgT_v02 *nmea_report_ptr)
+{
+
+ LocApiAdapter::reportNmea(nmea_report_ptr->nmea,
+ strlen(nmea_report_ptr->nmea));
+
+ LOC_LOGD("%s:%d]: $%c%c%c\n", __func__, __LINE__,
+ nmea_report_ptr->nmea[3], nmea_report_ptr->nmea[4],
+ nmea_report_ptr->nmea[5]);
+}
+
+/* convert and report an ATL request to loc engine */
+void LocApiV02Adapter :: reportAtlRequest(
+ const qmiLocEventLocationServerConnectionReqIndMsgT_v02 * server_request_ptr)
+{
+ uint32_t connHandle = server_request_ptr->connHandle;
+ // service ATL open request; copy the WWAN type
+ if(server_request_ptr->requestType == eQMI_LOC_SERVER_REQUEST_OPEN_V02 )
+ {
+ AGpsType agpsType;
+#ifdef FEATURE_IPV6
+ switch(server_request_ptr->wwanType)
+ {
+ case eQMI_LOC_WWAN_TYPE_INTERNET_V02:
+ agpsType = AGPS_TYPE_WWAN_ANY;
+ LocApiAdapter::requestATL(connHandle, agpsType);
+ break;
+ case eQMI_LOC_WWAN_TYPE_AGNSS_V02:
+ agpsType = AGPS_TYPE_SUPL;
+ LocApiAdapter::requestATL(connHandle, agpsType);
+ break;
+ case eQMI_LOC_WWAN_TYPE_AGNSS_EMERGENCY_V02:
+ LocApiAdapter::requestSuplES(connHandle);
+ break;
+ default:
+ agpsType = AGPS_TYPE_WWAN_ANY;
+ LocApiAdapter::requestATL(connHandle, agpsType);
+ break;
+ }
+#else
+ agpsType = AGPS_TYPE_SUPL;
+ LocApiAdapter::requestATL(connHandle, agpsType);
+#endif
+ }
+ // service the ATL close request
+ else if (server_request_ptr->requestType == eQMI_LOC_SERVER_REQUEST_CLOSE_V02)
+ {
+ LocApiAdapter::releaseATL(connHandle);
+ }
+}
+
+/* conver the NI report to loc eng format and send t loc engine */
+void LocApiV02Adapter :: reportNiRequest(
+ const qmiLocEventNiNotifyVerifyReqIndMsgT_v02 *ni_req_ptr)
+{
+ GpsNiNotification notif;
+
+ /* initialize the notification*/
+ memset(notif.extras, 0, sizeof notif.extras);
+ memset(notif.text, 0, sizeof notif.text);
+ memset(notif.requestor_id, 0, sizeof notif.requestor_id);
+
+ /* NI timeout gets overwritten in LocApiAdapter,
+ initializing to 0 here */
+ notif.timeout = 0;
+
+ notif.text_encoding = GPS_ENC_NONE ;
+
+ notif.requestor_id_encoding = GPS_ENC_UNKNOWN;
+
+ notif.notify_flags = 0;
+
+ notif.default_response = GPS_NI_RESPONSE_NORESP;
+
+ /*Handle Vx request */
+ if(ni_req_ptr->NiVxInd_valid == 1)
+ {
+ const qmiLocNiVxNotifyVerifyStructT_v02 *vx_req = &(ni_req_ptr->NiVxInd);
+
+ notif.ni_type = GPS_NI_TYPE_VOICE;
+
+ // Requestor ID, the requestor id recieved is NULL terminated
+ hexcode(notif.requestor_id, sizeof notif.requestor_id,
+ (char *)vx_req->requestorId, vx_req->requestorId_len );
+ }
+
+ /* Handle UMTS CP request*/
+ else if(ni_req_ptr->NiUmtsCpInd_valid == 1)
+ {
+ const qmiLocNiUmtsCpNotifyVerifyStructT_v02 *umts_cp_req =
+ &ni_req_ptr->NiUmtsCpInd;
+
+ notif.ni_type = GPS_NI_TYPE_UMTS_CTRL_PLANE;
+
+ /* notificationText should always be a NULL terminated string */
+ hexcode(notif.text, sizeof notif.text,
+ (char *)umts_cp_req->notificationText,
+ umts_cp_req->notificationText_len);
+
+ /* Store requestor ID */
+ hexcode(notif.requestor_id, sizeof(notif.requestor_id),
+ (char *)umts_cp_req->requestorId.codedString,
+ umts_cp_req->requestorId.codedString_len);
+
+ /* convert encodings */
+ notif.text_encoding = convertNiEncoding(umts_cp_req->dataCodingScheme);
+
+ notif.requestor_id_encoding =
+ convertNiEncoding(umts_cp_req->requestorId.dataCodingScheme);
+
+ /* LCS address (using extras field) */
+ if ( umts_cp_req->clientAddress_len != 0)
+ {
+ char lcs_addr[32]; // Decoded LCS address for UMTS CP NI
+
+ // Copy LCS Address into notif.extras in the format: Address = 012345
+ strlcat(notif.extras, LOC_NI_NOTIF_KEY_ADDRESS, sizeof (notif.extras));
+ strlcat(notif.extras, " = ", sizeof notif.extras);
+ int addr_len = 0;
+ const char *address_source = NULL;
+ address_source = (char *)umts_cp_req->clientAddress;
+ // client Address is always NULL terminated
+ addr_len = decodeAddress(lcs_addr, sizeof(lcs_addr), address_source,
+ umts_cp_req->clientAddress_len);
+
+ // The address is ASCII string
+ if (addr_len)
+ {
+ strlcat(notif.extras, lcs_addr, sizeof notif.extras);
+ }
+ }
+
+ }
+ else if(ni_req_ptr->NiSuplInd_valid == 1)
+ {
+ const qmiLocNiSuplNotifyVerifyStructT_v02 *supl_req =
+ &ni_req_ptr->NiSuplInd;
+
+ notif.ni_type = GPS_NI_TYPE_UMTS_SUPL;
+
+ // Client name
+ if (supl_req->valid_flags & QMI_LOC_SUPL_CLIENT_NAME_MASK_V02)
+ {
+ hexcode(notif.text, sizeof(notif.text),
+ (char *)supl_req->clientName.formattedString,
+ supl_req->clientName.formattedString_len);
+ LOC_LOGV("%s:%d]: SUPL NI: client_name: %s \n", __func__, __LINE__,
+ notif.text);
+ }
+ else
+ {
+ LOC_LOGV("%s:%d]: SUPL NI: client_name not present.",
+ __func__, __LINE__);
+ }
+
+ // Requestor ID
+ if (supl_req->valid_flags & QMI_LOC_SUPL_REQUESTOR_ID_MASK_V02)
+ {
+ hexcode(notif.requestor_id, sizeof notif.requestor_id,
+ (char*)supl_req->requestorId.formattedString,
+ supl_req->requestorId.formattedString_len );
+
+ LOC_LOGV("%s:%d]: SUPL NI: requestor_id: %s \n", __func__, __LINE__,
+ notif.requestor_id);
+ }
+ else
+ {
+ LOC_LOGV("%s:%d]: SUPL NI: requestor_id not present.",
+ __func__, __LINE__);
+ }
+
+ // Encoding type
+ if (supl_req->valid_flags & QMI_LOC_SUPL_DATA_CODING_SCHEME_MASK_V02)
+ {
+ notif.text_encoding = convertNiEncoding(supl_req->dataCodingScheme);
+
+ notif.requestor_id_encoding = convertNiEncoding(supl_req->dataCodingScheme);
+ }
+ else
+ {
+ notif.text_encoding = notif.requestor_id_encoding = GPS_ENC_UNKNOWN;
+ }
+
+ } //ni_req_ptr->NiSuplInd_valid == 1
+
+ else
+ {
+ LOC_LOGE("%s:%d]: unknown request event \n",__func__, __LINE__);
+ return;
+ }
+
+ // Set default_response & notify_flags
+ convertNiNotifyVerifyType(&notif, ni_req_ptr->notificationType);
+
+ qmiLocEventNiNotifyVerifyReqIndMsgT_v02 *ni_req_copy_ptr =
+ (qmiLocEventNiNotifyVerifyReqIndMsgT_v02 *)malloc(sizeof(*ni_req_copy_ptr));
+
+ if( NULL != ni_req_copy_ptr)
+ {
+ memcpy(ni_req_copy_ptr, ni_req_ptr, sizeof(*ni_req_copy_ptr));
+
+ LocApiAdapter::requestNiNotify(notif, (const void*)ni_req_copy_ptr);
+ }
+ else
+ {
+ LOC_LOGE("%s:%d]: Error copying NI request\n", __func__, __LINE__);
+ }
+
+}
+
+/* convert Ni Encoding type from QMI_LOC to loc eng format */
+GpsNiEncodingType LocApiV02Adapter ::convertNiEncoding(
+ qmiLocNiDataCodingSchemeEnumT_v02 loc_encoding)
+{
+ GpsNiEncodingType enc = GPS_ENC_UNKNOWN;
+
+ switch (loc_encoding)
+ {
+ case eQMI_LOC_NI_SUPL_UTF8_V02:
+ enc = GPS_ENC_SUPL_UTF8;
+ break;
+ case eQMI_LOC_NI_SUPL_UCS2_V02:
+ enc = GPS_ENC_SUPL_UCS2;
+ break;
+ case eQMI_LOC_NI_SUPL_GSM_DEFAULT_V02:
+ enc = GPS_ENC_SUPL_GSM_DEFAULT;
+ break;
+ case eQMI_LOC_NI_SS_LANGUAGE_UNSPEC_V02:
+ enc = GPS_ENC_SUPL_GSM_DEFAULT; // SS_LANGUAGE_UNSPEC = GSM
+ break;
+ default:
+ break;
+ }
+
+ return enc;
+}
+
+/*convert NI notify verify type from QMI LOC to loc eng format*/
+bool LocApiV02Adapter :: convertNiNotifyVerifyType (
+ GpsNiNotification *notif,
+ qmiLocNiNotifyVerifyEnumT_v02 notif_priv)
+{
+ switch (notif_priv)
+ {
+ case eQMI_LOC_NI_USER_NO_NOTIFY_NO_VERIFY_V02:
+ notif->notify_flags = 0;
+ break;
+
+ case eQMI_LOC_NI_USER_NOTIFY_ONLY_V02:
+ notif->notify_flags = GPS_NI_NEED_NOTIFY;
+ break;
+
+ case eQMI_LOC_NI_USER_NOTIFY_VERIFY_ALLOW_NO_RESP_V02:
+ notif->notify_flags = GPS_NI_NEED_NOTIFY | GPS_NI_NEED_VERIFY;
+ notif->default_response = GPS_NI_RESPONSE_ACCEPT;
+ break;
+
+ case eQMI_LOC_NI_USER_NOTIFY_VERIFY_NOT_ALLOW_NO_RESP_V02:
+ notif->notify_flags = GPS_NI_NEED_NOTIFY | GPS_NI_NEED_VERIFY;
+ notif->default_response = GPS_NI_RESPONSE_DENY;
+ break;
+
+ case eQMI_LOC_NI_USER_NOTIFY_VERIFY_PRIVACY_OVERRIDE_V02:
+ notif->notify_flags = GPS_NI_PRIVACY_OVERRIDE;
+ break;
+
+ default:
+ return false;
+ }
+
+ return true;
+}
+
+/* event callback registered with the loc_api v02 interface */
+void LocApiV02Adapter :: eventCb(locClientHandleType clientHandle,
+ uint32_t eventId, locClientEventIndUnionType eventPayload)
+{
+ LOC_LOGD("%s:%d]: event id = %d\n", __func__, __LINE__,
+ eventId);
+
+ switch(eventId)
+ {
+ //Position Report
+ case QMI_LOC_EVENT_POSITION_REPORT_IND_V02:
+ reportPosition(eventPayload.pPositionReportEvent);
+ break;
+
+ // Satellite report
+ case QMI_LOC_EVENT_GNSS_SV_INFO_IND_V02:
+ reportSv(eventPayload.pGnssSvInfoReportEvent);
+ break;
+
+ // Status report
+ case QMI_LOC_EVENT_ENGINE_STATE_IND_V02:
+ reportEngineState(eventPayload.pEngineState);
+ break;
+
+ case QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02:
+ reportFixSessionState(eventPayload.pFixSessionState);
+ break;
+
+ // NMEA
+ case QMI_LOC_EVENT_NMEA_IND_V02:
+ reportNmea(eventPayload.pNmeaReportEvent);
+ break;
+
+ // XTRA request
+ case QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02:
+ LOC_LOGD("%s:%d]: XTRA download request\n", __func__,
+ __LINE__);
+ requestXtraData();
+ break;
+
+ // time request
+ case QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02:
+ LOC_LOGD("%s:%d]: Time request\n", __func__,
+ __LINE__);
+ requestTime();
+ break;
+
+ //position request
+ case QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02:
+ LOC_LOGD("%s:%d]: Position request\n", __func__,
+ __LINE__);
+ //requestPosition();
+ break;
+
+ // NI request
+ case QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02:
+ reportNiRequest(eventPayload.pNiNotifyVerifyReqEvent);
+ break;
+
+ // AGPS connection request
+ case QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02:
+ reportAtlRequest(eventPayload.pLocationServerConnReqEvent);
+ break;
+ }
+}
+
+/* Call the service LocApiAdapter down event*/
+void LocApiV02Adapter :: errorCb(locClientHandleType handle,
+ locClientErrorEnumType errorId)
+{
+ if(errorId == eLOC_CLIENT_ERROR_SERVICE_UNAVAILABLE)
+ {
+ LOC_LOGE("%s:%d]: Service unavailable error\n",
+ __func__, __LINE__);
+
+ LocApiAdapter::handleEngineDownEvent();
+
+ /* immediately send the engine up event so that
+ the loc engine re-initializes the adapter and the
+ loc-api_v02 interface */
+
+ LocApiAdapter::handleEngineUpEvent();
+ }
+}
+
+/* return a Loc API adapter */
+LocApiAdapter* getLocApiAdapter(LocEng &locEng)
+{
+ return(new LocApiV02Adapter(locEng));
+}
+
+static void ds_client_global_event_cb(ds_client_status_enum_type result,
+ void *loc_adapter_cookie)
+{
+ LocApiV02Adapter *locApiV02AdapterInstance =
+ (LocApiV02Adapter *)loc_adapter_cookie;
+ locApiV02AdapterInstance->ds_client_event_cb(result);
+ return;
+}
+
+void LocApiV02Adapter::ds_client_event_cb(ds_client_status_enum_type result)
+{
+ if(result == E_DS_CLIENT_DATA_CALL_CONNECTED) {
+ LOC_LOGD("%s:%d]: Emergency call is up", __func__, __LINE__);
+ LocApiAdapter::reportDataCallOpened();
+ }
+ else if(result == E_DS_CLIENT_DATA_CALL_DISCONNECTED) {
+ LOC_LOGE("%s:%d]: Emergency call is stopped", __func__, __LINE__);
+ LocApiAdapter::reportDataCallClosed();
+ }
+ return;
+}
+
+ds_client_cb_data ds_client_cb{
+ ds_client_global_event_cb
+};
+
+int LocApiV02Adapter :: openAndStartDataCall()
+{
+ enum loc_api_adapter_err ret;
+ int profile_index;
+ ds_client_status_enum_type result = ds_client_open_call(&dsClientHandle,
+ &ds_client_cb,
+ (void *)this,
+ &profile_index);
+ if(result == E_DS_CLIENT_SUCCESS) {
+ result = ds_client_start_call(dsClientHandle, profile_index);
+
+ if(result == E_DS_CLIENT_SUCCESS) {
+ LOC_LOGD("%s:%d]: Request to start Emergency call sent\n",
+ __func__, __LINE__);
+ ret = LOC_API_ADAPTER_ERR_SUCCESS;
+ }
+ else {
+ LOC_LOGE("%s:%d]: Unable to bring up emergency call using DS. ret = %d",
+ __func__, __LINE__, (int)ret);
+ ret = LOC_API_ADAPTER_ERR_UNSUPPORTED;
+ }
+ }
+ else if(result == E_DS_CLIENT_RETRY_LATER) {
+ LOC_LOGE("%s:%d]: Could not start emergency call. Retry after delay\n",
+ __func__, __LINE__);
+ ret = LOC_API_ADAPTER_ERR_ENGINE_BUSY;
+ }
+ else {
+ LOC_LOGE("%s:%d]: Unable to bring up emergency call using DS. ret = %d",
+ __func__, __LINE__, (int)ret);
+ ret = LOC_API_ADAPTER_ERR_UNSUPPORTED;
+ }
+
+ return (int)ret;
+}
+
+void LocApiV02Adapter :: stopDataCall()
+{
+ ds_client_status_enum_type ret =
+ ds_client_stop_call(dsClientHandle);
+ if (ret == E_DS_CLIENT_SUCCESS) {
+ LOC_LOGD("%s:%d]: Request to Close SUPL ES call sent\n", __func__, __LINE__);
+ }
+ else {
+ if (ret == E_DS_CLIENT_FAILURE_INVALID_HANDLE) {
+ LOC_LOGE("%s:%d]: Conn handle not found for SUPL ES",
+ __func__, __LINE__);
+ }
+ LOC_LOGE("%s:%d]: Could not close SUPL ES call. Ret: %d\n"
+ ,__func__, __LINE__, ret);
+ }
+ return;
+}
+
+void LocApiV02Adapter :: closeDataCall()
+{
+ ds_client_close_call(&dsClientHandle);
+ LOC_LOGD("%s:%d]: Release data client handle\n", __func__, __LINE__);
+ return;
+}
+
+int LocApiV02Adapter :: initDataServiceClient()
+{
+ int ret=0;
+ ret = ds_client_init();
+ LOC_LOGD("%s:%d]: ret = %d\n", __func__, __LINE__,ret);
+ return ret;
+}
diff --git a/loc_api/loc_api_v02/LocApiV02Adapter.h b/loc_api/loc_api_v02/LocApiV02Adapter.h
new file mode 100644
index 0000000..df5ab52
--- /dev/null
+++ b/loc_api/loc_api_v02/LocApiV02Adapter.h
@@ -0,0 +1,182 @@
+/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef LOC_API_V_0_2_ADAPTER_H
+#define LOC_API_V_0_2_ADAPTER_H
+
+#include <LocApiAdapter.h>
+#include "loc_api_v02_client.h"
+#include <stdint.h>
+#include <stdbool.h>
+#include "ds_client.h"
+
+/* This class derives from the LocApiAdapter class.
+ The members of this class are responsible for converting
+ the Loc API V02 data structures into Loc Engine data structures.
+ This class also implements some of the virtual functions that
+ handle the requests from loc engine. */
+class LocApiV02Adapter : public LocApiAdapter {
+ /*ds client handle*/
+ dsClientHandleType dsClientHandle;
+
+ /* loc api v02 handle*/
+ locClientHandleType clientHandle;
+
+ /* events the client is registered for */
+ locClientEventMaskType eventMask;
+
+ /* Convert event mask from loc eng to loc_api_v02 format */
+ locClientEventMaskType convertMask(LOC_API_ADAPTER_EVENT_MASK_T mask);
+
+ /* Convert error from loc_api_v02 to loc eng format*/
+ enum loc_api_adapter_err convertErr(locClientStatusEnumType status);
+
+ /* convert Ni Encoding type from QMI_LOC to loc eng format */
+ GpsNiEncodingType convertNiEncoding(
+ qmiLocNiDataCodingSchemeEnumT_v02 loc_encoding);
+
+ /*convert NI notify verify type from QMI LOC to loc eng format*/
+ bool convertNiNotifyVerifyType (GpsNiNotification *notif,
+ qmiLocNiNotifyVerifyEnumT_v02 notif_priv);
+
+ /* close Loc API V02 client */
+ int deInitLocClient();
+
+ /* convert position report to loc eng format and send the converted
+ position to loc eng */
+ void reportPosition
+ (const qmiLocEventPositionReportIndMsgT_v02 *location_report_ptr);
+
+ /* convert satellite report to loc eng format and send the converted
+ report to loc eng */
+ void reportSv (const qmiLocEventGnssSvInfoIndMsgT_v02 *gnss_report_ptr);
+
+ /* convert engine state report to loc eng format and send the converted
+ report to loc eng */
+ void reportEngineState (
+ const qmiLocEventEngineStateIndMsgT_v02 *engine_state_ptr);
+
+ /* convert fix session report to loc eng format and send the converted
+ report to loc eng */
+ void reportFixSessionState (
+ const qmiLocEventFixSessionStateIndMsgT_v02 *fix_session_state_ptr);
+
+ /* convert NMEA report to loc eng format and send the converted
+ report to loc eng */
+ void reportNmea (const qmiLocEventNmeaIndMsgT_v02 *nmea_report_ptr);
+
+ /* convert and report an ATL request to loc engine */
+ void reportAtlRequest(
+ const qmiLocEventLocationServerConnectionReqIndMsgT_v02
+ *server_request_ptr);
+
+ /* convert and report NI request to loc eng */
+ void reportNiRequest(
+ const qmiLocEventNiNotifyVerifyReqIndMsgT_v02 *ni_req_ptr);
+
+public:
+ LocApiV02Adapter(LocEng &locEng);
+ ~LocApiV02Adapter();
+
+ /* event callback registered with the loc_api v02 interface */
+ void eventCb(locClientHandleType client_handle,
+ uint32_t loc_event_id,
+ locClientEventIndUnionType loc_event_payload);
+
+ /* error callback, this function handles the service unavailable
+ error */
+ void errorCb(locClientHandleType handle,
+ locClientErrorEnumType errorId);
+
+ void ds_client_event_cb(ds_client_status_enum_type result);
+ int openAndStartDataCall();
+ void stopDataCall();
+ void closeDataCall();
+ int initDataServiceClient();
+
+ virtual enum loc_api_adapter_err reinit();
+
+ virtual enum loc_api_adapter_err startFix();
+
+ virtual enum loc_api_adapter_err stopFix();
+
+ virtual enum loc_api_adapter_err
+ setPositionMode(const LocPosMode *mode);
+
+ virtual enum loc_api_adapter_err
+ setTime(GpsUtcTime time, int64_t timeReference, int uncertainty);
+
+ virtual enum loc_api_adapter_err
+ injectPosition(double latitude, double longitude, float accuracy);
+
+ virtual enum loc_api_adapter_err
+ deleteAidingData(GpsAidingData f);
+
+ virtual enum loc_api_adapter_err
+ informNiResponse(GpsUserResponseType userResponse,
+ const void* passThroughData);
+
+ virtual enum loc_api_adapter_err
+ setServer(const char* url, int len);
+ virtual enum loc_api_adapter_err
+ setServer(unsigned int ip, int port, LocServerType type);
+ virtual enum loc_api_adapter_err
+ setXtraData(char* data, int length);
+#ifdef FEATURE_IPV6
+ virtual enum loc_api_adapter_err
+ atlOpenStatus(int handle, int is_succ, char* apn, AGpsBearerType bear,
+ AGpsType agpsType);
+#else
+ virtual enum loc_api_adapter_err
+ atlOpenStatus(int handle, int is_succ, char* apn,
+ AGpsType agpsType);
+#endif
+ virtual enum loc_api_adapter_err atlCloseStatus(int handle, int is_succ);
+ virtual enum loc_api_adapter_err setSUPLVersion(uint32_t version);
+ virtual enum loc_api_adapter_err setLPPConfig(uint32_t profile);
+
+ virtual enum loc_api_adapter_err
+ setSensorControlConfig(int sensorUsage);
+
+ virtual enum loc_api_adapter_err
+ setSensorProperties(bool gyroBiasVarianceRandomWalk_valid, float gyroBiasVarianceRandomWalk,
+ bool accelBiasVarianceRandomWalk_valid, float accelBiasVarianceRandomWalk,
+ bool angleBiasVarianceRandomWalk_valid, float angleBiasVarianceRandomWalk,
+ bool rateBiasVarianceRandomWalk_valid, float rateBiasVarianceRandomWalk,
+ bool velocityBiasVarianceRandomWalk_valid, float velocityBiasVarianceRandomWalk);
+
+ virtual enum loc_api_adapter_err
+ setSensorPerfControlConfig(int controlMode, int accelSamplesPerBatch, int accelBatchesPerSec,
+ int gyroSamplesPerBatch, int gyroBatchesPerSec,
+ int accelSamplesPerBatchHigh, int accelBatchesPerSecHigh,
+ int gyroSamplesPerBatchHigh, int gyroBatchesPerSecHigh, int algorithmConfig);
+ virtual enum loc_api_adapter_err setExtPowerConfig(int isBatteryCharging);
+ virtual enum loc_api_adapter_err setAGLONASSProtocol(unsigned long aGlonassProtocol);
+};
+
+#endif //LOC_API_V_0_2_ADAPTER_H
diff --git a/loc_api/loc_api_v02/Makefile.am b/loc_api/loc_api_v02/Makefile.am
new file mode 100644
index 0000000..2308cd4
--- /dev/null
+++ b/loc_api/loc_api_v02/Makefile.am
@@ -0,0 +1,42 @@
+AM_CFLAGS = \
+ ${QMIF_CFLAGS} \
+ -I../../utils \
+ -I../../platform_lib_abstractions \
+ -I../libloc_api_50001
+
+requiredlibs = \
+ ${QMIF_LIBS} \
+ ../libloc_api_50001/libloc_adapter_so.la \
+ ../../utils/libgps_utils_so.la
+
+h_sources = LocApiV02Adapter.h \
+ loc_util_log.h \
+ location_service_v02.h \
+ loc_api_sync_req.h \
+ loc_api_v02_client.h \
+ loc_api_v02_log.h
+
+c_sources = LocApiV02Adapter.cpp \
+ loc_api_v02_log.c \
+ loc_api_v02_client.c \
+ loc_api_sync_req.c \
+ location_service_v02.c
+
+library_includedir = $(pkgincludedir)
+library_include_HEADERS = $(h_sources)
+
+libloc_api_la_SOURCES = $(c_sources) $(h_sources)
+
+if USE_GLIB
+libloc_api_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libloc_api_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libloc_api_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libloc_api_la_CFLAGS = $(AM_CFLAGS)
+libloc_api_la_LDFLAGS = -shared -version-info 1:0:0
+libloc_api_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+
+libloc_api_la_LIBADD = $(requiredlibs) -lstdc++
+
+lib_LTLIBRARIES = libloc_api.la
diff --git a/loc_api/loc_api_v02/loc_api_sync_req.c b/loc_api/loc_api_v02/loc_api_sync_req.c
new file mode 100644
index 0000000..6a08666
--- /dev/null
+++ b/loc_api/loc_api_v02/loc_api_sync_req.c
@@ -0,0 +1,547 @@
+/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+#include <stdio.h>
+#include <assert.h>
+#include <errno.h>
+#include <sys/time.h>
+#include <string.h>
+#include <pthread.h>
+#include <stdbool.h>
+#include <stdint.h>
+#include <loc_cfg.h>
+#include "loc_api_v02_client.h"
+#include "loc_api_sync_req.h"
+
+/* Logging */
+// Uncomment to log verbose logs
+#define LOG_NDEBUG 1
+
+// log debug logs
+#define LOG_NDDEBUG 1
+#define LOG_TAG "LocSvc_api_v02"
+#include "loc_util_log.h"
+
+#define LOC_SYNC_REQ_BUFFER_SIZE 8
+#define GPS_CONF_FILE "/etc/gps.conf"
+pthread_mutex_t loc_sync_call_mutex = PTHREAD_MUTEX_INITIALIZER;
+
+static bool loc_sync_call_initialized = false;
+
+typedef struct {
+ pthread_mutex_t sync_req_lock;
+
+ /* Client ID */
+ locClientHandleType client_handle;
+
+ /* waiting conditional variable */
+ pthread_cond_t ind_arrived_cond;
+
+ /* Callback waiting data block, protected by loc_cb_data_mutex */
+ bool ind_is_selected; /* is cb selected? */
+ bool ind_is_waiting; /* is waiting? */
+ bool ind_has_arrived; /* callback has arrived */
+ uint32_t req_id; /* sync request */
+ void *recv_ind_payload_ptr; /* received payload */
+ uint32_t recv_ind_id; /* received ind */
+
+} loc_sync_req_data_s_type;
+
+typedef struct {
+ bool in_use; /* at least one sync call is active */
+ bool slot_in_use[LOC_SYNC_REQ_BUFFER_SIZE];
+ loc_sync_req_data_s_type slots[LOC_SYNC_REQ_BUFFER_SIZE];
+} loc_sync_req_array_s_type;
+
+/***************************************************************************
+ * DATA FOR ASYNCHRONOUS RPC PROCESSING
+ **************************************************************************/
+loc_sync_req_array_s_type loc_sync_array;
+
+/*===========================================================================
+
+FUNCTION loc_sync_req_init
+
+DESCRIPTION
+ Initialize this module
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ none
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+void loc_sync_req_init()
+{
+ LOC_LOGV(" %s:%d]:\n", __func__, __LINE__);
+ UTIL_READ_CONF_DEFAULT(GPS_CONF_FILE);
+ pthread_mutex_lock(&loc_sync_call_mutex);
+ if(true == loc_sync_call_initialized)
+ {
+ LOC_LOGD("%s:%d]:already initialized\n", __func__, __LINE__);
+ pthread_mutex_unlock(&loc_sync_call_mutex);
+ return;
+ }
+
+ loc_sync_array.in_use = false;
+
+ memset(loc_sync_array.slot_in_use, 0, sizeof(loc_sync_array.slot_in_use));
+
+ int i;
+ for (i = 0; i < LOC_SYNC_REQ_BUFFER_SIZE; i++)
+ {
+ loc_sync_req_data_s_type *slot = &loc_sync_array.slots[i];
+
+ pthread_mutex_init(&slot->sync_req_lock, NULL);
+ pthread_cond_init(&slot->ind_arrived_cond, NULL);
+
+ slot->client_handle = LOC_CLIENT_INVALID_HANDLE_VALUE;
+ slot->ind_is_selected = false; /* is ind selected? */
+ slot->ind_is_waiting = false; /* is waiting? */
+ slot->ind_has_arrived = false; /* callback has arrived */
+ slot->recv_ind_id = 0; /* ind to wait for */
+ slot->recv_ind_payload_ptr = NULL;
+ slot->req_id = 0; /* req id */
+ }
+
+ loc_sync_call_initialized = true;
+ pthread_mutex_unlock(&loc_sync_call_mutex);
+}
+
+
+/*===========================================================================
+
+FUNCTION loc_sync_process_ind
+
+DESCRIPTION
+ Wakes up blocked API calls to check if the needed callback has arrived
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ none
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+void loc_sync_process_ind(
+ locClientHandleType client_handle, /* handle of the client */
+ uint32_t ind_id , /* ind id */
+ void *ind_payload_ptr /* payload */
+)
+{
+
+ LOC_LOGV("%s:%d]: received indication, handle = %p ind_id = %u \n",
+ __func__,__LINE__, client_handle, ind_id);
+
+ pthread_mutex_lock(&loc_sync_call_mutex);
+
+ if (!loc_sync_array.in_use)
+ {
+ LOC_LOGD("%s:%d]: loc_sync_array not in use \n",
+ __func__, __LINE__);
+ pthread_mutex_unlock(&loc_sync_call_mutex);
+ return;
+ }
+
+ bool in_use = false, consumed = false;
+ int i;
+
+ for (i = 0; i < LOC_SYNC_REQ_BUFFER_SIZE && !consumed; i++)
+ {
+ loc_sync_req_data_s_type *slot = &loc_sync_array.slots[i];
+
+ in_use |= loc_sync_array.slot_in_use[i];
+
+ pthread_mutex_lock(&slot->sync_req_lock);
+
+ if ( (loc_sync_array.slot_in_use[i]) && (slot->client_handle == client_handle)
+ && (ind_id == slot->recv_ind_id) && (!slot->ind_has_arrived))
+ {
+ // copy the payload to the slot waiting for this ind
+ size_t payload_size = 0;
+
+ LOC_LOGV("%s:%d]: found slot %d selected for ind %u \n",
+ __func__, __LINE__, i, ind_id);
+
+ if(true == locClientGetSizeByRespIndId(ind_id, &payload_size) &&
+ NULL != slot->recv_ind_payload_ptr && NULL != ind_payload_ptr)
+ {
+ LOC_LOGV("%s:%d]: copying ind payload size = %u \n",
+ __func__, __LINE__, payload_size);
+
+ memcpy(slot->recv_ind_payload_ptr, ind_payload_ptr, payload_size);
+
+ consumed = true;
+
+ }
+ /* Received a callback while waiting, wake up thread to check it */
+ if (slot->ind_is_waiting)
+ {
+ slot->recv_ind_id = ind_id;
+
+ pthread_cond_signal(&slot->ind_arrived_cond);
+ }
+ else
+ {
+ /* If callback arrives before wait, remember it */
+ LOC_LOGV("%s:%d]: ind %u arrived before wait was called \n",
+ __func__, __LINE__, ind_id);
+
+ slot->ind_has_arrived = true;
+ }
+ }
+ pthread_mutex_unlock(&slot->sync_req_lock);
+ }
+
+ if (!in_use) {
+ loc_sync_array.in_use = false;
+ }
+
+ pthread_mutex_unlock(&loc_sync_call_mutex);
+}
+
+/*===========================================================================
+
+FUNCTION loc_alloc_slot
+
+DESCRIPTION
+ Allocates a buffer slot for the synchronous API call
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ Select ID (>=0) : successful
+ -1 : buffer full
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+static int loc_alloc_slot()
+{
+ int i, select_id = -1; /* no free buffer */
+
+ pthread_mutex_lock(&loc_sync_call_mutex);
+
+ for (i = 0; i < LOC_SYNC_REQ_BUFFER_SIZE; i++)
+ {
+ if (!loc_sync_array.slot_in_use[i])
+ {
+ select_id = i;
+ loc_sync_array.slot_in_use[i] = 1;
+ loc_sync_array.in_use = true;
+ break;
+ }
+ }
+
+ pthread_mutex_unlock(&loc_sync_call_mutex);
+ LOC_LOGV("%s:%d]: returning slot %d\n",
+ __func__, __LINE__, select_id);
+ return select_id;
+}
+
+/*===========================================================================
+
+FUNCTION loc_free_slot
+
+DESCRIPTION
+ Frees a buffer slot after the synchronous API call
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ None
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+static void loc_free_slot(int select_id)
+{
+ int i;
+ loc_sync_req_data_s_type *slot;
+
+ pthread_mutex_lock(&loc_sync_call_mutex);
+
+ LOC_LOGD("%s:%d]: freeing slot %d\n", __func__, __LINE__, select_id);
+
+ loc_sync_array.slot_in_use[select_id] = 0;
+
+ slot = &loc_sync_array.slots[select_id];
+
+ slot->client_handle = LOC_CLIENT_INVALID_HANDLE_VALUE;
+ slot->ind_is_selected = false; /* is ind selected? */
+ slot->ind_is_waiting = false; /* is waiting? */
+ slot->ind_has_arrived = false; /* callback has arrived */
+ slot->recv_ind_id = 0; /* ind to wait for */
+ slot->recv_ind_payload_ptr = NULL;
+ slot->req_id = 0;
+
+ // check if all slots are now free
+ for (i = 0; i < LOC_SYNC_REQ_BUFFER_SIZE; i++)
+ {
+ if (loc_sync_array.slot_in_use[i]) break;
+ }
+
+ if (i >= LOC_SYNC_REQ_BUFFER_SIZE)
+ {
+ loc_sync_array.in_use = false;
+ }
+
+ pthread_mutex_unlock(&loc_sync_call_mutex);
+}
+
+/*===========================================================================
+
+FUNCTION loc_sync_select_ind
+
+DESCRIPTION
+ Selects which indication to wait for.
+
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ Select ID (>=0) : successful
+ -ENOMEM : out of buffer
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+static int loc_sync_select_ind(
+ locClientHandleType client_handle, /* Client handle */
+ uint32_t ind_id, /* ind Id wait for */
+ uint32_t req_id, /* req id */
+ void * ind_payload_ptr /* ptr where payload should be copied to*/
+)
+{
+ int select_id = loc_alloc_slot();
+
+ LOC_LOGV("%s:%d]: client handle %p, ind_id %u, req_id %u \n",
+ __func__, __LINE__, client_handle, ind_id, req_id);
+
+ if (select_id < 0)
+ {
+ LOC_LOGE("%s:%d]: buffer full for this synchronous req %s \n",
+ __func__, __LINE__, loc_get_v02_event_name(req_id));
+ return -ENOMEM;
+ }
+
+ loc_sync_req_data_s_type *slot = &loc_sync_array.slots[select_id];
+
+ pthread_mutex_lock(&slot->sync_req_lock);
+
+ slot->client_handle = client_handle;
+ slot->ind_is_selected = true;
+ slot->ind_is_waiting = false;
+ slot->ind_has_arrived = false;
+
+ slot->recv_ind_id = ind_id;
+ slot->req_id = req_id;
+ slot->recv_ind_payload_ptr = ind_payload_ptr; //store the payload ptr
+
+ pthread_mutex_unlock(&slot->sync_req_lock);
+
+ return select_id;
+}
+
+
+/*===========================================================================
+
+FUNCTION loc_sync_wait_for_ind
+
+DESCRIPTION
+ Waits for a selected indication. The wait expires in timeout_seconds seconds.
+ If the function is called before an existing wait has finished, it will
+ immediately return error.
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ 0 on SUCCESS, -ve value on failure
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+static int loc_sync_wait_for_ind(
+ int select_id, /* ID from loc_sync_select_ind() */
+ int timeout_seconds, /* Timeout in this number of seconds */
+ uint32_t ind_id
+)
+{
+ if (select_id < 0 || select_id >= LOC_SYNC_REQ_BUFFER_SIZE || !loc_sync_array.slot_in_use[select_id])
+ {
+ LOC_LOGE("%s:%d]: invalid select_id: %d \n",
+ __func__, __LINE__, select_id);
+
+ return (-EINVAL);
+ }
+
+ loc_sync_req_data_s_type *slot = &loc_sync_array.slots[select_id];
+
+ int ret_val = 0; /* the return value of this function: 0 = no error */
+ int rc; /* return code from pthread calls */
+
+ struct timeval present_time;
+ struct timespec expire_time;
+
+ pthread_mutex_lock(&slot->sync_req_lock);
+
+ do
+ {
+ if (slot->ind_has_arrived)
+ {
+ ret_val = 0; /* success */
+ break;
+ }
+
+ if (slot->ind_is_waiting)
+ {
+ LOC_LOGW("%s:%d]: already waiting in this slot %d\n", __func__,
+ __LINE__, select_id);
+ ret_val = -EBUSY; // busy
+ break;
+ }
+
+ /* Calculate absolute expire time */
+ gettimeofday(&present_time, NULL);
+ expire_time.tv_sec = present_time.tv_sec;
+ expire_time.tv_nsec = present_time.tv_usec * 1000;
+ expire_time.tv_sec += timeout_seconds;
+
+ /* Take new wait request */
+ slot->ind_is_waiting = true;
+
+ /* Waiting */
+ rc = pthread_cond_timedwait(&slot->ind_arrived_cond,
+ &slot->sync_req_lock, &expire_time);
+
+ slot->ind_is_waiting = false;
+
+ if(rc == ETIMEDOUT)
+ {
+ LOC_LOGE("%s:%d]: slot %d, timed out for ind_id %s\n",
+ __func__, __LINE__, select_id, loc_get_v02_event_name(ind_id));
+ ret_val = -ETIMEDOUT; //time out
+ }
+
+ } while (0);
+
+ pthread_mutex_unlock(&slot->sync_req_lock);
+ loc_free_slot(select_id);
+
+ return ret_val;
+}
+
+/*===========================================================================
+
+FUNCTION loc_sync_send_req
+
+DESCRIPTION
+ Synchronous req call (thread safe)
+
+DEPENDENCIES
+ N/A
+
+RETURN VALUE
+ Loc API 2.0 status
+
+SIDE EFFECTS
+ N/A
+
+===========================================================================*/
+locClientStatusEnumType loc_sync_send_req
+(
+ locClientHandleType client_handle,
+ uint32_t req_id, /* req id */
+ locClientReqUnionType req_payload,
+ uint32_t timeout_msec,
+ uint32_t ind_id, //ind ID to block for, usually the same as req_id */
+ void *ind_payload_ptr /* can be NULL*/
+)
+{
+ locClientStatusEnumType status = eLOC_CLIENT_SUCCESS ;
+ int select_id;
+ int rc = 0;
+
+ // Select the callback we are waiting for
+ select_id = loc_sync_select_ind(client_handle, ind_id, req_id,
+ ind_payload_ptr);
+
+ if (select_id >= 0)
+ {
+ status = locClientSendReq (client_handle, req_id, req_payload);
+ LOC_LOGV("%s:%d]: select_id = %d,locClientSendReq returned %d\n",
+ __func__, __LINE__, select_id, status);
+
+ if (status != eLOC_CLIENT_SUCCESS )
+ {
+ loc_free_slot(select_id);
+ }
+ else
+ {
+ // Wait for the indication callback
+ if (( rc = loc_sync_wait_for_ind( select_id,
+ timeout_msec / 1000,
+ ind_id) ) < 0)
+ {
+ if ( rc == -ETIMEDOUT)
+ status = eLOC_CLIENT_FAILURE_TIMEOUT;
+ else
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+
+ // Callback waiting failed
+ LOC_LOGE("%s:%d]: loc_api_wait_for_ind failed, err %d, "
+ "select id %d, status %s", __func__, __LINE__, rc ,
+ select_id, loc_get_v02_client_status_name(status));
+ }
+ else
+ {
+ status = eLOC_CLIENT_SUCCESS;
+ LOC_LOGV("%s:%d]: success (select id %d)\n",
+ __func__, __LINE__, select_id);
+ }
+ }
+ } /* select id */
+
+ return status;
+}
+
+
diff --git a/loc_api/loc_api_v02/loc_api_v02_client.c b/loc_api/loc_api_v02/loc_api_v02_client.c
new file mode 100644
index 0000000..86003da
--- /dev/null
+++ b/loc_api/loc_api_v02/loc_api_v02_client.c
@@ -0,0 +1,2211 @@
+/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <stdlib.h>
+#include <string.h>
+#include <stddef.h>
+
+#include <stdbool.h>
+#include <stdint.h>
+
+#include "qmi_client.h"
+#include "qmi_idl_lib.h"
+#include "qmi_cci_target_ext.h"
+
+#if defined( _ANDROID_)
+#include "qmi_cci_target.h"
+#include "qmi_cci_common.h"
+#define LOG_NDEBUG 0
+#define LOG_TAG "LocSvc_api_v02"
+#endif //_ANDROID_
+
+
+#include "loc_api_v02_client.h"
+#include "loc_util_log.h"
+
+#ifdef LOC_UTIL_TARGET_OFF_TARGET
+
+// timeout in ms before send_msg_sync should return
+#define LOC_CLIENT_ACK_TIMEOUT (5000)
+
+#else
+
+// timeout in ms before send_msg_sync should return
+#define LOC_CLIENT_ACK_TIMEOUT (1000)
+
+#endif //LOC_UTIL_TARGET_OFF_TARGET
+
+//timeout in ms that the service waits for qmi-fw notification
+#define LOC_CLIENT_SERVICE_TIMEOUT_UNIT (4000)
+// total timeout for the service to come up
+#define LOC_CLIENT_SERVICE_TIMEOUT_TOTAL (40000)
+
+/* Table to relate eventId, size and mask value used to enable the event*/
+typedef struct
+{
+ uint32_t eventId;
+ size_t eventSize;
+ locClientEventMaskType eventMask;
+}locClientEventIndTableStructT;
+
+
+static locClientEventIndTableStructT locClientEventIndTable[]= {
+
+ // position report ind
+ { QMI_LOC_EVENT_POSITION_REPORT_IND_V02,
+ sizeof(qmiLocEventPositionReportIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_POSITION_REPORT_V02 },
+
+ // satellite report ind
+ { QMI_LOC_EVENT_GNSS_SV_INFO_IND_V02,
+ sizeof(qmiLocEventGnssSvInfoIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_GNSS_SV_INFO_V02 },
+
+ // NMEA report ind
+ { QMI_LOC_EVENT_NMEA_IND_V02,
+ sizeof(qmiLocEventNmeaIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_NMEA_V02 },
+
+ //NI event ind
+ { QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02,
+ sizeof(qmiLocEventNiNotifyVerifyReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_NI_NOTIFY_VERIFY_REQ_V02 },
+
+ //Time Injection Request Ind
+ { QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02,
+ sizeof(qmiLocEventInjectTimeReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_INJECT_TIME_REQ_V02 },
+
+ //Predicted Orbits Injection Request
+ { QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02,
+ sizeof(qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_INJECT_PREDICTED_ORBITS_REQ_V02 },
+
+ //Position Injection Request Ind
+ { QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02,
+ sizeof(qmiLocEventInjectPositionReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_INJECT_POSITION_REQ_V02 } ,
+
+ //Engine State Report Ind
+ { QMI_LOC_EVENT_ENGINE_STATE_IND_V02,
+ sizeof(qmiLocEventEngineStateIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_ENGINE_STATE_V02 },
+
+ //Fix Session State Report Ind
+ { QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02,
+ sizeof(qmiLocEventFixSessionStateIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_FIX_SESSION_STATE_V02 },
+
+ //Wifi Request Indication
+ { QMI_LOC_EVENT_WIFI_REQ_IND_V02,
+ sizeof(qmiLocEventWifiReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_WIFI_REQ_V02 },
+
+ //Sensor Streaming Ready Status Ind
+ { QMI_LOC_EVENT_SENSOR_STREAMING_READY_STATUS_IND_V02,
+ sizeof(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_SENSOR_STREAMING_READY_STATUS_V02 },
+
+ // Time Sync Request Indication
+ { QMI_LOC_EVENT_TIME_SYNC_REQ_IND_V02,
+ sizeof(qmiLocEventTimeSyncReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_TIME_SYNC_REQ_V02 },
+
+ //Set Spi Streaming Report Event
+ { QMI_LOC_EVENT_SET_SPI_STREAMING_REPORT_IND_V02,
+ sizeof(qmiLocEventSetSpiStreamingReportIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_SET_SPI_STREAMING_REPORT_V02 },
+
+ //Location Server Connection Request event
+ { QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02,
+ sizeof(qmiLocEventLocationServerConnectionReqIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_LOCATION_SERVER_CONNECTION_REQ_V02 },
+
+ // NI Geofence Event
+ { QMI_LOC_EVENT_NI_GEOFENCE_NOTIFICATION_IND_V02,
+ sizeof(qmiLocEventNiGeofenceNotificationIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_NI_GEOFENCE_NOTIFICATION_V02},
+
+ // Geofence General Alert Event
+ { QMI_LOC_EVENT_GEOFENCE_GEN_ALERT_IND_V02,
+ sizeof(qmiLocEventGeofenceGenAlertIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_GEOFENCE_GEN_ALERT_V02},
+
+ //Geofence Breach event
+ { QMI_LOC_EVENT_GEOFENCE_BREACH_NOTIFICATION_IND_V02,
+ sizeof(qmiLocEventGeofenceBreachIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_GEOFENCE_BREACH_NOTIFICATION_V02},
+
+ //Pedometer Control event
+ { QMI_LOC_EVENT_PEDOMETER_CONTROL_IND_V02,
+ sizeof(qmiLocEventPedometerControlIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_PEDOMETER_CONTROL_V02 },
+
+ //Motion Data Control event
+ { QMI_LOC_EVENT_MOTION_DATA_CONTROL_IND_V02,
+ sizeof(qmiLocEventMotionDataControlIndMsgT_v02),
+ QMI_LOC_EVENT_MASK_MOTION_DATA_CONTROL_V02 }
+};
+
+/* table to relate the respInd Id with its size */
+typedef struct
+{
+ uint32_t respIndId;
+ size_t respIndSize;
+}locClientRespIndTableStructT;
+
+static locClientRespIndTableStructT locClientRespIndTable[]= {
+
+ // get service revision ind
+ { QMI_LOC_GET_SERVICE_REVISION_IND_V02,
+ sizeof(qmiLocGetServiceRevisionIndMsgT_v02)},
+
+ // Get Fix Criteria Resp Ind
+ { QMI_LOC_GET_FIX_CRITERIA_IND_V02,
+ sizeof(qmiLocGetFixCriteriaIndMsgT_v02)},
+
+ // NI User Resp In
+ { QMI_LOC_NI_USER_RESPONSE_IND_V02,
+ sizeof(qmiLocNiUserRespIndMsgT_v02)},
+
+ //Inject Predicted Orbits Data Resp Ind
+ { QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02,
+ sizeof(qmiLocInjectPredictedOrbitsDataIndMsgT_v02)},
+
+ //Get Predicted Orbits Data Src Resp Ind
+ { QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_IND_V02,
+ sizeof(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02)},
+
+ // Get Predicted Orbits Data Validity Resp Ind
+ { QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_IND_V02,
+ sizeof(qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02)},
+
+ // Inject UTC Time Resp Ind
+ { QMI_LOC_INJECT_UTC_TIME_IND_V02,
+ sizeof(qmiLocInjectUtcTimeIndMsgT_v02)},
+
+ //Inject Position Resp Ind
+ { QMI_LOC_INJECT_POSITION_IND_V02,
+ sizeof(qmiLocInjectPositionIndMsgT_v02)},
+
+ //Set Engine Lock Resp Ind
+ { QMI_LOC_SET_ENGINE_LOCK_IND_V02,
+ sizeof(qmiLocSetEngineLockIndMsgT_v02)},
+
+ //Get Engine Lock Resp Ind
+ { QMI_LOC_GET_ENGINE_LOCK_IND_V02,
+ sizeof(qmiLocGetEngineLockIndMsgT_v02)},
+
+ //Set SBAS Config Resp Ind
+ { QMI_LOC_SET_SBAS_CONFIG_IND_V02,
+ sizeof(qmiLocSetSbasConfigIndMsgT_v02)},
+
+ //Get SBAS Config Resp Ind
+ { QMI_LOC_GET_SBAS_CONFIG_IND_V02,
+ sizeof(qmiLocGetSbasConfigIndMsgT_v02)},
+
+ //Set NMEA Types Resp Ind
+ { QMI_LOC_SET_NMEA_TYPES_IND_V02,
+ sizeof(qmiLocSetNmeaTypesIndMsgT_v02)},
+
+ //Get NMEA Types Resp Ind
+ { QMI_LOC_GET_NMEA_TYPES_IND_V02,
+ sizeof(qmiLocGetNmeaTypesIndMsgT_v02)},
+
+ //Set Low Power Mode Resp Ind
+ { QMI_LOC_SET_LOW_POWER_MODE_IND_V02,
+ sizeof(qmiLocSetLowPowerModeIndMsgT_v02)},
+
+ //Get Low Power Mode Resp Ind
+ { QMI_LOC_GET_LOW_POWER_MODE_IND_V02,
+ sizeof(qmiLocGetLowPowerModeIndMsgT_v02)},
+
+ //Set Server Resp Ind
+ { QMI_LOC_SET_SERVER_IND_V02,
+ sizeof(qmiLocSetServerIndMsgT_v02)},
+
+ //Get Server Resp Ind
+ { QMI_LOC_GET_SERVER_IND_V02,
+ sizeof(qmiLocGetServerIndMsgT_v02)},
+
+ //Delete Assist Data Resp Ind
+ { QMI_LOC_DELETE_ASSIST_DATA_IND_V02,
+ sizeof(qmiLocDeleteAssistDataIndMsgT_v02)},
+
+ //Set XTRA-T Session Control Resp Ind
+ { QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02,
+ sizeof(qmiLocSetXtraTSessionControlIndMsgT_v02)},
+
+ //Get XTRA-T Session Control Resp Ind
+ { QMI_LOC_GET_XTRA_T_SESSION_CONTROL_IND_V02,
+ sizeof(qmiLocGetXtraTSessionControlIndMsgT_v02)},
+
+ //Inject Wifi Position Resp Ind
+ { QMI_LOC_INJECT_WIFI_POSITION_IND_V02,
+ sizeof(qmiLocInjectWifiPositionIndMsgT_v02)},
+
+ //Notify Wifi Status Resp Ind
+ { QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02,
+ sizeof(qmiLocNotifyWifiStatusIndMsgT_v02)},
+
+ //Get Registered Events Resp Ind
+ { QMI_LOC_GET_REGISTERED_EVENTS_IND_V02,
+ sizeof(qmiLocGetRegisteredEventsIndMsgT_v02)},
+
+ //Set Operation Mode Resp Ind
+ { QMI_LOC_SET_OPERATION_MODE_IND_V02,
+ sizeof(qmiLocSetOperationModeIndMsgT_v02)},
+
+ //Get Operation Mode Resp Ind
+ { QMI_LOC_GET_OPERATION_MODE_IND_V02,
+ sizeof(qmiLocGetOperationModeIndMsgT_v02)},
+
+ //Set SPI Status Resp Ind
+ { QMI_LOC_SET_SPI_STATUS_IND_V02,
+ sizeof(qmiLocSetSpiStatusIndMsgT_v02)},
+
+ //Inject Sensor Data Resp Ind
+ { QMI_LOC_INJECT_SENSOR_DATA_IND_V02,
+ sizeof(qmiLocInjectSensorDataIndMsgT_v02)},
+
+ //Inject Time Sync Data Resp Ind
+ { QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02,
+ sizeof(qmiLocInjectTimeSyncDataIndMsgT_v02)},
+
+ //Set Cradle Mount config Resp Ind
+ { QMI_LOC_SET_CRADLE_MOUNT_CONFIG_IND_V02,
+ sizeof(qmiLocSetCradleMountConfigIndMsgT_v02)},
+
+ //Get Cradle Mount config Resp Ind
+ { QMI_LOC_GET_CRADLE_MOUNT_CONFIG_IND_V02,
+ sizeof(qmiLocGetCradleMountConfigIndMsgT_v02)},
+
+ //Set External Power config Resp Ind
+ { QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02,
+ sizeof(qmiLocSetExternalPowerConfigIndMsgT_v02)},
+
+ //Get External Power config Resp Ind
+ { QMI_LOC_GET_EXTERNAL_POWER_CONFIG_IND_V02,
+ sizeof(qmiLocGetExternalPowerConfigIndMsgT_v02)},
+
+ //Location server connection status
+ { QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02,
+ sizeof(qmiLocInformLocationServerConnStatusIndMsgT_v02)},
+
+ //Set Protocol Config Parameters
+ { QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02,
+ sizeof(qmiLocSetProtocolConfigParametersIndMsgT_v02)},
+
+ //Get Protocol Config Parameters
+ { QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02,
+ sizeof(qmiLocGetProtocolConfigParametersIndMsgT_v02)},
+
+ //Set Sensor Control Config
+ { QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02,
+ sizeof(qmiLocSetSensorControlConfigIndMsgT_v02)},
+
+ //Get Sensor Control Config
+ { QMI_LOC_GET_SENSOR_CONTROL_CONFIG_IND_V02,
+ sizeof(qmiLocGetSensorControlConfigIndMsgT_v02)},
+
+ //Set Sensor Properties
+ { QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02,
+ sizeof(qmiLocSetSensorPropertiesIndMsgT_v02)},
+
+ //Get Sensor Properties
+ { QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02,
+ sizeof(qmiLocGetSensorPropertiesIndMsgT_v02)},
+
+ //Set Sensor Performance Control Config
+ { QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02,
+ sizeof(qmiLocSetSensorPerformanceControlConfigIndMsgT_v02)},
+
+ //Get Sensor Performance Control Config
+ { QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02,
+ sizeof(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02)},
+ //Inject SUPL certificate
+ { QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02,
+ sizeof(qmiLocInjectSuplCertificateIndMsgT_v02) },
+
+ //Delete SUPL certificate
+ { QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02,
+ sizeof(qmiLocDeleteSuplCertificateIndMsgT_v02) },
+
+ // Set Position Engine Config
+ { QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02,
+ sizeof(qmiLocSetPositionEngineConfigParametersIndMsgT_v02)},
+
+ // Get Position Engine Config
+ { QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02,
+ sizeof(qmiLocGetPositionEngineConfigParametersIndMsgT_v02)},
+
+ //Add a Circular Geofence
+ { QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02,
+ sizeof(qmiLocAddCircularGeofenceIndMsgT_v02)},
+
+ //Delete a Geofence
+ { QMI_LOC_DELETE_GEOFENCE_IND_V02,
+ sizeof(qmiLocDeleteGeofenceIndMsgT_v02)} ,
+
+ //Query a Geofence
+ { QMI_LOC_QUERY_GEOFENCE_IND_V02,
+ sizeof(qmiLocQueryGeofenceIndMsgT_v02)},
+
+ //Edit a Geofence
+ { QMI_LOC_EDIT_GEOFENCE_IND_V02,
+ sizeof(qmiLocEditGeofenceIndMsgT_v02)},
+
+ //Get best available position
+ { QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02,
+ sizeof(qmiLocGetBestAvailablePositionIndMsgT_v02)},
+
+ //Inject motion data
+ { QMI_LOC_INJECT_MOTION_DATA_IND_V02,
+ sizeof(qmiLocInjectMotionDataIndMsgT_v02)},
+
+ //Get NI Geofence list
+ { QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02,
+ sizeof(qmiLocGetNiGeofenceIdListIndMsgT_v02)},
+
+ //Inject GSM Cell Info
+ { QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02,
+ sizeof(qmiLocInjectGSMCellInfoIndMsgT_v02)},
+
+ //Inject Network Initiated Message
+ { QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02,
+ sizeof(qmiLocInjectNetworkInitiatedMessageIndMsgT_v02)},
+
+ //WWAN Out of Service Notification
+ { QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_IND_V02,
+ sizeof(qmiLocWWANOutOfServiceNotificationIndMsgT_v02)},
+
+ //Pedomete Report
+ { QMI_LOC_PEDOMETER_REPORT_IND_V02,
+ sizeof(qmiLocPedometerReportIndMsgT_v02)},
+
+ { QMI_LOC_INJECT_WCDMA_CELL_INFO_IND_V02,
+ sizeof(qmiLocInjectWCDMACellInfoIndMsgT_v02)},
+
+ { QMI_LOC_INJECT_TDSCDMA_CELL_INFO_IND_V02,
+ sizeof(qmiLocInjectTDSCDMACellInfoIndMsgT_v02)},
+
+ { QMI_LOC_INJECT_SUBSCRIBER_ID_IND_V02,
+ sizeof(qmiLocInjectSubscriberIDIndMsgT_v02)}
+};
+
+
+/** whether indication is an event or a response */
+typedef enum { eventIndType =0, respIndType = 1 } locClientIndEnumT;
+
+
+/** @struct locClientInternalState
+ */
+
+typedef struct locClientCbDataStructT locClientCallbackDataType;
+
+struct locClientCbDataStructT
+{
+ // client cookie
+ void *pClientCookie;
+ //QCCI handle for this control point
+ qmi_client_type userHandle;
+
+ // callbacks registered by the clients
+ locClientEventIndCbType eventCallback;
+ locClientRespIndCbType respCallback;
+ locClientErrorCbType errorCallback;
+
+ // the event mask the client has registered for
+ locClientEventMaskType eventRegMask;
+
+ //pointer to itself for checking consistency data
+ locClientCallbackDataType *pMe;
+};
+
+
+/*===========================================================================
+ *
+ * FUNCTION DECLARATION
+ *
+ *==========================================================================*/
+
+/** locClientGetSizeAndTypeByIndId
+ * @brief this function gets the size and the type (event,
+ * response)of the indication structure from its ID
+ * @param [in] indId ID of the indication
+ * @param [out] type event or response indication
+ * @param [out] size size of the indications
+ *
+ * @return true if the ID was found, false otherwise */
+
+static bool locClientGetSizeAndTypeByIndId (uint32_t indId, size_t *pIndSize,
+ locClientIndEnumT *pIndType)
+{
+ // look in the event table
+ if(true == locClientGetSizeByEventIndId(indId, pIndSize))
+ {
+ *pIndType = eventIndType;
+
+ LOC_LOGV("%s:%d]: indId %d is an event size = %d\n", __func__, __LINE__,
+ indId, (uint32_t)*pIndSize);
+ return true;
+ }
+
+ //else look in response table
+ if(true == locClientGetSizeByRespIndId(indId, pIndSize))
+ {
+ *pIndType = respIndType;
+
+ LOC_LOGV("%s:%d]: indId %d is a resp size = %d\n", __func__, __LINE__,
+ indId, (uint32_t)*pIndSize);
+ return true;
+ }
+
+ // Id not found
+ LOC_LOGW("%s:%d]: indId %d not found\n", __func__, __LINE__, indId);
+ return false;
+}
+
+/** isClientRegisteredForEvent
+* @brief checks the mask to identify if the client has
+* registered for the specified event Id
+* @param [in] eventIndId
+* @param [in] eventRegMask
+* @return true if client regstered for event; else false */
+
+static bool isClientRegisteredForEvent(
+ locClientEventMaskType eventRegMask,
+ uint32_t eventIndId)
+{
+ size_t idx = 0, eventIndTableSize = 0;
+
+ // look in the event table
+ eventIndTableSize =
+ (sizeof(locClientEventIndTable)/sizeof(locClientEventIndTableStructT));
+
+ for(idx=0; idx<eventIndTableSize; idx++ )
+ {
+ if(eventIndId == locClientEventIndTable[idx].eventId)
+ {
+ LOC_LOGV("%s:%d]: eventId %d registered mask = 0x%04x%04x, "
+ "eventMask = 0x%04x%04x\n", __func__, __LINE__,
+ eventIndId,(uint32_t)(eventRegMask>>32),
+ (uint32_t)(eventRegMask & 0xFFFFFFFF),
+ (uint32_t)(locClientEventIndTable[idx].eventMask >> 32),
+ (uint32_t)(locClientEventIndTable[idx].eventMask & 0xFFFFFFFF));
+
+ return((
+ eventRegMask & locClientEventIndTable[idx].eventMask)?
+ true:false);
+ }
+ }
+ LOC_LOGW("%s:%d]: eventId %d not found\n", __func__, __LINE__,
+ eventIndId);
+ return false;
+}
+
+/** convertQmiResponseToLocStatus
+ @brief converts a qmiLocGenRespMsgT to locClientStatusEnumType*
+ @param [in] pResponse; pointer to the response received from
+ QMI_LOC service.
+ @return locClientStatusEnumType corresponding to the
+ response.
+*/
+
+static locClientStatusEnumType convertQmiResponseToLocStatus(
+ qmiLocGenRespMsgT_v02 *pResponse)
+{
+ locClientStatusEnumType status = eLOC_CLIENT_FAILURE_INTERNAL;
+
+ // if result == SUCCESS don't look at error code
+ if(pResponse->resp.result == QMI_RESULT_SUCCESS_V01 )
+ {
+ status = eLOC_CLIENT_SUCCESS;
+ }
+ else
+ {
+ switch(pResponse->resp.error)
+ {
+ case QMI_ERR_MALFORMED_MSG_V01:
+ case QMI_ERR_INVALID_ARG_V01:
+ status = eLOC_CLIENT_FAILURE_INVALID_PARAMETER;
+ break;
+
+ case QMI_ERR_DEVICE_IN_USE_V01:
+ status = eLOC_CLIENT_FAILURE_ENGINE_BUSY;
+ break;
+
+ default:
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+ }
+ LOC_LOGV("%s:%d]: result = %d, error = %d, status = %d\n",
+ __func__, __LINE__, pResponse->resp.result,
+ pResponse->resp.error, status);
+ return status;
+}
+
+/** convertQmiErrorToLocError
+ @brief converts a qmi service error type to
+ locClientErrorEnumType
+ @param [in] error received QMI service.
+ @return locClientErrorEnumType corresponding to the error.
+*/
+
+static locClientErrorEnumType convertQmiErrorToLocError(
+ qmi_client_error_type error)
+{
+ locClientErrorEnumType locError ;
+ switch(error)
+ {
+ case QMI_SERVICE_ERR:
+ locError = eLOC_CLIENT_ERROR_SERVICE_UNAVAILABLE;
+ break;
+
+ default:
+ locError = eLOC_CLIENT_ERROR_SERVICE_UNAVAILABLE;
+ break;
+ }
+ LOC_LOGV("%s:%d]: qmi error = %d, loc error = %d\n",
+ __func__, __LINE__, error, locError);
+ return locError;
+}
+
+/** locClienHandlePosReportInd
+ * @brief Validates a position report ind
+ * @param [in] msg_id
+ * @param [in] ind_buf
+ * @param [in] ind_buf_len
+ * @return true if pos report is valid, false otherwise
+*/
+static bool locClientHandlePosReportInd
+(
+ uint32_t msg_id,
+ const void* ind_buf,
+ uint32_t ind_buf_len
+)
+{
+ // validate position report
+ qmiLocEventPositionReportIndMsgT_v02 *posReport =
+ (qmiLocEventPositionReportIndMsgT_v02 *)ind_buf;
+
+ LOC_LOGV ("%s:%d]: len = %d lat = %f, lon = %f, alt = %f\n",
+ __func__, __LINE__, ind_buf_len,
+ posReport->latitude, posReport->longitude,
+ posReport->altitudeWrtEllipsoid);
+
+ return true;
+}
+//-----------------------------------------------------------------------------
+
+/** locClientHandleSatReportInd
+ * @brief Validates a satellite report indication. Dk
+ * @param [in] msg_id
+ * @param [in] ind_buf
+ * @param [in] ind_buf_len
+ * @return true if sat report is valid, false otherwise
+*/
+static bool locClientHandleSatReportInd
+(
+ uint32_t msg_id,
+ const void* ind_buf,
+ uint32_t ind_buf_len
+)
+{
+ // validate sat reports
+ unsigned int idx = 0;
+ qmiLocEventGnssSvInfoIndMsgT_v02 *satReport =
+ (qmiLocEventGnssSvInfoIndMsgT_v02 *)ind_buf;
+
+ LOC_LOGV ("%s:%d]: len = %u , altitude assumed = %u, num SV's = %u"
+ " validity = %d \n ", __func__, __LINE__,
+ ind_buf_len, satReport->altitudeAssumed,
+ satReport->svList_len, satReport->svList_valid);
+ //Log SV report
+ for( idx = 0; idx <satReport->svList_len; idx++ )
+ {
+ LOC_LOGV("%s:%d]: valid_mask = %x, prn = %u, system = %d, "
+ "status = %d \n", __func__, __LINE__,
+ satReport->svList[idx].validMask, satReport->svList[idx].gnssSvId,
+ satReport->svList[idx].system, satReport->svList[idx].svStatus);
+ }
+
+ return true;
+}
+
+
+/** locClientHandleNmeaReportInd
+ * @brief Validate a NMEA report indication.
+ * @param [in] msg_id
+ * @param [in] ind_buf
+ * @param [in] ind_buf_len
+ * @return true if nmea report is valid, false otherwise
+*/
+
+
+static bool locClientHandleNmeaReportInd
+(
+ uint32_t msg_id,
+ const void* ind_buf,
+ uint32_t ind_buf_len
+)
+{
+ // validate NMEA report
+ return true;
+}
+
+/** locClientHandleGetServiceRevisionRespInd
+ * @brief Handles a Get Service Revision Rresponse indication.
+ * @param [in] msg_id
+ * @param [in] ind_buf
+ * @param [in] ind_buf_len
+ * @return true if service revision is valid, false otherwise
+*/
+
+static bool locClientHandleGetServiceRevisionRespInd
+(
+ uint32_t msg_id,
+ const void* ind_buf,
+ uint32_t ind_buf_len
+)
+{
+ LOC_LOGV("%s:%d] :\n", __func__, __LINE__);
+ return true;
+}
+
+/** locClientHandleIndication
+ * @brief looks at each indication and calls the appropriate
+ * validation handler
+ * @param [in] indId
+ * @param [in] indBuffer
+ * @param [in] indSize
+ * @return true if indication was validated; else false */
+
+static bool locClientHandleIndication(
+ uint32_t indId,
+ void* indBuffer,
+ size_t indSize
+ )
+{
+ bool status = false;
+ switch(indId)
+ {
+ // handle the event indications
+ //-------------------------------------------------------------------------
+
+ // handle position report
+ case QMI_LOC_EVENT_POSITION_REPORT_IND_V02:
+ {
+ status = locClientHandlePosReportInd(indId, indBuffer, indSize);
+ break;
+ }
+ // handle satellite report
+ case QMI_LOC_EVENT_GNSS_SV_INFO_IND_V02:
+ {
+ status = locClientHandleSatReportInd(indId, indBuffer, indSize);
+ break;
+ }
+
+ // handle NMEA report
+ case QMI_LOC_EVENT_NMEA_IND_V02:
+ {
+ status = locClientHandleNmeaReportInd(indId, indBuffer, indSize);
+ break;
+ }
+
+ // handle NI Notify Verify Request Ind
+ case QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02:
+ {
+ // locClientHandleNiReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle Time Inject request Ind
+ case QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02:
+ {
+ // locClientHandleTimeInjectReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle XTRA data Inject request Ind
+ case QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02:
+ {
+ // locClientHandleXtraInjectReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle position inject request Ind
+ case QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02:
+ {
+ // locClientHandlePositionInjectReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle engine state Ind
+ case QMI_LOC_EVENT_ENGINE_STATE_IND_V02:
+ {
+ // locClientHandleEngineStateInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle fix session state Ind
+ case QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02:
+ {
+ // locClientHandleFixSessionStateInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle Wifi request Ind
+ case QMI_LOC_EVENT_WIFI_REQ_IND_V02:
+ {
+ // locClientHandleWifiReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle sensor streaming ready status Ind
+ case QMI_LOC_EVENT_SENSOR_STREAMING_READY_STATUS_IND_V02:
+ {
+ // locClientHandleSensorStreamingReadyInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle time sync Ind
+ case QMI_LOC_EVENT_TIME_SYNC_REQ_IND_V02:
+ {
+ // locClientHandleTimeSyncReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // handle set streaming report ind
+ case QMI_LOC_EVENT_SET_SPI_STREAMING_REPORT_IND_V02:
+ {
+ // locClientHandleSetSpiStreamingInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02:
+ {
+ //locClientHandleLocServerConnReqInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EVENT_NI_GEOFENCE_NOTIFICATION_IND_V02:
+ {
+ //locClientHandleNiGeofenceNotificationInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EVENT_GEOFENCE_GEN_ALERT_IND_V02:
+ {
+ //locClientHandleGeofenceGenAlertInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EVENT_GEOFENCE_BREACH_NOTIFICATION_IND_V02:
+ {
+ //locClientHandleGeofenceBreachInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EVENT_PEDOMETER_CONTROL_IND_V02 :
+ {
+ //locClientHandlePedometerControlInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EVENT_MOTION_DATA_CONTROL_IND_V02:
+ {
+ //locClientHandleMotionDataControlInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ //-------------------------------------------------------------------------
+
+ // handle the response indications
+ //-------------------------------------------------------------------------
+
+ // Get service Revision response indication
+ case QMI_LOC_GET_SERVICE_REVISION_IND_V02:
+ {
+ status = locClientHandleGetServiceRevisionRespInd(indId,
+ indBuffer, indSize);
+ break;
+ }
+
+ case QMI_LOC_GET_FIX_CRITERIA_IND_V02:
+ {
+ status = true;
+ break;
+ }
+
+ // predicted orbits data response indication
+ case QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02:
+ {
+ //locClientHandleInjectPredictedOrbitsDataInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // get predicted orbits source response indication
+ case QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_IND_V02:
+ {
+ //locClientHandleGetPredictedOrbitsSourceInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ // get predicted orbits validity response indication
+ case QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_IND_V02:
+ {
+ //locClientHandleGetPredictedOrbitsDataValidityInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_INJECT_SENSOR_DATA_IND_V02 :
+ {
+ //locClientHandleInjectSensorDataInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02:
+ {
+ //locClientHandleGetProtocolConfigParametersInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02:
+ {
+ //locClientHandleSetProtocolConfigParametersInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_EXTERNAL_POWER_CONFIG_IND_V02:
+ {
+ //locClientHandleGetExtPowerConfigInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_CRADLE_MOUNT_CONFIG_IND_V02:
+ {
+ //locClientHandleGetCradleMountConfigInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_SENSOR_CONTROL_CONFIG_IND_V02:
+ {
+ //locClientHandleGetSensorControlConfigInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02:
+ {
+ //locClientHandleGetSensorPerformanceControlConfigInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02:
+ {
+ //locClientHandleGetSensorPropertiesInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02:
+ {
+ //locClientHandleSetSensorPerformanceControlConfigInd(user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02:
+ {
+ // locClientHandleSetPositionEngineConfigParam(
+ // user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02:
+ {
+ // locClientHandleSetPositionEngineConfigParam(
+ // user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02:
+ {
+ // locClientHandleAddCircularGeofenceInd(
+ // user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_DELETE_GEOFENCE_IND_V02:
+ {
+ // locClientHandleDeleteGeofenceInd(
+ // user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_EDIT_GEOFENCE_IND_V02:
+ {
+ // locClientHandleEditGeofenceInd(
+ // user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_QUERY_GEOFENCE_IND_V02:
+ {
+ // locClientHandleQueryGeofenceInd(
+ // user_handle, msg_id, ind_buf, ind_buf_len);
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02:
+ {
+ status = true;
+ break;
+ }
+ case QMI_LOC_GET_ENGINE_LOCK_IND_V02:
+ {
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02:
+ {
+ status = true;
+ break;
+ }
+
+ case QMI_LOC_PEDOMETER_REPORT_IND_V02:
+ {
+ status = true;
+ break;
+ }
+
+ // for indications that only have a "status" field
+ case QMI_LOC_NI_USER_RESPONSE_IND_V02:
+ case QMI_LOC_INJECT_UTC_TIME_IND_V02:
+ case QMI_LOC_INJECT_POSITION_IND_V02:
+ case QMI_LOC_SET_ENGINE_LOCK_IND_V02:
+ case QMI_LOC_SET_SBAS_CONFIG_IND_V02:
+ case QMI_LOC_SET_NMEA_TYPES_IND_V02:
+ case QMI_LOC_SET_LOW_POWER_MODE_IND_V02:
+ case QMI_LOC_SET_SERVER_IND_V02:
+ case QMI_LOC_DELETE_ASSIST_DATA_IND_V02:
+ case QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02:
+ case QMI_LOC_INJECT_WIFI_POSITION_IND_V02:
+ case QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02:
+ case QMI_LOC_SET_OPERATION_MODE_IND_V02:
+ case QMI_LOC_SET_SPI_STATUS_IND_V02:
+ case QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02:
+ case QMI_LOC_SET_CRADLE_MOUNT_CONFIG_IND_V02:
+ case QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02:
+ case QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02:
+ case QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02:
+ case QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02:
+ case QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02:
+ case QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02:
+ case QMI_LOC_INJECT_MOTION_DATA_IND_V02:
+ case QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02:
+ case QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02:
+ case QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_IND_V02:
+ case QMI_LOC_INJECT_WCDMA_CELL_INFO_IND_V02:
+ case QMI_LOC_INJECT_TDSCDMA_CELL_INFO_IND_V02:
+ case QMI_LOC_INJECT_SUBSCRIBER_ID_IND_V02:
+ {
+ status = true;
+ break;
+ }
+ default:
+ LOC_LOGW("%s:%d]: unknown ind id %d\n", __func__, __LINE__,
+ (uint32_t)indId);
+ status = false;
+ break;
+ }
+ return status;
+}
+
+
+/** locClientErrorCb
+ * @brief handles the QCCI error events, this is called by the
+ * QCCI infrastructure when the service is no longer
+ * available.
+ * @param [in] user handle
+ * @param [in] error
+ * @param [in] *err_cb_data
+ */
+
+static void locClientErrorCb
+(
+ qmi_client_type user_handle,
+ qmi_client_error_type error,
+ void *err_cb_data
+)
+{
+ locClientCallbackDataType* pCallbackData =
+ (locClientCallbackDataType *)err_cb_data;
+ locClientErrorCbType localErrorCallback = NULL;
+
+ /* copy the errorCallback function pointer from the callback
+ * data to local variable. This is to protect against the race
+ * condition between open/close and error callback.
+ */
+ if(NULL != pCallbackData)
+ {
+ localErrorCallback = pCallbackData->errorCallback;
+ }
+
+ LOC_LOGD("%s:%d]: Service Error %d received, pCallbackData = %p\n",
+ __func__, __LINE__, error, err_cb_data);
+
+ /* call the error callback
+ * To avoid calling the errorCallback after locClientClose
+ * is called, check pCallbackData->errorCallback again here
+ */
+
+ if( (NULL != pCallbackData) &&
+ (NULL != localErrorCallback) &&
+ (NULL != pCallbackData->errorCallback) &&
+ (pCallbackData == pCallbackData->pMe) )
+ {
+ //invoke the error callback for the corresponding client
+ localErrorCallback(
+ (locClientHandleType)pCallbackData,
+ convertQmiErrorToLocError(error),
+ pCallbackData->pClientCookie);
+ }
+}
+
+
+/** locClientIndCb
+ * @brief handles the indications sent from the service, if a
+ * response indication was received then the it is sent
+ * to the response callback. If a event indication was
+ * received then it is sent to the event callback
+ * @param [in] user handle
+ * @param [in] msg_id
+ * @param [in] ind_buf
+ * @param [in] ind_buf_len
+ * @param [in] ind_cb_data */
+
+static void locClientIndCb
+(
+ qmi_client_type user_handle,
+ unsigned int msg_id,
+ void *ind_buf,
+ unsigned int ind_buf_len,
+ void *ind_cb_data
+)
+{
+ locClientIndEnumT indType;
+ size_t indSize = 0;
+ qmi_client_error_type rc ;
+ locClientCallbackDataType* pCallbackData =
+ (locClientCallbackDataType *)ind_cb_data;
+
+ LOC_LOGV("%s:%d]: Indication: msg_id=%d buf_len=%d pCallbackData = %p\n",
+ __func__, __LINE__, (uint32_t)msg_id, ind_buf_len,
+ pCallbackData);
+
+ // check callback data
+ if(NULL == pCallbackData ||(pCallbackData != pCallbackData->pMe))
+ {
+ LOC_LOGE("%s:%d]: invalid callback data", __func__, __LINE__);
+ return;
+ }
+
+ // check user handle
+ if(memcmp(&pCallbackData->userHandle, &user_handle, sizeof(user_handle)))
+ {
+ LOC_LOGE("%s:%d]: invalid user_handle got %p expected %p\n",
+ __func__, __LINE__,
+ user_handle, pCallbackData->userHandle);
+ return;
+ }
+ // Get the indication size and type ( eventInd or respInd)
+ if( true == locClientGetSizeAndTypeByIndId(msg_id, &indSize, &indType))
+ {
+ void *indBuffer = NULL;
+
+ // if the client did not register for this event then just drop it
+ if( (eventIndType == indType) &&
+ ( (NULL == pCallbackData->eventCallback) ||
+ (false == isClientRegisteredForEvent(pCallbackData->eventRegMask, msg_id)) ) )
+ {
+ LOC_LOGW("%s:%d]: client is not registered for event %d\n",
+ __func__, __LINE__, (uint32_t)msg_id);
+ return;
+ }
+
+ // decode the indication
+ indBuffer = malloc(indSize);
+
+ if(NULL == indBuffer)
+ {
+ LOC_LOGE("%s:%d]: memory allocation failed\n", __func__, __LINE__);
+ return;
+ }
+
+ // decode the indication
+ rc = qmi_client_message_decode(
+ user_handle,
+ QMI_IDL_INDICATION,
+ msg_id,
+ ind_buf,
+ ind_buf_len,
+ indBuffer,
+ indSize);
+
+ if( rc == QMI_NO_ERR )
+ {
+ //validate indication
+ if (true == locClientHandleIndication(msg_id, indBuffer, indSize))
+ {
+ if(eventIndType == indType)
+ {
+ locClientEventIndUnionType eventIndUnion;
+
+ /* copy the eventCallback function pointer from the callback
+ * data to local variable. This is to protect against the race
+ * condition between open/close and indication callback.
+ */
+ locClientEventIndCbType localEventCallback =
+ pCallbackData->eventCallback;
+
+ // dummy event
+ eventIndUnion.pPositionReportEvent =
+ (qmiLocEventPositionReportIndMsgT_v02 *)indBuffer;
+
+ /* call the event callback
+ * To avoid calling the eventCallback after locClientClose
+ * is called, check pCallbackData->eventCallback again here
+ */
+ if((NULL != localEventCallback) &&
+ (NULL != pCallbackData->eventCallback))
+ {
+ localEventCallback(
+ (locClientHandleType)pCallbackData,
+ msg_id,
+ eventIndUnion,
+ pCallbackData->pClientCookie);
+ }
+ }
+ else if(respIndType == indType)
+ {
+ locClientRespIndUnionType respIndUnion;
+
+ /* copy the respCallback function pointer from the callback
+ * data to local variable. This is to protect against the race
+ * condition between open/close and indication callback.
+ */
+ locClientRespIndCbType localRespCallback =
+ pCallbackData->respCallback;
+
+ // dummy to suppress compiler warnings
+ respIndUnion.pDeleteAssistDataInd =
+ (qmiLocDeleteAssistDataIndMsgT_v02 *)indBuffer;
+
+ /* call the response callback
+ * To avoid calling the respCallback after locClientClose
+ * is called, check pCallbackData->respCallback again here
+ */
+ if((NULL != localRespCallback) &&
+ (NULL != pCallbackData->respCallback))
+ {
+ localRespCallback(
+ (locClientHandleType)pCallbackData,
+ msg_id,
+ respIndUnion,
+ pCallbackData->pClientCookie);
+ }
+ }
+ }
+ else // error handling indication
+ {
+ LOC_LOGE("%s:%d]: Error handling the indication %d\n",
+ __func__, __LINE__, (uint32_t)msg_id);
+ }
+ }
+ else
+ {
+ LOC_LOGE("%s:%d]: Error decoding indication %d\n",
+ __func__, __LINE__, rc);
+ }
+ if(indBuffer)
+ {
+ free (indBuffer);
+ }
+ }
+ else // Id not found
+ {
+ LOC_LOGE("%s:%d]: Error indication not found %d\n",
+ __func__, __LINE__,(uint32_t)msg_id);
+ }
+ return;
+}
+
+
+/** locClientRegisterEventMask
+ * @brief registers the event mask with loc service
+ * @param [in] clientHandle
+ * @param [in] eventRegMask
+ * @return true if indication was validated; else false */
+
+static bool locClientRegisterEventMask(
+ locClientHandleType clientHandle,
+ locClientEventMaskType eventRegMask)
+{
+ locClientStatusEnumType status = eLOC_CLIENT_SUCCESS;
+ locClientReqUnionType reqUnion;
+ qmiLocRegEventsReqMsgT_v02 regEventsReq;
+
+ memset(&regEventsReq, 0, sizeof(regEventsReq));
+
+ regEventsReq.eventRegMask = eventRegMask;
+ reqUnion.pRegEventsReq = &regEventsReq;
+
+ status = locClientSendReq(clientHandle,
+ QMI_LOC_REG_EVENTS_REQ_V02,
+ reqUnion);
+
+ if(eLOC_CLIENT_SUCCESS != status )
+ {
+ LOC_LOGE("%s:%d] status %s\n", __func__, __LINE__,
+ loc_get_v02_client_status_name(status) );
+ return false;
+ }
+
+ return true;
+}
+
+/** validateRequest
+ @brief validates the input request
+ @param [in] reqId request ID
+ @param [in] reqPayload Union of pointers to message payload
+ @param [out] ppOutData Pointer to void *data if successful
+ @param [out] pOutLen Pointer to length of data if succesful.
+ @return false on failure, true on Success
+*/
+
+static bool validateRequest(
+ uint32_t reqId,
+ const locClientReqUnionType reqPayload,
+ void **ppOutData,
+ uint32_t *pOutLen )
+
+{
+ bool noPayloadFlag = false;
+
+ LOC_LOGV("%s:%d]: reqId = %d\n", __func__, __LINE__, reqId);
+ switch(reqId)
+ {
+ case QMI_LOC_INFORM_CLIENT_REVISION_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInformClientRevisionReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_REG_EVENTS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocRegEventsReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_START_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocStartReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_STOP_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocStopReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_NI_USER_RESPONSE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocNiUserRespReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectPredictedOrbitsDataReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_UTC_TIME_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectUtcTimeReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_POSITION_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectPositionReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_ENGINE_LOCK_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetEngineLockReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_SBAS_CONFIG_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetSbasConfigReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_NMEA_TYPES_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetNmeaTypesReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_LOW_POWER_MODE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetLowPowerModeReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_SERVER_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetServerReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_DELETE_ASSIST_DATA_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocDeleteAssistDataReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_XTRA_T_SESSION_CONTROL_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetXtraTSessionControlReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_WIFI_POSITION_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectWifiPositionReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_NOTIFY_WIFI_STATUS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocNotifyWifiStatusReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_OPERATION_MODE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetOperationModeReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_SPI_STATUS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetSpiStatusReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_SENSOR_DATA_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectSensorDataReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_TIME_SYNC_DATA_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectTimeSyncDataReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_CRADLE_MOUNT_CONFIG_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetCradleMountConfigReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetExternalPowerConfigReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInformLocationServerConnStatusReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetProtocolConfigParametersReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocGetProtocolConfigParametersReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetSensorControlConfigReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_GET_SENSOR_PROPERTIES_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocGetSensorPropertiesReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetSensorPropertiesReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_SUPL_CERTIFICATE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectSuplCertificateReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_DELETE_SUPL_CERTIFICATE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocDeleteSuplCertificateReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocSetPositionEngineConfigParametersReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocGetPositionEngineConfigParametersReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_ADD_CIRCULAR_GEOFENCE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocAddCircularGeofenceReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_DELETE_GEOFENCE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocDeleteGeofenceReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_QUERY_GEOFENCE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocQueryGeofenceReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_EDIT_GEOFENCE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocEditGeofenceReqMsgT_v02);
+ break;
+ }
+ case QMI_LOC_GET_BEST_AVAILABLE_POSITION_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocGetBestAvailablePositionReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_MOTION_DATA_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectMotionDataReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_GET_NI_GEOFENCE_ID_LIST_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocGetNiGeofenceIdListReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_GSM_CELL_INFO_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectGSMCellInfoReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectNetworkInitiatedMessageReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_PEDOMETER_REPORT_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocPedometerReportReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_WCDMA_CELL_INFO_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectWCDMACellInfoReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_TDSCDMA_CELL_INFO_REQ_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectTDSCDMACellInfoReqMsgT_v02);
+ break;
+ }
+
+ case QMI_LOC_INJECT_SUBSCRIBER_ID_IND_V02:
+ {
+ *pOutLen = sizeof(qmiLocInjectSubscriberIDReqMsgT_v02);
+ break;
+ }
+
+ // ALL requests with no payload
+ case QMI_LOC_GET_SERVICE_REVISION_REQ_V02:
+ case QMI_LOC_GET_FIX_CRITERIA_REQ_V02:
+ case QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_REQ_V02:
+ case QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_REQ_V02:
+ case QMI_LOC_GET_ENGINE_LOCK_REQ_V02:
+ case QMI_LOC_GET_SBAS_CONFIG_REQ_V02:
+ case QMI_LOC_GET_NMEA_TYPES_REQ_V02:
+ case QMI_LOC_GET_LOW_POWER_MODE_REQ_V02:
+ case QMI_LOC_GET_SERVER_REQ_V02:
+ case QMI_LOC_GET_XTRA_T_SESSION_CONTROL_REQ_V02:
+ case QMI_LOC_GET_REGISTERED_EVENTS_REQ_V02:
+ case QMI_LOC_GET_OPERATION_MODE_REQ_V02:
+ case QMI_LOC_GET_CRADLE_MOUNT_CONFIG_REQ_V02:
+ case QMI_LOC_GET_EXTERNAL_POWER_CONFIG_REQ_V02:
+ case QMI_LOC_GET_SENSOR_CONTROL_CONFIG_REQ_V02:
+ case QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02:
+ case QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_REQ_V02:
+ case QMI_LOC_GET_SUPPORTED_MSGS_REQ_V02:
+ case QMI_LOC_GET_SUPPORTED_FIELDS_REQ_V02:
+ {
+ noPayloadFlag = true;
+ break;
+ }
+
+ default:
+ LOC_LOGW("%s:%d]: Error unknown reqId=%d\n", __func__, __LINE__,
+ reqId);
+ return false;
+ }
+ if(true == noPayloadFlag)
+ {
+ *ppOutData = NULL;
+ *pOutLen = 0;
+ }
+ else
+ {
+ //set dummy pointer for request union
+ *ppOutData = (void*) reqPayload.pInformClientRevisionReq;
+ }
+ LOC_LOGV("%s:%d]: reqId=%d, len = %d\n", __func__, __LINE__,
+ reqId, *pOutLen);
+ return true;
+}
+
+/** locClientQmiCtrlPointInit
+ @brief wait for the service to come up or timeout; when the
+ service comes up initialize the control point and set
+ internal handle and indication callback.
+ @param pQmiClient,
+*/
+
+static locClientStatusEnumType locClientQmiCtrlPointInit(
+ locClientCallbackDataType *pLocClientCbData)
+{
+ qmi_client_type clnt, notifier;
+ bool notifierInitFlag = false;
+ locClientStatusEnumType status = eLOC_CLIENT_SUCCESS;
+ // instances of this service
+ qmi_service_info *pServiceInfo = NULL;
+
+ do
+ {
+ uint32_t num_services = 0, num_entries = 0;
+ qmi_client_error_type rc = QMI_NO_ERR;
+ bool nosignal = false;
+ qmi_client_os_params os_params;
+ int timeout = 0;
+
+ // Get the service object for the qmiLoc Service
+ qmi_idl_service_object_type locClientServiceObject =
+ loc_get_service_object_v02();
+
+ // Verify that qmiLoc_get_service_object did not return NULL
+ if (NULL == locClientServiceObject)
+ {
+ LOC_LOGE("%s:%d]: qmiLoc_get_service_object_v02 failed\n" ,
+ __func__, __LINE__ );
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ // register for service notification
+ rc = qmi_client_notifier_init(locClientServiceObject, &os_params, &notifier);
+ notifierInitFlag = (NULL != notifier);
+
+ if (rc != QMI_NO_ERR) {
+ LOC_LOGE("%s:%d]: qmi_client_notifier_init failed %d\n",
+ __func__, __LINE__, rc);
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ do {
+ QMI_CCI_OS_SIGNAL_CLEAR(&os_params);
+ // get the service addressing information
+ rc = qmi_client_get_service_list(locClientServiceObject, NULL, NULL,
+ &num_services);
+ LOC_LOGV("%s:%d]: qmi_client_get_service_list() rc: %d "
+ "total timeout: %d", __func__, __LINE__, rc, timeout);
+
+ if(rc == QMI_NO_ERR)
+ break;
+
+ /* Service is not up. Wait on a signal until the service is up
+ or a timeout occurs. */
+ LOC_LOGD("%s:%d]: Service not up. Starting delay timer\n", __func__, __LINE__);
+ QMI_CCI_OS_SIGNAL_WAIT(&os_params, LOC_CLIENT_SERVICE_TIMEOUT_UNIT);
+ nosignal = QMI_CCI_OS_SIGNAL_TIMED_OUT(&os_params);
+ if(nosignal)
+ timeout += LOC_CLIENT_SERVICE_TIMEOUT_UNIT;
+
+ } while (timeout < LOC_CLIENT_SERVICE_TIMEOUT_TOTAL);
+
+ if (0 == num_services || rc != QMI_NO_ERR) {
+ if (!nosignal) {
+ LOC_LOGE("%s:%d]: qmi_client_get_service_list failed even though"
+ "service is up !!! Error %d \n", __func__, __LINE__, rc);
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ } else {
+ LOC_LOGE("%s:%d]: qmi_client_get_service_list failed after retries,"
+ " final Err %d", __func__, __LINE__, rc);
+ status = eLOC_CLIENT_FAILURE_TIMEOUT;
+ }
+ break;
+ }
+
+ pServiceInfo =
+ (qmi_service_info *)malloc(num_services * sizeof(qmi_service_info));
+
+ if(NULL == pServiceInfo)
+ {
+ LOC_LOGE("%s:%d]: could not allocate memory for serviceInfo !!\n",
+ __func__, __LINE__);
+
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ //set the number of entries to get equal to the total number of
+ //services.
+ num_entries = num_services;
+ //populate the serviceInfo
+ rc = qmi_client_get_service_list( locClientServiceObject, pServiceInfo,
+ &num_entries, &num_services);
+
+
+ LOC_LOGV("%s:%d]: qmi_client_get_service_list()"
+ " returned %d num_entries = %d num_services = %d\n",
+ __func__, __LINE__,
+ rc, num_entries, num_services);
+
+ if(rc != QMI_NO_ERR)
+ {
+ LOC_LOGE("%s:%d]: qmi_client_get_service_list Error %d \n",
+ __func__, __LINE__, rc);
+
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ LOC_LOGV("%s:%d]: passing the pointer %p to qmi_client_init \n",
+ __func__, __LINE__, pLocClientCbData);
+
+ // initialize the client
+ //sent the address of the first service found
+ // if IPC router is present, this will go to the service instance
+ // enumerated over IPC router, else it will go over the next transport where
+ // the service was enumerated.
+ rc = qmi_client_init(&pServiceInfo[0], locClientServiceObject,
+ locClientIndCb, (void *) pLocClientCbData,
+ NULL, &clnt);
+
+ if(rc != QMI_NO_ERR)
+ {
+ LOC_LOGE("%s:%d]: qmi_client_init error %d\n",
+ __func__, __LINE__, rc);
+
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ LOC_LOGV("%s:%d]: passing the pointer %p to"
+ "qmi_client_register_error_cb \n",
+ __func__, __LINE__, pLocClientCbData);
+
+ // register error callback
+ rc = qmi_client_register_error_cb(clnt,
+ locClientErrorCb, (void *) pLocClientCbData);
+
+ if( QMI_NO_ERR != rc)
+ {
+ LOC_LOGE("%s:%d]: could not register QCCI error callback error:%d\n",
+ __func__, __LINE__, rc);
+
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ // copy the clnt handle returned in qmi_client_init
+ memcpy(&(pLocClientCbData->userHandle), &clnt, sizeof(qmi_client_type));
+
+ status = eLOC_CLIENT_SUCCESS;
+
+ } while(0);
+
+ /* release the notifier handle */
+ if(true == notifierInitFlag)
+ {
+ qmi_client_release(notifier);
+ }
+
+ if(NULL != pServiceInfo)
+ {
+ free((void *)pServiceInfo);
+ }
+
+ return status;
+}
+//----------------------- END INTERNAL FUNCTIONS ----------------------------------------
+
+/** locClientOpen
+ @brief Connects a location client to the location engine. If the connection
+ is successful, returns a handle that the location client uses for
+ future location operations.
+
+ @param [in] eventRegMask Mask of asynchronous events the client is
+ interested in receiving
+ @param [in] eventIndCb Function to be invoked to handle an event.
+ @param [in] respIndCb Function to be invoked to handle a response
+ indication.
+ @param [out] locClientHandle Handle to be used by the client
+ for any subsequent requests.
+
+ @return
+ One of the following error codes:
+ - eLOC_CLIENT_SUCCESS -- If the connection is opened.
+ - non-zero error code(see locClientStatusEnumType)-- On failure.
+*/
+
+locClientStatusEnumType locClientOpen (
+ locClientEventMaskType eventRegMask,
+ const locClientCallbacksType* pLocClientCallbacks,
+ locClientHandleType* pLocClientHandle,
+ const void* pClientCookie)
+{
+ locClientStatusEnumType status = eLOC_CLIENT_SUCCESS;
+ locClientCallbackDataType *pCallbackData = NULL;
+
+ // check input parameters
+ if( (NULL == pLocClientCallbacks) || (NULL == pLocClientHandle)
+ || (NULL == pLocClientCallbacks->respIndCb) ||
+ (pLocClientCallbacks->size != sizeof(locClientCallbacksType)))
+ {
+ LOC_LOGE("%s:%d]: Invalid parameters in locClientOpen\n",
+ __func__, __LINE__);
+ return eLOC_CLIENT_FAILURE_INVALID_PARAMETER;
+ }
+
+ do
+ {
+ // Allocate memory for the callback data
+ pCallbackData =
+ ( locClientCallbackDataType*)calloc(
+ 1, sizeof(locClientCallbackDataType));
+
+ if(NULL == pCallbackData)
+ {
+ LOC_LOGE("%s:%d]: Could not allocate memory for callback data \n",
+ __func__, __LINE__);
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ /* Initialize the QMI control point; this function will block
+ * until a service is up or a timeout occurs. If the connection to
+ * the service succeeds the callback data will be filled in with
+ * a qmi_client value.
+ */
+
+
+ EXIT_LOG_CALLFLOW(%s, "loc client open");
+ status = locClientQmiCtrlPointInit(pCallbackData);
+
+ LOC_LOGV ("%s:%d] locClientQmiCtrlPointInit returned %d\n",
+ __func__, __LINE__, status);
+
+ if(status != eLOC_CLIENT_SUCCESS)
+ {
+ free(pCallbackData);
+ pCallbackData = NULL;
+ LOC_LOGE ("%s:%d] locClientQmiCtrlPointInit returned %d\n",
+ __func__, __LINE__, status);
+ break;
+ }
+ // set the self pointer
+ pCallbackData->pMe = pCallbackData;
+ // set the handle to the callback data
+ *pLocClientHandle = (locClientHandleType)pCallbackData;
+
+ if(true != locClientRegisterEventMask(*pLocClientHandle,eventRegMask))
+ {
+ LOC_LOGE("%s:%d]: Error sending registration mask\n",
+ __func__, __LINE__);
+
+ // release the client
+ locClientClose(pLocClientHandle);
+
+ status = eLOC_CLIENT_FAILURE_INTERNAL;
+ break;
+ }
+
+ /* Initialize rest of the client structure now that the connection
+ * to the service has been created successfully.
+ */
+
+ //fill in the event callback
+ pCallbackData->eventCallback = pLocClientCallbacks->eventIndCb;
+
+ //fill in the response callback
+ pCallbackData->respCallback = pLocClientCallbacks->respIndCb;
+
+ //fill in the error callback
+ pCallbackData->errorCallback = pLocClientCallbacks->errorCb;
+
+ //set the client event registration mask
+ pCallbackData->eventRegMask = eventRegMask;
+
+ // set the client cookie
+ pCallbackData->pClientCookie = (void *)pClientCookie;
+
+ }while(0);
+
+ if(eLOC_CLIENT_SUCCESS != status)
+ {
+ *pLocClientHandle = LOC_CLIENT_INVALID_HANDLE_VALUE;
+ LOC_LOGE("%s:%d]: Error! status = %d\n", __func__, __LINE__,status);
+ }
+
+ else
+ {
+ LOC_LOGD("%s:%d]: returning handle = %p, user_handle=%p, status = %d\n",
+ __func__, __LINE__, *pLocClientHandle,
+ pCallbackData->userHandle, status);
+ }
+
+ return(status);
+}
+
+/** locClientClose
+ @brief Disconnects a client from the location engine.
+ @param [in] pLocClientHandle Pointer to the handle returned by the
+ locClientOpen() function.
+ @return
+ One of the following error codes:
+ - 0 (eLOC_CLIENT_SUCCESS) - On success.
+ - non-zero error code(see locClientStatusEnumType) - On failure.
+*/
+
+locClientStatusEnumType locClientClose(
+ locClientHandleType* pLocClientHandle)
+{
+ // convert handle to callback data
+ locClientCallbackDataType *pCallbackData;
+ qmi_client_error_type rc = QMI_NO_ERR; //No error
+
+ if(NULL == pLocClientHandle)
+ {
+ // invalid handle
+ LOC_LOGE("%s:%d]: invalid pointer to handle \n",
+ __func__, __LINE__);
+
+ return(eLOC_CLIENT_FAILURE_INVALID_PARAMETER);
+ }
+
+ pCallbackData = (locClientCallbackDataType *)(*pLocClientHandle);
+
+ // check the input handle for sanity
+ if(NULL == pCallbackData ||
+ NULL == pCallbackData->userHandle ||
+ pCallbackData != pCallbackData->pMe )
+ {
+ // invalid handle
+ LOC_LOGE("%s:%d]: invalid handle \n",
+ __func__, __LINE__);
+
+ return(eLOC_CLIENT_FAILURE_INVALID_HANDLE);
+ }
+
+ LOC_LOGV("locClientClose releasing handle %p, user handle %p\n",
+ *pLocClientHandle, pCallbackData->userHandle );
+
+ // NEXT call goes out to modem. We log the callflow before it
+ // actually happens to ensure the this comes before resp callflow
+ // back from the modem, to avoid confusing log order. We trust
+ // that the QMI framework is robust.
+ EXIT_LOG_CALLFLOW(%s, "loc client close");
+
+ // release the handle
+ rc = qmi_client_release(pCallbackData->userHandle);
+ if(QMI_NO_ERR != rc )
+ {
+ LOC_LOGW("%s:%d]: qmi_client_release error %d for client %p\n",
+ __func__, __LINE__, rc, pCallbackData->userHandle);
+ return(eLOC_CLIENT_FAILURE_INTERNAL);
+ }
+
+ /* clear the memory allocated to callback data to minimize the chances
+ * of a race condition occurring between close and the indication
+ * callback
+ */
+ memset(pCallbackData, 0, sizeof(*pCallbackData));
+
+ // free the memory assigned in locClientOpen
+ free(pCallbackData);
+ pCallbackData= NULL;
+
+ // set the handle to invalid value
+ *pLocClientHandle = LOC_CLIENT_INVALID_HANDLE_VALUE;
+ return eLOC_CLIENT_SUCCESS;
+}
+
+/** locClientSendReq
+ @brief Sends a message to the location engine. If the locClientSendMsg()
+ function is successful, the client should expect an indication
+ (except start, stop, event reg and sensor injection messages),
+ through the registered callback in the locOpen() function. The
+ indication will contain the status of the request and if status is a
+ success, indication also contains the payload
+ associated with response.
+ @param [in] handle Handle returned by the locClientOpen()
+ function.
+ @param [in] reqId message ID of the request
+ @param [in] reqPayload Payload of the request, can be NULL
+ if request has no payload
+
+ @return
+ One of the following error codes:
+ - 0 (eLOC_CLIENT_SUCCESS ) - On success.
+ - non-zero error code (see locClientStatusEnumType) - On failure.
+*/
+
+locClientStatusEnumType locClientSendReq(
+ locClientHandleType handle,
+ uint32_t reqId,
+ locClientReqUnionType reqPayload )
+{
+ locClientStatusEnumType status = eLOC_CLIENT_SUCCESS;
+ qmi_client_error_type rc = QMI_NO_ERR; //No error
+ qmiLocGenRespMsgT_v02 resp;
+ uint32_t reqLen = 0;
+ void *pReqData = NULL;
+ locClientCallbackDataType *pCallbackData =
+ (locClientCallbackDataType *)handle;
+
+ // check the input handle for sanity
+ if(NULL == pCallbackData ||
+ NULL == pCallbackData->userHandle ||
+ pCallbackData != pCallbackData->pMe )
+ {
+ // did not find the handle in the client List
+ LOC_LOGE("%s:%d]: invalid handle \n",
+ __func__, __LINE__);
+
+ return(eLOC_CLIENT_FAILURE_INVALID_HANDLE);
+ }
+
+ // validate that the request is correct
+ if (validateRequest(reqId, reqPayload, &pReqData, &reqLen) == false)
+ {
+
+ LOC_LOGE("%s:%d] error invalid request\n", __func__,
+ __LINE__);
+
+ return(eLOC_CLIENT_FAILURE_INVALID_PARAMETER);
+ }
+
+ LOC_LOGV("%s:%d] sending reqId= %d, len = %d\n", __func__,
+ __LINE__, reqId, reqLen);
+
+ // NEXT call goes out to modem. We log the callflow before it
+ // actually happens to ensure the this comes before resp callflow
+ // back from the modem, to avoid confusing log order. We trust
+ // that the QMI framework is robust.
+ EXIT_LOG_CALLFLOW(%s, loc_get_v02_event_name(reqId));
+ rc = qmi_client_send_msg_sync(
+ pCallbackData->userHandle,
+ reqId,
+ pReqData,
+ reqLen,
+ &resp,
+ sizeof(resp),
+ LOC_CLIENT_ACK_TIMEOUT);
+
+ LOC_LOGV("%s:%d] qmi_client_send_msg_sync returned %d\n", __func__,
+ __LINE__, rc);
+
+ if (rc != QMI_NO_ERR)
+ {
+ LOC_LOGE("%s:%d]: send_msg_sync error: %d\n",__func__, __LINE__, rc);
+ return(eLOC_CLIENT_FAILURE_INTERNAL);
+ }
+
+ // map the QCCI response to Loc API v02 status
+ status = convertQmiResponseToLocStatus(&resp);
+
+ // if the request is to change registered events, update the
+ // loc api copy of that
+ if(eLOC_CLIENT_SUCCESS == status &&
+ QMI_LOC_REG_EVENTS_REQ_V02 == reqId)
+ {
+ if(NULL != reqPayload.pRegEventsReq )
+ {
+ pCallbackData->eventRegMask =
+ (locClientEventMaskType)(reqPayload.pRegEventsReq->eventRegMask);
+ }
+ }
+ return(status);
+}
+
+/** locClientGetSizeByRespIndId
+ * @brief Get the size of the response indication structure,
+ * from a specified id
+ * @param [in] respIndId
+ * @param [out] pRespIndSize
+ * @return true if resp ID was found; else false
+*/
+
+bool locClientGetSizeByRespIndId(uint32_t respIndId, size_t *pRespIndSize)
+{
+ size_t idx = 0, respIndTableSize = 0;
+ respIndTableSize = (sizeof(locClientRespIndTable)/sizeof(locClientRespIndTableStructT));
+ for(idx=0; idx<respIndTableSize; idx++ )
+ {
+ if(respIndId == locClientRespIndTable[idx].respIndId)
+ {
+ // found
+ *pRespIndSize = locClientRespIndTable[idx].respIndSize;
+
+ LOC_LOGV("%s:%d]: resp ind Id %d size = %d\n", __func__, __LINE__,
+ respIndId, (uint32_t)*pRespIndSize);
+ return true;
+ }
+ }
+
+ //not found
+ return false;
+}
+
+
+/** locClientGetSizeByEventIndId
+ * @brief Gets the size of the event indication structure, from
+ * a specified id
+ * @param [in] eventIndId
+ * @param [out] pEventIndSize
+ * @return true if event ID was found; else false
+*/
+bool locClientGetSizeByEventIndId(uint32_t eventIndId, size_t *pEventIndSize)
+{
+ size_t idx = 0, eventIndTableSize = 0;
+
+ // look in the event table
+ eventIndTableSize =
+ (sizeof(locClientEventIndTable)/sizeof(locClientEventIndTableStructT));
+
+ for(idx=0; idx<eventIndTableSize; idx++ )
+ {
+ if(eventIndId == locClientEventIndTable[idx].eventId)
+ {
+ // found
+ *pEventIndSize = locClientEventIndTable[idx].eventSize;
+
+ LOC_LOGV("%s:%d]: event ind Id %d size = %d\n", __func__, __LINE__,
+ eventIndId, (uint32_t)*pEventIndSize);
+ return true;
+ }
+ }
+ // not found
+ return false;
+}
diff --git a/loc_api/loc_api_v02/loc_api_v02_client.h b/loc_api/loc_api_v02/loc_api_v02_client.h
new file mode 100644
index 0000000..6181615
--- /dev/null
+++ b/loc_api/loc_api_v02/loc_api_v02_client.h
@@ -0,0 +1,1437 @@
+/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/** @file loc_api_v02_client.h
+*/
+
+#ifndef LOC_API_V02_CLIENT_H
+#define LOC_API_V02_CLIENT_H
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+
+/*=============================================================================
+ *
+ * DATA DECLARATION
+ *
+ *============================================================================*/
+#include <stdbool.h>
+#include <stdint.h>
+
+#include "location_service_v02.h" //QMI LOC Service data types definitions
+
+#include <stddef.h>
+
+/******************************************************************************
+ * Constants and configuration
+ *****************************************************************************/
+
+/** @ingroup constants_macros
+ Specific value of #locClientHandleType, indicating an invalid handle. */
+#define LOC_CLIENT_INVALID_HANDLE_VALUE (NULL)
+
+
+/** @addtogroup data_types
+@{ */
+
+/** Location client handle used to represent a specific client. Negative values
+ are invalid handles.
+*/
+typedef void* locClientHandleType;
+
+/** Data type for events and event masks. */
+typedef uint64_t locClientEventMaskType;
+
+/** Location client status values.
+*/
+typedef enum
+{
+ eLOC_CLIENT_SUCCESS = 0,
+ /**< Request was successful. */
+
+ eLOC_CLIENT_FAILURE_GENERAL = 1,
+ /**< Failed because of a general failure. */
+
+ eLOC_CLIENT_FAILURE_UNSUPPORTED = 2,
+ /**< Failed because the service does not support the command. */
+
+ eLOC_CLIENT_FAILURE_INVALID_PARAMETER = 3,
+ /**< Failed because the request contained invalid parameters. */
+
+ eLOC_CLIENT_FAILURE_ENGINE_BUSY = 4,
+ /**< Failed because the engine is busy. */
+
+ eLOC_CLIENT_FAILURE_PHONE_OFFLINE = 5,
+ /**< Failed because the phone is offline. */
+
+ eLOC_CLIENT_FAILURE_TIMEOUT = 6,
+ /**< Failed because of a timeout. */
+
+ eLOC_CLIENT_FAILURE_SERVICE_NOT_PRESENT = 7,
+ /**< Failed because the service is not present. */
+
+ eLOC_CLIENT_FAILURE_SERVICE_VERSION_UNSUPPORTED = 8,
+ /**< Failed because the service version is unsupported. */
+
+ eLOC_CLIENT_FAILURE_CLIENT_VERSION_UNSUPPORTED = 9,
+ /**< Failed because the service does not support client version. */
+
+ eLOC_CLIENT_FAILURE_INVALID_HANDLE = 10,
+ /**< Failed because an invalid handle was specified. */
+
+ eLOC_CLIENT_FAILURE_INTERNAL = 11,
+ /**< Failed because of an internal error in the service. */
+
+ eLOC_CLIENT_FAILURE_NOT_INITIALIZED = 12,
+ /**< Failed because the service has not been initialized. */
+
+ eLOC_CLIENT_FAILURE_NOT_ENOUGH_MEMORY = 13
+ /**< Failed because there is not enough memory to do the operation. */
+
+}locClientStatusEnumType;
+
+/** Location client error values
+*/
+typedef enum
+{
+ eLOC_CLIENT_ERROR_SERVICE_UNAVAILABLE = 1
+ /**< Service is no longer available. Upon getting this error, the client
+ must close the existing connection and reopen the connection. */
+
+}locClientErrorEnumType;
+
+
+/** Request messages the client can send to the location engine.
+
+ The following requests do not have any data associated, so they do not have a
+ payload structure defined:
+
+ - GetServiceRevision
+ - GetFixCriteria
+ - GetPredictedOrbitsDataSource
+ - GetPredictedOrbitsDataValidity
+ - GetEngineLock
+ - GetSbasConfigReq
+ - GetRegisteredEvents
+ - GetNmeaTypes
+ - GetLowPowerMode
+ - GetXtraTSessionControl
+ - GetRegisteredEvents
+ - GetOperationMode
+ - GetCradleMountConfig
+ - GetExternalPowerConfig
+ - GetSensorControlConfig
+ - GetSensorPerformanceControlConfiguration
+ - WWANOutOfServiceNotification
+*/
+typedef union
+{
+ const qmiLocInformClientRevisionReqMsgT_v02* pInformClientRevisionReq;
+ /**< Notifies the service about the revision the client is using.
+
+ The client does not receive any indications corresponding to this
+ request.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INFORM_CLIENT_REVISION_REQ_V02. */
+
+ const qmiLocRegEventsReqMsgT_v02* pRegEventsReq;
+ /**< Changes the events the client is interested in receiving.
+
+ The client does not receive any indications corresponding to this
+ request.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_REG_EVENTS_REQ_V02. */
+
+ const qmiLocStartReqMsgT_v02* pStartReq;
+ /**< Starts a positioning session.
+
+ The client receives the following indications: position report,
+ satellite report, fix session report, and NMEA report (if applicable).
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_START_REQ_V02. */
+
+ const qmiLocStopReqMsgT_v02* pStopReq;
+ /**< Stops a positioning session. The client receives a fix session report
+ denoting that the fix session ended after this message was sent.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_STOP_REQ_V02. */
+
+ const qmiLocNiUserRespReqMsgT_v02* pNiUserRespReq;
+ /**< Informs the service about the user response for a network-initiated call.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_NI_USER_RESPONSE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_NI_USER_RESPONSE_REQ_V02. */
+
+ const qmiLocInjectPredictedOrbitsDataReqMsgT_v02* pInjectPredictedOrbitsDataReq;
+ /**< Injects the predicted orbits data into the service.
+
+ When all predicted orbits data parts have been injected, the client
+ receives the following indication containing a response:
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02.
+
+ The client injects successive data parts without waiting for this
+ indication as long as locClientSendReq() returns successfully.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02. */
+
+ const qmiLocInjectUtcTimeReqMsgT_v02* pInjectUtcTimeReq;
+ /**< Injects UTC time into the service.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_UTC_TIME_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_UTC_TIME_REQ_V02. */
+
+ const qmiLocInjectPositionReqMsgT_v02* pInjectPositionReq;
+ /**< Injects a position into the service.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_POSITION_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_POSITION_REQ_V02. */
+
+ const qmiLocSetEngineLockReqMsgT_v02* pSetEngineLockReq;
+ /**< Sets the location engine lock.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_ENGINE_LOCK_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_ENGINE_LOCK_REQ_V02. */
+
+ const qmiLocSetSbasConfigReqMsgT_v02* pSetSbasConfigReq;
+ /**< Sets the SBAS configuration.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_SBAS_CONFIG_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_SBAS_CONFIG_REQ_V02 . */
+
+ const qmiLocSetNmeaTypesReqMsgT_v02* pSetNmeaTypesReq;
+ /**< Sets the NMEA types configuration.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_NMEA_TYPES_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_NMEA_TYPES_REQ_V02. */
+
+ const qmiLocSetLowPowerModeReqMsgT_v02* pSetLowPowerModeReq;
+ /**< Sets the Low Power mode configuration.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_LOW_POWER_MODE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_LOW_POWER_MODE_REQ_V02. */
+
+ const qmiLocSetServerReqMsgT_v02* pSetServerReq;
+ /**< Sets the A-GPS server type and address.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_SERVER_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_SERVER_REQ_V02. */
+
+ const qmiLocGetServerReqMsgT_v02* pGetServerReq;
+ /**< Gets the A-GPS server type and address.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_GET_SERVER_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_GET_SERVER_REQ_V02. */
+
+ const qmiLocDeleteAssistDataReqMsgT_v02* pDeleteAssistDataReq;
+ /**< Deletes the aiding data from the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_DELETE_ASSIST_DATA_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_DELETE_ASSIST_DATA_REQ_V02. */
+
+ const qmiLocSetXtraTSessionControlReqMsgT_v02* pSetXtraTSessionControlReq;
+ /**< Sets XTRA-T session control in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_XTRA_T_SESSION_CONTROL_REQ_V02. */
+
+ const qmiLocInjectWifiPositionReqMsgT_v02* pInjectWifiPositionReq;
+ /**< Injects a WiFi position into the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_WIFI_POSITION_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_WIFI_POSITION_REQ_V02. */
+
+ const qmiLocNotifyWifiStatusReqMsgT_v02* pNotifyWifiStatusReq;
+ /**< Notifies the engine about the WiFi status.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_NOTIFY_WIFI_STATUS_REQ_V02. */
+
+ const qmiLocSetOperationModeReqMsgT_v02* pSetOperationModeReq;
+ /**< Sets the engine Operation mode.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_OPERATION_MODE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_OPERATION_MODE_REQ_V02. */
+
+ const qmiLocSetSpiStatusReqMsgT_v02* pSetSpiStatusReq;
+ /**< Sends the stationary position status to the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_SPI_STATUS_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_SPI_STATUS_REQ_V02. */
+
+ const qmiLocInjectSensorDataReqMsgT_v02* pInjectSensorDataReq;
+ /**< Injects sensor data into the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_SENSOR_DATA_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_SENSOR_DATA_REQ_V02. */
+
+ const qmiLocInjectTimeSyncDataReqMsgT_v02* pInjectTimeSyncReq;
+ /**< Injects time synchronization information into the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_TIME_SYNC_DATA_REQ_V02. */
+
+ const qmiLocSetCradleMountConfigReqMsgT_v02* pSetCradleMountConfigReq;
+ /**< Sets the cradle mount state information in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ SET_CRADLE_MOUNT_CONFIG_REQ_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ SET_CRADLE_MOUNT_CONFIG_IND_V02. */
+
+ const qmiLocSetExternalPowerConfigReqMsgT_v02* pSetExternalPowerConfigReq;
+ /**< Sets external power configuration state in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02. */
+
+ const qmiLocInformLocationServerConnStatusReqMsgT_v02*
+ pInformLocationServerConnStatusReq;
+ /**< Informs the engine about the connection status to the location server.
+
+ This can be sent in response to a
+ QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02 request. The
+ service sends back a QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02
+ response indication for this request.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02. */
+
+ const qmiLocSetProtocolConfigParametersReqMsgT_v02*
+ pSetProtocolConfigParametersReq;
+ /**< Sets the protocol configuration parameters in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02. */
+
+ const qmiLocGetProtocolConfigParametersReqMsgT_v02*
+ pGetProtocolConfigParametersReq;
+ /**< Retrieves protocol configuration parameters from the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02. */
+
+ const qmiLocSetSensorControlConfigReqMsgT_v02*
+ pSetSensorControlConfigReq;
+ /**< Sets the sensor control configuration parameters in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02. */
+
+ const qmiLocSetSensorPerformanceControlConfigReqMsgT_v02*
+ pSetSensorPerformanceControlConfigReq;
+ /**< Sets the sensor performance configuration parameters in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02. */
+
+ const qmiLocGetSensorPropertiesReqMsgT_v02* pGetSensorPropertiesReq;
+ /**< Retrieves the sensor properties from the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_GET_SENSOR_PROPERTIES_REQ_V02. */
+
+ const qmiLocSetSensorPropertiesReqMsgT_v02* pSetSensorPropertiesReq;
+ /**< Sets the sensor properties in the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02. */
+
+ const qmiLocInjectSuplCertificateReqMsgT_v02* pInjectSuplCertificateReq;
+ /**< Injects a SUPL certificate into the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_SUPL_CERTIFICATE_REQ_V02. */
+
+ const qmiLocDeleteSuplCertificateReqMsgT_v02* pDeleteSuplCertificateReq;
+ /**< Deletes a SUPL certificate from the engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_DELETE_SUPL_CERTIFICATE_REQ_V02. */
+
+ const qmiLocSetPositionEngineConfigParametersReqMsgT_v02*
+ pSetPositionEngineConfigParametersReq;
+ /**< Sets position engine configuration.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND _V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02. */
+
+ const qmiLocGetPositionEngineConfigParametersReqMsgT_v02*
+ pGetPositionEngineConfigParametersReq;
+ /**< Gets position engine configuration.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02. */
+
+ const qmiLocAddCircularGeofenceReqMsgT_v02* pAddCircularGeofenceReq;
+ /**< Adds a circular geofence.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_ADD_CIRCULAR_GEOFENCE_REQ_V02 */
+
+ const qmiLocDeleteGeofenceReqMsgT_v02* pDeleteGeofenceReq;
+ /**< Deletes a geofence.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_DELETE_GEOFENCE_IND_V02.
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_DELETE_GEOFENCE_REQ_V02 */
+
+ const qmiLocQueryGeofenceReqMsgT_v02* pQueryGeofenceReq;
+ /**< Queries a geofence.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_QUERY_GEOFENCE_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_QUERY_GEOFENCE_REQ_V02. */
+
+ const qmiLocEditGeofenceReqMsgT_v02* pEditGeofenceReq;
+ /**< Edits geofence parameters.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_EDIT_GEOFENCE_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_EDIT_GEOFENCE_REQ_V02. */
+
+ const qmiLocGetBestAvailablePositionReqMsgT_v02*
+ pGetBestAvailablePositionReq;
+ /**< Get the best available position from location engine
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_GET_BEST_AVAILABLE_POSITION_REQ_V02. @newpagetable */
+
+ const qmiLocInjectMotionDataReqMsgT_v02* pInjectMotionDataReq;
+ /**< Inject motion data in the location engine
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_MOTION_DATA_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_MOTION_DATA_REQ_V02 */
+
+ const qmiLocGetNiGeofenceIdListReqMsgT_v02* pGetNiGeofenceIdListReq;
+ /**< Get the list of Network Initiated Geofences from the location engine.
+
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_GET_NI_GEOFENCE_ID_LIST_REQ_V02 */
+
+ const qmiLocInjectGSMCellInfoReqMsgT_v02 *pInjectGSMCellInfoReq;
+ /**< Inject GSM Cell Information into the location engine.
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_GSM_CELL_INFO_REQ_V02 */
+
+ const qmiLocInjectNetworkInitiatedMessageReqMsgT_v02
+ *pInjectNetworkInitiatedMessageReq;
+ /**< Inject Network Initiated Message into the location engine.
+ If the request is accepted by the service, the client receives the
+ following indication containing a response:
+ QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_REQ_V02 */
+
+ const void *pWWANOutOfServiceNotificationReq;
+
+ const qmiLocPedometerReportReqMsgT_v02 *pPedometerReportReq;
+ /**< Send pedometer data to the location engine. If the request is
+ accepted by the service, the client receives the following
+ indication containing a response:
+ QMI_LOC_PEDOMETER_REPORT_IND_V02
+
+ To send this request, set the reqId field in locClientSendReq() to
+ QMI_LOC_PEDOMETER_REPORT_REQ_V02 */
+
+ const qmiLocInjectWCDMACellInfoReqMsgT_v02 *pInjectWCDMACellInfoReq;
+ const qmiLocInjectTDSCDMACellInfoReqMsgT_v02 *pInjectTDSCDMACellInfoReq;
+ const qmiLocInjectSubscriberIDReqMsgT_v02 *pInjectSubscriberIDReq;
+
+}locClientReqUnionType;
+
+
+/** Event indications that are sent by the service.
+*/
+typedef union
+{
+ const qmiLocEventPositionReportIndMsgT_v02* pPositionReportEvent;
+ /**< Contains the position information.
+
+ This event is generated after QMI_LOC_START_REQ_V02 is sent. If
+ periodic fix criteria is specified, this event is generated multiple
+ times periodically at the specified rate until QMI_LOC_STOP_REQ_V02 is
+ sent.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_POSITION_REPORT_IND_V02. */
+
+ const qmiLocEventGnssSvInfoIndMsgT_v02* pGnssSvInfoReportEvent;
+ /**< Contains the GNSS satellite information.
+
+ This event is generated after QMI_LOC_START_REQ_V02 is sent. This event
+ is generated at 1 Hz if the location engine is tracking satellites to
+ make a location fix.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_GNSS_INFO_IND_V02. */
+
+ const qmiLocEventNmeaIndMsgT_v02* pNmeaReportEvent;
+ /**< Contains an NMEA report sentence.
+
+ The entire NMEA report consisting of multiple sentences is sent at a
+ 1 Hz rate. This event is generated after QMI_LOC_START_REQ_V02 is sent.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_NMEA_IND_V02. */
+
+ const qmiLocEventNiNotifyVerifyReqIndMsgT_v02* pNiNotifyVerifyReqEvent;
+ /**< Notifies a location client when the network triggers a positioning
+ request to the mobile.
+
+ Upon getting this event, the location client displays the
+ network-initiated fix request in a dialog and prompts the user to
+ accept or deny the request. The client responds to this request with
+ the message QMI_LOC_NI_USER_RESPONSE_REQ_V02.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02. */
+
+ const qmiLocEventInjectTimeReqIndMsgT_v02* pInjectTimeReqEvent;
+ /**< Asks the client for time assistance.
+
+ The client responds to this request with the message
+ QMI_LOC_INJECT_UTC_TIME_REQ_V02.
+
+ The eventIndId field in the event indication callback is
+ set to QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02. */
+
+ const qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02*
+ pInjectPredictedOrbitsReqEvent;
+ /**< Asks the client for predicted orbits data assistance.
+
+ The client responds to this request with the message
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02. */
+
+ const qmiLocEventInjectPositionReqIndMsgT_v02* pInjectPositionReqEvent;
+ /**< Asks the client for position assistance.
+
+ The client responds to this request with the message
+ QMI_LOC_INJECT_POSITION_REQ_V02.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02. */
+
+ const qmiLocEventEngineStateIndMsgT_v02* pEngineState;
+ /**< Sent by the engine whenever it turns on or off.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_ENGINE_STATE_IND_V02. */
+
+ const qmiLocEventFixSessionStateIndMsgT_v02* pFixSessionState;
+ /**< Sent by the engine when a location session begins or ends.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02. */
+
+ const qmiLocEventWifiReqIndMsgT_v02* pWifiReqEvent;
+ /**< Sent by the engine when it needs WiFi support.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_WIFI_REQ_IND_V02. */
+
+ const qmiLocEventSensorStreamingReadyStatusIndMsgT_v02*
+ pSensorStreamingReadyStatusEvent;
+ /**< Notifies the client that the engine is ready to accept sensor data.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_SENSOR_STREAMING_READY_STATUS_IND_V02. */
+
+ const qmiLocEventTimeSyncReqIndMsgT_v02* pTimeSyncReqEvent;
+ /**< Sent by the engine when it needs to synchronize its time with the sensor
+ processor time.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_TIME_SYNC_REQ_IND_V02. */
+
+ const qmiLocEventSetSpiStreamingReportIndMsgT_v02*
+ pSetSpiStreamingReportEvent;
+ /**< Asks the client to start/stop sending a Stationary Position Indicator
+ (SPI) stream.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_SET_SPI_STREAMING_REPORT_IND_V02. */
+
+ const qmiLocEventLocationServerConnectionReqIndMsgT_v02*
+ pLocationServerConnReqEvent;
+ /**< Sent by the engine to ask the client to open or close a connection to
+ a location server.
+
+ The client responds to this request by sending the
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02 message.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02. */
+
+ const qmiLocEventNiGeofenceNotificationIndMsgT_v02*
+ pNiGeofenceNotificationEvent;
+ /**< Sent by the engine to notify the client about changes to a
+ network-initiated geofence.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_NI_GEOFENCE_NOTIFICATION_IND_V02. */
+
+ const qmiLocEventGeofenceGenAlertIndMsgT_v02* pGeofenceGenAlertEvent;
+ /**< Sent by the engine to notify the client about updates that may
+ affect a geofence operation.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_GEOFENCE_GEN_ALERT_IND_V02. */
+
+ const qmiLocEventGeofenceBreachIndMsgT_v02* pGeofenceBreachEvent;
+ /**< Sent by the engine to notify the client about a geofence breach
+ event.
+
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_GEOFENCE_BREACH_NOTIFICATION_IND_V02. @newpagetable */
+
+ const qmiLocEventPedometerControlIndMsgT_v02* pPedometerControlEvent;
+ /**< Sent by the engine to recommend how pedometer data is sent to the
+ location engine.
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_PEDOMETER_CONTROL_IND_V02. @newpagetable */
+
+ const qmiLocEventMotionDataControlIndMsgT_v02* pMotionDataControlEvent;
+ /**< Sent by the engine to recommend how motion data is sent to the
+ location engine.
+ The eventIndId field in the event indication callback is set to
+ QMI_LOC_EVENT_MOTION_DATA_CONTROL_IND_V02. @newpagetable */
+
+}locClientEventIndUnionType;
+
+
+/** Response indications that are sent by the service.
+*/
+typedef union
+{
+ const qmiLocGetServiceRevisionIndMsgT_v02* pGetServiceRevisionInd;
+ /**< Response to the QMI_LOC_GET_SERVICE_REVISION_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_SERVICE_REVISION_IND_V02. */
+
+ const qmiLocGetFixCriteriaIndMsgT_v02* pGetFixCriteriaInd;
+ /**< Response to the QMI_LOC_GET_FIX_CRITERIA_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_FIX_CRITERIA_IND_V02. */
+
+ const qmiLocNiUserRespIndMsgT_v02* pNiUserRespInd;
+ /**< Response to the QMI_LOC_NI_USER_RESPONSE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_NI_USER_RESPONSE_IND_V02. */
+
+ const qmiLocInjectPredictedOrbitsDataIndMsgT_v02*
+ pInjectPredictedOrbitsDataInd;
+ /**< Sent after a predicted orbits data part has been successfully injected.
+
+ The client waits for this indication before injecting the next part.
+ This indication is sent in response to
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02. */
+
+ const qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02*
+ pGetPredictedOrbitsDataSourceInd;
+ /**< Response to the QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_REQ_V02
+ request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_IND_V02. */
+
+ const qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02*
+ pGetPredictedOrbitsDataValidityInd;
+ /**< Response to the QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_REQ_V02
+ request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_IND_V02. */
+
+ const qmiLocInjectUtcTimeIndMsgT_v02* pInjectUtcTimeInd;
+ /**< Response to the QMI_LOC_INJECT_UTC_TIME_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_UTC_TIME_IND_V02. */
+
+ const qmiLocInjectPositionIndMsgT_v02* pInjectPositionInd;
+ /**< Response to the QMI_LOC_INJECT_POSITION_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_POSITION_IND_V02. */
+
+ const qmiLocSetEngineLockIndMsgT_v02* pSetEngineLockInd;
+ /**< Response to the QMI_LOC_SET_ENGINE_LOCK_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_ENGINE_LOCK_IND_V02. */
+
+ const qmiLocGetEngineLockIndMsgT_v02* pGetEngineLockInd;
+ /**< Response to the QMI_LOC_GET_ENGINE_LOCK_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_ENGINE_LOCK_IND_V02. */
+
+ const qmiLocSetSbasConfigIndMsgT_v02* pSetSbasConfigInd;
+ /**< Response to the QMI_LOC_SET_SBAS_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_SBAS_CONFIG_IND_V02. */
+
+ const qmiLocGetSbasConfigIndMsgT_v02* pGetSbasConfigInd;
+ /**< Response to the QMI_LOC_GET_SBAS_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_SBAS_CONFIG_IND_V02. */
+
+ const qmiLocSetNmeaTypesIndMsgT_v02* pSetNmeaTypesInd;
+ /**< Response to the QMI_LOC_SET_NMEA_TYPES_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_NMEA_TYPES_IND_V02. */
+
+ const qmiLocGetNmeaTypesIndMsgT_v02* pGetNmeaTypesInd;
+ /**< Response to the QMI_LOC_GET_NMEA_TYPES_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_NMEA_TYPES_IND_V02. */
+
+ const qmiLocSetLowPowerModeIndMsgT_v02* pSetLowPowerModeInd;
+ /**< Response to the QMI_LOC_SET_LOW_POWER_MODE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_LOW_POWER_MODE_IND_V02. */
+
+ const qmiLocGetLowPowerModeIndMsgT_v02* pGetLowPowerModeInd;
+ /**< Response to the QMI_LOC_GET_LOW_POWER_MODE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_LOW_POWER_MODE_IND_V02. */
+
+ const qmiLocSetServerIndMsgT_v02* pSetServerInd;
+ /**< Response to the QMI_LOC_SET_SERVER_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_SERVER_IND_V02. */
+
+ const qmiLocGetServerIndMsgT_v02* pGetServerInd;
+ /**< Response to the QMI_LOC_GET_SERVER_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_SERVER_IND_V02. */
+
+ const qmiLocDeleteAssistDataIndMsgT_v02* pDeleteAssistDataInd;
+ /**< Response to the QMI_LOC_DELETE_ASSIST_DATA_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_DELETE_ASSIST_DATA_IND_V02. */
+
+ const qmiLocSetXtraTSessionControlIndMsgT_v02* pSetXtraTSessionControlInd;
+ /**< Response to the QMI_LOC_SET_XTRA_T_SESSION_CONTROL_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02. */
+
+ const qmiLocGetXtraTSessionControlIndMsgT_v02* pGetXtraTSessionControlInd;
+ /**< Response to the QMI_LOC_GET_XTRA_T_SESSION_CONTROL_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_XTRA_T_SESSION_CONTROL_IND_V02. */
+
+ const qmiLocInjectWifiPositionIndMsgT_v02* pInjectWifiPositionInd;
+ /**< Response to the QMI_LOC_INJECT_WIFI_POSITION_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_WIFI_POSITION_IND_V02. */
+
+ const qmiLocNotifyWifiStatusIndMsgT_v02* pNotifyWifiStatusInd;
+ /**< Response to the QMI_LOC_NOTIFY_WIFI_STATUS_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02. */
+
+ const qmiLocGetRegisteredEventsIndMsgT_v02* pGetRegisteredEventsInd;
+ /**< Response to the QMI_LOC_GET_REGISTERED_EVENTS_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_REGISTERED_EVENTS_IND_V02. */
+
+ const qmiLocSetOperationModeIndMsgT_v02* pSetOperationModeInd;
+ /**< Response to the QMI_LOC_SET_OPERATION_MODE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_OPERATION_MODE_IND_V02. */
+
+ const qmiLocGetOperationModeIndMsgT_v02* pGetOperationModeInd;
+ /**< Response to the QMI_LOC_GET_OPERATION_MODE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_OPERATION_MODE_IND_V02. */
+
+ const qmiLocSetSpiStatusIndMsgT_v02* pSetSpiStatusInd;
+ /**< Response to the QMI_LOC_SET_SPI_STATUS_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_SPI_STATUS_IND_V02. */
+
+ const qmiLocInjectSensorDataIndMsgT_v02* pInjectSensorDataInd;
+ /**< Response to the QMI_LOC_INJECT_SENSOR_DATA_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_SENSOR_DATA_IND_V02. */
+
+ const qmiLocInjectTimeSyncDataIndMsgT_v02* pInjectTimeSyncDataInd;
+ /**< Response to the QMI_LOC_INJECT_TIME_SYNC_DATA_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02. */
+
+ const qmiLocSetCradleMountConfigIndMsgT_v02* pSetCradleMountConfigInd;
+ /**< Response to the QMI_LOC_SET_CRADLE_MOUNT_CONFIG_IND_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_CRADLE_MOUNT_CONFIG_REQ_V02. */
+
+ const qmiLocGetCradleMountConfigIndMsgT_v02* pGetCradleMountConfigInd;
+ /**< Response to the QMI_LOC_GET_CRADLE_MOUNT_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_CRADLE_MOUNT_CONFIG_IND_V02. */
+
+ const qmiLocSetExternalPowerConfigIndMsgT_v02* pSetExternalPowerConfigInd;
+ /**< Response to the QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02. */
+
+ const qmiLocGetExternalPowerConfigIndMsgT_v02* pGetExternalPowerConfigInd;
+ /**< Response to the QMI_LOC_GET_EXTERNAL_POWER_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_EXTERNAL_POWER_CONFIG_IND_V02. */
+
+ const qmiLocInformLocationServerConnStatusIndMsgT_v02*
+ pInformLocationServerConnStatusInd;
+ /**< Response to the QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02
+ request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02.*/
+
+ const qmiLocSetProtocolConfigParametersIndMsgT_v02*
+ pSetProtocolConfigParametersInd;
+ /**< Response to the QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02. */
+
+ const qmiLocGetProtocolConfigParametersIndMsgT_v02*
+ pGetProtocolConfigParametersInd;
+ /**< Response to the QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02. */
+
+ const qmiLocSetSensorControlConfigIndMsgT_v02* pSetSensorControlConfigInd;
+ /**< Response to the QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02.
+ */
+
+ const qmiLocGetSensorControlConfigIndMsgT_v02* pGetSensorControlConfigInd;
+ /**< Response to the QMI_LOC_GET_SENSOR_CONTROL_CONFIG_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_SENSOR_CONTROL_CONFIG_IND_V02.
+ */
+
+ const qmiLocSetSensorPropertiesIndMsgT_v02* pSetSensorPropertiesInd;
+ /**< Response to the QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02.
+ */
+
+ const qmiLocGetSensorPropertiesIndMsgT_v02* pGetSensorPropertiesInd;
+ /**< Response to the QMI_LOC_GET_SENSOR_PROPERTIES_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02.
+ */
+
+ const qmiLocSetSensorPerformanceControlConfigIndMsgT_v02*
+ pSetSensorPerformanceControlConfigInd;
+ /**< Response to the
+ QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02. */
+
+ const qmiLocGetSensorPerformanceControlConfigIndMsgT_v02*
+ pGetSensorPerformanceControlConfigInd;
+ /**< Response to the
+ QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02. */
+
+ const qmiLocInjectSuplCertificateIndMsgT_v02* pInjectSuplCertificateInd;
+ /**< Response to the QMI_LOC_INJECT_SUPL_CERTIFICATE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02. */
+
+ const qmiLocDeleteSuplCertificateIndMsgT_v02* pDeleteSuplCertificateInd;
+ /**< Response to the QMI_LOC_DELETE_SUPL_CERTIFICATE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02. */
+
+ const qmiLocSetPositionEngineConfigParametersIndMsgT_v02*
+ pSetPositionEngineConfigParametersInd;
+ /**< Response to the QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02
+ request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02. */
+
+ const qmiLocGetPositionEngineConfigParametersIndMsgT_v02*
+ pGetPositionEngineConfigParametersInd;
+ /**< Response to the QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02
+ request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02. */
+
+ const qmiLocAddCircularGeofenceIndMsgT_v02* pAddCircularGeofenceInd;
+ /**< Response to the QMI_LOC_ADD_CIRCULAR_GEOFENCE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02. */
+
+ const qmiLocDeleteGeofenceIndMsgT_v02* pDeleteGeofenceInd;
+ /**< Response to the QMI_LOC_DELETE_GEOFENCE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_DELETE_GEOFENCE_IND_V02. */
+
+ const qmiLocQueryGeofenceIndMsgT_v02* pQueryGeofenceInd;
+ /**< Response to the QMI_LOC_QUERY_GEOFENCE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_QUERY_GEOFENCE_IND_V02. */
+
+ const qmiLocEditGeofenceIndMsgT_v02* pEditGeofenceInd;
+ /**< Response to the QMI_LOC_EDIT_GEOFENCE_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_EDIT_GEOFENCE_IND_V02. */
+
+ const qmiLocGetBestAvailablePositionIndMsgT_v02*
+ pGetBestAvailablePositionInd;
+ /**< Response to the QMI_LOC_GET_BEST_AVAILABLE_POSITION_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02. */
+
+ const qmiLocInjectMotionDataIndMsgT_v02* pInjectMotionDataInd;
+ /**< Response to the QMI_LOC_INJECT_MOTION_DATA_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_MOTION_DATA_IND_V02. */
+
+ const qmiLocGetNiGeofenceIdListIndMsgT_v02* pGetNiGeofenceIdListInd;
+ /**< Response to the QMI_LOC_GET_NI_GEOFENCE_ID_LIST_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02. */
+
+ const qmiLocInjectGSMCellInfoIndMsgT_v02* pInjectGSMCellInfoInd;
+ /**< Response to the QMI_LOC_INJECT_GSM_CELL_INFO_REQ_V02 request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02. */
+
+ const qmiLocInjectNetworkInitiatedMessageIndMsgT_v02*
+ pInjectNetworkInitiatedMessageInd;
+
+ /**< Response to the QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_REQ_V02
+ request.
+
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02. */
+
+ const qmiLocWWANOutOfServiceNotificationIndMsgT_v02*
+ pWWANOutOfServiceNotificationInd;
+
+ /**< Response to the QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_REQ_V02
+ request.
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_IND_V02. */
+
+ const qmiLocPedometerReportIndMsgT_v02* pPedometerReportInd;
+
+ /**< Response to the QMI_LOC_PEDOMETER_REPORT_REQ_V02 request.
+ The respIndId field in the response indication callback is set to
+ QMI_LOC_PEDOMETER_REPORT_IND_V02. */
+
+ const qmiLocInjectWCDMACellInfoIndMsgT_v02 *pInjectWCDMACellInfoInd;
+ const qmiLocInjectTDSCDMACellInfoIndMsgT_v02 *pInjectTDSCDMACellInfoInd;
+ const qmiLocInjectSubscriberIDIndMsgT_v02 *pInjectSubscriberIDInd;
+
+}locClientRespIndUnionType;
+
+/** @} */ /* end_addtogroup data_types */
+
+/** @addtogroup callback_functions
+@{ */
+/**
+ Location event indication callback function type. The Location service can
+ generate two types of indications:
+
+ - Asynchronous events indications, such as time injection request and satellite
+ reports. The client specifies the asynchronous events it is interested in
+ receiving through the event mask (see locClientOpen()).
+ - Response indications that are generated as a response to a request. For
+ example, the QMI_LOC_GET_FIX_CRITERIA_REQ_V02 request generates the
+ indication, QMI_LOC_GET_FIX_CRITERIA_IND_V02.
+
+ This callback handles the asynchronous event indications.
+
+ @datatypes
+ #locClientHandleType \n
+ #locClientEventIndUnionType
+
+ @param handle Location client for this event. Only the client who
+ registered for the corresponding event receives
+ this callback.
+ @param eventIndId ID of the event indication.
+ @param eventIndPayload Event indication payload.
+ @param pClientCookie Pointer to the cookie the client specified during
+ registration.
+
+ @return
+ None.
+
+ @dependencies
+ None. @newpage
+*/
+typedef void (*locClientEventIndCbType)(
+ locClientHandleType handle,
+ uint32_t eventIndId,
+ const locClientEventIndUnionType eventIndPayload,
+ void *pClientCookie
+);
+
+/**
+ Location response indication callback function type. The Location service can
+ generate two types of indications:
+
+ - Asynchronous events indications, such as time injection request and satellite
+ reports. The client specifies the asynchronous events it is interested in
+ receiving through the event mask (see locClientOpen()).
+ - Response indications that are generated as a response to a request. For
+ example, the QMI_LOC_GET_FIX_CRITERIA_REQ_V02 request generates the
+ indication, QMI_LOC_GET_FIX_CRITERIA_IND_V02.
+
+ This callback handles the response indications.
+
+ @datatypes
+ #locClientHandleType \n
+ #locClientRespIndUnionType
+
+ @param handle Location client who sent the request for which this
+ response indication is generated.
+ @param respIndId ID of the response. It is the same value as the ID
+ of request sent to the engine.
+ @param respIndPayload Payload of the response indication.
+ @param pClientCookie Pointer to the cookie the client specified during
+ registration.
+
+ @return
+ None.
+
+ @dependencies
+ None. @newpage
+*/
+typedef void (*locClientRespIndCbType)(
+ locClientHandleType handle,
+ uint32_t respIndId,
+ const locClientRespIndUnionType respIndPayload,
+ void *pClientCookie
+);
+
+/**
+ Location error callback function type. This function is called to inform
+ the client that the service is no longer available. When the client
+ receives this callback, it must close the existing connection and reopen
+ the client connection.
+
+ @datatypes
+ #locClientHandleType \n
+ #locClientErrorEnumType
+
+ @param handle Location client who sent the request for which this
+ error indication is generated.
+ @param errorId Error ID.
+ @param pClientCookie Payload associated with the error indication.
+
+ @return
+ None.
+
+ @dependencies
+ None.
+*/
+typedef void (*locClientErrorCbType)(
+ locClientHandleType handle,
+ locClientErrorEnumType errorId,
+ void* pClientCookie
+ );
+/** @} */ /* end_addtogroup callback_functions */
+
+
+/** @ingroup data_types
+ Callback functions to be registered during locClientOpen().
+*/
+typedef struct
+{
+ uint32_t size; /**< Size of the structure. */
+ locClientEventIndCbType eventIndCb; /**< Event indication callback. */
+ locClientRespIndCbType respIndCb; /**< Response indication callback. */
+ locClientErrorCbType errorCb; /**< Error indication callback.
+ @newpagetable */
+}locClientCallbacksType;
+
+
+/*===========================================================================
+ *
+ * FUNCTION DECLARATION
+ *
+ *==========================================================================*/
+/** @addtogroup operation_functions
+@{ */
+/*==========================================================================
+ locClientOpen */
+/** @xreflabel{hdr:locClientOpenFunction}
+ Connects a location client to the location engine. If the connection is
+ successful, this function returns a handle that the location client uses for
+ future location operations.
+
+ @datatypes
+ #locClientStatusEnumType \n
+ #locClientEventMaskType \n
+ #locClientCallbacksType \n
+ #locClientHandleType
+
+ @param[in] eventRegMask Mask of asynchronous events the client is
+ interested in receiving.
+ @param[in] pLocClientCallbacks Pointer to structure containing the
+ callbacks.
+ @param[out] pLocClientHandle Pointer to the handle to be used by the
+ client for any subsequent requests.
+ @param[in] pLocClientCookie Pointer to a cookie to be returned to the
+ client along with the callbacks.
+
+ @return
+ One of the following error codes:
+ - eLOC_CLIENT_SUCCESS -- If the connection is opened.
+ - Non-zero error code (see #locClientStatusEnumType) -- On failure.
+
+ @dependencies
+ None. @newpage
+*/
+extern locClientStatusEnumType locClientOpen (
+ locClientEventMaskType eventRegMask,
+ const locClientCallbacksType* pLocClientCallbacks,
+ locClientHandleType* pLocClientHandle,
+ const void* pLocClientCookie
+);
+
+
+/*==========================================================================
+ locClientClose */
+/** @xreflabel{hdr:locClientCloseFunction}
+ Disconnects a client from the location engine and sets the handle to
+ LOC_CLIENT_INVALID_HANDLE_VALUE.
+
+ @datatypes
+ #locClientStatusEnumType \n
+ #locClientHandleType
+
+ @param[in] pLocClientHandle Pointer to the handle returned by the
+ locClientOpen() function.
+
+ @return
+ One of the following error codes:
+ - 0 (eLOC_CLIENT_SUCCESS) -- On success.
+ - Non-zero error code (see \ref locClientStatusEnumType) -- On failure.
+
+ @dependencies
+ None. @newpage
+*/
+extern locClientStatusEnumType locClientClose (
+ locClientHandleType* pLocClientHandle
+);
+
+/*=============================================================================
+ locClientSendReq */
+/** @xreflabel{hdr:locClientSendReqFunction}
+ Sends a message to the location engine. If this function is successful, the
+ client expects an indication (except start, stop, event registration, and
+ sensor injection messages) through the registered callback in the
+ locClientOpen() function.
+
+ The indication contains the status of the request. If the status is a success,
+ the indication also contains the payload associated with response.
+
+ @datatypes
+ #locClientStatusEnumType \n
+ #locClientHandleType \n
+ #locClientReqUnionType
+
+ @param[in] handle Handle returned by the locClientOpen() function.
+ @param[in] reqId QMI_LOC service message ID of the request.
+ @param[in] reqPayload Payload of the request. This can be NULL if the
+ request has no payload.
+
+ @return
+ One of the following error codes:
+ - 0 (eLOC_CLIENT_SUCCESS) -- On success.
+ - Non-zero error code (see \ref locClientStatusEnumType) -- On failure.
+
+ @dependencies
+ None. @newpage
+*/
+extern locClientStatusEnumType locClientSendReq(
+ locClientHandleType handle,
+ uint32_t reqId,
+ locClientReqUnionType reqPayload
+);
+
+
+/*=============================================================================
+ locClientGetSizeByEventIndId */
+/** Gets the size of the event indication structure from a specified ID.
+
+ @param[in] eventIndId Event indicator ID.
+ @param[out] pEventIndSize Pointer to the size of the structure.
+
+ @return
+ TRUE -- The event ID was found. \n
+ FALSE -- Otherwise.
+
+ @dependencies
+ None. @newpage
+*/
+extern bool locClientGetSizeByEventIndId(
+ uint32_t eventIndId,
+ size_t *pEventIndSize);
+
+
+/*=============================================================================
+ locClientGetSizeByRespIndId */
+/** Gets the size of the response indication structure from a specified ID.
+
+ @param[in] respIndId Response indicator ID.
+ @param[out] pRespIndSize Pointer to the size of the structure.
+
+ @return
+ TRUE -- The response ID was found. \n
+ FALSE -- Otherwise.
+
+ @dependencies
+ None.
+*/
+extern bool locClientGetSizeByRespIndId(
+ uint32_t respIndId,
+ size_t *pRespIndSize);
+
+/*=============================================================================*/
+/** @} */ /* end_addtogroup operation_functions */
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* LOC_API_V02_CLIENT_H*/
diff --git a/loc_api/loc_api_v02/loc_api_v02_log.c b/loc_api/loc_api_v02/loc_api_v02_log.c
new file mode 100644
index 0000000..bcae199
--- /dev/null
+++ b/loc_api/loc_api_v02/loc_api_v02_log.c
@@ -0,0 +1,295 @@
+/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+#include <loc_api_v02_log.h>
+#include <location_service_v02.h>
+
+static loc_name_val_s_type loc_v02_event_name[] =
+{
+ NAME_VAL(QMI_LOC_INFORM_CLIENT_REVISION_REQ_V02),
+ NAME_VAL(QMI_LOC_INFORM_CLIENT_REVISION_RESP_V02),
+ NAME_VAL(QMI_LOC_REG_EVENTS_REQ_V02),
+ NAME_VAL(QMI_LOC_REG_EVENTS_RESP_V02),
+ NAME_VAL(QMI_LOC_START_REQ_V02),
+ NAME_VAL(QMI_LOC_START_RESP_V02),
+ NAME_VAL(QMI_LOC_STOP_REQ_V02),
+ NAME_VAL(QMI_LOC_STOP_RESP_V02),
+ NAME_VAL(QMI_LOC_EVENT_POSITION_REPORT_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_GNSS_SV_INFO_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_NMEA_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_ENGINE_STATE_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_WIFI_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_SENSOR_STREAMING_READY_STATUS_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_TIME_SYNC_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_SET_SPI_STREAMING_REPORT_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SERVICE_REVISION_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SERVICE_REVISION_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SERVICE_REVISION_IND_V02),
+ NAME_VAL(QMI_LOC_GET_FIX_CRITERIA_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_FIX_CRITERIA_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_FIX_CRITERIA_IND_V02),
+ NAME_VAL(QMI_LOC_NI_USER_RESPONSE_REQ_V02),
+ NAME_VAL(QMI_LOC_NI_USER_RESPONSE_RESP_V02),
+ NAME_VAL(QMI_LOC_NI_USER_RESPONSE_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02),
+ NAME_VAL(QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_IND_V02),
+ NAME_VAL(QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_UTC_TIME_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_UTC_TIME_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_UTC_TIME_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_POSITION_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_POSITION_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_POSITION_IND_V02),
+ NAME_VAL(QMI_LOC_SET_ENGINE_LOCK_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_ENGINE_LOCK_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_ENGINE_LOCK_IND_V02),
+ NAME_VAL(QMI_LOC_GET_ENGINE_LOCK_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_ENGINE_LOCK_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_ENGINE_LOCK_IND_V02),
+ NAME_VAL(QMI_LOC_SET_SBAS_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_SBAS_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_SBAS_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SBAS_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SBAS_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SBAS_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_SET_NMEA_TYPES_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_NMEA_TYPES_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_NMEA_TYPES_IND_V02),
+ NAME_VAL(QMI_LOC_GET_NMEA_TYPES_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_NMEA_TYPES_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_NMEA_TYPES_IND_V02),
+ NAME_VAL(QMI_LOC_SET_LOW_POWER_MODE_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_LOW_POWER_MODE_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_LOW_POWER_MODE_IND_V02),
+ NAME_VAL(QMI_LOC_GET_LOW_POWER_MODE_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_LOW_POWER_MODE_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_LOW_POWER_MODE_IND_V02),
+ NAME_VAL(QMI_LOC_SET_SERVER_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_SERVER_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_SERVER_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SERVER_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SERVER_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SERVER_IND_V02),
+ NAME_VAL(QMI_LOC_DELETE_ASSIST_DATA_REQ_V02),
+ NAME_VAL(QMI_LOC_DELETE_ASSIST_DATA_RESP_V02),
+ NAME_VAL(QMI_LOC_DELETE_ASSIST_DATA_IND_V02),
+ NAME_VAL(QMI_LOC_SET_XTRA_T_SESSION_CONTROL_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_XTRA_T_SESSION_CONTROL_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02),
+ NAME_VAL(QMI_LOC_GET_XTRA_T_SESSION_CONTROL_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_XTRA_T_SESSION_CONTROL_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_XTRA_T_SESSION_CONTROL_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_WIFI_POSITION_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_WIFI_POSITION_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_WIFI_POSITION_IND_V02),
+ NAME_VAL(QMI_LOC_NOTIFY_WIFI_STATUS_REQ_V02),
+ NAME_VAL(QMI_LOC_NOTIFY_WIFI_STATUS_RESP_V02),
+ NAME_VAL(QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02),
+ NAME_VAL(QMI_LOC_GET_REGISTERED_EVENTS_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_REGISTERED_EVENTS_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_REGISTERED_EVENTS_IND_V02),
+ NAME_VAL(QMI_LOC_SET_OPERATION_MODE_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_OPERATION_MODE_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_OPERATION_MODE_IND_V02),
+ NAME_VAL(QMI_LOC_GET_OPERATION_MODE_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_OPERATION_MODE_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_OPERATION_MODE_IND_V02),
+ NAME_VAL(QMI_LOC_SET_SPI_STATUS_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_SPI_STATUS_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_SPI_STATUS_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_SENSOR_DATA_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_SENSOR_DATA_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_SENSOR_DATA_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_TIME_SYNC_DATA_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_TIME_SYNC_DATA_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02),
+ NAME_VAL(QMI_LOC_SET_CRADLE_MOUNT_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_CRADLE_MOUNT_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_CRADLE_MOUNT_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_GET_CRADLE_MOUNT_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_CRADLE_MOUNT_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_CRADLE_MOUNT_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_EXTERNAL_POWER_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_GET_EXTERNAL_POWER_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_EXTERNAL_POWER_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_EXTERNAL_POWER_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02),
+ NAME_VAL(QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_RESP_V02),
+ NAME_VAL(QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02),
+ NAME_VAL(QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02),
+ NAME_VAL(QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_CONTROL_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_CONTROL_CONFIG_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_CONTROL_CONFIG_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_CONTROL_CONFIG_IND_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_PROPERTIES_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_PROPERTIES_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_PROPERTIES_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_SUPL_CERTIFICATE_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_SUPL_CERTIFICATE_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02),
+ NAME_VAL(QMI_LOC_DELETE_SUPL_CERTIFICATE_REQ_V02),
+ NAME_VAL(QMI_LOC_DELETE_SUPL_CERTIFICATE_RESP_V02),
+ NAME_VAL(QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02),
+ NAME_VAL(QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02),
+ NAME_VAL(QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_RESP_V02),
+ NAME_VAL(QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02),
+ NAME_VAL(QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_NI_GEOFENCE_NOTIFICATION_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_GEOFENCE_GEN_ALERT_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_GEOFENCE_BREACH_NOTIFICATION_IND_V02),
+ NAME_VAL(QMI_LOC_ADD_CIRCULAR_GEOFENCE_REQ_V02),
+ NAME_VAL(QMI_LOC_ADD_CIRCULAR_GEOFENCE_RESP_V02),
+ NAME_VAL(QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02),
+ NAME_VAL(QMI_LOC_DELETE_GEOFENCE_REQ_V02),
+ NAME_VAL(QMI_LOC_DELETE_GEOFENCE_RESP_V02),
+ NAME_VAL(QMI_LOC_DELETE_GEOFENCE_IND_V02),
+ NAME_VAL(QMI_LOC_QUERY_GEOFENCE_REQ_V02),
+ NAME_VAL(QMI_LOC_QUERY_GEOFENCE_RESP_V02),
+ NAME_VAL(QMI_LOC_QUERY_GEOFENCE_IND_V02),
+ NAME_VAL(QMI_LOC_EDIT_GEOFENCE_REQ_V02),
+ NAME_VAL(QMI_LOC_EDIT_GEOFENCE_RESP_V02),
+ NAME_VAL(QMI_LOC_EDIT_GEOFENCE_IND_V02),
+ NAME_VAL(QMI_LOC_GET_BEST_AVAILABLE_POSITION_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_BEST_AVAILABLE_POSITION_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_MOTION_DATA_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_MOTION_DATA_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_MOTION_DATA_IND_V02),
+ NAME_VAL(QMI_LOC_GET_NI_GEOFENCE_ID_LIST_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_NI_GEOFENCE_ID_LIST_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_GSM_CELL_INFO_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_GSM_CELL_INFO_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02),
+ NAME_VAL(QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_REQ_V02),
+ NAME_VAL(QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_RESP_V02),
+ NAME_VAL(QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_PEDOMETER_CONTROL_IND_V02),
+ NAME_VAL(QMI_LOC_EVENT_MOTION_DATA_CONTROL_IND_V02),
+ NAME_VAL(QMI_LOC_PEDOMETER_REPORT_REQ_V02),
+ NAME_VAL(QMI_LOC_PEDOMETER_REPORT_RESP_V02),
+ NAME_VAL(QMI_LOC_PEDOMETER_REPORT_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_WCDMA_CELL_INFO_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_WCDMA_CELL_INFO_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_WCDMA_CELL_INFO_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_TDSCDMA_CELL_INFO_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_TDSCDMA_CELL_INFO_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_TDSCDMA_CELL_INFO_IND_V02),
+ NAME_VAL(QMI_LOC_INJECT_SUBSCRIBER_ID_REQ_V02),
+ NAME_VAL(QMI_LOC_INJECT_SUBSCRIBER_ID_RESP_V02),
+ NAME_VAL(QMI_LOC_INJECT_SUBSCRIBER_ID_IND_V02),
+ NAME_VAL(QMI_LOC_GET_SUPPORTED_MSGS_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SUPPORTED_MSGS_RESP_V02),
+ NAME_VAL(QMI_LOC_GET_SUPPORTED_FIELDS_REQ_V02),
+ NAME_VAL(QMI_LOC_GET_SUPPORTED_FIELDS_RESP_V02),
+};
+static int loc_v02_event_num = sizeof(loc_v02_event_name) / sizeof(loc_name_val_s_type);
+
+const char* loc_get_v02_event_name(uint32_t event)
+{
+ return loc_get_name_from_val(loc_v02_event_name, loc_v02_event_num, (long) event);
+}
+
+static loc_name_val_s_type loc_v02_client_status_name[] =
+{
+ NAME_VAL(eLOC_CLIENT_SUCCESS),
+ NAME_VAL(eLOC_CLIENT_FAILURE_GENERAL),
+ NAME_VAL(eLOC_CLIENT_FAILURE_UNSUPPORTED),
+ NAME_VAL(eLOC_CLIENT_FAILURE_INVALID_PARAMETER),
+ NAME_VAL(eLOC_CLIENT_FAILURE_ENGINE_BUSY),
+ NAME_VAL(eLOC_CLIENT_FAILURE_PHONE_OFFLINE),
+ NAME_VAL(eLOC_CLIENT_FAILURE_TIMEOUT),
+ NAME_VAL(eLOC_CLIENT_FAILURE_SERVICE_NOT_PRESENT),
+ NAME_VAL(eLOC_CLIENT_FAILURE_SERVICE_VERSION_UNSUPPORTED),
+ NAME_VAL(eLOC_CLIENT_FAILURE_CLIENT_VERSION_UNSUPPORTED),
+ NAME_VAL(eLOC_CLIENT_FAILURE_INVALID_HANDLE),
+ NAME_VAL(eLOC_CLIENT_FAILURE_INTERNAL),
+ NAME_VAL(eLOC_CLIENT_FAILURE_NOT_INITIALIZED),
+ NAME_VAL(eLOC_CLIENT_FAILURE_NOT_ENOUGH_MEMORY),
+};
+static int loc_v02_client_status_num = sizeof(loc_v02_client_status_name) / sizeof(loc_name_val_s_type);
+
+const char* loc_get_v02_client_status_name(locClientStatusEnumType status)
+{
+ return loc_get_name_from_val(loc_v02_client_status_name, loc_v02_client_status_num, (long) status);
+}
+
+
+static loc_name_val_s_type loc_v02_qmi_status_name[] =
+{
+ NAME_VAL(eQMI_LOC_SUCCESS_V02),
+ NAME_VAL(eQMI_LOC_GENERAL_FAILURE_V02),
+ NAME_VAL(eQMI_LOC_UNSUPPORTED_V02),
+ NAME_VAL(eQMI_LOC_INVALID_PARAMETER_V02),
+ NAME_VAL(eQMI_LOC_ENGINE_BUSY_V02),
+ NAME_VAL(eQMI_LOC_PHONE_OFFLINE_V02),
+ NAME_VAL(eQMI_LOC_TIMEOUT_V02),
+ NAME_VAL(eQMI_LOC_CONFIG_NOT_SUPPORTED_V02),
+ NAME_VAL(eQMI_LOC_INSUFFICIENT_MEMORY_V02),
+};
+static int loc_v02_qmi_status_num = sizeof(loc_v02_qmi_status_name) / sizeof(loc_name_val_s_type);
+
+const char* loc_get_v02_qmi_status_name(qmiLocStatusEnumT_v02 status)
+{
+ return loc_get_name_from_val(loc_v02_qmi_status_name, loc_v02_qmi_status_num, (long) status);
+}
diff --git a/loc_api/loc_api_v02/loc_util_log.h b/loc_api/loc_api_v02/loc_util_log.h
new file mode 100644
index 0000000..7f4e62d
--- /dev/null
+++ b/loc_api/loc_api_v02/loc_util_log.h
@@ -0,0 +1,75 @@
+/* Copyright (c) 2011-2012, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+#ifndef LOC_UTIL_LOG_H
+#define LOC_UTIL_LOG_H
+
+#if defined(_ANDROID_)
+#include "loc_api_v02_log.h"
+#include <log_util.h>
+
+#else // no _ANDROID_
+
+// common for QNX and Griffon
+
+//error logs
+#define LOC_LOGE(...) printf(__VA_ARGS__)
+//warning logs
+#define LOC_LOGW(...) printf(__VA_ARGS__)
+// debug logs
+#define LOC_LOGD(...) printf(__VA_ARGS__)
+//info logs
+#define LOC_LOGI(...) printf(__VA_ARGS__)
+//verbose logs
+#define LOC_LOGV(...) printf(__VA_ARGS__)
+
+#define MODEM_LOG_CALLFLOW(SPEC, VAL)
+#define EXIT_LOG_CALLFLOW(SPEC, VAL)
+
+#define loc_get_v02_event_name(X) #X
+#define loc_get_v02_client_status_name(X) #X
+
+#define loc_get_v02_qmi_status_name(X) #X
+
+//specific to OFF TARGET
+#ifdef LOC_UTIL_TARGET_OFF_TARGET
+
+#include <stdio.h>
+# include <asm/errno.h>
+# include <sys/time.h>
+
+// get around strl*: not found in glibc
+// TBD:look for presence of eglibc other libraries
+// with strlcpy supported.
+#define strlcpy(X,Y,Z) strcpy(X,Y)
+#define strlcat(X,Y,Z) strcat(X,Y)
+
+#endif //LOC_UTIL_TARGET_OFF_TARGET
+
+#endif //_ANDROID_
+
+#endif //LOC_UTIL_LOG_H
diff --git a/loc_api/loc_api_v02/location_service_v02.c b/loc_api/loc_api_v02/location_service_v02.c
new file mode 100644
index 0000000..e883c36
--- /dev/null
+++ b/loc_api/loc_api_v02/location_service_v02.c
@@ -0,0 +1,3346 @@
+/* Copyright (c) 2011-2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*====*====*====*====*====*====*====*====*====*====*====*====*====*====*====*
+ *THIS IS AN AUTO GENERATED FILE. DO NOT ALTER IN ANY WAY
+ *====*====*====*====*====*====*====*====*====*====*====*====*====*====*====*/
+
+/* This file was generated with Tool version 6.1
+ It requires encode/decode library version 5 or later
+ It was generated on: Fri Mar 29 2013 (Spin 1)
+ From IDL File: location_service_v02.idl */
+
+#include "stdint.h"
+#include "qmi_idl_lib_internal.h"
+#include "location_service_v02.h"
+#include "common_v01.h"
+
+
+/*Type Definitions*/
+static const uint8_t qmiLocApplicationIdStructT_data_v02[] = {
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocApplicationIdStructT_v02, applicationProvider),
+ QMI_LOC_MAX_APP_ID_PROVIDER_LENGTH_V02,
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocApplicationIdStructT_v02, applicationName),
+ QMI_LOC_MAX_APP_ID_NAME_LENGTH_V02,
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocApplicationIdStructT_v02, applicationVersion_valid),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocApplicationIdStructT_v02, applicationVersion),
+ QMI_LOC_MAX_APP_ID_VERSION_LENGTH_V02,
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocGPSTimeStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGPSTimeStructT_v02, gpsWeek),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGPSTimeStructT_v02, gpsTimeOfWeekMs),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocDOPStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDOPStructT_v02, PDOP),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDOPStructT_v02, HDOP),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDOPStructT_v02, VDOP),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocSensorUsageIndicatorStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorUsageIndicatorStructT_v02, usageMask),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorUsageIndicatorStructT_v02, aidingIndicatorMask),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocSvInfoStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, validMask),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, system),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, gnssSvId),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, healthStatus),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, svStatus),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, svInfoMask),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, elevation),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, azimuth),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSvInfoStructT_v02, snr),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiVxNotifyVerifyStructT_data_v02[] = {
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, posQosIncl),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, posQos),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, numFixes),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, timeBetweenFixes),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, posMode),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, encodingScheme),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, requestorId),
+ QMI_LOC_NI_MAX_REQUESTOR_ID_LENGTH_V02,
+ QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, requestorId) - QMI_IDL_OFFSET8(qmiLocNiVxNotifyVerifyStructT_v02, requestorId_len),
+
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiVxNotifyVerifyStructT_v02, userRespTimerInSeconds),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiSuplFormattedStringStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplFormattedStringStructT_v02, formatType),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplFormattedStringStructT_v02, formattedString),
+ QMI_LOC_NI_MAX_CLIENT_NAME_LENGTH_V02,
+ QMI_IDL_OFFSET8(qmiLocNiSuplFormattedStringStructT_v02, formattedString) - QMI_IDL_OFFSET8(qmiLocNiSuplFormattedStringStructT_v02, formattedString_len),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiSuplQopStructT_data_v02[] = {
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplQopStructT_v02, validMask),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplQopStructT_v02, horizontalAccuracy),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplQopStructT_v02, verticalAccuracy),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplQopStructT_v02, maxLocAge),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplQopStructT_v02, delay),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocIpV4AddrStructType_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocIpV4AddrStructType_v02, addr),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocIpV4AddrStructType_v02, port),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocIpV6AddrStructType_data_v02[] = {
+ QMI_IDL_FLAGS_IS_ARRAY |QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocIpV6AddrStructType_v02, addr),
+ QMI_LOC_IPV6_ADDR_LENGTH_V02,
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocIpV6AddrStructType_v02, port),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiSuplServerInfoStructT_data_v02[] = {
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplServerInfoStructT_v02, suplServerAddrTypeMask),
+
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplServerInfoStructT_v02, ipv4Addr),
+ 8, 0,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplServerInfoStructT_v02, ipv6Addr),
+ 9, 0,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocNiSuplServerInfoStructT_v02, urlAddr),
+ QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02,
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiSuplNotifyVerifyStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplNotifyVerifyStructT_v02, valid_flags),
+
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplNotifyVerifyStructT_v02, suplServerInfo),
+ 10, 0,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_FLAGS_IS_ARRAY |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, suplSessionId),
+ QMI_LOC_NI_SUPL_SLP_SESSION_ID_BYTE_LENGTH_V02,
+
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_FLAGS_IS_ARRAY |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, suplHash),
+ QMI_LOC_NI_SUPL_HASH_LENGTH_V02,
+
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, posMethod),
+
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, dataCodingScheme),
+
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, requestorId),
+ 6, 0,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, clientName),
+ 6, 0,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, suplQop),
+ 7, 0,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiSuplNotifyVerifyStructT_v02, userResponseTimer),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiUmtsCpCodedStringStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpCodedStringStructT_v02, dataCodingScheme),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpCodedStringStructT_v02, codedString),
+ QMI_LOC_NI_CODEWORD_MAX_LENGTH_V02,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpCodedStringStructT_v02, codedString) - QMI_IDL_OFFSET8(qmiLocNiUmtsCpCodedStringStructT_v02, codedString_len),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiUmtsCpNotifyVerifyStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, valid_flags),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, invokeId),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, dataCodingScheme),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, notificationText),
+ QMI_LOC_NI_MAX_CLIENT_NAME_LENGTH_V02,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, notificationText) - QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, notificationText_len),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, clientAddress),
+ QMI_LOC_NI_MAX_EXT_CLIENT_ADDRESS_V02,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, clientAddress) - QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, clientAddress_len),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, locationType),
+
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, requestorId),
+ 12, 0,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, codewordString),
+ 12, 0,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, lcsServiceTypeId),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUmtsCpNotifyVerifyStructT_v02, userResponseTimer),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiVxServiceInteractionStructT_data_v02[] = {
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiVxServiceInteractionStructT_v02, niVxReq),
+ 5, 0,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiVxServiceInteractionStructT_v02, serviceInteractionType),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocNiSuplVer2ExtStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplVer2ExtStructT_v02, supportedNetworksMask),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplVer2ExtStructT_v02, triggerType),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiSuplVer2ExtStructT_v02, gnssType),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocAssistanceServerUrlStructT_data_v02[] = {
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocAssistanceServerUrlStructT_v02, serverUrl),
+ QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02,
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocTimeServerListStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocTimeServerListStructT_v02, delayThreshold),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocTimeServerListStructT_v02, timeServerList),
+ QMI_LOC_MAX_NTP_SERVERS_V02,
+ QMI_IDL_OFFSET8(qmiLocTimeServerListStructT_v02, timeServerList) - QMI_IDL_OFFSET8(qmiLocTimeServerListStructT_v02, timeServerList_len),
+ 16, 0,
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocPredictedOrbitsAllowedSizesStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPredictedOrbitsAllowedSizesStructT_v02, maxFileSizeInBytes),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPredictedOrbitsAllowedSizesStructT_v02, maxPartSize),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocPredictedOrbitsServerListStructT_data_v02[] = {
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocPredictedOrbitsServerListStructT_v02, serverList),
+ QMI_LOC_MAX_PREDICTED_ORBITS_SERVERS_V02,
+ QMI_IDL_OFFSET8(qmiLocPredictedOrbitsServerListStructT_v02, serverList) - QMI_IDL_OFFSET8(qmiLocPredictedOrbitsServerListStructT_v02, serverList_len),
+ 16, 0,
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocSensorControlConfigSamplingSpecStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorControlConfigSamplingSpecStructT_v02, samplesPerBatch),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorControlConfigSamplingSpecStructT_v02, batchesPerSecond),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocSensorReadyStatusStructT_data_v02[] = {
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorReadyStatusStructT_v02, injectEnable),
+
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSensorReadyStatusStructT_v02, dataFrequency),
+ 20, 0,
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocGeofencePositionStructT_data_v02[] = {
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, timestampUtc),
+
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, latitude),
+
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, longitude),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, horUncEllipseSemiMinor),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, horUncEllipseSemiMajor),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, horUncEllipseOrientAzimuth),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, speedHorizontal_valid),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, speedHorizontal),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, altitudeWrtEllipsoid_valid),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, altitudeWrtEllipsoid),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, vertUnc_valid),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, vertUnc),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, speedVertical_valid),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, speedVertical),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, heading_valid),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGeofencePositionStructT_v02, heading),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocPredictedOrbitsDataValidityStructT_data_v02[] = {
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPredictedOrbitsDataValidityStructT_v02, startTimeInUTC),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPredictedOrbitsDataValidityStructT_v02, durationHours),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocAltitudeSrcInfoStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAltitudeSrcInfoStructT_v02, source),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAltitudeSrcInfoStructT_v02, linkage),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAltitudeSrcInfoStructT_v02, coverage),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocDeleteSvInfoStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteSvInfoStructT_v02, gnssSvId),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteSvInfoStructT_v02, system),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteSvInfoStructT_v02, deleteSvInfoMask),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocWifiFixTimeStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiFixTimeStructT_v02, wifiPositionTime),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocWifiFixPosStructT_data_v02[] = {
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiFixPosStructT_v02, lat),
+
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiFixPosStructT_v02, lon),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiFixPosStructT_v02, hepe),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiFixPosStructT_v02, numApsUsed),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiFixPosStructT_v02, fixErrorCode),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocWifiApInfoStructT_data_v02[] = {
+ QMI_IDL_FLAGS_IS_ARRAY |QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiApInfoStructT_v02, macAddr),
+ QMI_LOC_WIFI_MAC_ADDR_LENGTH_V02,
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiApInfoStructT_v02, rssi),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiApInfoStructT_v02, channel),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWifiApInfoStructT_v02, apQualifier),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLoc3AxisSensorSampleStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleStructT_v02, timeOffset),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleStructT_v02, xAxis),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleStructT_v02, yAxis),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleStructT_v02, zAxis),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLoc3AxisSensorSampleListStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleListStructT_v02, timeOfFirstSample),
+
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleListStructT_v02, flags),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleListStructT_v02, sensorData),
+ QMI_LOC_SENSOR_DATA_MAX_SAMPLES_V02,
+ QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleListStructT_v02, sensorData) - QMI_IDL_OFFSET8(qmiLoc3AxisSensorSampleListStructT_v02, sensorData_len),
+ 29, 0,
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocApnProfilesStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocApnProfilesStructT_v02, pdnType),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocApnProfilesStructT_v02, apnName),
+ QMI_LOC_MAX_APN_NAME_LENGTH_V02,
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocCircularGeofenceArgsStructT_data_v02[] = {
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocCircularGeofenceArgsStructT_v02, latitude),
+
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocCircularGeofenceArgsStructT_v02, longitude),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocCircularGeofenceArgsStructT_v02, radius),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocMotionDataStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocMotionDataStructT_v02, motion_state),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocMotionDataStructT_v02, motion_mode),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocMotionDataStructT_v02, probability_of_state),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocMotionDataStructT_v02, age),
+
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocMotionDataStructT_v02, timeout),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocGSMCellIdStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGSMCellIdStructT_v02, MCC),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGSMCellIdStructT_v02, MNC),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGSMCellIdStructT_v02, LAC),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGSMCellIdStructT_v02, CID),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocEmergencyNotificationStructT_data_v02[] = {
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN |QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocEmergencyNotificationStructT_v02, eslpUrl),
+ QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02,
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocSensorTemperatureSampleStructT_data_v02[] = {
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleStructT_v02, timeOffset),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleStructT_v02, temperature),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocSensorTemperatureSampleListStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleListStructT_v02, timeSource),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleListStructT_v02, timeOfFirstSample),
+
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleListStructT_v02, temperatureData),
+ QMI_LOC_SENSOR_DATA_MAX_SAMPLES_V02,
+ QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleListStructT_v02, temperatureData) - QMI_IDL_OFFSET8(qmiLocSensorTemperatureSampleListStructT_v02, temperatureData_len),
+ 36, 0,
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocWCDMACellIdStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWCDMACellIdStructT_v02, mcc),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWCDMACellIdStructT_v02, mnc),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWCDMACellIdStructT_v02, cid),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+static const uint8_t qmiLocTDSCDMACellIdStructT_data_v02[] = {
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocTDSCDMACellIdStructT_v02, mcc),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocTDSCDMACellIdStructT_v02, mnc),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocTDSCDMACellIdStructT_v02, cid),
+
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocTDSCDMACellIdStructT_v02, lac),
+
+ QMI_IDL_FLAG_END_VALUE
+};
+
+/*Message Definitions*/
+static const uint8_t qmiLocGenRespMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGenRespMsgT_v02, resp),
+ 0, 1
+};
+
+static const uint8_t qmiLocInformClientRevisionReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInformClientRevisionReqMsgT_v02, revision)
+};
+
+static const uint8_t qmiLocRegEventsReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocRegEventsReqMsgT_v02, eventRegMask)
+};
+
+static const uint8_t qmiLocStartReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, sessionId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, fixRecurrence) - QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, fixRecurrence_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, fixRecurrence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, horizontalAccuracyLevel) - QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, horizontalAccuracyLevel_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, horizontalAccuracyLevel),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, intermediateReportState) - QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, intermediateReportState_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, intermediateReportState),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, minInterval) - QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, minInterval_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, minInterval),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, applicationId) - QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, applicationId_valid)),
+ 0x14,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocStartReqMsgT_v02, applicationId),
+ 0, 0
+};
+
+static const uint8_t qmiLocStopReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocStopReqMsgT_v02, sessionId)
+};
+
+static const uint8_t qmiLocEventPositionReportIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, sessionStatus),
+
+ 0x02,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, sessionId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, latitude) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, latitude_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, latitude),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, longitude) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, longitude_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, longitude),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncCircular) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncCircular_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncCircular),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseSemiMinor) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseSemiMinor_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseSemiMinor),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseSemiMajor) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseSemiMajor_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseSemiMajor),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseOrientAzimuth) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseOrientAzimuth_valid)),
+ 0x15,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horUncEllipseOrientAzimuth),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horConfidence) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horConfidence_valid)),
+ 0x16,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horReliability) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horReliability_valid)),
+ 0x17,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, horReliability),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedHorizontal) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedHorizontal_valid)),
+ 0x18,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedHorizontal),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedUnc) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedUnc_valid)),
+ 0x19,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, altitudeWrtEllipsoid) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, altitudeWrtEllipsoid_valid)),
+ 0x1A,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, altitudeWrtEllipsoid),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, altitudeWrtMeanSeaLevel) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, altitudeWrtMeanSeaLevel_valid)),
+ 0x1B,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, altitudeWrtMeanSeaLevel),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertUnc) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertUnc_valid)),
+ 0x1C,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertConfidence) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertConfidence_valid)),
+ 0x1D,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertReliability) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertReliability_valid)),
+ 0x1E,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, vertReliability),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedVertical) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedVertical_valid)),
+ 0x1F,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, speedVertical),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, heading) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, heading_valid)),
+ 0x20,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, heading),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, headingUnc) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, headingUnc_valid)),
+ 0x21,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, headingUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, magneticDeviation) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, magneticDeviation_valid)),
+ 0x22,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, magneticDeviation),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, technologyMask) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, technologyMask_valid)),
+ 0x23,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, technologyMask),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, DOP) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, DOP_valid)),
+ 0x24,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, DOP),
+ 2, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, timestampUtc) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, timestampUtc_valid)),
+ 0x25,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, timestampUtc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, leapSeconds) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, leapSeconds_valid)),
+ 0x26,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, leapSeconds),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, gpsTime) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, gpsTime_valid)),
+ 0x27,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, gpsTime),
+ 1, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, timeUnc) - QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, timeUnc_valid)),
+ 0x28,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPositionReportIndMsgT_v02, timeUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, timeSrc) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, timeSrc_valid)),
+ 0x29,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventPositionReportIndMsgT_v02, timeSrc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, sensorDataUsage) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, sensorDataUsage_valid)),
+ 0x2A,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventPositionReportIndMsgT_v02, sensorDataUsage),
+ 3, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, fixId) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, fixId_valid)),
+ 0x2B,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventPositionReportIndMsgT_v02, fixId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, gnssSvUsedList) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, gnssSvUsedList_valid)),
+ 0x2C,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventPositionReportIndMsgT_v02, gnssSvUsedList),
+ QMI_LOC_MAX_SV_USED_LIST_LENGTH_V02,
+ QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, gnssSvUsedList) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, gnssSvUsedList_len),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, altitudeAssumed) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventPositionReportIndMsgT_v02, altitudeAssumed_valid)),
+ 0x2D,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventPositionReportIndMsgT_v02, altitudeAssumed)
+};
+
+static const uint8_t qmiLocEventGnssSvInfoIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventGnssSvInfoIndMsgT_v02, altitudeAssumed),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventGnssSvInfoIndMsgT_v02, svList) - QMI_IDL_OFFSET8(qmiLocEventGnssSvInfoIndMsgT_v02, svList_valid)),
+ 0x10,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventGnssSvInfoIndMsgT_v02, svList),
+ QMI_LOC_SV_INFO_LIST_MAX_SIZE_V02,
+ QMI_IDL_OFFSET8(qmiLocEventGnssSvInfoIndMsgT_v02, svList) - QMI_IDL_OFFSET8(qmiLocEventGnssSvInfoIndMsgT_v02, svList_len),
+ 4, 0
+};
+
+static const uint8_t qmiLocEventNmeaIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocEventNmeaIndMsgT_v02, nmea),
+ QMI_LOC_NMEA_STRING_MAX_LENGTH_V02
+};
+
+static const uint8_t qmiLocEventNiNotifyVerifyReqIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, notificationType),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiVxInd) - QMI_IDL_OFFSET8(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiVxInd_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiVxInd),
+ 5, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiSuplInd) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiSuplInd_valid)),
+ 0x11,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiSuplInd),
+ 11, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiUmtsCpInd) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiUmtsCpInd_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiUmtsCpInd),
+ 13, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiVxServiceInteractionInd) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiVxServiceInteractionInd_valid)),
+ 0x13,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiVxServiceInteractionInd),
+ 14, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiSuplVer2ExtInd) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiSuplVer2ExtInd_valid)),
+ 0x14,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, NiSuplVer2ExtInd),
+ 15, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, suplEmergencyNotification) - QMI_IDL_OFFSET16RELATIVE(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, suplEmergencyNotification_valid)),
+ 0x15,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocEventNiNotifyVerifyReqIndMsgT_v02, suplEmergencyNotification),
+ 35, 0
+};
+
+static const uint8_t qmiLocEventInjectTimeReqIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventInjectTimeReqIndMsgT_v02, timeServerInfo) - QMI_IDL_OFFSET8(qmiLocEventInjectTimeReqIndMsgT_v02, timeServerInfo_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectTimeReqIndMsgT_v02, timeServerInfo),
+ 17, 0
+};
+
+static const uint8_t qmiLocEventInjectPredictedOrbitsReqIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02, allowedSizes),
+ 18, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02, serverList) - QMI_IDL_OFFSET8(qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02, serverList_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02, serverList),
+ 19, 0
+};
+
+static const uint8_t qmiLocEventInjectPositionReqIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectPositionReqIndMsgT_v02, latitude),
+
+ 0x02,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectPositionReqIndMsgT_v02, longitude),
+
+ 0x03,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectPositionReqIndMsgT_v02, horUncCircular),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x04,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventInjectPositionReqIndMsgT_v02, timestampUtc)
+};
+
+static const uint8_t qmiLocEventEngineStateIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventEngineStateIndMsgT_v02, engineState)
+};
+
+static const uint8_t qmiLocEventFixSessionStateIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventFixSessionStateIndMsgT_v02, sessionState),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventFixSessionStateIndMsgT_v02, sessionId) - QMI_IDL_OFFSET8(qmiLocEventFixSessionStateIndMsgT_v02, sessionId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventFixSessionStateIndMsgT_v02, sessionId)
+};
+
+static const uint8_t qmiLocEventWifiReqIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventWifiReqIndMsgT_v02, requestType),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventWifiReqIndMsgT_v02, tbfInMs) - QMI_IDL_OFFSET8(qmiLocEventWifiReqIndMsgT_v02, tbfInMs_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventWifiReqIndMsgT_v02, tbfInMs)
+};
+
+static const uint8_t qmiLocEventSensorStreamingReadyStatusIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, accelReady) - QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, accelReady_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, accelReady),
+ 21, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, gyroReady) - QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, gyroReady_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, gyroReady),
+ 21, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, accelTemperatureReady) - QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, accelTemperatureReady_valid)),
+ 0x12,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, accelTemperatureReady),
+ 21, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, gyroTemperatureReady) - QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, gyroTemperatureReady_valid)),
+ 0x13,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02, gyroTemperatureReady),
+ 21, 0
+};
+
+static const uint8_t qmiLocEventTimeSyncReqIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventTimeSyncReqIndMsgT_v02, refCounter)
+};
+
+static const uint8_t qmiLocEventSetSpiStreamingReportIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventSetSpiStreamingReportIndMsgT_v02, enable)
+};
+
+static const uint8_t qmiLocEventLocationServerConnectionReqIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventLocationServerConnectionReqIndMsgT_v02, connHandle),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventLocationServerConnectionReqIndMsgT_v02, requestType),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x03,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventLocationServerConnectionReqIndMsgT_v02, wwanType)
+};
+
+static const uint8_t qmiLocEventNiGeofenceNotificationIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventNiGeofenceNotificationIndMsgT_v02, geofenceId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventNiGeofenceNotificationIndMsgT_v02, operationType)
+};
+
+static const uint8_t qmiLocEventGeofenceGenAlertIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventGeofenceGenAlertIndMsgT_v02, geofenceAlert)
+};
+
+static const uint8_t qmiLocEventGeofenceBreachIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventGeofenceBreachIndMsgT_v02, geofenceId),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventGeofenceBreachIndMsgT_v02, breachType),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventGeofenceBreachIndMsgT_v02, geofencePosition) - QMI_IDL_OFFSET8(qmiLocEventGeofenceBreachIndMsgT_v02, geofencePosition_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocEventGeofenceBreachIndMsgT_v02, geofencePosition),
+ 22, 0
+};
+
+/*
+ * qmiLocGetServiceRevisionReqMsgT is empty
+ * static const uint8_t qmiLocGetServiceRevisionReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetServiceRevisionIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, status),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, revision),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, gnssMeFWVerString) - QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, gnssMeFWVerString_valid)),
+ 0x10,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, gnssMeFWVerString),
+ QMI_LOC_GNSS_ME_VERSION_STRING_MAX_LENGTH_V02,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, gnssHostSWVerString) - QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, gnssHostSWVerString_valid)),
+ 0x11,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocGetServiceRevisionIndMsgT_v02, gnssHostSWVerString),
+ QMI_LOC_GNSS_HOSTED_SW_VERSION_STRING_MAX_LENGTH_V02,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocGetServiceRevisionIndMsgT_v02, gnssSWVerString) - QMI_IDL_OFFSET16RELATIVE(qmiLocGetServiceRevisionIndMsgT_v02, gnssSWVerString_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_STRING,
+ QMI_IDL_OFFSET16ARRAY(qmiLocGetServiceRevisionIndMsgT_v02, gnssSWVerString),
+ QMI_LOC_GNSS_SW_VERSION_STRING_MAX_LENGTH_V02
+};
+
+/*
+ * qmiLocGetFixCriteriaReqMsgT is empty
+ * static const uint8_t qmiLocGetFixCriteriaReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetFixCriteriaIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, horizontalAccuracyLevel) - QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, horizontalAccuracyLevel_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, horizontalAccuracyLevel),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, intermediateReportState) - QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, intermediateReportState_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, intermediateReportState),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, minInterval) - QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, minInterval_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, minInterval),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, applicationId) - QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, applicationId_valid)),
+ 0x13,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetFixCriteriaIndMsgT_v02, applicationId),
+ 0, 0
+};
+
+static const uint8_t qmiLocNiUserRespReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUserRespReqMsgT_v02, userResp),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUserRespReqMsgT_v02, notificationType),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocNiUserRespReqMsgT_v02, NiVxPayload) - QMI_IDL_OFFSET8(qmiLocNiUserRespReqMsgT_v02, NiVxPayload_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocNiUserRespReqMsgT_v02, NiVxPayload),
+ 5, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiSuplPayload) - QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiSuplPayload_valid)),
+ 0x11,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiUserRespReqMsgT_v02, NiSuplPayload),
+ 11, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiUmtsCpPayload) - QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiUmtsCpPayload_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiUserRespReqMsgT_v02, NiUmtsCpPayload),
+ 13, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiVxServiceInteractionPayload) - QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiVxServiceInteractionPayload_valid)),
+ 0x13,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiUserRespReqMsgT_v02, NiVxServiceInteractionPayload),
+ 14, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiSuplVer2ExtPayload) - QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, NiSuplVer2ExtPayload_valid)),
+ 0x14,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiUserRespReqMsgT_v02, NiSuplVer2ExtPayload),
+ 15, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, suplEmergencyNotification) - QMI_IDL_OFFSET16RELATIVE(qmiLocNiUserRespReqMsgT_v02, suplEmergencyNotification_valid)),
+ 0x15,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocNiUserRespReqMsgT_v02, suplEmergencyNotification),
+ 35, 0
+};
+
+static const uint8_t qmiLocNiUserRespIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNiUserRespIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectPredictedOrbitsDataReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, totalSize),
+
+ 0x02,
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, totalParts),
+
+ 0x03,
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, partNum),
+
+ 0x04,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_FLAGS_SZ_IS_16 | QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, partData),
+ ((QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02) & 0xFF), ((QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02) >> 8),
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, partData) - QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, partData_len),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, formatType) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, formatType_valid)),
+ 0x10,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectPredictedOrbitsDataReqMsgT_v02, formatType)
+};
+
+static const uint8_t qmiLocInjectPredictedOrbitsDataIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataIndMsgT_v02, partNum) - QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataIndMsgT_v02, partNum_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPredictedOrbitsDataIndMsgT_v02, partNum)
+};
+
+/*
+ * qmiLocGetPredictedOrbitsDataSourceReqMsgT is empty
+ * static const uint8_t qmiLocGetPredictedOrbitsDataSourceReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetPredictedOrbitsDataSourceIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, allowedSizes) - QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, allowedSizes_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, allowedSizes),
+ 18, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, serverList) - QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, serverList_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02, serverList),
+ 19, 0
+};
+
+/*
+ * qmiLocGetPredictedOrbitsDataValidityReqMsgT is empty
+ * static const uint8_t qmiLocGetPredictedOrbitsDataValidityReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetPredictedOrbitsDataValidityIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02, validityInfo) - QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02, validityInfo_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02, validityInfo),
+ 23, 0
+};
+
+static const uint8_t qmiLocInjectUtcTimeReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectUtcTimeReqMsgT_v02, timeUtc),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectUtcTimeReqMsgT_v02, timeUnc)
+};
+
+static const uint8_t qmiLocInjectUtcTimeIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectUtcTimeIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectPositionReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, latitude) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, latitude_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, latitude),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, longitude) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, longitude_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, longitude),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horUncCircular) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horUncCircular_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horUncCircular),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horConfidence) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horConfidence_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horReliability) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horReliability_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, horReliability),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altitudeWrtEllipsoid) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altitudeWrtEllipsoid_valid)),
+ 0x15,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altitudeWrtEllipsoid),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altitudeWrtMeanSeaLevel) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altitudeWrtMeanSeaLevel_valid)),
+ 0x16,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altitudeWrtMeanSeaLevel),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertUnc) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertUnc_valid)),
+ 0x17,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertConfidence) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertConfidence_valid)),
+ 0x18,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertReliability) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertReliability_valid)),
+ 0x19,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, vertReliability),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altSourceInfo) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altSourceInfo_valid)),
+ 0x1A,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, altSourceInfo),
+ 24, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, timestampUtc) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, timestampUtc_valid)),
+ 0x1B,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, timestampUtc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, timestampAge) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, timestampAge_valid)),
+ 0x1C,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, timestampAge),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, positionSrc) - QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, positionSrc_valid)),
+ 0x1D,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionReqMsgT_v02, positionSrc)
+};
+
+static const uint8_t qmiLocInjectPositionIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectPositionIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocSetEngineLockReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetEngineLockReqMsgT_v02, lockType)
+};
+
+static const uint8_t qmiLocSetEngineLockIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetEngineLockIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetEngineLockReqMsgT is empty
+ * static const uint8_t qmiLocGetEngineLockReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetEngineLockIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetEngineLockIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetEngineLockIndMsgT_v02, lockType) - QMI_IDL_OFFSET8(qmiLocGetEngineLockIndMsgT_v02, lockType_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetEngineLockIndMsgT_v02, lockType)
+};
+
+static const uint8_t qmiLocSetSbasConfigReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSbasConfigReqMsgT_v02, sbasConfig)
+};
+
+static const uint8_t qmiLocSetSbasConfigIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSbasConfigIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetSbasConfigReqMsgT is empty
+ * static const uint8_t qmiLocGetSbasConfigReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetSbasConfigIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSbasConfigIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSbasConfigIndMsgT_v02, sbasConfig) - QMI_IDL_OFFSET8(qmiLocGetSbasConfigIndMsgT_v02, sbasConfig_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSbasConfigIndMsgT_v02, sbasConfig)
+};
+
+static const uint8_t qmiLocSetNmeaTypesReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetNmeaTypesReqMsgT_v02, nmeaSentenceType)
+};
+
+static const uint8_t qmiLocSetNmeaTypesIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetNmeaTypesIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetNmeaTypesReqMsgT is empty
+ * static const uint8_t qmiLocGetNmeaTypesReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetNmeaTypesIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetNmeaTypesIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetNmeaTypesIndMsgT_v02, nmeaSentenceType) - QMI_IDL_OFFSET8(qmiLocGetNmeaTypesIndMsgT_v02, nmeaSentenceType_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetNmeaTypesIndMsgT_v02, nmeaSentenceType)
+};
+
+static const uint8_t qmiLocSetLowPowerModeReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetLowPowerModeReqMsgT_v02, lowPowerMode)
+};
+
+static const uint8_t qmiLocSetLowPowerModeIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetLowPowerModeIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetLowPowerModeReqMsgT is empty
+ * static const uint8_t qmiLocGetLowPowerModeReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetLowPowerModeIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetLowPowerModeIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetLowPowerModeIndMsgT_v02, lowPowerMode) - QMI_IDL_OFFSET8(qmiLocGetLowPowerModeIndMsgT_v02, lowPowerMode_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetLowPowerModeIndMsgT_v02, lowPowerMode)
+};
+
+static const uint8_t qmiLocSetServerReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, serverType),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, ipv4Addr) - QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, ipv4Addr_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, ipv4Addr),
+ 8, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, ipv6Addr) - QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, ipv6Addr_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, ipv6Addr),
+ 9, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, urlAddr) - QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, urlAddr_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocSetServerReqMsgT_v02, urlAddr),
+ QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02
+};
+
+static const uint8_t qmiLocSetServerIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetServerIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocGetServerReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetServerReqMsgT_v02, serverType),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetServerReqMsgT_v02, serverAddrTypeMask) - QMI_IDL_OFFSET8(qmiLocGetServerReqMsgT_v02, serverAddrTypeMask_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetServerReqMsgT_v02, serverAddrTypeMask)
+};
+
+static const uint8_t qmiLocGetServerIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, status),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, serverType),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, ipv4Addr) - QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, ipv4Addr_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, ipv4Addr),
+ 8, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, ipv6Addr) - QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, ipv6Addr_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, ipv6Addr),
+ 9, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, urlAddr) - QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, urlAddr_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_STRING,
+ QMI_IDL_OFFSET8(qmiLocGetServerIndMsgT_v02, urlAddr),
+ QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02
+};
+
+static const uint8_t qmiLocDeleteAssistDataReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteAssistDataReqMsgT_v02, deleteAllFlag),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocDeleteAssistDataReqMsgT_v02, deleteSvInfoList) - QMI_IDL_OFFSET8(qmiLocDeleteAssistDataReqMsgT_v02, deleteSvInfoList_valid)),
+ 0x10,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocDeleteAssistDataReqMsgT_v02, deleteSvInfoList),
+ QMI_LOC_DELETE_MAX_SV_INFO_LENGTH_V02,
+ QMI_IDL_OFFSET8(qmiLocDeleteAssistDataReqMsgT_v02, deleteSvInfoList) - QMI_IDL_OFFSET8(qmiLocDeleteAssistDataReqMsgT_v02, deleteSvInfoList_len),
+ 25, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocDeleteAssistDataReqMsgT_v02, deleteGnssDataMask) - QMI_IDL_OFFSET16RELATIVE(qmiLocDeleteAssistDataReqMsgT_v02, deleteGnssDataMask_valid)),
+ 0x11,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocDeleteAssistDataReqMsgT_v02, deleteGnssDataMask),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocDeleteAssistDataReqMsgT_v02, deleteCellDbDataMask) - QMI_IDL_OFFSET16RELATIVE(qmiLocDeleteAssistDataReqMsgT_v02, deleteCellDbDataMask_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocDeleteAssistDataReqMsgT_v02, deleteCellDbDataMask),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocDeleteAssistDataReqMsgT_v02, deleteClockInfoMask) - QMI_IDL_OFFSET16RELATIVE(qmiLocDeleteAssistDataReqMsgT_v02, deleteClockInfoMask_valid)),
+ 0x13,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocDeleteAssistDataReqMsgT_v02, deleteClockInfoMask)
+};
+
+static const uint8_t qmiLocDeleteAssistDataIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteAssistDataIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocSetXtraTSessionControlReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetXtraTSessionControlReqMsgT_v02, xtraTSessionControl)
+};
+
+static const uint8_t qmiLocSetXtraTSessionControlIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetXtraTSessionControlIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetXtraTSessionControlReqMsgT is empty
+ * static const uint8_t qmiLocGetXtraTSessionControlReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetXtraTSessionControlIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetXtraTSessionControlIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetXtraTSessionControlIndMsgT_v02, xtraTSessionControl) - QMI_IDL_OFFSET8(qmiLocGetXtraTSessionControlIndMsgT_v02, xtraTSessionControl_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetXtraTSessionControlIndMsgT_v02, xtraTSessionControl)
+};
+
+static const uint8_t qmiLocInjectWifiPositionReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, wifiFixTime) - QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, wifiFixTime_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, wifiFixTime),
+ 26, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, wifiFixPosition) - QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, wifiFixPosition_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, wifiFixPosition),
+ 27, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, apInfo) - QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, apInfo_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, apInfo),
+ QMI_LOC_WIFI_MAX_REPORTED_APS_PER_MSG_V02,
+ QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, apInfo) - QMI_IDL_OFFSET8(qmiLocInjectWifiPositionReqMsgT_v02, apInfo_len),
+ 28, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectWifiPositionReqMsgT_v02, horizontalReliability) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectWifiPositionReqMsgT_v02, horizontalReliability_valid)),
+ 0x13,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectWifiPositionReqMsgT_v02, horizontalReliability)
+};
+
+static const uint8_t qmiLocInjectWifiPositionIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectWifiPositionIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocNotifyWifiStatusReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNotifyWifiStatusReqMsgT_v02, wifiStatus)
+};
+
+static const uint8_t qmiLocNotifyWifiStatusIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocNotifyWifiStatusIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetRegisteredEventsReqMsgT is empty
+ * static const uint8_t qmiLocGetRegisteredEventsReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetRegisteredEventsIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetRegisteredEventsIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetRegisteredEventsIndMsgT_v02, eventRegMask) - QMI_IDL_OFFSET8(qmiLocGetRegisteredEventsIndMsgT_v02, eventRegMask_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetRegisteredEventsIndMsgT_v02, eventRegMask)
+};
+
+static const uint8_t qmiLocSetOperationModeReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetOperationModeReqMsgT_v02, operationMode)
+};
+
+static const uint8_t qmiLocSetOperationModeIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetOperationModeIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetOperationModeReqMsgT is empty
+ * static const uint8_t qmiLocGetOperationModeReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetOperationModeIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetOperationModeIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetOperationModeIndMsgT_v02, operationMode) - QMI_IDL_OFFSET8(qmiLocGetOperationModeIndMsgT_v02, operationMode_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetOperationModeIndMsgT_v02, operationMode)
+};
+
+static const uint8_t qmiLocSetSpiStatusReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSpiStatusReqMsgT_v02, stationary),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSpiStatusReqMsgT_v02, confidenceStationary) - QMI_IDL_OFFSET8(qmiLocSetSpiStatusReqMsgT_v02, confidenceStationary_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSpiStatusReqMsgT_v02, confidenceStationary)
+};
+
+static const uint8_t qmiLocSetSpiStatusIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSpiStatusIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectSensorDataReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataReqMsgT_v02, opaqueIdentifier) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataReqMsgT_v02, opaqueIdentifier_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataReqMsgT_v02, opaqueIdentifier),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataReqMsgT_v02, threeAxisAccelData) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataReqMsgT_v02, threeAxisAccelData_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataReqMsgT_v02, threeAxisAccelData),
+ 30, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, threeAxisGyroData) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, threeAxisGyroData_valid)),
+ 0x12,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectSensorDataReqMsgT_v02, threeAxisGyroData),
+ 30, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, threeAxisAccelDataTimeSource) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, threeAxisAccelDataTimeSource_valid)),
+ 0x13,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectSensorDataReqMsgT_v02, threeAxisAccelDataTimeSource),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, threeAxisGyroDataTimeSource) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, threeAxisGyroDataTimeSource_valid)),
+ 0x14,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectSensorDataReqMsgT_v02, threeAxisGyroDataTimeSource),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, accelTemperatureData) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, accelTemperatureData_valid)),
+ 0x15,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectSensorDataReqMsgT_v02, accelTemperatureData),
+ 37, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, gyroTemperatureData) - QMI_IDL_OFFSET16RELATIVE(qmiLocInjectSensorDataReqMsgT_v02, gyroTemperatureData_valid)),
+ 0x16,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocInjectSensorDataReqMsgT_v02, gyroTemperatureData),
+ 37, 0
+};
+
+static const uint8_t qmiLocInjectSensorDataIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, opaqueIdentifier) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, opaqueIdentifier_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, opaqueIdentifier),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, threeAxisAccelSamplesAccepted) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, threeAxisAccelSamplesAccepted_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, threeAxisAccelSamplesAccepted),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, threeAxisGyroSamplesAccepted) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, threeAxisGyroSamplesAccepted_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, threeAxisGyroSamplesAccepted),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, accelTemperatureSamplesAccepted) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, accelTemperatureSamplesAccepted_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, accelTemperatureSamplesAccepted),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, gyroTemperatureSamplesAccepted) - QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, gyroTemperatureSamplesAccepted_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSensorDataIndMsgT_v02, gyroTemperatureSamplesAccepted)
+};
+
+static const uint8_t qmiLocInjectTimeSyncDataReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTimeSyncDataReqMsgT_v02, refCounter),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTimeSyncDataReqMsgT_v02, sensorProcRxTime),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x03,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTimeSyncDataReqMsgT_v02, sensorProcTxTime)
+};
+
+static const uint8_t qmiLocInjectTimeSyncDataIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTimeSyncDataIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetCradleMountConfigReqMsgT is empty
+ * static const uint8_t qmiLocGetCradleMountConfigReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetCradleMountConfigIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, cradleMountState) - QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, cradleMountState_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, cradleMountState),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, confidenceCradleMountState) - QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, confidenceCradleMountState_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetCradleMountConfigIndMsgT_v02, confidenceCradleMountState)
+};
+
+static const uint8_t qmiLocSetCradleMountConfigReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetCradleMountConfigReqMsgT_v02, cradleMountState),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetCradleMountConfigReqMsgT_v02, confidenceCradleMountState) - QMI_IDL_OFFSET8(qmiLocSetCradleMountConfigReqMsgT_v02, confidenceCradleMountState_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetCradleMountConfigReqMsgT_v02, confidenceCradleMountState)
+};
+
+static const uint8_t qmiLocSetCradleMountConfigIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetCradleMountConfigIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetExternalPowerConfigReqMsgT is empty
+ * static const uint8_t qmiLocGetExternalPowerConfigReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetExternalPowerConfigIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetExternalPowerConfigIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetExternalPowerConfigIndMsgT_v02, externalPowerState) - QMI_IDL_OFFSET8(qmiLocGetExternalPowerConfigIndMsgT_v02, externalPowerState_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetExternalPowerConfigIndMsgT_v02, externalPowerState)
+};
+
+static const uint8_t qmiLocSetExternalPowerConfigReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetExternalPowerConfigReqMsgT_v02, externalPowerState)
+};
+
+static const uint8_t qmiLocSetExternalPowerConfigIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetExternalPowerConfigIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInformLocationServerConnStatusReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusReqMsgT_v02, connHandle),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusReqMsgT_v02, requestType),
+
+ 0x03,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusReqMsgT_v02, statusType),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusReqMsgT_v02, apnProfile) - QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusReqMsgT_v02, apnProfile_valid)),
+ 0x10,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusReqMsgT_v02, apnProfile),
+ 31, 0
+};
+
+static const uint8_t qmiLocInformLocationServerConnStatusIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInformLocationServerConnStatusIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocSetProtocolConfigParametersReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplSecurity) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplSecurity_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplSecurity),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, vxVersion) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, vxVersion_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, vxVersion),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplVersion) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplVersion_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplVersion),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, lppConfig) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, lppConfig_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, lppConfig),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, assistedGlonassProtocolMask) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, assistedGlonassProtocolMask_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, assistedGlonassProtocolMask),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplHashAlgo) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplHashAlgo_valid)),
+ 0x15,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplHashAlgo),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplTlsVersion) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplTlsVersion_valid)),
+ 0x16,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, suplTlsVersion),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, emergencyProtocol) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, emergencyProtocol_valid)),
+ 0x17,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersReqMsgT_v02, emergencyProtocol)
+};
+
+static const uint8_t qmiLocSetProtocolConfigParametersIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersIndMsgT_v02, failedProtocolConfigParamMask) - QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersIndMsgT_v02, failedProtocolConfigParamMask_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetProtocolConfigParametersIndMsgT_v02, failedProtocolConfigParamMask)
+};
+
+static const uint8_t qmiLocGetProtocolConfigParametersReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersReqMsgT_v02, getProtocolConfigParamMask)
+};
+
+static const uint8_t qmiLocGetProtocolConfigParametersIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplSecurity) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplSecurity_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplSecurity),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, vxVersion) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, vxVersion_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, vxVersion),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplVersion) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplVersion_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplVersion),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, lppConfig) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, lppConfig_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, lppConfig),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, assistedGlonassProtocolMask) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, assistedGlonassProtocolMask_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, assistedGlonassProtocolMask),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplHashAlgo) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplHashAlgo_valid)),
+ 0x15,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplHashAlgo),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplTlsVersion) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplTlsVersion_valid)),
+ 0x16,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, suplTlsVersion),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, emergencyProtocol) - QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, emergencyProtocol_valid)),
+ 0x17,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetProtocolConfigParametersIndMsgT_v02, emergencyProtocol)
+};
+
+static const uint8_t qmiLocSetSensorControlConfigReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorControlConfigReqMsgT_v02, sensorsUsage) - QMI_IDL_OFFSET8(qmiLocSetSensorControlConfigReqMsgT_v02, sensorsUsage_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorControlConfigReqMsgT_v02, sensorsUsage)
+};
+
+static const uint8_t qmiLocSetSensorControlConfigIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorControlConfigIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocGetSensorControlConfigReqMsgT is empty
+ * static const uint8_t qmiLocGetSensorControlConfigReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetSensorControlConfigIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorControlConfigIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorControlConfigIndMsgT_v02, sensorsUsage) - QMI_IDL_OFFSET8(qmiLocGetSensorControlConfigIndMsgT_v02, sensorsUsage_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorControlConfigIndMsgT_v02, sensorsUsage)
+};
+
+static const uint8_t qmiLocSetSensorPropertiesReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, gyroBiasVarianceRandomWalk) - QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, gyroBiasVarianceRandomWalk_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, gyroBiasVarianceRandomWalk),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, velocityRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, velocityRandomWalkSpectralDensity_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, velocityRandomWalkSpectralDensity),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, accelerationRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, accelerationRandomWalkSpectralDensity_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, accelerationRandomWalkSpectralDensity),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, angleRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, angleRandomWalkSpectralDensity_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, angleRandomWalkSpectralDensity),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, rateRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, rateRandomWalkSpectralDensity_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesReqMsgT_v02, rateRandomWalkSpectralDensity)
+};
+
+static const uint8_t qmiLocSetSensorPropertiesIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesIndMsgT_v02, failedSensorPropertiesMask) - QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesIndMsgT_v02, failedSensorPropertiesMask_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPropertiesIndMsgT_v02, failedSensorPropertiesMask)
+};
+
+static const uint8_t qmiLocGetSensorPropertiesReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesReqMsgT_v02, getSensorPropertiesMask)
+};
+
+static const uint8_t qmiLocGetSensorPropertiesIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, gyroBiasVarianceRandomWalk) - QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, gyroBiasVarianceRandomWalk_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, gyroBiasVarianceRandomWalk),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, velocityRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, velocityRandomWalkSpectralDensity_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, velocityRandomWalkSpectralDensity),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, accelerationRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, accelerationRandomWalkSpectralDensity_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, accelerationRandomWalkSpectralDensity),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, angleRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, angleRandomWalkSpectralDensity_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, angleRandomWalkSpectralDensity),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, rateRandomWalkSpectralDensity) - QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, rateRandomWalkSpectralDensity_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPropertiesIndMsgT_v02, rateRandomWalkSpectralDensity)
+};
+
+static const uint8_t qmiLocSetSensorPerformanceControlConfigReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, performanceControlMode) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, performanceControlMode_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, performanceControlMode),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, accelSamplingSpec) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, accelSamplingSpec_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, accelSamplingSpec),
+ 20, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, gyroSamplingSpec) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, gyroSamplingSpec_valid)),
+ 0x12,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, gyroSamplingSpec),
+ 20, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, algorithmConfig) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, algorithmConfig_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, algorithmConfig),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, accelSamplingSpecHigh) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, accelSamplingSpecHigh_valid)),
+ 0x14,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, accelSamplingSpecHigh),
+ 20, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, gyroSamplingSpecHigh) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, gyroSamplingSpecHigh_valid)),
+ 0x15,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02, gyroSamplingSpecHigh),
+ 20, 0
+};
+
+static const uint8_t qmiLocSetSensorPerformanceControlConfigIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigIndMsgT_v02, failedConfiguration) - QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigIndMsgT_v02, failedConfiguration_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetSensorPerformanceControlConfigIndMsgT_v02, failedConfiguration)
+};
+
+/*
+ * qmiLocGetSensorPerformanceControlConfigReqMsgT is empty
+ * static const uint8_t qmiLocGetSensorPerformanceControlConfigReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocGetSensorPerformanceControlConfigIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, performanceControlMode) - QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, performanceControlMode_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, performanceControlMode),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, accelSamplingSpec) - QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, accelSamplingSpec_valid)),
+ 0x11,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, accelSamplingSpec),
+ 20, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, gyroSamplingSpec) - QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, gyroSamplingSpec_valid)),
+ 0x12,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, gyroSamplingSpec),
+ 20, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, algorithmConfig) - QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, algorithmConfig_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, algorithmConfig),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, accelSamplingSpecHigh) - QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, accelSamplingSpecHigh_valid)),
+ 0x14,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, accelSamplingSpecHigh),
+ 20, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, gyroSamplingSpecHigh) - QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, gyroSamplingSpecHigh_valid)),
+ 0x15,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02, gyroSamplingSpecHigh),
+ 20, 0
+};
+
+static const uint8_t qmiLocInjectSuplCertificateReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSuplCertificateReqMsgT_v02, suplCertId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_FLAGS_SZ_IS_16 | QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSuplCertificateReqMsgT_v02, suplCertData),
+ ((QMI_LOC_MAX_SUPL_CERT_LENGTH_V02) & 0xFF), ((QMI_LOC_MAX_SUPL_CERT_LENGTH_V02) >> 8),
+ QMI_IDL_OFFSET8(qmiLocInjectSuplCertificateReqMsgT_v02, suplCertData) - QMI_IDL_OFFSET8(qmiLocInjectSuplCertificateReqMsgT_v02, suplCertData_len)
+};
+
+static const uint8_t qmiLocInjectSuplCertificateIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSuplCertificateIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocDeleteSuplCertificateReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocDeleteSuplCertificateReqMsgT_v02, suplCertId) - QMI_IDL_OFFSET8(qmiLocDeleteSuplCertificateReqMsgT_v02, suplCertId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteSuplCertificateReqMsgT_v02, suplCertId)
+};
+
+static const uint8_t qmiLocDeleteSuplCertificateIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteSuplCertificateIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocSetPositionEngineConfigParametersReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, injectedPositionControl) - QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, injectedPositionControl_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, injectedPositionControl),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, filterSvUsage) - QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, filterSvUsage_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, filterSvUsage),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, storeAssistData) - QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, storeAssistData_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, storeAssistData),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, enableFasterTTFF) - QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, enableFasterTTFF_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersReqMsgT_v02, enableFasterTTFF)
+};
+
+static const uint8_t qmiLocSetPositionEngineConfigParametersIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersIndMsgT_v02, failedPositionEngineConfigParamMask) - QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersIndMsgT_v02, failedPositionEngineConfigParamMask_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocSetPositionEngineConfigParametersIndMsgT_v02, failedPositionEngineConfigParamMask)
+};
+
+static const uint8_t qmiLocGetPositionEngineConfigParametersReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersReqMsgT_v02, getPositionEngineConfigParamMask)
+};
+
+static const uint8_t qmiLocGetPositionEngineConfigParametersIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, injectedPositionControl) - QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, injectedPositionControl_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, injectedPositionControl),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, filterSvUsage) - QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, filterSvUsage_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, filterSvUsage),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, storeAssistData) - QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, storeAssistData_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, storeAssistData),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, enableFasterTTFF) - QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, enableFasterTTFF_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetPositionEngineConfigParametersIndMsgT_v02, enableFasterTTFF)
+};
+
+static const uint8_t qmiLocAddCircularGeofenceReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, transactionId),
+
+ 0x02,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, circularGeofenceArgs),
+ 32, 0,
+
+ 0x03,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, breachMask),
+
+ 0x04,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, includePosition),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, responsiveness) - QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, responsiveness_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, responsiveness),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, confidence) - QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, confidence_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceReqMsgT_v02, confidence)
+};
+
+static const uint8_t qmiLocAddCircularGeofenceIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, transactionId) - QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, transactionId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, transactionId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, geofenceId) - QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, geofenceId_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocAddCircularGeofenceIndMsgT_v02, geofenceId)
+};
+
+static const uint8_t qmiLocDeleteGeofenceReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteGeofenceReqMsgT_v02, geofenceId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteGeofenceReqMsgT_v02, transactionId)
+};
+
+static const uint8_t qmiLocDeleteGeofenceIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, geofenceId) - QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, geofenceId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, geofenceId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, transactionId) - QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, transactionId_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocDeleteGeofenceIndMsgT_v02, transactionId)
+};
+
+static const uint8_t qmiLocQueryGeofenceReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceReqMsgT_v02, geofenceId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceReqMsgT_v02, transactionId)
+};
+
+static const uint8_t qmiLocQueryGeofenceIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceId) - QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, transactionId) - QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, transactionId_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, transactionId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceOrigin) - QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceOrigin_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceOrigin),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, posWrtGeofence) - QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, posWrtGeofence_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, posWrtGeofence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, circularGeofenceArgs) - QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, circularGeofenceArgs_valid)),
+ 0x14,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, circularGeofenceArgs),
+ 32, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceState) - QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceState_valid)),
+ 0x15,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocQueryGeofenceIndMsgT_v02, geofenceState)
+};
+
+static const uint8_t qmiLocEditGeofenceReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, geofenceId),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, transactionId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, geofenceState) - QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, geofenceState_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, geofenceState),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, breachMask) - QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, breachMask_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceReqMsgT_v02, breachMask)
+};
+
+static const uint8_t qmiLocEditGeofenceIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, geofenceId) - QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, geofenceId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, geofenceId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, transactionId) - QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, transactionId_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, transactionId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, failedParams) - QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, failedParams_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEditGeofenceIndMsgT_v02, failedParams)
+};
+
+static const uint8_t qmiLocGetBestAvailablePositionReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionReqMsgT_v02, transactionId)
+};
+
+static const uint8_t qmiLocGetBestAvailablePositionIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, transactionId) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, transactionId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, transactionId),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, latitude) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, latitude_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, latitude),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, longitude) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, longitude_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, longitude),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncCircular) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncCircular_valid)),
+ 0x13,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncCircular),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, altitudeWrtEllipsoid) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, altitudeWrtEllipsoid_valid)),
+ 0x14,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, altitudeWrtEllipsoid),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertUnc) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertUnc_valid)),
+ 0x15,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, timestampUtc) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, timestampUtc_valid)),
+ 0x16,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, timestampUtc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, timeUnc) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, timeUnc_valid)),
+ 0x17,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, timeUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseSemiMinor) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseSemiMinor_valid)),
+ 0x18,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseSemiMinor),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseSemiMajor) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseSemiMajor_valid)),
+ 0x19,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseSemiMajor),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseOrientAzimuth) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseOrientAzimuth_valid)),
+ 0x1A,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horUncEllipseOrientAzimuth),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horCircularConfidence) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horCircularConfidence_valid)),
+ 0x1B,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horCircularConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horEllipticalConfidence) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horEllipticalConfidence_valid)),
+ 0x1C,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horEllipticalConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horReliability) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horReliability_valid)),
+ 0x1D,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horReliability),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horSpeed) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horSpeed_valid)),
+ 0x1E,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horSpeed),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horSpeedUnc) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horSpeedUnc_valid)),
+ 0x1F,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, horSpeedUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, altitudeWrtMeanSeaLevel) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, altitudeWrtMeanSeaLevel_valid)),
+ 0x20,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, altitudeWrtMeanSeaLevel),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertConfidence) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertConfidence_valid)),
+ 0x21,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertReliability) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertReliability_valid)),
+ 0x22,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertReliability),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertSpeed) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertSpeed_valid)),
+ 0x23,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertSpeed),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertSpeedUnc) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertSpeedUnc_valid)),
+ 0x24,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, vertSpeedUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, heading) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, heading_valid)),
+ 0x25,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, heading),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, headingUnc) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, headingUnc_valid)),
+ 0x26,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, headingUnc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, magneticDeviation) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, magneticDeviation_valid)),
+ 0x27,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, magneticDeviation),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, technologyMask) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, technologyMask_valid)),
+ 0x28,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, technologyMask),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, DOP) - QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, DOP_valid)),
+ 0x29,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocGetBestAvailablePositionIndMsgT_v02, DOP),
+ 2, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, gpsTime) - QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, gpsTime_valid)),
+ 0x2A,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocGetBestAvailablePositionIndMsgT_v02, gpsTime),
+ 1, 0,
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, timeSrc) - QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, timeSrc_valid)),
+ 0x2B,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocGetBestAvailablePositionIndMsgT_v02, timeSrc),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, sensorDataUsage) - QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, sensorDataUsage_valid)),
+ 0x2C,
+ QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocGetBestAvailablePositionIndMsgT_v02, sensorDataUsage),
+ 3, 0,
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, gnssSvUsedList) - QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, gnssSvUsedList_valid)),
+ 0x2D,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_FLAGS_OFFSET_IS_16 | QMI_IDL_GENERIC_2_BYTE,
+ QMI_IDL_OFFSET16ARRAY(qmiLocGetBestAvailablePositionIndMsgT_v02, gnssSvUsedList),
+ QMI_LOC_MAX_SV_USED_LIST_LENGTH_V02,
+ QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, gnssSvUsedList) - QMI_IDL_OFFSET16RELATIVE(qmiLocGetBestAvailablePositionIndMsgT_v02, gnssSvUsedList_len)
+};
+
+static const uint8_t qmiLocInjectMotionDataReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectMotionDataReqMsgT_v02, motion_data),
+ 33, 0
+};
+
+static const uint8_t qmiLocInjectMotionDataIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectMotionDataIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocGetNiGeofenceIdListReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListReqMsgT_v02, transactionId)
+};
+
+static const uint8_t qmiLocGetNiGeofenceIdListIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, status),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, transactionId) - QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, transactionId_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, transactionId),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, niGeofenceIdList) - QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, niGeofenceIdList_valid)),
+ 0x11,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, niGeofenceIdList),
+ QMI_LOC_MAX_NI_GEOFENCE_ID_LIST_LENGTH_V02,
+ QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, niGeofenceIdList) - QMI_IDL_OFFSET8(qmiLocGetNiGeofenceIdListIndMsgT_v02, niGeofenceIdList_len)
+};
+
+static const uint8_t qmiLocInjectGSMCellInfoReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectGSMCellInfoReqMsgT_v02, gsmCellId),
+ 34, 0,
+
+ 0x02,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectGSMCellInfoReqMsgT_v02, roamingStatus),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectGSMCellInfoReqMsgT_v02, timingAdvance) - QMI_IDL_OFFSET8(qmiLocInjectGSMCellInfoReqMsgT_v02, timingAdvance_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectGSMCellInfoReqMsgT_v02, timingAdvance)
+};
+
+static const uint8_t qmiLocInjectGSMCellInfoIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectGSMCellInfoIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectNetworkInitiatedMessageReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectNetworkInitiatedMessageReqMsgT_v02, injectedNIMessageType),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x02,
+ QMI_IDL_FLAGS_IS_ARRAY | QMI_IDL_FLAGS_IS_VARIABLE_LEN | QMI_IDL_FLAGS_SZ_IS_16 | QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectNetworkInitiatedMessageReqMsgT_v02, injectedNIMessage),
+ ((QMI_LOC_MAX_INJECTED_NETWORK_INITIATED_MESSAGE_LENGTH_V02) & 0xFF), ((QMI_LOC_MAX_INJECTED_NETWORK_INITIATED_MESSAGE_LENGTH_V02) >> 8),
+ QMI_IDL_OFFSET8(qmiLocInjectNetworkInitiatedMessageReqMsgT_v02, injectedNIMessage) - QMI_IDL_OFFSET8(qmiLocInjectNetworkInitiatedMessageReqMsgT_v02, injectedNIMessage_len)
+};
+
+static const uint8_t qmiLocInjectNetworkInitiatedMessageIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectNetworkInitiatedMessageIndMsgT_v02, status)
+};
+
+/*
+ * qmiLocWWANOutOfServiceNotificationReqMsgT is empty
+ * static const uint8_t qmiLocWWANOutOfServiceNotificationReqMsgT_data_v02[] = {
+ * };
+ */
+
+static const uint8_t qmiLocWWANOutOfServiceNotificationIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocWWANOutOfServiceNotificationIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocEventPedometerControlIndMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, requestPedometerData),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, resetStepCount) - QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, resetStepCount_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, resetStepCount),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, stepCountThreshold) - QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, stepCountThreshold_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventPedometerControlIndMsgT_v02, stepCountThreshold)
+};
+
+static const uint8_t qmiLocEventMotionDataControlIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocEventMotionDataControlIndMsgT_v02, requestMotionData)
+};
+
+static const uint8_t qmiLocPedometerReportReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, timeSource),
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, timestamp),
+
+ 0x03,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, timeInterval),
+
+ 0x04,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepCount),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepConfidence) - QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepConfidence_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_1_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepConfidence),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepCountUncertainty) - QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepCountUncertainty_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepCountUncertainty),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepRate) - QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepRate_valid)),
+ 0x12,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportReqMsgT_v02, stepRate)
+};
+
+static const uint8_t qmiLocPedometerReportIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocPedometerReportIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectWCDMACellInfoReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, wcdmaCellId),
+ 38, 0,
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, roamingStatus),
+
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, freq) - QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, freq_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, freq),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, psc) - QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, psc_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoReqMsgT_v02, psc)
+};
+
+static const uint8_t qmiLocInjectWCDMACellInfoIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectWCDMACellInfoIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectTDSCDMACellInfoReqMsgT_data_v02[] = {
+ 0x01,
+ QMI_IDL_AGGREGATE,
+ QMI_IDL_OFFSET8(qmiLocInjectTDSCDMACellInfoReqMsgT_v02, tdscdmaCellId),
+ 39, 0,
+
+ 0x02,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTDSCDMACellInfoReqMsgT_v02, roamingStatus),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectTDSCDMACellInfoReqMsgT_v02, freq) - QMI_IDL_OFFSET8(qmiLocInjectTDSCDMACellInfoReqMsgT_v02, freq_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTDSCDMACellInfoReqMsgT_v02, freq)
+};
+
+static const uint8_t qmiLocInjectTDSCDMACellInfoIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectTDSCDMACellInfoIndMsgT_v02, status)
+};
+
+static const uint8_t qmiLocInjectSubscriberIDReqMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDReqMsgT_v02, preferredIMSI) - QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDReqMsgT_v02, preferredIMSI_valid)),
+ 0x10,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDReqMsgT_v02, preferredIMSI),
+
+ QMI_IDL_TLV_FLAGS_LAST_TLV | QMI_IDL_TLV_FLAGS_OPTIONAL | (QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDReqMsgT_v02, preferredMSISDN) - QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDReqMsgT_v02, preferredMSISDN_valid)),
+ 0x11,
+ QMI_IDL_GENERIC_8_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDReqMsgT_v02, preferredMSISDN)
+};
+
+static const uint8_t qmiLocInjectSubscriberIDIndMsgT_data_v02[] = {
+ QMI_IDL_TLV_FLAGS_LAST_TLV | 0x01,
+ QMI_IDL_GENERIC_4_BYTE,
+ QMI_IDL_OFFSET8(qmiLocInjectSubscriberIDIndMsgT_v02, status)
+};
+
+/* Type Table */
+static const qmi_idl_type_table_entry loc_type_table_v02[] = {
+ {sizeof(qmiLocApplicationIdStructT_v02), qmiLocApplicationIdStructT_data_v02},
+ {sizeof(qmiLocGPSTimeStructT_v02), qmiLocGPSTimeStructT_data_v02},
+ {sizeof(qmiLocDOPStructT_v02), qmiLocDOPStructT_data_v02},
+ {sizeof(qmiLocSensorUsageIndicatorStructT_v02), qmiLocSensorUsageIndicatorStructT_data_v02},
+ {sizeof(qmiLocSvInfoStructT_v02), qmiLocSvInfoStructT_data_v02},
+ {sizeof(qmiLocNiVxNotifyVerifyStructT_v02), qmiLocNiVxNotifyVerifyStructT_data_v02},
+ {sizeof(qmiLocNiSuplFormattedStringStructT_v02), qmiLocNiSuplFormattedStringStructT_data_v02},
+ {sizeof(qmiLocNiSuplQopStructT_v02), qmiLocNiSuplQopStructT_data_v02},
+ {sizeof(qmiLocIpV4AddrStructType_v02), qmiLocIpV4AddrStructType_data_v02},
+ {sizeof(qmiLocIpV6AddrStructType_v02), qmiLocIpV6AddrStructType_data_v02},
+ {sizeof(qmiLocNiSuplServerInfoStructT_v02), qmiLocNiSuplServerInfoStructT_data_v02},
+ {sizeof(qmiLocNiSuplNotifyVerifyStructT_v02), qmiLocNiSuplNotifyVerifyStructT_data_v02},
+ {sizeof(qmiLocNiUmtsCpCodedStringStructT_v02), qmiLocNiUmtsCpCodedStringStructT_data_v02},
+ {sizeof(qmiLocNiUmtsCpNotifyVerifyStructT_v02), qmiLocNiUmtsCpNotifyVerifyStructT_data_v02},
+ {sizeof(qmiLocNiVxServiceInteractionStructT_v02), qmiLocNiVxServiceInteractionStructT_data_v02},
+ {sizeof(qmiLocNiSuplVer2ExtStructT_v02), qmiLocNiSuplVer2ExtStructT_data_v02},
+ {sizeof(qmiLocAssistanceServerUrlStructT_v02), qmiLocAssistanceServerUrlStructT_data_v02},
+ {sizeof(qmiLocTimeServerListStructT_v02), qmiLocTimeServerListStructT_data_v02},
+ {sizeof(qmiLocPredictedOrbitsAllowedSizesStructT_v02), qmiLocPredictedOrbitsAllowedSizesStructT_data_v02},
+ {sizeof(qmiLocPredictedOrbitsServerListStructT_v02), qmiLocPredictedOrbitsServerListStructT_data_v02},
+ {sizeof(qmiLocSensorControlConfigSamplingSpecStructT_v02), qmiLocSensorControlConfigSamplingSpecStructT_data_v02},
+ {sizeof(qmiLocSensorReadyStatusStructT_v02), qmiLocSensorReadyStatusStructT_data_v02},
+ {sizeof(qmiLocGeofencePositionStructT_v02), qmiLocGeofencePositionStructT_data_v02},
+ {sizeof(qmiLocPredictedOrbitsDataValidityStructT_v02), qmiLocPredictedOrbitsDataValidityStructT_data_v02},
+ {sizeof(qmiLocAltitudeSrcInfoStructT_v02), qmiLocAltitudeSrcInfoStructT_data_v02},
+ {sizeof(qmiLocDeleteSvInfoStructT_v02), qmiLocDeleteSvInfoStructT_data_v02},
+ {sizeof(qmiLocWifiFixTimeStructT_v02), qmiLocWifiFixTimeStructT_data_v02},
+ {sizeof(qmiLocWifiFixPosStructT_v02), qmiLocWifiFixPosStructT_data_v02},
+ {sizeof(qmiLocWifiApInfoStructT_v02), qmiLocWifiApInfoStructT_data_v02},
+ {sizeof(qmiLoc3AxisSensorSampleStructT_v02), qmiLoc3AxisSensorSampleStructT_data_v02},
+ {sizeof(qmiLoc3AxisSensorSampleListStructT_v02), qmiLoc3AxisSensorSampleListStructT_data_v02},
+ {sizeof(qmiLocApnProfilesStructT_v02), qmiLocApnProfilesStructT_data_v02},
+ {sizeof(qmiLocCircularGeofenceArgsStructT_v02), qmiLocCircularGeofenceArgsStructT_data_v02},
+ {sizeof(qmiLocMotionDataStructT_v02), qmiLocMotionDataStructT_data_v02},
+ {sizeof(qmiLocGSMCellIdStructT_v02), qmiLocGSMCellIdStructT_data_v02},
+ {sizeof(qmiLocEmergencyNotificationStructT_v02), qmiLocEmergencyNotificationStructT_data_v02},
+ {sizeof(qmiLocSensorTemperatureSampleStructT_v02), qmiLocSensorTemperatureSampleStructT_data_v02},
+ {sizeof(qmiLocSensorTemperatureSampleListStructT_v02), qmiLocSensorTemperatureSampleListStructT_data_v02},
+ {sizeof(qmiLocWCDMACellIdStructT_v02), qmiLocWCDMACellIdStructT_data_v02},
+ {sizeof(qmiLocTDSCDMACellIdStructT_v02), qmiLocTDSCDMACellIdStructT_data_v02}
+};
+
+/* Message Table */
+static const qmi_idl_message_table_entry loc_message_table_v02[] = {
+ {sizeof(qmiLocGenRespMsgT_v02), qmiLocGenRespMsgT_data_v02},
+ {sizeof(qmiLocInformClientRevisionReqMsgT_v02), qmiLocInformClientRevisionReqMsgT_data_v02},
+ {sizeof(qmiLocRegEventsReqMsgT_v02), qmiLocRegEventsReqMsgT_data_v02},
+ {sizeof(qmiLocStartReqMsgT_v02), qmiLocStartReqMsgT_data_v02},
+ {sizeof(qmiLocStopReqMsgT_v02), qmiLocStopReqMsgT_data_v02},
+ {sizeof(qmiLocEventPositionReportIndMsgT_v02), qmiLocEventPositionReportIndMsgT_data_v02},
+ {sizeof(qmiLocEventGnssSvInfoIndMsgT_v02), qmiLocEventGnssSvInfoIndMsgT_data_v02},
+ {sizeof(qmiLocEventNmeaIndMsgT_v02), qmiLocEventNmeaIndMsgT_data_v02},
+ {sizeof(qmiLocEventNiNotifyVerifyReqIndMsgT_v02), qmiLocEventNiNotifyVerifyReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventInjectTimeReqIndMsgT_v02), qmiLocEventInjectTimeReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02), qmiLocEventInjectPredictedOrbitsReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventInjectPositionReqIndMsgT_v02), qmiLocEventInjectPositionReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventEngineStateIndMsgT_v02), qmiLocEventEngineStateIndMsgT_data_v02},
+ {sizeof(qmiLocEventFixSessionStateIndMsgT_v02), qmiLocEventFixSessionStateIndMsgT_data_v02},
+ {sizeof(qmiLocEventWifiReqIndMsgT_v02), qmiLocEventWifiReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventSensorStreamingReadyStatusIndMsgT_v02), qmiLocEventSensorStreamingReadyStatusIndMsgT_data_v02},
+ {sizeof(qmiLocEventTimeSyncReqIndMsgT_v02), qmiLocEventTimeSyncReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventSetSpiStreamingReportIndMsgT_v02), qmiLocEventSetSpiStreamingReportIndMsgT_data_v02},
+ {sizeof(qmiLocEventLocationServerConnectionReqIndMsgT_v02), qmiLocEventLocationServerConnectionReqIndMsgT_data_v02},
+ {sizeof(qmiLocEventNiGeofenceNotificationIndMsgT_v02), qmiLocEventNiGeofenceNotificationIndMsgT_data_v02},
+ {sizeof(qmiLocEventGeofenceGenAlertIndMsgT_v02), qmiLocEventGeofenceGenAlertIndMsgT_data_v02},
+ {sizeof(qmiLocEventGeofenceBreachIndMsgT_v02), qmiLocEventGeofenceBreachIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetServiceRevisionIndMsgT_v02), qmiLocGetServiceRevisionIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetFixCriteriaIndMsgT_v02), qmiLocGetFixCriteriaIndMsgT_data_v02},
+ {sizeof(qmiLocNiUserRespReqMsgT_v02), qmiLocNiUserRespReqMsgT_data_v02},
+ {sizeof(qmiLocNiUserRespIndMsgT_v02), qmiLocNiUserRespIndMsgT_data_v02},
+ {sizeof(qmiLocInjectPredictedOrbitsDataReqMsgT_v02), qmiLocInjectPredictedOrbitsDataReqMsgT_data_v02},
+ {sizeof(qmiLocInjectPredictedOrbitsDataIndMsgT_v02), qmiLocInjectPredictedOrbitsDataIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02), qmiLocGetPredictedOrbitsDataSourceIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02), qmiLocGetPredictedOrbitsDataValidityIndMsgT_data_v02},
+ {sizeof(qmiLocInjectUtcTimeReqMsgT_v02), qmiLocInjectUtcTimeReqMsgT_data_v02},
+ {sizeof(qmiLocInjectUtcTimeIndMsgT_v02), qmiLocInjectUtcTimeIndMsgT_data_v02},
+ {sizeof(qmiLocInjectPositionReqMsgT_v02), qmiLocInjectPositionReqMsgT_data_v02},
+ {sizeof(qmiLocInjectPositionIndMsgT_v02), qmiLocInjectPositionIndMsgT_data_v02},
+ {sizeof(qmiLocSetEngineLockReqMsgT_v02), qmiLocSetEngineLockReqMsgT_data_v02},
+ {sizeof(qmiLocSetEngineLockIndMsgT_v02), qmiLocSetEngineLockIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetEngineLockIndMsgT_v02), qmiLocGetEngineLockIndMsgT_data_v02},
+ {sizeof(qmiLocSetSbasConfigReqMsgT_v02), qmiLocSetSbasConfigReqMsgT_data_v02},
+ {sizeof(qmiLocSetSbasConfigIndMsgT_v02), qmiLocSetSbasConfigIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetSbasConfigIndMsgT_v02), qmiLocGetSbasConfigIndMsgT_data_v02},
+ {sizeof(qmiLocSetNmeaTypesReqMsgT_v02), qmiLocSetNmeaTypesReqMsgT_data_v02},
+ {sizeof(qmiLocSetNmeaTypesIndMsgT_v02), qmiLocSetNmeaTypesIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetNmeaTypesIndMsgT_v02), qmiLocGetNmeaTypesIndMsgT_data_v02},
+ {sizeof(qmiLocSetLowPowerModeReqMsgT_v02), qmiLocSetLowPowerModeReqMsgT_data_v02},
+ {sizeof(qmiLocSetLowPowerModeIndMsgT_v02), qmiLocSetLowPowerModeIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetLowPowerModeIndMsgT_v02), qmiLocGetLowPowerModeIndMsgT_data_v02},
+ {sizeof(qmiLocSetServerReqMsgT_v02), qmiLocSetServerReqMsgT_data_v02},
+ {sizeof(qmiLocSetServerIndMsgT_v02), qmiLocSetServerIndMsgT_data_v02},
+ {sizeof(qmiLocGetServerReqMsgT_v02), qmiLocGetServerReqMsgT_data_v02},
+ {sizeof(qmiLocGetServerIndMsgT_v02), qmiLocGetServerIndMsgT_data_v02},
+ {sizeof(qmiLocDeleteAssistDataReqMsgT_v02), qmiLocDeleteAssistDataReqMsgT_data_v02},
+ {sizeof(qmiLocDeleteAssistDataIndMsgT_v02), qmiLocDeleteAssistDataIndMsgT_data_v02},
+ {sizeof(qmiLocSetXtraTSessionControlReqMsgT_v02), qmiLocSetXtraTSessionControlReqMsgT_data_v02},
+ {sizeof(qmiLocSetXtraTSessionControlIndMsgT_v02), qmiLocSetXtraTSessionControlIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetXtraTSessionControlIndMsgT_v02), qmiLocGetXtraTSessionControlIndMsgT_data_v02},
+ {sizeof(qmiLocInjectWifiPositionReqMsgT_v02), qmiLocInjectWifiPositionReqMsgT_data_v02},
+ {sizeof(qmiLocInjectWifiPositionIndMsgT_v02), qmiLocInjectWifiPositionIndMsgT_data_v02},
+ {sizeof(qmiLocNotifyWifiStatusReqMsgT_v02), qmiLocNotifyWifiStatusReqMsgT_data_v02},
+ {sizeof(qmiLocNotifyWifiStatusIndMsgT_v02), qmiLocNotifyWifiStatusIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetRegisteredEventsIndMsgT_v02), qmiLocGetRegisteredEventsIndMsgT_data_v02},
+ {sizeof(qmiLocSetOperationModeReqMsgT_v02), qmiLocSetOperationModeReqMsgT_data_v02},
+ {sizeof(qmiLocSetOperationModeIndMsgT_v02), qmiLocSetOperationModeIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetOperationModeIndMsgT_v02), qmiLocGetOperationModeIndMsgT_data_v02},
+ {sizeof(qmiLocSetSpiStatusReqMsgT_v02), qmiLocSetSpiStatusReqMsgT_data_v02},
+ {sizeof(qmiLocSetSpiStatusIndMsgT_v02), qmiLocSetSpiStatusIndMsgT_data_v02},
+ {sizeof(qmiLocInjectSensorDataReqMsgT_v02), qmiLocInjectSensorDataReqMsgT_data_v02},
+ {sizeof(qmiLocInjectSensorDataIndMsgT_v02), qmiLocInjectSensorDataIndMsgT_data_v02},
+ {sizeof(qmiLocInjectTimeSyncDataReqMsgT_v02), qmiLocInjectTimeSyncDataReqMsgT_data_v02},
+ {sizeof(qmiLocInjectTimeSyncDataIndMsgT_v02), qmiLocInjectTimeSyncDataIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetCradleMountConfigIndMsgT_v02), qmiLocGetCradleMountConfigIndMsgT_data_v02},
+ {sizeof(qmiLocSetCradleMountConfigReqMsgT_v02), qmiLocSetCradleMountConfigReqMsgT_data_v02},
+ {sizeof(qmiLocSetCradleMountConfigIndMsgT_v02), qmiLocSetCradleMountConfigIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetExternalPowerConfigIndMsgT_v02), qmiLocGetExternalPowerConfigIndMsgT_data_v02},
+ {sizeof(qmiLocSetExternalPowerConfigReqMsgT_v02), qmiLocSetExternalPowerConfigReqMsgT_data_v02},
+ {sizeof(qmiLocSetExternalPowerConfigIndMsgT_v02), qmiLocSetExternalPowerConfigIndMsgT_data_v02},
+ {sizeof(qmiLocInformLocationServerConnStatusReqMsgT_v02), qmiLocInformLocationServerConnStatusReqMsgT_data_v02},
+ {sizeof(qmiLocInformLocationServerConnStatusIndMsgT_v02), qmiLocInformLocationServerConnStatusIndMsgT_data_v02},
+ {sizeof(qmiLocSetProtocolConfigParametersReqMsgT_v02), qmiLocSetProtocolConfigParametersReqMsgT_data_v02},
+ {sizeof(qmiLocSetProtocolConfigParametersIndMsgT_v02), qmiLocSetProtocolConfigParametersIndMsgT_data_v02},
+ {sizeof(qmiLocGetProtocolConfigParametersReqMsgT_v02), qmiLocGetProtocolConfigParametersReqMsgT_data_v02},
+ {sizeof(qmiLocGetProtocolConfigParametersIndMsgT_v02), qmiLocGetProtocolConfigParametersIndMsgT_data_v02},
+ {sizeof(qmiLocSetSensorControlConfigReqMsgT_v02), qmiLocSetSensorControlConfigReqMsgT_data_v02},
+ {sizeof(qmiLocSetSensorControlConfigIndMsgT_v02), qmiLocSetSensorControlConfigIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetSensorControlConfigIndMsgT_v02), qmiLocGetSensorControlConfigIndMsgT_data_v02},
+ {sizeof(qmiLocSetSensorPropertiesReqMsgT_v02), qmiLocSetSensorPropertiesReqMsgT_data_v02},
+ {sizeof(qmiLocSetSensorPropertiesIndMsgT_v02), qmiLocSetSensorPropertiesIndMsgT_data_v02},
+ {sizeof(qmiLocGetSensorPropertiesReqMsgT_v02), qmiLocGetSensorPropertiesReqMsgT_data_v02},
+ {sizeof(qmiLocGetSensorPropertiesIndMsgT_v02), qmiLocGetSensorPropertiesIndMsgT_data_v02},
+ {sizeof(qmiLocSetSensorPerformanceControlConfigReqMsgT_v02), qmiLocSetSensorPerformanceControlConfigReqMsgT_data_v02},
+ {sizeof(qmiLocSetSensorPerformanceControlConfigIndMsgT_v02), qmiLocSetSensorPerformanceControlConfigIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocGetSensorPerformanceControlConfigIndMsgT_v02), qmiLocGetSensorPerformanceControlConfigIndMsgT_data_v02},
+ {sizeof(qmiLocInjectSuplCertificateReqMsgT_v02), qmiLocInjectSuplCertificateReqMsgT_data_v02},
+ {sizeof(qmiLocInjectSuplCertificateIndMsgT_v02), qmiLocInjectSuplCertificateIndMsgT_data_v02},
+ {sizeof(qmiLocDeleteSuplCertificateReqMsgT_v02), qmiLocDeleteSuplCertificateReqMsgT_data_v02},
+ {sizeof(qmiLocDeleteSuplCertificateIndMsgT_v02), qmiLocDeleteSuplCertificateIndMsgT_data_v02},
+ {sizeof(qmiLocSetPositionEngineConfigParametersReqMsgT_v02), qmiLocSetPositionEngineConfigParametersReqMsgT_data_v02},
+ {sizeof(qmiLocSetPositionEngineConfigParametersIndMsgT_v02), qmiLocSetPositionEngineConfigParametersIndMsgT_data_v02},
+ {sizeof(qmiLocGetPositionEngineConfigParametersReqMsgT_v02), qmiLocGetPositionEngineConfigParametersReqMsgT_data_v02},
+ {sizeof(qmiLocGetPositionEngineConfigParametersIndMsgT_v02), qmiLocGetPositionEngineConfigParametersIndMsgT_data_v02},
+ {sizeof(qmiLocAddCircularGeofenceReqMsgT_v02), qmiLocAddCircularGeofenceReqMsgT_data_v02},
+ {sizeof(qmiLocAddCircularGeofenceIndMsgT_v02), qmiLocAddCircularGeofenceIndMsgT_data_v02},
+ {sizeof(qmiLocDeleteGeofenceReqMsgT_v02), qmiLocDeleteGeofenceReqMsgT_data_v02},
+ {sizeof(qmiLocDeleteGeofenceIndMsgT_v02), qmiLocDeleteGeofenceIndMsgT_data_v02},
+ {sizeof(qmiLocQueryGeofenceReqMsgT_v02), qmiLocQueryGeofenceReqMsgT_data_v02},
+ {sizeof(qmiLocQueryGeofenceIndMsgT_v02), qmiLocQueryGeofenceIndMsgT_data_v02},
+ {sizeof(qmiLocEditGeofenceReqMsgT_v02), qmiLocEditGeofenceReqMsgT_data_v02},
+ {sizeof(qmiLocEditGeofenceIndMsgT_v02), qmiLocEditGeofenceIndMsgT_data_v02},
+ {sizeof(qmiLocGetBestAvailablePositionReqMsgT_v02), qmiLocGetBestAvailablePositionReqMsgT_data_v02},
+ {sizeof(qmiLocGetBestAvailablePositionIndMsgT_v02), qmiLocGetBestAvailablePositionIndMsgT_data_v02},
+ {sizeof(qmiLocInjectMotionDataReqMsgT_v02), qmiLocInjectMotionDataReqMsgT_data_v02},
+ {sizeof(qmiLocInjectMotionDataIndMsgT_v02), qmiLocInjectMotionDataIndMsgT_data_v02},
+ {sizeof(qmiLocGetNiGeofenceIdListReqMsgT_v02), qmiLocGetNiGeofenceIdListReqMsgT_data_v02},
+ {sizeof(qmiLocGetNiGeofenceIdListIndMsgT_v02), qmiLocGetNiGeofenceIdListIndMsgT_data_v02},
+ {sizeof(qmiLocInjectGSMCellInfoReqMsgT_v02), qmiLocInjectGSMCellInfoReqMsgT_data_v02},
+ {sizeof(qmiLocInjectGSMCellInfoIndMsgT_v02), qmiLocInjectGSMCellInfoIndMsgT_data_v02},
+ {sizeof(qmiLocInjectNetworkInitiatedMessageReqMsgT_v02), qmiLocInjectNetworkInitiatedMessageReqMsgT_data_v02},
+ {sizeof(qmiLocInjectNetworkInitiatedMessageIndMsgT_v02), qmiLocInjectNetworkInitiatedMessageIndMsgT_data_v02},
+ {0, 0},
+ {sizeof(qmiLocWWANOutOfServiceNotificationIndMsgT_v02), qmiLocWWANOutOfServiceNotificationIndMsgT_data_v02},
+ {sizeof(qmiLocEventPedometerControlIndMsgT_v02), qmiLocEventPedometerControlIndMsgT_data_v02},
+ {sizeof(qmiLocEventMotionDataControlIndMsgT_v02), qmiLocEventMotionDataControlIndMsgT_data_v02},
+ {sizeof(qmiLocPedometerReportReqMsgT_v02), qmiLocPedometerReportReqMsgT_data_v02},
+ {sizeof(qmiLocPedometerReportIndMsgT_v02), qmiLocPedometerReportIndMsgT_data_v02},
+ {sizeof(qmiLocInjectWCDMACellInfoReqMsgT_v02), qmiLocInjectWCDMACellInfoReqMsgT_data_v02},
+ {sizeof(qmiLocInjectWCDMACellInfoIndMsgT_v02), qmiLocInjectWCDMACellInfoIndMsgT_data_v02},
+ {sizeof(qmiLocInjectTDSCDMACellInfoReqMsgT_v02), qmiLocInjectTDSCDMACellInfoReqMsgT_data_v02},
+ {sizeof(qmiLocInjectTDSCDMACellInfoIndMsgT_v02), qmiLocInjectTDSCDMACellInfoIndMsgT_data_v02},
+ {sizeof(qmiLocInjectSubscriberIDReqMsgT_v02), qmiLocInjectSubscriberIDReqMsgT_data_v02},
+ {sizeof(qmiLocInjectSubscriberIDIndMsgT_v02), qmiLocInjectSubscriberIDIndMsgT_data_v02}
+};
+
+/* Predefine the Type Table Object */
+static const qmi_idl_type_table_object loc_qmi_idl_type_table_object_v02;
+
+/*Referenced Tables Array*/
+static const qmi_idl_type_table_object *loc_qmi_idl_type_table_object_referenced_tables_v02[] =
+{&loc_qmi_idl_type_table_object_v02, &common_qmi_idl_type_table_object_v01};
+
+/*Type Table Object*/
+static const qmi_idl_type_table_object loc_qmi_idl_type_table_object_v02 = {
+ sizeof(loc_type_table_v02)/sizeof(qmi_idl_type_table_entry ),
+ sizeof(loc_message_table_v02)/sizeof(qmi_idl_message_table_entry),
+ 1,
+ loc_type_table_v02,
+ loc_message_table_v02,
+ loc_qmi_idl_type_table_object_referenced_tables_v02
+};
+
+/*Arrays of service_message_table_entries for commands, responses and indications*/
+static const qmi_idl_service_message_table_entry loc_service_command_messages_v02[] = {
+ {QMI_LOC_GET_SUPPORTED_MSGS_REQ_V02, QMI_IDL_TYPE16(1, 0), 0},
+ {QMI_LOC_GET_SUPPORTED_FIELDS_REQ_V02, QMI_IDL_TYPE16(1, 2), 5},
+ {QMI_LOC_INFORM_CLIENT_REVISION_REQ_V02, QMI_IDL_TYPE16(0, 1), 7},
+ {QMI_LOC_REG_EVENTS_REQ_V02, QMI_IDL_TYPE16(0, 2), 11},
+ {QMI_LOC_START_REQ_V02, QMI_IDL_TYPE16(0, 3), 103},
+ {QMI_LOC_STOP_REQ_V02, QMI_IDL_TYPE16(0, 4), 4},
+ {QMI_LOC_GET_SERVICE_REVISION_REQ_V02, QMI_IDL_TYPE16(0, 22), 0},
+ {QMI_LOC_GET_FIX_CRITERIA_REQ_V02, QMI_IDL_TYPE16(0, 24), 0},
+ {QMI_LOC_NI_USER_RESPONSE_REQ_V02, QMI_IDL_TYPE16(0, 26), 1345},
+ {QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02, QMI_IDL_TYPE16(0, 28), 1053},
+ {QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_REQ_V02, QMI_IDL_TYPE16(0, 30), 0},
+ {QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_REQ_V02, QMI_IDL_TYPE16(0, 32), 0},
+ {QMI_LOC_INJECT_UTC_TIME_REQ_V02, QMI_IDL_TYPE16(0, 34), 18},
+ {QMI_LOC_INJECT_POSITION_REQ_V02, QMI_IDL_TYPE16(0, 36), 112},
+ {QMI_LOC_SET_ENGINE_LOCK_REQ_V02, QMI_IDL_TYPE16(0, 38), 7},
+ {QMI_LOC_GET_ENGINE_LOCK_REQ_V02, QMI_IDL_TYPE16(0, 40), 0},
+ {QMI_LOC_SET_SBAS_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 42), 4},
+ {QMI_LOC_GET_SBAS_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 44), 0},
+ {QMI_LOC_SET_NMEA_TYPES_REQ_V02, QMI_IDL_TYPE16(0, 46), 7},
+ {QMI_LOC_GET_NMEA_TYPES_REQ_V02, QMI_IDL_TYPE16(0, 48), 0},
+ {QMI_LOC_SET_LOW_POWER_MODE_REQ_V02, QMI_IDL_TYPE16(0, 50), 4},
+ {QMI_LOC_GET_LOW_POWER_MODE_REQ_V02, QMI_IDL_TYPE16(0, 52), 0},
+ {QMI_LOC_SET_SERVER_REQ_V02, QMI_IDL_TYPE16(0, 54), 297},
+ {QMI_LOC_GET_SERVER_REQ_V02, QMI_IDL_TYPE16(0, 56), 11},
+ {QMI_LOC_DELETE_ASSIST_DATA_REQ_V02, QMI_IDL_TYPE16(0, 58), 929},
+ {QMI_LOC_SET_XTRA_T_SESSION_CONTROL_REQ_V02, QMI_IDL_TYPE16(0, 60), 4},
+ {QMI_LOC_GET_XTRA_T_SESSION_CONTROL_REQ_V02, QMI_IDL_TYPE16(0, 62), 0},
+ {QMI_LOC_INJECT_WIFI_POSITION_REQ_V02, QMI_IDL_TYPE16(0, 64), 694},
+ {QMI_LOC_NOTIFY_WIFI_STATUS_REQ_V02, QMI_IDL_TYPE16(0, 66), 7},
+ {QMI_LOC_GET_REGISTERED_EVENTS_REQ_V02, QMI_IDL_TYPE16(0, 68), 0},
+ {QMI_LOC_SET_OPERATION_MODE_REQ_V02, QMI_IDL_TYPE16(0, 70), 7},
+ {QMI_LOC_GET_OPERATION_MODE_REQ_V02, QMI_IDL_TYPE16(0, 72), 0},
+ {QMI_LOC_SET_SPI_STATUS_REQ_V02, QMI_IDL_TYPE16(0, 74), 8},
+ {QMI_LOC_INJECT_SENSOR_DATA_REQ_V02, QMI_IDL_TYPE16(0, 76), 2063},
+ {QMI_LOC_INJECT_TIME_SYNC_DATA_REQ_V02, QMI_IDL_TYPE16(0, 78), 21},
+ {QMI_LOC_SET_CRADLE_MOUNT_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 82), 11},
+ {QMI_LOC_GET_CRADLE_MOUNT_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 80), 0},
+ {QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 86), 7},
+ {QMI_LOC_GET_EXTERNAL_POWER_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 84), 0},
+ {QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02, QMI_IDL_TYPE16(0, 88), 129},
+ {QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02, QMI_IDL_TYPE16(0, 90), 53},
+ {QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02, QMI_IDL_TYPE16(0, 92), 11},
+ {QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 94), 7},
+ {QMI_LOC_GET_SENSOR_CONTROL_CONFIG_REQ_V02, QMI_IDL_TYPE16(0, 96), 0},
+ {QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02, QMI_IDL_TYPE16(0, 98), 35},
+ {QMI_LOC_GET_SENSOR_PROPERTIES_REQ_V02, QMI_IDL_TYPE16(0, 100), 7},
+ {QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02, QMI_IDL_TYPE16(0, 102), 42},
+ {QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02, QMI_IDL_TYPE16(0, 104), 0},
+ {QMI_LOC_INJECT_SUPL_CERTIFICATE_REQ_V02, QMI_IDL_TYPE16(0, 106), 2009},
+ {QMI_LOC_DELETE_SUPL_CERTIFICATE_REQ_V02, QMI_IDL_TYPE16(0, 108), 4},
+ {QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02, QMI_IDL_TYPE16(0, 110), 16},
+ {QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02, QMI_IDL_TYPE16(0, 112), 7},
+ {QMI_LOC_ADD_CIRCULAR_GEOFENCE_REQ_V02, QMI_IDL_TYPE16(0, 114), 52},
+ {QMI_LOC_DELETE_GEOFENCE_REQ_V02, QMI_IDL_TYPE16(0, 116), 14},
+ {QMI_LOC_QUERY_GEOFENCE_REQ_V02, QMI_IDL_TYPE16(0, 118), 14},
+ {QMI_LOC_EDIT_GEOFENCE_REQ_V02, QMI_IDL_TYPE16(0, 120), 25},
+ {QMI_LOC_GET_BEST_AVAILABLE_POSITION_REQ_V02, QMI_IDL_TYPE16(0, 122), 7},
+ {QMI_LOC_INJECT_MOTION_DATA_REQ_V02, QMI_IDL_TYPE16(0, 124), 19},
+ {QMI_LOC_GET_NI_GEOFENCE_ID_LIST_REQ_V02, QMI_IDL_TYPE16(0, 126), 7},
+ {QMI_LOC_INJECT_GSM_CELL_INFO_REQ_V02, QMI_IDL_TYPE16(0, 128), 30},
+ {QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_REQ_V02, QMI_IDL_TYPE16(0, 130), 1036},
+ {QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_REQ_V02, QMI_IDL_TYPE16(0, 132), 0},
+ {QMI_LOC_PEDOMETER_REPORT_REQ_V02, QMI_IDL_TYPE16(0, 136), 46},
+ {QMI_LOC_INJECT_WCDMA_CELL_INFO_REQ_V02, QMI_IDL_TYPE16(0, 138), 36},
+ {QMI_LOC_INJECT_TDSCDMA_CELL_INFO_REQ_V02, QMI_IDL_TYPE16(0, 140), 33},
+ {QMI_LOC_INJECT_SUBSCRIBER_ID_REQ_V02, QMI_IDL_TYPE16(0, 142), 22}
+};
+
+static const qmi_idl_service_message_table_entry loc_service_response_messages_v02[] = {
+ {QMI_LOC_GET_SUPPORTED_MSGS_RESP_V02, QMI_IDL_TYPE16(1, 1), 8204},
+ {QMI_LOC_GET_SUPPORTED_FIELDS_RESP_V02, QMI_IDL_TYPE16(1, 3), 115},
+ {QMI_LOC_INFORM_CLIENT_REVISION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_REG_EVENTS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_START_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_STOP_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_SERVICE_REVISION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_FIX_CRITERIA_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_NI_USER_RESPONSE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_UTC_TIME_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_POSITION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_ENGINE_LOCK_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_ENGINE_LOCK_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_SBAS_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_SBAS_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_NMEA_TYPES_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_NMEA_TYPES_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_LOW_POWER_MODE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_LOW_POWER_MODE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_SERVER_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_SERVER_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_DELETE_ASSIST_DATA_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_XTRA_T_SESSION_CONTROL_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_XTRA_T_SESSION_CONTROL_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_WIFI_POSITION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_NOTIFY_WIFI_STATUS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_REGISTERED_EVENTS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_OPERATION_MODE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_OPERATION_MODE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_SPI_STATUS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_SENSOR_DATA_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_TIME_SYNC_DATA_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_CRADLE_MOUNT_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_CRADLE_MOUNT_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_EXTERNAL_POWER_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_EXTERNAL_POWER_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_SENSOR_CONTROL_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_SENSOR_CONTROL_CONFIG_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_SENSOR_PROPERTIES_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_SENSOR_PROPERTIES_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_SUPL_CERTIFICATE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_DELETE_SUPL_CERTIFICATE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_ADD_CIRCULAR_GEOFENCE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_DELETE_GEOFENCE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_QUERY_GEOFENCE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_EDIT_GEOFENCE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_BEST_AVAILABLE_POSITION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_MOTION_DATA_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_GET_NI_GEOFENCE_ID_LIST_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_GSM_CELL_INFO_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_PEDOMETER_REPORT_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_WCDMA_CELL_INFO_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_TDSCDMA_CELL_INFO_RESP_V02, QMI_IDL_TYPE16(0, 0), 7},
+ {QMI_LOC_INJECT_SUBSCRIBER_ID_RESP_V02, QMI_IDL_TYPE16(0, 0), 7}
+};
+
+static const qmi_idl_service_message_table_entry loc_service_indication_messages_v02[] = {
+ {QMI_LOC_EVENT_POSITION_REPORT_IND_V02, QMI_IDL_TYPE16(0, 5), 392},
+ {QMI_LOC_EVENT_GNSS_SV_INFO_IND_V02, QMI_IDL_TYPE16(0, 6), 2248},
+ {QMI_LOC_EVENT_NMEA_IND_V02, QMI_IDL_TYPE16(0, 7), 203},
+ {QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02, QMI_IDL_TYPE16(0, 8), 1338},
+ {QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02, QMI_IDL_TYPE16(0, 9), 776},
+ {QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02, QMI_IDL_TYPE16(0, 10), 783},
+ {QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02, QMI_IDL_TYPE16(0, 11), 40},
+ {QMI_LOC_EVENT_ENGINE_STATE_IND_V02, QMI_IDL_TYPE16(0, 12), 7},
+ {QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02, QMI_IDL_TYPE16(0, 13), 11},
+ {QMI_LOC_EVENT_WIFI_REQ_IND_V02, QMI_IDL_TYPE16(0, 14), 12},
+ {QMI_LOC_EVENT_SENSOR_STREAMING_READY_STATUS_IND_V02, QMI_IDL_TYPE16(0, 15), 32},
+ {QMI_LOC_EVENT_TIME_SYNC_REQ_IND_V02, QMI_IDL_TYPE16(0, 16), 7},
+ {QMI_LOC_EVENT_SET_SPI_STREAMING_REPORT_IND_V02, QMI_IDL_TYPE16(0, 17), 4},
+ {QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02, QMI_IDL_TYPE16(0, 18), 21},
+ {QMI_LOC_GET_SERVICE_REVISION_IND_V02, QMI_IDL_TYPE16(0, 23), 532},
+ {QMI_LOC_GET_FIX_CRITERIA_IND_V02, QMI_IDL_TYPE16(0, 25), 99},
+ {QMI_LOC_NI_USER_RESPONSE_IND_V02, QMI_IDL_TYPE16(0, 27), 7},
+ {QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02, QMI_IDL_TYPE16(0, 29), 12},
+ {QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_IND_V02, QMI_IDL_TYPE16(0, 31), 790},
+ {QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_IND_V02, QMI_IDL_TYPE16(0, 33), 20},
+ {QMI_LOC_INJECT_UTC_TIME_IND_V02, QMI_IDL_TYPE16(0, 35), 7},
+ {QMI_LOC_INJECT_POSITION_IND_V02, QMI_IDL_TYPE16(0, 37), 7},
+ {QMI_LOC_SET_ENGINE_LOCK_IND_V02, QMI_IDL_TYPE16(0, 39), 7},
+ {QMI_LOC_GET_ENGINE_LOCK_IND_V02, QMI_IDL_TYPE16(0, 41), 14},
+ {QMI_LOC_SET_SBAS_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 43), 7},
+ {QMI_LOC_GET_SBAS_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 45), 11},
+ {QMI_LOC_SET_NMEA_TYPES_IND_V02, QMI_IDL_TYPE16(0, 47), 7},
+ {QMI_LOC_GET_NMEA_TYPES_IND_V02, QMI_IDL_TYPE16(0, 49), 14},
+ {QMI_LOC_SET_LOW_POWER_MODE_IND_V02, QMI_IDL_TYPE16(0, 51), 7},
+ {QMI_LOC_GET_LOW_POWER_MODE_IND_V02, QMI_IDL_TYPE16(0, 53), 11},
+ {QMI_LOC_SET_SERVER_IND_V02, QMI_IDL_TYPE16(0, 55), 7},
+ {QMI_LOC_GET_SERVER_IND_V02, QMI_IDL_TYPE16(0, 57), 304},
+ {QMI_LOC_DELETE_ASSIST_DATA_IND_V02, QMI_IDL_TYPE16(0, 59), 7},
+ {QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02, QMI_IDL_TYPE16(0, 61), 7},
+ {QMI_LOC_GET_XTRA_T_SESSION_CONTROL_IND_V02, QMI_IDL_TYPE16(0, 63), 11},
+ {QMI_LOC_INJECT_WIFI_POSITION_IND_V02, QMI_IDL_TYPE16(0, 65), 7},
+ {QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02, QMI_IDL_TYPE16(0, 67), 7},
+ {QMI_LOC_GET_REGISTERED_EVENTS_IND_V02, QMI_IDL_TYPE16(0, 69), 18},
+ {QMI_LOC_SET_OPERATION_MODE_IND_V02, QMI_IDL_TYPE16(0, 71), 7},
+ {QMI_LOC_GET_OPERATION_MODE_IND_V02, QMI_IDL_TYPE16(0, 73), 14},
+ {QMI_LOC_SET_SPI_STATUS_IND_V02, QMI_IDL_TYPE16(0, 75), 7},
+ {QMI_LOC_INJECT_SENSOR_DATA_IND_V02, QMI_IDL_TYPE16(0, 77), 30},
+ {QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02, QMI_IDL_TYPE16(0, 79), 7},
+ {QMI_LOC_SET_CRADLE_MOUNT_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 83), 7},
+ {QMI_LOC_GET_CRADLE_MOUNT_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 81), 18},
+ {QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 87), 7},
+ {QMI_LOC_GET_EXTERNAL_POWER_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 85), 14},
+ {QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02, QMI_IDL_TYPE16(0, 89), 7},
+ {QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02, QMI_IDL_TYPE16(0, 91), 18},
+ {QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02, QMI_IDL_TYPE16(0, 93), 60},
+ {QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 95), 7},
+ {QMI_LOC_GET_SENSOR_CONTROL_CONFIG_IND_V02, QMI_IDL_TYPE16(0, 97), 14},
+ {QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02, QMI_IDL_TYPE16(0, 99), 14},
+ {QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02, QMI_IDL_TYPE16(0, 101), 42},
+ {QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02, QMI_IDL_TYPE16(0, 103), 14},
+ {QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02, QMI_IDL_TYPE16(0, 105), 49},
+ {QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02, QMI_IDL_TYPE16(0, 107), 7},
+ {QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02, QMI_IDL_TYPE16(0, 109), 7},
+ {QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02, QMI_IDL_TYPE16(0, 111), 14},
+ {QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02, QMI_IDL_TYPE16(0, 113), 23},
+ {QMI_LOC_EVENT_NI_GEOFENCE_NOTIFICATION_IND_V02, QMI_IDL_TYPE16(0, 19), 14},
+ {QMI_LOC_EVENT_GEOFENCE_GEN_ALERT_IND_V02, QMI_IDL_TYPE16(0, 20), 7},
+ {QMI_LOC_EVENT_GEOFENCE_BREACH_NOTIFICATION_IND_V02, QMI_IDL_TYPE16(0, 21), 78},
+ {QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02, QMI_IDL_TYPE16(0, 115), 21},
+ {QMI_LOC_DELETE_GEOFENCE_IND_V02, QMI_IDL_TYPE16(0, 117), 21},
+ {QMI_LOC_QUERY_GEOFENCE_IND_V02, QMI_IDL_TYPE16(0, 119), 65},
+ {QMI_LOC_EDIT_GEOFENCE_IND_V02, QMI_IDL_TYPE16(0, 121), 28},
+ {QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02, QMI_IDL_TYPE16(0, 123), 391},
+ {QMI_LOC_INJECT_MOTION_DATA_IND_V02, QMI_IDL_TYPE16(0, 125), 7},
+ {QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02, QMI_IDL_TYPE16(0, 127), 82},
+ {QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02, QMI_IDL_TYPE16(0, 129), 7},
+ {QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02, QMI_IDL_TYPE16(0, 131), 7},
+ {QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_IND_V02, QMI_IDL_TYPE16(0, 133), 7},
+ {QMI_LOC_EVENT_PEDOMETER_CONTROL_IND_V02, QMI_IDL_TYPE16(0, 134), 15},
+ {QMI_LOC_EVENT_MOTION_DATA_CONTROL_IND_V02, QMI_IDL_TYPE16(0, 135), 4},
+ {QMI_LOC_PEDOMETER_REPORT_IND_V02, QMI_IDL_TYPE16(0, 137), 7},
+ {QMI_LOC_INJECT_WCDMA_CELL_INFO_IND_V02, QMI_IDL_TYPE16(0, 139), 7},
+ {QMI_LOC_INJECT_TDSCDMA_CELL_INFO_IND_V02, QMI_IDL_TYPE16(0, 141), 7},
+ {QMI_LOC_INJECT_SUBSCRIBER_ID_IND_V02, QMI_IDL_TYPE16(0, 143), 7}
+};
+
+/*Service Object*/
+struct qmi_idl_service_object loc_qmi_idl_service_object_v02 = {
+ 0x05,
+ 0x02,
+ 0x10,
+ 8204,
+ { sizeof(loc_service_command_messages_v02)/sizeof(qmi_idl_service_message_table_entry),
+ sizeof(loc_service_response_messages_v02)/sizeof(qmi_idl_service_message_table_entry),
+ sizeof(loc_service_indication_messages_v02)/sizeof(qmi_idl_service_message_table_entry) },
+ { loc_service_command_messages_v02, loc_service_response_messages_v02, loc_service_indication_messages_v02},
+ &loc_qmi_idl_type_table_object_v02,
+ 0x14,
+ NULL
+};
+
+/* Service Object Accessor */
+qmi_idl_service_object_type loc_get_service_object_internal_v02
+ ( int32_t idl_maj_version, int32_t idl_min_version, int32_t library_version ){
+ if ( LOC_V02_IDL_MAJOR_VERS != idl_maj_version || LOC_V02_IDL_MINOR_VERS != idl_min_version
+ || LOC_V02_IDL_TOOL_VERS != library_version)
+ {
+ return NULL;
+ }
+ return (qmi_idl_service_object_type)&loc_qmi_idl_service_object_v02;
+}
diff --git a/loc_api/loc_api_v02/location_service_v02.h b/loc_api/loc_api_v02/location_service_v02.h
new file mode 100644
index 0000000..e6665c0
--- /dev/null
+++ b/loc_api/loc_api_v02/location_service_v02.h
@@ -0,0 +1,8862 @@
+/* Copyright (c) 2011-2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef LOC_SERVICE_H
+#define LOC_SERVICE_H
+/**
+ @file location_service_v02.h
+
+ @brief This is the public header file which defines the loc service Data structures.
+
+ This header file defines the types and structures that were defined in
+ loc. It contains the constant values defined, enums, structures,
+ messages, and service message IDs (in that order) Structures that were
+ defined in the IDL as messages contain mandatory elements, optional
+ elements, a combination of mandatory and optional elements (mandatory
+ always come before optionals in the structure), or nothing (null message)
+
+ An optional element in a message is preceded by a uint8_t value that must be
+ set to true if the element is going to be included. When decoding a received
+ message, the uint8_t values will be set to true or false by the decode
+ routine, and should be checked before accessing the values that they
+ correspond to.
+
+ Variable sized arrays are defined as static sized arrays with an unsigned
+ integer (32 bit) preceding it that must be set to the number of elements
+ in the array that are valid. For Example:
+
+ uint32_t test_opaque_len;
+ uint8_t test_opaque[16];
+
+ If only 4 elements are added to test_opaque[] then test_opaque_len must be
+ set to 4 before sending the message. When decoding, the _len value is set
+ by the decode routine and should be checked so that the correct number of
+ elements in the array will be accessed.
+
+*/
+
+/*====*====*====*====*====*====*====*====*====*====*====*====*====*====*====*
+ *THIS IS AN AUTO GENERATED FILE. DO NOT ALTER IN ANY WAY
+ *====*====*====*====*====*====*====*====*====*====*====*====*====*====*====*/
+
+/* This file was generated with Tool version 6.1
+ It requires encode/decode library version 5 or later
+ It was generated on: Fri Mar 29 2013 (Spin 1)
+ From IDL File: location_service_v02.idl */
+
+/** @defgroup loc_qmi_consts Constant values defined in the IDL */
+/** @defgroup loc_qmi_msg_ids Constant values for QMI message IDs */
+/** @defgroup loc_qmi_enums Enumerated types used in QMI messages */
+/** @defgroup loc_qmi_messages Structures sent as QMI messages */
+/** @defgroup loc_qmi_aggregates Aggregate types used in QMI messages */
+/** @defgroup loc_qmi_accessor Accessor for QMI service object */
+/** @defgroup loc_qmi_version Constant values for versioning information */
+
+#include <stdint.h>
+#include "qmi_idl_lib.h"
+#include "common_v01.h"
+
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/** @addtogroup loc_qmi_version
+ @{
+ */
+/** Major Version Number of the IDL used to generate this file */
+#define LOC_V02_IDL_MAJOR_VERS 0x02
+/** Revision Number of the IDL used to generate this file */
+#define LOC_V02_IDL_MINOR_VERS 0x14
+/** Major Version Number of the qmi_idl_compiler used to generate this file */
+#define LOC_V02_IDL_TOOL_VERS 0x06
+/** Maximum Defined Message ID */
+#define LOC_V02_MAX_MESSAGE_ID 0x0072;
+/**
+ @}
+ */
+
+
+/** @addtogroup loc_qmi_consts
+ @{
+ */
+
+/** Maximum string length for the Provider field in the application ID. */
+#define QMI_LOC_MAX_APP_ID_PROVIDER_LENGTH_V02 24
+
+/** Maximum string length for the Name field in the application ID. */
+#define QMI_LOC_MAX_APP_ID_NAME_LENGTH_V02 32
+
+/** Maximum string length for the Version field in the application ID. */
+#define QMI_LOC_MAX_APP_ID_VERSION_LENGTH_V02 8
+
+/** Maximum length of the list containing the SVs that were used to generate
+ a position report. */
+#define QMI_LOC_MAX_SV_USED_LIST_LENGTH_V02 80
+
+/** Maximum number of satellites in the satellite report. */
+#define QMI_LOC_SV_INFO_LIST_MAX_SIZE_V02 80
+
+/** Maximum NMEA string length. */
+#define QMI_LOC_NMEA_STRING_MAX_LENGTH_V02 200
+
+/** Maximum length of the requestor ID string. */
+#define QMI_LOC_NI_MAX_REQUESTOR_ID_LENGTH_V02 200
+
+/** Session ID byte length. */
+#define QMI_LOC_NI_SUPL_SLP_SESSION_ID_BYTE_LENGTH_V02 4
+
+/** Maximum client name length allowed. */
+#define QMI_LOC_NI_MAX_CLIENT_NAME_LENGTH_V02 64
+
+/** Maximum URL length accepted by the location engine. */
+#define QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02 255
+
+/** IPV6 address length in bytes. */
+#define QMI_LOC_IPV6_ADDR_LENGTH_V02 8
+
+/** SUPL hash length. */
+#define QMI_LOC_NI_SUPL_HASH_LENGTH_V02 8
+
+/** Maximum client address length allowed. */
+#define QMI_LOC_NI_MAX_EXT_CLIENT_ADDRESS_V02 20
+
+/** Maximum codeword length allowed. */
+#define QMI_LOC_NI_CODEWORD_MAX_LENGTH_V02 20
+
+/** Maximum number of NTP Servers sent out with this event. */
+#define QMI_LOC_MAX_NTP_SERVERS_V02 3
+
+/** Maximum number of predicted orbits servers supported in the location
+ engine. */
+#define QMI_LOC_MAX_PREDICTED_ORBITS_SERVERS_V02 3
+
+/** Maximum GNSS Measurement Engine Firmware Version String length. */
+#define QMI_LOC_GNSS_ME_VERSION_STRING_MAX_LENGTH_V02 127
+
+/** Maximum GNSS Measurement Engine Hosted Software Version String length. */
+#define QMI_LOC_GNSS_HOSTED_SW_VERSION_STRING_MAX_LENGTH_V02 127
+
+/** Maximum GNSS Measurement Engine Full Version String length. */
+#define QMI_LOC_GNSS_SW_VERSION_STRING_MAX_LENGTH_V02 255
+
+/** Maximum part length that can be injected. The client should
+ also look at the maxPartSize field in the predicted orbits injection
+ request indication and pick the minimum of the two. */
+#define QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02 1024
+
+/** Maximum length of the delete SV information list */
+#define QMI_LOC_DELETE_MAX_SV_INFO_LENGTH_V02 128
+
+/** MAC address length in bytes. */
+#define QMI_LOC_WIFI_MAC_ADDR_LENGTH_V02 6
+
+/** Maximum number of APs that the sender can report. */
+#define QMI_LOC_WIFI_MAX_REPORTED_APS_PER_MSG_V02 50
+
+/** Maximum number of samples that can be injected in a TLV. */
+#define QMI_LOC_SENSOR_DATA_MAX_SAMPLES_V02 50
+
+/** Maximum APN string length allowed. */
+#define QMI_LOC_MAX_APN_NAME_LENGTH_V02 100
+
+/** Maximum APN profiles supported. */
+#define QMI_LOC_MAX_APN_PROFILES_V02 6
+
+/** Maximum length of the SUPL certificate. */
+#define QMI_LOC_MAX_SUPL_CERT_LENGTH_V02 2000
+
+/** Maximum length of the network-initiated Geofence ID
+ list. */
+#define QMI_LOC_MAX_NI_GEOFENCE_ID_LIST_LENGTH_V02 16
+
+/** Maximum value of WDMA frequency for injection of WCDMA cell
+ information. */
+#define QMI_LOC_MAX_WCDMA_FREQ_V02 16383
+
+/** Maximum value of PSC for injection of WCDMA cell information. */
+#define QMI_LOC_MAX_WCDMA_PSC_V02 511
+
+/** Maximum value of TDSCDMA frequency for injection of TDSCDMA cell
+ information. */
+#define QMI_LOC_MAX_TDSCDMA_FREQ_V02 16383
+
+/** Maximum length of the injected network-initiated message. */
+#define QMI_LOC_MAX_INJECTED_NETWORK_INITIATED_MESSAGE_LENGTH_V02 1024
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Response Message; Generic response definition. This message is used to tell
+ clients whether their message was accepted for further
+ processing or rejected. */
+typedef struct {
+
+ /* Mandatory */
+ /* Result Code */
+ qmi_response_type_v01 resp;
+}qmiLocGenRespMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Informs the service of the minor revision of the interface
+ definition that the control point implements. */
+typedef struct {
+
+ /* Mandatory */
+ /* Revision */
+ uint32_t revision;
+ /**< Revision that the control point is using. */
+}qmiLocInformClientRevisionReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint64_t qmiLocEventRegMaskT_v02;
+#define QMI_LOC_EVENT_MASK_POSITION_REPORT_V02 ((qmiLocEventRegMaskT_v02)0x00000001ull) /**< The control point must enable this mask to receive position report
+ event indications. */
+#define QMI_LOC_EVENT_MASK_GNSS_SV_INFO_V02 ((qmiLocEventRegMaskT_v02)0x00000002ull) /**< The control point must enable this mask to receive satellite report
+ event indications. These reports are sent at a 1 Hz rate. */
+#define QMI_LOC_EVENT_MASK_NMEA_V02 ((qmiLocEventRegMaskT_v02)0x00000004ull) /**< The control point must enable this mask to receive NMEA reports for
+ position and satellites in view. The report is at a 1 Hz rate. */
+#define QMI_LOC_EVENT_MASK_NI_NOTIFY_VERIFY_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00000008ull) /**< The control point must enable this mask to receive NI Notify/Verify request
+ event indications. */
+#define QMI_LOC_EVENT_MASK_INJECT_TIME_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00000010ull) /**< The control point must enable this mask to receive time injection request
+ event indications. */
+#define QMI_LOC_EVENT_MASK_INJECT_PREDICTED_ORBITS_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00000020ull) /**< The control point must enable this mask to receive predicted orbits request
+ event indications. */
+#define QMI_LOC_EVENT_MASK_INJECT_POSITION_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00000040ull) /**< The control point must enable this mask to receive position injection request
+ event indications. */
+#define QMI_LOC_EVENT_MASK_ENGINE_STATE_V02 ((qmiLocEventRegMaskT_v02)0x00000080ull) /**< The control point must enable this mask to receive engine state report
+ event indications. */
+#define QMI_LOC_EVENT_MASK_FIX_SESSION_STATE_V02 ((qmiLocEventRegMaskT_v02)0x00000100ull) /**< The control point must enable this mask to receive fix session status report
+ event indications. */
+#define QMI_LOC_EVENT_MASK_WIFI_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00000200ull) /**< The control point must enable this mask to receive WiFi position request
+ event indications. */
+#define QMI_LOC_EVENT_MASK_SENSOR_STREAMING_READY_STATUS_V02 ((qmiLocEventRegMaskT_v02)0x00000400ull) /**< The control point must enable this mask to receive notifications from the
+ GPS engine indicating its readiness to accept data from the
+ sensors (accelerometer, gyroscope, etc.). */
+#define QMI_LOC_EVENT_MASK_TIME_SYNC_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00000800ull) /**< The control point must enable this mask to receive time sync requests
+ from the GPS engine. Time sync enables the GPS engine to synchronize
+ its clock with the sensor processor's clock. */
+#define QMI_LOC_EVENT_MASK_SET_SPI_STREAMING_REPORT_V02 ((qmiLocEventRegMaskT_v02)0x00001000ull) /**< The control point must enable this mask to receive Stationary Position
+ Indicator (SPI) streaming report indications. */
+#define QMI_LOC_EVENT_MASK_LOCATION_SERVER_CONNECTION_REQ_V02 ((qmiLocEventRegMaskT_v02)0x00002000ull) /**< The control point must enable this mask to receive location server
+ requests. These requests are generated when the service wishes to
+ establish a connection with a location server. */
+#define QMI_LOC_EVENT_MASK_NI_GEOFENCE_NOTIFICATION_V02 ((qmiLocEventRegMaskT_v02)0x00004000ull) /**< The control point must enable this mask to receive notifications
+ related to network-initiated Geofences. These events notify the client
+ when a network-initiated Geofence is added, deleted, or edited. */
+#define QMI_LOC_EVENT_MASK_GEOFENCE_GEN_ALERT_V02 ((qmiLocEventRegMaskT_v02)0x00008000ull) /**< The control point must enable this mask to receive Geofence alerts.
+ These alerts are generated to inform the client of the changes that may
+ affect Geofence, e.g., if GPS is turned off or if the network is
+ unavailable. */
+#define QMI_LOC_EVENT_MASK_GEOFENCE_BREACH_NOTIFICATION_V02 ((qmiLocEventRegMaskT_v02)0x00010000ull) /**< The control point must enable this mask to receive notifications when
+ a Geofence is breached. These events are generated when the UE enters
+ or leaves the perimeter of a Geofence. */
+#define QMI_LOC_EVENT_MASK_PEDOMETER_CONTROL_V02 ((qmiLocEventRegMaskT_v02)0x00020000ull) /**< The control point must enable this mask to register for pedometer
+ control requests from the location engine. The location engine sends
+ this event to control the injection of pedometer reports. */
+#define QMI_LOC_EVENT_MASK_MOTION_DATA_CONTROL_V02 ((qmiLocEventRegMaskT_v02)0x00040000ull) /**< The control point must enable this mask to register for motion data
+ control requests from the location engine. The location engine sends
+ this event to control the injection of motion data. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to register for events from the
+ location subsystem. */
+typedef struct {
+
+ /* Mandatory */
+ /* Event Registration Mask */
+ qmiLocEventRegMaskT_v02 eventRegMask;
+ /**< Specifies the events that the control point is interested in receiving.
+ Valid bitmasks:
+ - QMI_LOC_EVENT_MASK_POSITION_REPORT (0x00000001) -- The control point must enable this mask to receive position report
+ event indications.
+ - QMI_LOC_EVENT_MASK_GNSS_SV_INFO (0x00000002) -- The control point must enable this mask to receive satellite report
+ event indications. These reports are sent at a 1 Hz rate.
+ - QMI_LOC_EVENT_MASK_NMEA (0x00000004) -- The control point must enable this mask to receive NMEA reports for
+ position and satellites in view. The report is at a 1 Hz rate.
+ - QMI_LOC_EVENT_MASK_NI_NOTIFY_VERIFY_REQ (0x00000008) -- The control point must enable this mask to receive NI Notify/Verify request
+ event indications.
+ - QMI_LOC_EVENT_MASK_INJECT_TIME_REQ (0x00000010) -- The control point must enable this mask to receive time injection request
+ event indications.
+ - QMI_LOC_EVENT_MASK_INJECT_PREDICTED_ORBITS_REQ (0x00000020) -- The control point must enable this mask to receive predicted orbits request
+ event indications.
+ - QMI_LOC_EVENT_MASK_INJECT_POSITION_REQ (0x00000040) -- The control point must enable this mask to receive position injection request
+ event indications.
+ - QMI_LOC_EVENT_MASK_ENGINE_STATE (0x00000080) -- The control point must enable this mask to receive engine state report
+ event indications.
+ - QMI_LOC_EVENT_MASK_FIX_SESSION_STATE (0x00000100) -- The control point must enable this mask to receive fix session status report
+ event indications.
+ - QMI_LOC_EVENT_MASK_WIFI_REQ (0x00000200) -- The control point must enable this mask to receive WiFi position request
+ event indications.
+ - QMI_LOC_EVENT_MASK_SENSOR_STREAMING_READY_STATUS (0x00000400) -- The control point must enable this mask to receive notifications from the
+ GPS engine indicating its readiness to accept data from the
+ sensors (accelerometer, gyroscope, etc.).
+ - QMI_LOC_EVENT_MASK_TIME_SYNC_REQ (0x00000800) -- The control point must enable this mask to receive time sync requests
+ from the GPS engine. Time sync enables the GPS engine to synchronize
+ its clock with the sensor processor's clock.
+ - QMI_LOC_EVENT_MASK_SET_SPI_STREAMING_REPORT (0x00001000) -- The control point must enable this mask to receive Stationary Position
+ Indicator (SPI) streaming report indications.
+ - QMI_LOC_EVENT_MASK_LOCATION_SERVER_CONNECTION_REQ (0x00002000) -- The control point must enable this mask to receive location server
+ requests. These requests are generated when the service wishes to
+ establish a connection with a location server.
+ - QMI_LOC_EVENT_MASK_NI_GEOFENCE_NOTIFICATION (0x00004000) -- The control point must enable this mask to receive notifications
+ related to network-initiated Geofences. These events notify the client
+ when a network-initiated Geofence is added, deleted, or edited.
+ - QMI_LOC_EVENT_MASK_GEOFENCE_GEN_ALERT (0x00008000) -- The control point must enable this mask to receive Geofence alerts.
+ These alerts are generated to inform the client of the changes that may
+ affect Geofence, e.g., if GPS is turned off or if the network is
+ unavailable.
+ - QMI_LOC_EVENT_MASK_GEOFENCE_BREACH_NOTIFICATION (0x00010000) -- The control point must enable this mask to receive notifications when
+ a Geofence is breached. These events are generated when the UE enters
+ or leaves the perimeter of a Geofence.
+ - QMI_LOC_EVENT_MASK_PEDOMETER_CONTROL (0x00020000) -- The control point must enable this mask to register for pedometer
+ control requests from the location engine. The location engine sends
+ this event to control the injection of pedometer reports.
+ - QMI_LOC_EVENT_MASK_MOTION_DATA_CONTROL (0x00040000) -- The control point must enable this mask to register for motion data
+ control requests from the location engine. The location engine sends
+ this event to control the injection of motion data.
+
+ Multiple events can be registered by ORing the individual masks and
+ sending them in this TLV. All unused bits in this mask must be set to 0.
+ */
+}qmiLocRegEventsReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCFIXRECURRENCEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_RECURRENCE_PERIODIC_V02 = 1, /**< Request periodic position fixes. */
+ eQMI_LOC_RECURRENCE_SINGLE_V02 = 2, /**< Request a single position fix. */
+ QMILOCFIXRECURRENCEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocFixRecurrenceEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCACCURACYLEVELENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_ACCURACY_LOW_V02 = 1, /**< Low accuracy. */
+ eQMI_LOC_ACCURACY_MED_V02 = 2, /**< Medium accuracy. */
+ eQMI_LOC_ACCURACY_HIGH_V02 = 3, /**< High accuracy. */
+ QMILOCACCURACYLEVELENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocAccuracyLevelEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCINTERMEDIATEREPORTSTATEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_INTERMEDIATE_REPORTS_ON_V02 = 1, /**< Intermediate reports are turned on. */
+ eQMI_LOC_INTERMEDIATE_REPORTS_OFF_V02 = 2, /**< Intermediate reports are turned off. */
+ QMILOCINTERMEDIATEREPORTSTATEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocIntermediateReportStateEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ char applicationProvider[QMI_LOC_MAX_APP_ID_PROVIDER_LENGTH_V02 + 1];
+ /**< Application provider. */
+
+ char applicationName[QMI_LOC_MAX_APP_ID_NAME_LENGTH_V02 + 1];
+ /**< Application name. */
+
+ uint8_t applicationVersion_valid;
+ /**< Specifies whether the application version string contains
+ a valid value: \begin{itemize1}
+ \item 0x00 (FALSE) -- Application version string is invalid
+ \item 0x01 (TRUE) -- Application version string is valid
+ \vspace{-0.18in} \end{itemize1} */
+
+ char applicationVersion[QMI_LOC_MAX_APP_ID_VERSION_LENGTH_V02 + 1];
+ /**< Application version. */
+}qmiLocApplicationIdStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to initiate a GPS session. */
+typedef struct {
+
+ /* Mandatory */
+ /* Session ID */
+ uint8_t sessionId;
+ /**< ID of the session as identified by the control point. The session ID
+ is reported back in the position reports. The control point must
+ specify the same session ID in the QMI_LOC_STOP_REQ message. \n
+ - Range: 0 to 255
+ */
+
+ /* Optional */
+ /* Recurrence Type */
+ uint8_t fixRecurrence_valid; /**< Must be set to true if fixRecurrence is being passed */
+ qmiLocFixRecurrenceEnumT_v02 fixRecurrence;
+ /**< Specifies the type of session in which the control point is interested.
+ If this TLV is not specified, recurrence defaults to SINGLE.
+
+ Valid values: \n
+ - 0x00000001 -- Request periodic fixes \n
+ - 0x00000002 -- Request a single fix
+ */
+
+ /* Optional */
+ /* Horizontal Accuracy */
+ uint8_t horizontalAccuracyLevel_valid; /**< Must be set to true if horizontalAccuracyLevel is being passed */
+ qmiLocAccuracyLevelEnumT_v02 horizontalAccuracyLevel;
+ /**< Specifies the horizontal accuracy level required by the control point.
+ If not specified, accuracy defaults to LOW.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- LOW: Client requires low horizontal accuracy
+ \item 0x00000002 -- MED: Client requires medium horizontal accuracy
+ \item 0x00000003 -- HIGH: Client requires high horizontal accuracy
+ \vspace{-0.18in}
+ \end{itemize1}
+ */
+
+ /* Optional */
+ /* Enable/Disable Intermediate Reports */
+ uint8_t intermediateReportState_valid; /**< Must be set to true if intermediateReportState is being passed */
+ qmiLocIntermediateReportStateEnumT_v02 intermediateReportState;
+ /**< Specifies if the control point is interested in receiving intermediate
+ reports. The control point must explicitly set this field to OFF if it
+ does not wish to receive intermediate position reports. Intermediate
+ position reports are generated at 1 Hz and are ON by default. If
+ intermediate reports are turned ON, the client receives position reports
+ even if the accuracy criteria are not met. The status in such a position
+ report is set to IN_PROGRESS in order for the control point to identify
+ intermediate reports.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- ON: Client is interested in receiving intermediate
+ reports
+ \item 0x00000002 -- OFF: Client is not interested in receiving
+ intermediate reports
+ \vspace{-0.18in}
+ \end{itemize1}
+ */
+
+ /* Optional */
+ /* Minimum Interval Between Position Reports */
+ uint8_t minInterval_valid; /**< Must be set to true if minInterval is being passed */
+ uint32_t minInterval;
+ /**< Minimum time interval, specified by the control point, that must elapse between
+ position reports. \n
+ - Units: Milliseconds \n
+ - Default: 1000 ms
+ */
+
+ /* Optional */
+ /* ID of the Application that Sent this Request */
+ uint8_t applicationId_valid; /**< Must be set to true if applicationId is being passed */
+ qmiLocApplicationIdStructT_v02 applicationId;
+ /**< \n Application provider, name, and version.*/
+}qmiLocStartReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to stop a GPS session. */
+typedef struct {
+
+ /* Mandatory */
+ /* Session ID */
+ uint8_t sessionId;
+ /**< ID of the session that was specified in the Start request
+ (QMI_LOC_START_REQ).\n
+ - Range: 0 to 255 */
+}qmiLocStopReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocPosTechMaskT_v02;
+#define QMI_LOC_POS_TECH_MASK_SATELLITE_V02 ((qmiLocPosTechMaskT_v02)0x00000001) /**< Satellites were used to generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_CELLID_V02 ((qmiLocPosTechMaskT_v02)0x00000002) /**< Cell towers were used to generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_WIFI_V02 ((qmiLocPosTechMaskT_v02)0x00000004) /**< WiFi access points were used to generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_SENSORS_V02 ((qmiLocPosTechMaskT_v02)0x00000008) /**< Sensors were used to generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_REFERENCE_LOCATION_V02 ((qmiLocPosTechMaskT_v02)0x00000010) /**< Reference Location was used to generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_INJECTED_COARSE_POSITION_V02 ((qmiLocPosTechMaskT_v02)0x00000020) /**< Coarse position injected into the location engine was used to
+ generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_AFLT_V02 ((qmiLocPosTechMaskT_v02)0x00000040) /**< AFLT was used to generate the fix. */
+#define QMI_LOC_POS_TECH_MASK_HYBRID_V02 ((qmiLocPosTechMaskT_v02)0x00000080) /**< GNSS and network-provided measurements were used to
+ generate the fix. */
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSESSIONSTATUSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SESS_STATUS_SUCCESS_V02 = 0, /**< Session was successful. */
+ eQMI_LOC_SESS_STATUS_IN_PROGRESS_V02 = 1, /**< Session still in progress. Further position reports will be
+ generated until either the fix criteria specified by the client
+ are met or the client response timeout occurs. */
+ eQMI_LOC_SESS_STATUS_GENERAL_FAILURE_V02 = 2, /**< Session failed. */
+ eQMI_LOC_SESS_STATUS_TIMEOUT_V02 = 3, /**< Fix request failed because the session timed out. */
+ eQMI_LOC_SESS_STATUS_USER_END_V02 = 4, /**< Fix request failed because the session was ended by the user. */
+ eQMI_LOC_SESS_STATUS_BAD_PARAMETER_V02 = 5, /**< Fix request failed due to bad parameters in the request. */
+ eQMI_LOC_SESS_STATUS_PHONE_OFFLINE_V02 = 6, /**< Fix request failed because the phone is offline. */
+ eQMI_LOC_SESS_STATUS_ENGINE_LOCKED_V02 = 7, /**< Fix request failed because the engine is locked. */
+ QMILOCSESSIONSTATUSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSessionStatusEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint16_t gpsWeek;
+ /**< Current GPS week as calculated from midnight, Jan. 6, 1980. \n
+ - Units: Weeks */
+
+ uint32_t gpsTimeOfWeekMs;
+ /**< Amount of time into the current GPS week. \n
+ - Units: Milliseconds */
+}qmiLocGPSTimeStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ float PDOP;
+ /**< Position dilution of precision.
+ \begin{itemize1}
+ \item Range: 1 (highest accuracy) to 50 (lowest accuracy)
+ \item PDOP = square root of (HDOP^2 + VDOP^2)
+ \vspace{-0.18in} \end{itemize1} */
+
+ float HDOP;
+ /**< Horizontal dilution of precision.
+ \begin{itemize1}
+ \item Range: 1 (highest accuracy) to 50 (lowest accuracy)
+ \vspace{-0.18in} \end{itemize1} */
+
+ float VDOP;
+ /**< Vertical dilution of precision.
+ \begin{itemize1}
+ \item Range: 1 (highest accuracy) to 50 (lowest accuracy)
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocDOPStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocSensorUsageMaskT_v02;
+#define QMI_LOC_SENSOR_MASK_USED_ACCEL_V02 ((qmiLocSensorUsageMaskT_v02)0x00000001) /**< Bitmask to specify whether an accelerometer was used. */
+#define QMI_LOC_SENSOR_MASK_USED_GYRO_V02 ((qmiLocSensorUsageMaskT_v02)0x00000002) /**< Bitmask to specify whether a gyroscope was used. */
+typedef uint32_t qmiLocSensorAidedMaskT_v02;
+#define QMI_LOC_SENSOR_AIDED_MASK_HEADING_V02 ((qmiLocSensorAidedMaskT_v02)0x00000001) /**< Bitmask to specify whether a sensor was used to calculate heading. */
+#define QMI_LOC_SENSOR_AIDED_MASK_SPEED_V02 ((qmiLocSensorAidedMaskT_v02)0x00000002) /**< Bitmask to specify whether a sensor was used to calculate speed. */
+#define QMI_LOC_SENSOR_AIDED_MASK_POSITION_V02 ((qmiLocSensorAidedMaskT_v02)0x00000004) /**< Bitmask to specify whether a sensor was used to calculate position. */
+#define QMI_LOC_SENSOR_AIDED_MASK_VELOCITY_V02 ((qmiLocSensorAidedMaskT_v02)0x00000008) /**< Bitmask to specify whether a sensor was used to calculate velocity. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocSensorUsageMaskT_v02 usageMask;
+ /**< Specifies which sensors were used in calculating the position in the
+ position report.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- SENSOR_USED_ ACCEL
+ \item 0x00000002 -- SENSOR_USED_ GYRO
+ \vspace{-0.18in} \end{itemize1} */
+
+ qmiLocSensorAidedMaskT_v02 aidingIndicatorMask;
+ /**< Specifies which results were aided by sensors.
+
+ Valid bitmasks: \n
+ - 0x00000001 -- AIDED_HEADING \n
+ - 0x00000002 -- AIDED_SPEED \n
+ - 0x00000004 -- AIDED_POSITION \n
+ - 0x00000008 -- AIDED_VELOCITY */
+}qmiLocSensorUsageIndicatorStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCTIMESOURCEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_TIME_SRC_INVALID_V02 = 0, /**< Invalid time. */
+ eQMI_LOC_TIME_SRC_NETWORK_TIME_TRANSFER_V02 = 1, /**< Time is set by the 1x system. */
+ eQMI_LOC_TIME_SRC_NETWORK_TIME_TAGGING_V02 = 2, /**< Time is set by WCDMA/GSM time tagging (i.e.,
+ associating network time with GPS time). */
+ eQMI_LOC_TIME_SRC_EXTERNAL_INPUT_V02 = 3, /**< Time is set by an external injection. */
+ eQMI_LOC_TIME_SRC_TOW_DECODE_V02 = 4, /**< Time is set after decoding over-the-air GPS navigation data
+ from one GPS satellite. */
+ eQMI_LOC_TIME_SRC_TOW_CONFIRMED_V02 = 5, /**< Time is set after decoding over-the-air GPS navigation data
+ from multiple satellites. */
+ eQMI_LOC_TIME_SRC_TOW_AND_WEEK_CONFIRMED_V02 = 6, /**< Both time of the week and the GPS week number are known. */
+ eQMI_LOC_TIME_SRC_NAV_SOLUTION_V02 = 7, /**< Time is set by the position engine after the fix is obtained. */
+ eQMI_LOC_TIME_SRC_SOLVE_FOR_TIME_V02 = 8, /**< Time is set by the position engine after performing SFT.
+ This is done when the clock time uncertainty is large. */
+ eQMI_LOC_TIME_SRC_GLO_TOW_DECODE_V02 = 9, /**< Time is set after decoding GLO satellites */
+ eQMI_LOC_TIME_SRC_TIME_TRANSFORM_V02 = 10, /**< Time is set after transforming the GPS to GLO time */
+ eQMI_LOC_TIME_SRC_WCDMA_SLEEP_TIME_TAGGING_V02 = 11, /**< Time is set by the sleep time tag provided by the WCDMA network */
+ eQMI_LOC_TIME_SRC_GSM_SLEEP_TIME_TAGGING_V02 = 12, /**< Time is set by the sleep time tag provided by the GSM network */
+ eQMI_LOC_TIME_SRC_UNKNOWN_V02 = 13, /**< Source of the time is unknown */
+ eQMI_LOC_TIME_SRC_SYSTEM_TIMETICK_V02 = 14, /**< Time is derived from the system clock (better known as the slow clock);
+ GNSS time is maintained irrespective of the GNSS receiver state */
+ QMILOCTIMESOURCEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocTimeSourceEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCRELIABILITYENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_RELIABILITY_NOT_SET_V02 = 0, /**< Location reliability is not set */
+ eQMI_LOC_RELIABILITY_VERY_LOW_V02 = 1, /**< Location reliability is very low; use it at your own risk */
+ eQMI_LOC_RELIABILITY_LOW_V02 = 2, /**< Location reliability is low; little or no cross-checking is possible */
+ eQMI_LOC_RELIABILITY_MEDIUM_V02 = 3, /**< Location reliability is medium; limited cross-check passed */
+ eQMI_LOC_RELIABILITY_HIGH_V02 = 4, /**< Location reliability is high; strong cross-check passed */
+ QMILOCRELIABILITYENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocReliabilityEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends the position report to the control point. */
+typedef struct {
+
+ /* Mandatory */
+ /* Session Status */
+ qmiLocSessionStatusEnumT_v02 sessionStatus;
+ /**< Session status.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SESS_STATUS_ SUCCESS
+ \item 0x00000001 -- SESS_STATUS_ IN_PROGRESS
+ \item 0x00000002 -- SESS_STATUS_ GENERAL_FAILURE
+ \item 0x00000003 -- SESS_STATUS_ TIMEOUT
+ \item 0x00000004 -- SESS_STATUS_ USER_END
+ \item 0x00000005 -- SESS_STATUS_ BAD_PARAMETER
+ \item 0x00000006 -- SESS_STATUS_ PHONE_OFFLINE
+ \item 0x00000007 -- SESS_STATUS_ ENGINE_LOCKED
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Mandatory */
+ /* Session ID */
+ uint8_t sessionId;
+ /**< ID of the session that was specified in the Start request
+ QMI_LOC_START_REQ. \n
+ - Range: 0 to 255 */
+
+ /* Optional */
+ /* Latitude */
+ uint8_t latitude_valid; /**< Must be set to true if latitude is being passed */
+ double latitude;
+ /**< Latitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -90.0 to 90.0 \begin{itemize1}
+ \item Positive values indicate northern latitude
+ \item Negative values indicate southern latitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Optional */
+ /* Longitude */
+ uint8_t longitude_valid; /**< Must be set to true if longitude is being passed */
+ double longitude;
+ /**< Longitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -180.0 to 180.0 \begin{itemize1}
+ \item Positive values indicate eastern longitude
+ \item Negative values indicate western longitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Optional */
+ /* Circular Horizontal Position Uncertainty */
+ uint8_t horUncCircular_valid; /**< Must be set to true if horUncCircular is being passed */
+ float horUncCircular;
+ /**< Horizontal position uncertainty (circular).\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Horizontal Elliptical Uncertainty (Semi-Minor Axis) */
+ uint8_t horUncEllipseSemiMinor_valid; /**< Must be set to true if horUncEllipseSemiMinor is being passed */
+ float horUncEllipseSemiMinor;
+ /**< Semi-minor axis of horizontal elliptical uncertainty.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Horizontal Elliptical Uncertainty (Semi-Major Axis) */
+ uint8_t horUncEllipseSemiMajor_valid; /**< Must be set to true if horUncEllipseSemiMajor is being passed */
+ float horUncEllipseSemiMajor;
+ /**< Semi-major axis of horizontal elliptical uncertainty.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Elliptical Horizontal Uncertainty Azimuth */
+ uint8_t horUncEllipseOrientAzimuth_valid; /**< Must be set to true if horUncEllipseOrientAzimuth is being passed */
+ float horUncEllipseOrientAzimuth;
+ /**< Elliptical horizontal uncertainty azimuth of orientation.\n
+ - Units: Decimal degrees \n
+ - Range: 0 to 180 */
+
+ /* Optional */
+ /* Horizontal Confidence */
+ uint8_t horConfidence_valid; /**< Must be set to true if horConfidence is being passed */
+ uint8_t horConfidence;
+ /**< Horizontal uncertainty confidence.\n
+ - Units: Percent \n
+ - Range: 0 to 99 */
+
+ /* Optional */
+ /* Horizontal Reliability */
+ uint8_t horReliability_valid; /**< Must be set to true if horReliability is being passed */
+ qmiLocReliabilityEnumT_v02 horReliability;
+ /**< Specifies the reliability of the horizontal position. \n
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- RELIABILITY_NOT_ SET
+ \item 0x00000001 -- RELIABILITY_ VERY_LOW
+ \item 0x00000002 -- RELIABILITY_LOW
+ \item 0x00000003 -- RELIABILITY_ MEDIUM
+ \item 0x00000004 -- RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Horizontal Speed */
+ uint8_t speedHorizontal_valid; /**< Must be set to true if speedHorizontal is being passed */
+ float speedHorizontal;
+ /**< Horizontal speed.\n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Speed Uncertainty */
+ uint8_t speedUnc_valid; /**< Must be set to true if speedUnc is being passed */
+ float speedUnc;
+ /**< 3-D Speed uncertainty.\n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Altitude With Respect to Ellipsoid */
+ uint8_t altitudeWrtEllipsoid_valid; /**< Must be set to true if altitudeWrtEllipsoid is being passed */
+ float altitudeWrtEllipsoid;
+ /**< Altitude with respect to the WGS84 ellipsoid.\n
+ - Units: Meters \n
+ - Range: -500 to 15883 */
+
+ /* Optional */
+ /* Altitude With Respect to Sea Level */
+ uint8_t altitudeWrtMeanSeaLevel_valid; /**< Must be set to true if altitudeWrtMeanSeaLevel is being passed */
+ float altitudeWrtMeanSeaLevel;
+ /**< Altitude with respect to mean sea level.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Vertical Uncertainty */
+ uint8_t vertUnc_valid; /**< Must be set to true if vertUnc is being passed */
+ float vertUnc;
+ /**< Vertical uncertainty.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Vertical Confidence */
+ uint8_t vertConfidence_valid; /**< Must be set to true if vertConfidence is being passed */
+ uint8_t vertConfidence;
+ /**< Vertical uncertainty confidence.\n
+ - Units: Percent \n
+ - Range: 0 to 99 */
+
+ /* Optional */
+ /* Vertical Reliability */
+ uint8_t vertReliability_valid; /**< Must be set to true if vertReliability is being passed */
+ qmiLocReliabilityEnumT_v02 vertReliability;
+ /**< Specifies the reliability of the vertical position. \n
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- RELIABILITY_NOT_ SET
+ \item 0x00000001 -- RELIABILITY_ VERY_LOW
+ \item 0x00000002 -- RELIABILITY_LOW
+ \item 0x00000003 -- RELIABILITY_ MEDIUM
+ \item 0x00000004 -- RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1}*/
+
+ /* Optional */
+ /* Vertical Speed */
+ uint8_t speedVertical_valid; /**< Must be set to true if speedVertical is being passed */
+ float speedVertical;
+ /**< Vertical speed.\n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Heading */
+ uint8_t heading_valid; /**< Must be set to true if heading is being passed */
+ float heading;
+ /**< Heading.\n
+ - Units: Degrees \n
+ - Range: 0 to 359.999 */
+
+ /* Optional */
+ /* Heading Uncertainty */
+ uint8_t headingUnc_valid; /**< Must be set to true if headingUnc is being passed */
+ float headingUnc;
+ /**< Heading uncertainty.\n
+ - Units: Degrees \n
+ - Range: 0 to 359.999 */
+
+ /* Optional */
+ /* Magnetic Deviation */
+ uint8_t magneticDeviation_valid; /**< Must be set to true if magneticDeviation is being passed */
+ float magneticDeviation;
+ /**< Difference between the bearing to true north and the bearing shown
+ on a magnetic compass. The deviation is positive when the magnetic
+ north is east of true north. */
+
+ /* Optional */
+ /* Technology Used */
+ uint8_t technologyMask_valid; /**< Must be set to true if technologyMask is being passed */
+ qmiLocPosTechMaskT_v02 technologyMask;
+ /**< Technology used in computing this fix.
+ Valid bitmasks: \n
+ - QMI_LOC_POS_TECH_MASK_SATELLITE (0x00000001) -- Satellites were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_CELLID (0x00000002) -- Cell towers were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_WIFI (0x00000004) -- WiFi access points were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_SENSORS (0x00000008) -- Sensors were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_REFERENCE_LOCATION (0x00000010) -- Reference Location was used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_INJECTED_COARSE_POSITION (0x00000020) -- Coarse position injected into the location engine was used to
+ generate the fix.
+ - QMI_LOC_POS_TECH_MASK_AFLT (0x00000040) -- AFLT was used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_HYBRID (0x00000080) -- GNSS and network-provided measurements were used to
+ generate the fix.
+ */
+
+ /* Optional */
+ /* Dilution of Precision */
+ uint8_t DOP_valid; /**< Must be set to true if DOP is being passed */
+ qmiLocDOPStructT_v02 DOP;
+ /**< \vspace{0.06in} \n Dilution of precision associated with this position. */
+
+ /* Optional */
+ /* UTC Timestamp */
+ uint8_t timestampUtc_valid; /**< Must be set to true if timestampUtc is being passed */
+ uint64_t timestampUtc;
+ /**< UTC timestamp. \n
+ - Units: Milliseconds since Jan. 1, 1970 */
+
+ /* Optional */
+ /* Leap Seconds */
+ uint8_t leapSeconds_valid; /**< Must be set to true if leapSeconds is being passed */
+ uint8_t leapSeconds;
+ /**< Leap second information. If leapSeconds is not available,
+ timestampUtc is calculated based on a hard-coded value
+ for leap seconds. \n
+ - Units: Seconds */
+
+ /* Optional */
+ /* GPS Time */
+ uint8_t gpsTime_valid; /**< Must be set to true if gpsTime is being passed */
+ qmiLocGPSTimeStructT_v02 gpsTime;
+ /**< \vspace{0.06in} \n The number of weeks since Jan. 5, 1980, and
+ milliseconds into the current week. */
+
+ /* Optional */
+ /* Time Uncertainty */
+ uint8_t timeUnc_valid; /**< Must be set to true if timeUnc is being passed */
+ float timeUnc;
+ /**< Time uncertainty. \n
+ - Units: Milliseconds */
+
+ /* Optional */
+ /* Time Source */
+ uint8_t timeSrc_valid; /**< Must be set to true if timeSrc is being passed */
+ qmiLocTimeSourceEnumT_v02 timeSrc;
+ /**< Time source. Valid values: \n
+ - eQMI_LOC_TIME_SRC_INVALID (0) -- Invalid time.
+ - eQMI_LOC_TIME_SRC_NETWORK_TIME_TRANSFER (1) -- Time is set by the 1x system.
+ - eQMI_LOC_TIME_SRC_NETWORK_TIME_TAGGING (2) -- Time is set by WCDMA/GSM time tagging (i.e.,
+ associating network time with GPS time).
+ - eQMI_LOC_TIME_SRC_EXTERNAL_INPUT (3) -- Time is set by an external injection.
+ - eQMI_LOC_TIME_SRC_TOW_DECODE (4) -- Time is set after decoding over-the-air GPS navigation data
+ from one GPS satellite.
+ - eQMI_LOC_TIME_SRC_TOW_CONFIRMED (5) -- Time is set after decoding over-the-air GPS navigation data
+ from multiple satellites.
+ - eQMI_LOC_TIME_SRC_TOW_AND_WEEK_CONFIRMED (6) -- Both time of the week and the GPS week number are known.
+ - eQMI_LOC_TIME_SRC_NAV_SOLUTION (7) -- Time is set by the position engine after the fix is obtained.
+ - eQMI_LOC_TIME_SRC_SOLVE_FOR_TIME (8) -- Time is set by the position engine after performing SFT.
+ This is done when the clock time uncertainty is large.
+ - eQMI_LOC_TIME_SRC_GLO_TOW_DECODE (9) -- Time is set after decoding GLO satellites
+ - eQMI_LOC_TIME_SRC_TIME_TRANSFORM (10) -- Time is set after transforming the GPS to GLO time
+ - eQMI_LOC_TIME_SRC_WCDMA_SLEEP_TIME_TAGGING (11) -- Time is set by the sleep time tag provided by the WCDMA network
+ - eQMI_LOC_TIME_SRC_GSM_SLEEP_TIME_TAGGING (12) -- Time is set by the sleep time tag provided by the GSM network
+ - eQMI_LOC_TIME_SRC_UNKNOWN (13) -- Source of the time is unknown
+ - eQMI_LOC_TIME_SRC_SYSTEM_TIMETICK (14) -- Time is derived from the system clock (better known as the slow clock);
+ GNSS time is maintained irrespective of the GNSS receiver state */
+
+ /* Optional */
+ /* Sensor Data Usage */
+ uint8_t sensorDataUsage_valid; /**< Must be set to true if sensorDataUsage is being passed */
+ qmiLocSensorUsageIndicatorStructT_v02 sensorDataUsage;
+ /**< \vspace{0.06in} \n Indicates whether sensor data was used in computing the position in this
+ position report. */
+
+ /* Optional */
+ /* Fix Count for This Session */
+ uint8_t fixId_valid; /**< Must be set to true if fixId is being passed */
+ uint32_t fixId;
+ /**< Fix count for the session. Starts with 0 and increments by one
+ for each successive position report for a particular session. */
+
+ /* Optional */
+ /* SVs Used to Calculate the Fix */
+ uint8_t gnssSvUsedList_valid; /**< Must be set to true if gnssSvUsedList is being passed */
+ uint32_t gnssSvUsedList_len; /**< Must be set to # of elements in gnssSvUsedList */
+ uint16_t gnssSvUsedList[QMI_LOC_MAX_SV_USED_LIST_LENGTH_V02];
+ /**< Each entry in the list contains the SV ID of a satellite
+ used for calculating this position report. The following
+ information is associated with each SV ID: \begin{itemize1}
+ \item Range: \begin{itemize1}
+ \item For GPS: 1 to 32
+ \item For SBAS: 33 to 64
+ \item For GLONASS: 65 to 96
+ \item For QZSS: 193 to 197
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Optional */
+ /* Altitude Assumed */
+ uint8_t altitudeAssumed_valid; /**< Must be set to true if altitudeAssumed is being passed */
+ uint8_t altitudeAssumed;
+ /**< Indicates whether altitude is assumed or calculated: \begin{itemize1}
+ \item 0x00 (FALSE) -- Altitude is calculated
+ \item 0x01 (TRUE) -- Altitude is assumed; there may not be enough
+ satellites to determine the precise altitude
+ \vspace{-0.18in} \end{itemize1}*/
+}qmiLocEventPositionReportIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSVSYSTEMENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SV_SYSTEM_GPS_V02 = 1, /**< GPS satellite. */
+ eQMI_LOC_SV_SYSTEM_GALILEO_V02 = 2, /**< GALILEO satellite. */
+ eQMI_LOC_SV_SYSTEM_SBAS_V02 = 3, /**< SBAS satellite. */
+ eQMI_LOC_SV_SYSTEM_COMPASS_V02 = 4, /**< COMPASS satellite. */
+ eQMI_LOC_SV_SYSTEM_GLONASS_V02 = 5, /**< GLONASS satellite. */
+ QMILOCSVSYSTEMENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSvSystemEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSVSTATUSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SV_STATUS_IDLE_V02 = 1, /**< SV is not being actively processed. */
+ eQMI_LOC_SV_STATUS_SEARCH_V02 = 2, /**< The system is searching for this SV. */
+ eQMI_LOC_SV_STATUS_TRACK_V02 = 3, /**< SV is being tracked. */
+ QMILOCSVSTATUSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSvStatusEnumT_v02;
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocSvInfoValidMaskT_v02;
+#define QMI_LOC_SV_INFO_MASK_VALID_SYSTEM_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000001) /**< System field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_GNSS_SVID_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000002) /**< gnssSvId field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_HEALTH_STATUS_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000004) /**< healthStatus field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_PROCESS_STATUS_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000008) /**< processStatus field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_SVINFO_MASK_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000010) /**< svInfoMask field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_ELEVATION_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000020) /**< Elevation field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_AZIMUTH_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000040) /**< Azimuth field is valid in SV information. */
+#define QMI_LOC_SV_INFO_MASK_VALID_SNR_V02 ((qmiLocSvInfoValidMaskT_v02)0x00000080) /**< SNR field is valid in SV information. */
+typedef uint8_t qmiLocSvInfoMaskT_v02;
+#define QMI_LOC_SVINFO_MASK_HAS_EPHEMERIS_V02 ((qmiLocSvInfoMaskT_v02)0x01) /**< Ephemeris is available for this SV. */
+#define QMI_LOC_SVINFO_MASK_HAS_ALMANAC_V02 ((qmiLocSvInfoMaskT_v02)0x02) /**< Almanac is available for this SV. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocSvInfoValidMaskT_v02 validMask;
+ /**< Bitmask indicating which of the fields in this TLV are valid.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- VALID_SYSTEM
+ \item 0x00000002 -- VALID_GNSS_SVID
+ \item 0x00000004 -- VALID_HEALTH_ STATUS
+ \item 0x00000008 -- VALID_PROCESS_ STATUS
+ \item 0x00000010 -- VALID_SVINFO_ MASK
+ \item 0x00000020 -- VALID_ELEVATION
+ \item 0x00000040 -- VALID_AZIMUTH
+ \item 0x00000080 -- VALID_SNR
+ \vspace{-0.18in} \end{itemize1} */
+
+ qmiLocSvSystemEnumT_v02 system;
+ /**< Indicates to which constellation this SV belongs.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- eQMI_LOC_SV_ SYSTEM_GPS
+ \item 0x00000002 -- eQMI_LOC_SV_ SYSTEM_GALILEO
+ \item 0x00000003 -- eQMI_LOC_SV_ SYSTEM_SBAS
+ \item 0x00000004 -- eQMI_LOC_SV_ SYSTEM_COMPASS
+ \item 0x00000005 -- eQMI_LOC_SV_ SYSTEM_GLONASS
+ \vspace{-0.18in} \end{itemize1} */
+
+ uint16_t gnssSvId;
+ /**< GNSS SV ID.
+ \begin{itemize1}
+ \item Range: \begin{itemize1}
+ \item For GPS: 1 to 32
+ \item For GLONASS: 1 to 32
+ \item For SBAS: 120 to 151
+ \end{itemize1} \end{itemize1}
+
+ The GPS and GLONASS SVs can be disambiguated using the system field. */
+
+ uint8_t healthStatus;
+ /**< Health status.
+ \begin{itemize1}
+ \item Range: 0 to 1; 0 = unhealthy, \newline 1 = healthy
+ \vspace{-0.18in} \end{itemize1}*/
+
+ qmiLocSvStatusEnumT_v02 svStatus;
+ /**< SV processing status. \n
+ Valid values:\n
+ - 0x00000001 -- SV_STATUS_IDLE \n
+ - 0x00000002 -- SV_STATUS_SEARCH \n
+ - 0x00000003 -- SV_STATUS_TRACK
+ */
+
+ qmiLocSvInfoMaskT_v02 svInfoMask;
+ /**< Indicates whether almanac and ephemeris information is available. \n
+ Valid bitmasks: \n
+ - 0x01 -- SVINFO_HAS_EPHEMERIS \n
+ - 0x02 -- SVINFO_HAS_ALMANAC
+ */
+
+ float elevation;
+ /**< SV elevation angle.\n
+ - Units: Degrees \n
+ - Range: 0 to 90 */
+
+ float azimuth;
+ /**< SV azimuth angle.\n
+ - Units: Degrees \n
+ - Range: 0 to 360 */
+
+ float snr;
+ /**< SV signal-to-noise ratio. \n
+ - Units: dB-Hz */
+}qmiLocSvInfoStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends a satellite report to the control point. */
+typedef struct {
+
+ /* Mandatory */
+ /* Altitude Assumed */
+ uint8_t altitudeAssumed;
+ /**< Indicates whether altitude is assumed or calculated: \begin{itemize1}
+ \item 0x00 (FALSE) -- Valid altitude is calculated
+ \item 0x01 (TRUE) -- Valid altitude is assumed; there may not be
+ enough satellites to determine precise altitude
+ \vspace{-0.18in} \end{itemize1}*/
+
+ /* Optional */
+ /* Satellite Info */
+ uint8_t svList_valid; /**< Must be set to true if svList is being passed */
+ uint32_t svList_len; /**< Must be set to # of elements in svList */
+ qmiLocSvInfoStructT_v02 svList[QMI_LOC_SV_INFO_LIST_MAX_SIZE_V02];
+ /**< \vspace{0.06in} \n SV information list. */
+}qmiLocEventGnssSvInfoIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends NMEA sentences to the control point */
+typedef struct {
+
+ /* Mandatory */
+ /* NMEA String */
+ char nmea[QMI_LOC_NMEA_STRING_MAX_LENGTH_V02 + 1];
+ /**< NMEA string.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 201
+ \vspace{-0.18in} \end{itemize1}*/
+}qmiLocEventNmeaIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNINOTIFYVERIFYENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_USER_NO_NOTIFY_NO_VERIFY_V02 = 1, /**< No notification and no verification required. */
+ eQMI_LOC_NI_USER_NOTIFY_ONLY_V02 = 2, /**< Notify only; no verification required. */
+ eQMI_LOC_NI_USER_NOTIFY_VERIFY_ALLOW_NO_RESP_V02 = 3, /**< Notify and verify, but no response required. */
+ eQMI_LOC_NI_USER_NOTIFY_VERIFY_NOT_ALLOW_NO_RESP_V02 = 4, /**< Notify and verify, and require a response. */
+ eQMI_LOC_NI_USER_NOTIFY_VERIFY_PRIVACY_OVERRIDE_V02 = 5, /**< Notify and Verify, and require a response. */
+ QMILOCNINOTIFYVERIFYENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiNotifyVerifyEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNIVXPOSMODEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_VX_MS_ASSISTED_ONLY_V02 = 1, /**< MS-assisted only allowed. */
+ eQMI_LOC_NI_VX_MS_BASED_ONLY_V02 = 2, /**< MS-based only allowed. */
+ eQMI_LOC_NI_VX_MS_ASSISTED_PREFERRED_MS_BASED_ALLOWED_V02 = 3, /**< MS-assisted preferred, but MS-based allowed. */
+ eQMI_LOC_NI_VX_MS_BASED_PREFERRED_MS_ASSISTED_ALLOWED_V02 = 4, /**< MS-based preferred, but MS-assisted allowed. */
+ QMILOCNIVXPOSMODEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiVxPosModeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNIVXREQUESTORIDENCODINGSCHEMEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_VX_OCTET_V02 = 0, /**< Encoding is OCTET. */
+ eQMI_LOC_NI_VX_EXN_PROTOCOL_MSG_V02 = 1, /**< Encoding is EXN PROTOCOL MSG. */
+ eQMI_LOC_NI_VX_ASCII_V02 = 2, /**< Encoding is ASCII. */
+ eQMI_LOC_NI_VX_IA5_V02 = 3, /**< Encoding is IA5. */
+ eQMI_LOC_NI_VX_UNICODE_V02 = 4, /**< Encoding is UNICODE. */
+ eQMI_LOC_NI_VX_SHIFT_JIS_V02 = 5, /**< Encoding is SHIFT JIS. */
+ eQMI_LOC_NI_VX_KOREAN_V02 = 6, /**< Encoding is KOREAN. */
+ eQMI_LOC_NI_VX_LATIN_HEBREW_V02 = 7, /**< Encoding is LATIN HEBREW. */
+ eQMI_LOC_NI_VX_LATIN_V02 = 8, /**< Encoding is LATIN. */
+ eQMI_LOC_NI_VX_GSM_V02 = 9, /**< Encoding is GSM. */
+ QMILOCNIVXREQUESTORIDENCODINGSCHEMEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiVxRequestorIdEncodingSchemeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint8_t posQosIncl;
+ /**< Indicates whether quality of service is included:\n
+ - 0x01 (TRUE) -- QoS is included \n
+ - 0x00 (FALSE) -- QoS is not included */
+
+ uint8_t posQos;
+ /**< Position QoS timeout. \n
+ - Units: Seconds \n
+ - Range: 0 to 255 */
+
+ uint32_t numFixes;
+ /**< Number of fixes allowed. */
+
+ uint32_t timeBetweenFixes;
+ /**< Time between fixes.\n
+ - Units: Seconds */
+
+ qmiLocNiVxPosModeEnumT_v02 posMode;
+ /**< Position mode.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- NI_VX_MS_ ASSISTED_ONLY
+ \item 0x00000002 -- NI_VX_MS_BASED_ ONLY
+ \item 0x00000003 -- NI_VX_MS_ ASSISTED_PREFERRED_ MS_BASED_ALLOWED
+ \item 0x00000004 -- NI_VX_MS_ BASED_PREFERRED_ MS_ASSISTED_ALLOWED
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocNiVxRequestorIdEncodingSchemeEnumT_v02 encodingScheme;
+ /**< VX encoding scheme.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- NI_VX_OCTET
+ \item 0x00000001 -- NI_VX_EXN_ PROTOCOL_MSG
+ \item 0x00000002 -- NI_VX_ASCII
+ \item 0x00000003 -- NI_VX_IA5
+ \item 0x00000004 -- NI_VX_UNICODE
+ \item 0x00000005 -- NI_VX_SHIFT_JIS
+ \item 0x00000006 -- NI_VX_KOREAN
+ \item 0x00000007 -- NI_VX_LATIN_ HEBREW
+ \item 0x00000008 -- NI_VX_LATIN
+ \item 0x00000009 -- NI_VX_GSM
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ uint32_t requestorId_len; /**< Must be set to # of elements in requestorId */
+ uint8_t requestorId[QMI_LOC_NI_MAX_REQUESTOR_ID_LENGTH_V02];
+ /**< Requestor ID. \n
+ - Type: Array of bytes \n
+ - Maximum array length: 200
+ */
+
+ uint16_t userRespTimerInSeconds;
+ /**< Time to wait for the user to respond. \n
+ - Units: Seconds */
+}qmiLocNiVxNotifyVerifyStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNISUPLPOSMETHODENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_SUPL_POSMETHOD_AGPS_SETASSISTED_V02 = 1, /**< Set assisted. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_AGPS_SETBASED_V02 = 2, /**< Set based. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_AGPS_SETASSISTED_PREF_V02 = 3, /**< Set assisted preferred. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_AGPS_SETBASED_PREF_V02 = 4, /**< Set based preferred. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_AUTONOMOUS_GPS_V02 = 5, /**< Standalone GPS. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_AFLT_V02 = 6, /**< Advanced forward link trilateration. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_ECID_V02 = 7, /**< Exclusive chip ID. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_EOTD_V02 = 8, /**< Enhnaced observed time difference. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_OTDOA_V02 = 9, /**< Observed time delay of arrival. */
+ eQMI_LOC_NI_SUPL_POSMETHOD_NO_POSITION_V02 = 10, /**< No position. */
+ QMILOCNISUPLPOSMETHODENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiSuplPosMethodEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNIDATACODINGSCHEMEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_SS_GERMAN_V02 = 12, /**< Language is German. */
+ eQMI_LOC_NI_SS_ENGLISH_V02 = 13, /**< Language is English. */
+ eQMI_LOC_NI_SS_ITALIAN_V02 = 14, /**< Language is Italian. */
+ eQMI_LOC_NI_SS_FRENCH_V02 = 15, /**< Language is French. */
+ eQMI_LOC_NI_SS_SPANISH_V02 = 16, /**< Language is Spanish. */
+ eQMI_LOC_NI_SS_DUTCH_V02 = 17, /**< Language is Dutch. */
+ eQMI_LOC_NI_SS_SWEDISH_V02 = 18, /**< Language is Swedish. */
+ eQMI_LOC_NI_SS_DANISH_V02 = 19, /**< Language is Danish. */
+ eQMI_LOC_NI_SS_PORTUGUESE_V02 = 20, /**< Language is Portuguese. */
+ eQMI_LOC_NI_SS_FINNISH_V02 = 21, /**< Language is Finnish. */
+ eQMI_LOC_NI_SS_NORWEGIAN_V02 = 22, /**< Language is Norwegian. */
+ eQMI_LOC_NI_SS_GREEK_V02 = 23, /**< Language is Greek. */
+ eQMI_LOC_NI_SS_TURKISH_V02 = 24, /**< Language is Turkish. */
+ eQMI_LOC_NI_SS_HUNGARIAN_V02 = 25, /**< Language is Hungarian. */
+ eQMI_LOC_NI_SS_POLISH_V02 = 26, /**< Language is Polish. */
+ eQMI_LOC_NI_SS_LANGUAGE_UNSPEC_V02 = 27, /**< Language is unspecified. */
+ eQMI_LOC_NI_SUPL_UTF8_V02 = 28, /**< Encoding is UTF 8. */
+ eQMI_LOC_NI_SUPL_UCS2_V02 = 29, /**< Encoding is UCS 2. */
+ eQMI_LOC_NI_SUPL_GSM_DEFAULT_V02 = 30, /**< Encoding is GSM default. */
+ QMILOCNIDATACODINGSCHEMEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiDataCodingSchemeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNISUPLFORMATENUMTYPE_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_SUPL_FORMAT_LOGICAL_NAME_V02 = 0, /**< SUPL logical name format. */
+ eQMI_LOC_NI_SUPL_FORMAT_EMAIL_ADDRESS_V02 = 1, /**< SUPL email address format. */
+ eQMI_LOC_NI_SUPL_FORMAT_MSISDN_V02 = 2, /**< SUPL logical name format. */
+ eQMI_LOC_NI_SUPL_FORMAT_URL_V02 = 3, /**< SUPL URL format. */
+ eQMI_LOC_NI_SUPL_FORMAT_SIP_URL_V02 = 4, /**< SUPL SIP URL format. */
+ eQMI_LOC_NI_SUPL_FORMAT_MIN_V02 = 5, /**< SUPL MIN format. */
+ eQMI_LOC_NI_SUPL_FORMAT_MDN_V02 = 6, /**< SUPL MDN format. */
+ eQMI_LOC_NI_SUPL_FORMAT_IMSPUBLIC_IDENTITY_V02 = 7, /**< SUPL IMS public identity */
+ eQMI_LOC_NI_SUPL_FORMAT_OSS_UNKNOWN_V02 = 2147483647, /**< SUPL unknown format. */
+ QMILOCNISUPLFORMATENUMTYPE_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiSuplFormatEnumType_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocNiSuplFormatEnumType_v02 formatType;
+ /**< Format of the formatted string.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- FORMAT_LOGICAL_ NAME
+ \item 0x00000001 -- FORMAT_EMAIL_ ADDRESS
+ \item 0x00000002 -- FORMAT_MSISDN
+ \item 0x00000003 -- FORMAT_URL
+ \item 0x00000004 -- FORMAT_SIP_URL
+ \item 0x00000005 -- FORMAT_MIN
+ \item 0x00000006 -- FORMAT_MDN
+ \item 0x00000007 -- FORMAT_ IMSPUBLIC_IDENTITY
+ \item 0x7FFFFFFF -- FORMAT_OSS_ UNKNOWN
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ uint32_t formattedString_len; /**< Must be set to # of elements in formattedString */
+ uint8_t formattedString[QMI_LOC_NI_MAX_CLIENT_NAME_LENGTH_V02];
+ /**< Formatted string. \n
+ - Type: Byte array \n
+ - Maximum string length: 64
+ */
+}qmiLocNiSuplFormattedStringStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint8_t qmiLocSuplQopValidMaskT_v02;
+#define QMI_LOC_NI_SUPL_MASK_QOP_HORZ_ACC_VALID_V02 ((qmiLocSuplQopValidMaskT_v02)0x01) /**< Horizontal accuracy is valid in the Quality of Position (QoP). */
+#define QMI_LOC_NI_SUPL_MASK_QOP_VER_ACC_VALID_V02 ((qmiLocSuplQopValidMaskT_v02)0x02) /**< Vertical accuracy is valid in the QoP. */
+#define QMI_LOC_NI_SUPL_MASK_QOP_MAXAGE_VALID_V02 ((qmiLocSuplQopValidMaskT_v02)0x04) /**< Vertical accuracy is valid in the QoP. */
+#define QMI_LOC_NI_SUPL_MASK_QOP_DELAY_VALID_V02 ((qmiLocSuplQopValidMaskT_v02)0x08) /**< Vertical accuracy is valid in the QoP. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocSuplQopValidMaskT_v02 validMask;
+ /**< Bit field indicating which fields are valid in this value.
+
+ Valid bitmasks: \n
+ - 0x01 -- QOP_HORZ_ACC_VALID \n
+ - 0x02 -- QOP_VER_ACC_VALID \n
+ - 0x04 -- QOP_MAXAGE_VALID \n
+ - 0x08 -- QOP_DELAY_VALID*/
+
+ uint8_t horizontalAccuracy;
+ /**< Horizontal accuracy. \n
+ - Units: Meters */
+
+ uint8_t verticalAccuracy;
+ /**< Vertical accuracy. \n
+ - Units: Meters */
+
+ uint16_t maxLocAge;
+ /**< Maximum age of the location if the engine sends a previously
+ computed position. \n
+ - Units: Seconds */
+
+ uint8_t delay;
+ /**< Delay the server is willing to tolerate for the fix. \n
+ - Units: Seconds */
+}qmiLocNiSuplQopStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint8_t qmiLocServerAddrTypeMaskT_v02;
+#define QMI_LOC_SERVER_ADDR_TYPE_IPV4_MASK_V02 ((qmiLocServerAddrTypeMaskT_v02)0x01) /**< IPV4 server address type. */
+#define QMI_LOC_SERVER_ADDR_TYPE_IPV6_MASK_V02 ((qmiLocServerAddrTypeMaskT_v02)0x02) /**< IPV6 server address type. */
+#define QMI_LOC_SERVER_ADDR_TYPE_URL_MASK_V02 ((qmiLocServerAddrTypeMaskT_v02)0x04) /**< URL server address type. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t addr;
+ /**< IPV4 address. */
+
+ uint16_t port;
+ /**< IPV4 port. */
+}qmiLocIpV4AddrStructType_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint16_t addr[QMI_LOC_IPV6_ADDR_LENGTH_V02];
+ /**< IPV6 address. \n
+ - Type: Array of unsigned integers \n
+ - Maximum length of the array: 8 */
+
+ uint32_t port;
+ /**< IPV6 port. */
+}qmiLocIpV6AddrStructType_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocServerAddrTypeMaskT_v02 suplServerAddrTypeMask;
+ /**< Mask specifying the valid fields in this value.
+
+ Valid bitmasks: \n
+ - 0x01 -- IPV4 \n
+ - 0x02 -- IPV6 \n
+ - 0x04 -- URL
+ */
+
+ qmiLocIpV4AddrStructType_v02 ipv4Addr;
+ /**< IPV4 address and port. */
+
+ qmiLocIpV6AddrStructType_v02 ipv6Addr;
+ /**< IPV6 address and port. */
+
+ char urlAddr[QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02 + 1];
+ /**< URL.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 256
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocNiSuplServerInfoStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocNiSuplNotifyVerifyValidMaskT_v02;
+#define QMI_LOC_SUPL_SERVER_INFO_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000001) /**< Mask to denote that the server information
+ is present in an NI SUPL Notify/Verify request event. This mask is set in
+ the valid_flags field of a Notify/Verify structure. */
+#define QMI_LOC_SUPL_SESSION_ID_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000002) /**< Mask to denote that the SUPL session ID
+ is present in an NI SUPL Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_HASH_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000004) /**< Mask to denote that the SUPL hash is present
+ in an NI Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_POS_METHOD_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000008) /**< Mask to denote that the position method is present
+ in an NI SUPL Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_DATA_CODING_SCHEME_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000010) /**< Mask to denote that the data coding scheme
+ is present in an NI SUPL Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_REQUESTOR_ID_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000020) /**< Mask to denote that the requestor ID
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_CLIENT_NAME_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000040) /**< Mask to denote that the requestor ID
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_QOP_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000080) /**< Mask to denote that the quality of position
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_SUPL_USER_RESP_TIMER_MASK_V02 ((qmiLocNiSuplNotifyVerifyValidMaskT_v02)0x00000100) /**< Mask to denote that the user response timer
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid_flags field of a
+ Notify/Verify structure. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocNiSuplNotifyVerifyValidMaskT_v02 valid_flags;
+ /**< Indicates which of the following fields are present in this value.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- SUPL_SERVER_INFO
+ \item 0x00000002 -- SUPL_SESSION_ID
+ \item 0x00000004 -- SUPL_HASH
+ \item 0x00000008 -- SUPL_POS_METHOD
+ \item 0x00000010 -- SUPL_DATA_ CODING_SCHEME
+ \item 0x00000020 -- SUPL_REQUESTOR_ ID
+ \item 0x00000040 -- SUPL_CLIENT_ NAME
+ \item 0x00000080 -- SUPL_QOP
+ \item 0x00000100 -- SUPL_USER_RESP_ TIMER
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocNiSuplServerInfoStructT_v02 suplServerInfo;
+ /**< SUPL server information. */
+
+ uint8_t suplSessionId[QMI_LOC_NI_SUPL_SLP_SESSION_ID_BYTE_LENGTH_V02];
+ /**< SUPL session ID. \n
+ - Type: Array of unsigned integers \n
+ - Maximum length of the array: 4 */
+
+ uint8_t suplHash[QMI_LOC_NI_SUPL_HASH_LENGTH_V02];
+ /**< Hash for SUPL_INIT; used to validate that the message was not
+ corrupted. \n
+ - Type: Array of unsigned integers \n
+ - Length of the array: 8 */
+
+ qmiLocNiSuplPosMethodEnumT_v02 posMethod;
+ /**< GPS mode to be used for the fix.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- AGPS_SETASSISTED
+ \item 0x00000002 -- AGPS_SETBASED
+ \item 0x00000003 -- AGPS_ SETASSISTED_PREF
+ \item 0x00000004 -- AGPS_SETBASED_ PREF
+ \item 0x00000005 -- AUTONOMOUS_GPS
+ \item 0x00000006 -- AFLT
+ \item 0x00000007 -- ECID
+ \item 0x00000008 -- EOTD
+ \item 0x00000009 -- OTDOA
+ \item 0x0000000A -- NO_POSITION
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocNiDataCodingSchemeEnumT_v02 dataCodingScheme;
+ /**< Data coding scheme applies to both the requestor ID and the client
+ name.
+
+ Valid values: \begin{itemize1}
+ \item 0x0000000C -- NI_SS_GERMAN
+ \item 0x0000000D -- NI_SS_ENGLISH
+ \item 0x0000000E -- NI_SS_ITALIAN
+ \item 0x0000000F -- NI_SS_FRENCH
+ \item 0x00000010 -- NI_SS_SPANISH
+ \item 0x00000011 -- NI_SS_DUTCH
+ \item 0x00000012 -- NI_SS_SWEDISH
+ \item 0x00000013 -- NI_SS_DANISH
+ \item 0x00000014 -- NI_SS_PORTUGUESE
+ \item 0x00000015 -- NI_SS_FINNISH
+ \item 0x00000016 -- NI_SS_NORWEGIAN
+ \item 0x00000017 -- NI_SS_GREEK
+ \item 0x00000018 -- NI_SS_TURKISH
+ \item 0x00000019 -- NI_SS_HUNGARIAN
+ \item 0x0000001A -- NI_SS_POLISH
+ \item 0x0000001B -- NI_SS_LANGUAGE_ UNSPEC
+ \item 0x0000001C -- NI_SUPL_UTF8
+ \item 0x0000001D -- NI_SUPL_UCS2
+ \item 0x0000001E -- NI_SUPL_GSM_ DEFAULT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocNiSuplFormattedStringStructT_v02 requestorId;
+ /**< Requestor ID. The encoding scheme for requestor_id is specified in
+ the dataCodingScheme field. */
+
+ qmiLocNiSuplFormattedStringStructT_v02 clientName;
+ /**< Client name. The encoding scheme for client_name is specified in
+ the dataCodingScheme field. */
+
+ qmiLocNiSuplQopStructT_v02 suplQop;
+ /**< SUPL QoP. */
+
+ uint16_t userResponseTimer;
+ /**< Time to wait for the user to respond. \n
+ - Units: Seconds*/
+}qmiLocNiSuplNotifyVerifyStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNILOCATIONTYPEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_LOCATIONTYPE_CURRENT_LOCATION_V02 = 1, /**< Current location. */
+ eQMI_LOC_NI_LOCATIONTYPE_CURRENT_OR_LAST_KNOWN_LOCATION_V02 = 2, /**< Last known location; may be current location. */
+ eQMI_LOC_NI_LOCATIONTYPE_INITIAL_LOCATION_V02 = 3, /**< Initial location. */
+ QMILOCNILOCATIONTYPEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiLocationTypeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocNiDataCodingSchemeEnumT_v02 dataCodingScheme;
+ /**< Identifies the coding scheme of the coded string.
+
+ Valid values: \begin{itemize1}
+ \item 0x0000000C -- NI_SS_GERMAN
+ \item 0x0000000D -- NI_SS_ENGLISH
+ \item 0x0000000E -- NI_SS_ITALIAN
+ \item 0x0000000F -- NI_SS_FRENCH
+ \item 0x00000010 -- NI_SS_SPANISH
+ \item 0x00000011 -- NI_SS_DUTCH
+ \item 0x00000012 -- NI_SS_SWEDISH
+ \item 0x00000013 -- NI_SS_DANISH
+ \item 0x00000014 -- NI_SS_PORTUGUESE
+ \item 0x00000015 -- NI_SS_FINNISH
+ \item 0x00000016 -- NI_SS_NORWEGIAN
+ \item 0x00000017 -- NI_SS_GREEK
+ \item 0x00000018 -- NI_SS_TURKISH
+ \item 0x00000019 -- NI_SS_HUNGARIAN
+ \item 0x0000001A -- NI_SS_POLISH
+ \item 0x0000001B -- NI_SS_LANGUAGE_ UNSPEC
+ \item 0x0000001C -- NI_SUPL_UTF8
+ \item 0x0000001D -- NI_SUPL_UCS2
+ \item 0x0000001E -- NI_SUPL_GSM_ DEFAULT
+ \vspace{-0.18in} \end{itemize1}
+
+ */
+
+ uint32_t codedString_len; /**< Must be set to # of elements in codedString */
+ uint8_t codedString[QMI_LOC_NI_CODEWORD_MAX_LENGTH_V02];
+ /**< Coded string. \n
+ - Type: Array of bytes \n
+ - Maximum string length: 20 */
+}qmiLocNiUmtsCpCodedStringStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint16_t qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02;
+#define QMI_LOC_UMTS_CP_INVOKE_ID_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0001) /**< Mask to denote that the invoke ID
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_DATA_CODING_SCHEME_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0002) /**< Mask to denote that the data coding scheme
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_NOTIFICATION_TEXT_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0004) /**< Mask to denote that the notification text
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_CLIENT_ADDRESS_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0008) /**< Mask to denote that the client address
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_LOCATION_TYPE_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0010) /**< Mask to denote that the location type
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_REQUESTOR_ID_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0020) /**< Mask to denote that the requestor ID
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_CODEWORD_STRING_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0040) /**< Mask to denote that the code word string
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_SERVICE_TYPE_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0080) /**< Mask to denote that the service type
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+#define QMI_LOC_UMTS_CP_USER_RESP_TIMER_MASK_V02 ((qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02)0x0100) /**< Mask to denote that the user response timer
+ is present in an NI Notify/Verify request event.
+ This mask is set in the valid flags field of a
+ Notify/Verify structure. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocNiUmtsCpNotifyVerifyValidMaskT_v02 valid_flags;
+ /**< Fields that are valid in this value.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x0001 -- INVOKE_ID_MASK
+ \item 0x0002 -- DATA_CODING_ SCHEME_MASK
+ \item 0x0004 -- NOTIFICATION_TEXT_ MASK
+ \item 0x0008 -- CLIENT_ADDRESS_ MASK
+ \item 0x0010 -- LOCATION_TYPE_ MASK
+ \item 0x0020 -- REQUESTOR_ID_MASK
+ \item 0x0040 -- CODEWORD_STRING_ MASK
+ \item 0x0080 -- SERVICE_TYPE_MASK
+ \item 0x0100 -- USER_RESP_TIMER_ MASK
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ uint8_t invokeId;
+ /**< Supplementary Services invoke ID. */
+
+ qmiLocNiDataCodingSchemeEnumT_v02 dataCodingScheme;
+ /**< Type of data encoding scheme for the text.
+ Applies to both the notification text and the client address.
+
+ Valid values: \begin{itemize1}
+ \item 0x0000000C -- NI_SS_GERMAN
+ \item 0x0000000D -- NI_SS_ENGLISH
+ \item 0x0000000E -- NI_SS_ITALIAN
+ \item 0x0000000F -- NI_SS_FRENCH
+ \item 0x00000010 -- NI_SS_SPANISH
+ \item 0x00000011 -- NI_SS_DUTCH
+ \item 0x00000012 -- NI_SS_SWEDISH
+ \item 0x00000013 -- NI_SS_DANISH
+ \item 0x00000014 -- NI_SS_PORTUGUESE
+ \item 0x00000015 -- NI_SS_FINNISH
+ \item 0x00000016 -- NI_SS_NORWEGIAN
+ \item 0x00000017 -- NI_SS_GREEK
+ \item 0x00000018 -- NI_SS_TURKISH
+ \item 0x00000019 -- NI_SS_HUNGARIAN
+ \item 0x0000001A -- NI_SS_POLISH
+ \item 0x0000001B -- NI_SS_LANGUAGE_ UNSPEC
+ \item 0x0000001C -- NI_SUPL_UTF8
+ \item 0x0000001D -- NI_SUPL_UCS2
+ \item 0x0000001E -- NI_SUPL_GSM_ DEFAULT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ uint32_t notificationText_len; /**< Must be set to # of elements in notificationText */
+ uint8_t notificationText[QMI_LOC_NI_MAX_CLIENT_NAME_LENGTH_V02];
+ /**< Notification text; the encoding method is specified in
+ dataCodingScheme. \n
+ - Type: Array of bytes \n
+ - Maximum array length: 64 */
+
+ uint32_t clientAddress_len; /**< Must be set to # of elements in clientAddress */
+ uint8_t clientAddress[QMI_LOC_NI_MAX_EXT_CLIENT_ADDRESS_V02];
+ /**< Client address; the encoding method is specified in
+ dataCodingScheme. \n
+ - Maximum array length: 20 */
+
+ qmiLocNiLocationTypeEnumT_v02 locationType;
+ /**< Location type.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- CURRENT_ LOCATION
+ \item 0x00000002 -- CURRENT_OR_ LAST_KNOWN_LOCATION
+ \item 0x00000004 -- INITIAL_LOCATION
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocNiUmtsCpCodedStringStructT_v02 requestorId;
+ /**< Requestor ID; the encoding method is specified in the
+ qmiLocNiUmtsCpCodedStringStructT.dataCodingScheme field. */
+
+ qmiLocNiUmtsCpCodedStringStructT_v02 codewordString;
+ /**< Codeword string; the encoding method is specified in the
+ qmiLocNiUmtsCpCodedStringStructT.dataCodingScheme field. */
+
+ uint8_t lcsServiceTypeId;
+ /**< Service type ID. */
+
+ uint16_t userResponseTimer;
+ /**< Time to wait for the user to respond. \n
+ - Units: Seconds */
+}qmiLocNiUmtsCpNotifyVerifyStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNISERVICEINTERACTIONENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_SERVICE_INTERACTION_ONGOING_NI_INCOMING_MO_V02 = 1, /**< Service interaction between ongoing NI and incoming MO sessions. */
+ QMILOCNISERVICEINTERACTIONENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiServiceInteractionEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocNiVxNotifyVerifyStructT_v02 niVxReq;
+ /**< Ongoing NI session request; this information is currently not filled. */
+
+ qmiLocNiServiceInteractionEnumT_v02 serviceInteractionType;
+ /**< Service interaction type specified in qmiLocNiServiceInteractionEnumT.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- ONGOING_NI_ INCOMING_MO
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocNiVxServiceInteractionStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint16_t qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02;
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_WLAN_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0001) /**< Denotes that WLAN measurements are allowed as part of location ID
+ and multiple location IDs in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_GSM_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0002) /**< Denotes that GSM measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_WCDMA_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0004) /**< Denotes that WCDMA measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_CDMA_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0008) /**< Denotes that CDMA measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_HRDP_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0010) /**< Denotes that HRDP measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_UMB_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0020) /**< Denotes that UMB measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_LTE_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0040) /**< Denotes that LTE measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_WIMAX_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0080) /**< Denotes that WIMAX measurements are allowed as part of location ID
+ and multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_HISTORIC_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0100) /**< Denotes that historical information is allowed as part of
+ multiple location ID in the SUPL_POS_INIT message. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_SUPPORTED_NETWORK_NONSVRV_V02 ((qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02)0x0200) /**< Denotes that information about nonserving cells is allowed
+ as part of multiple location ID in the SUPL_POS_INIT message. */
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNISUPLVER2EXTTRIGGERTYPEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SUPL_VER_2_EXT_TRIGGER_TYPE_SINGLE_SHOT_V02 = -1, /**< The SUPL INIT message indicates a request for a single shot
+ triggered session. */
+ eQMI_LOC_SUPL_VER_2_EXT_TRIGGER_TYPE_PERIODIC_V02 = 0, /**< The SUPL INIT message indicates a request for a periodic
+ triggered session. */
+ eQMI_LOC_SUPL_VER_2_EXT_TRIGGER_TYPE_AREA_EVENT_V02 = 1, /**< The SUPL INIT message indicates a request for an area event
+ triggered session. */
+ QMILOCNISUPLVER2EXTTRIGGERTYPEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiSuplVer2ExtTriggerTypeEnumT_v02;
+/**
+ @}
+ */
+
+typedef uint16_t qmiLocNiSuplVer2ExtGnssTypeMaskT_v02;
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_GNSS_GPS_V02 ((qmiLocNiSuplVer2ExtGnssTypeMaskT_v02)0x0001) /**< GPS is allowed to be used as the positioning technology. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_GNSS_GLONASS_V02 ((qmiLocNiSuplVer2ExtGnssTypeMaskT_v02)0x0002) /**< GLONASS is allowed to be used as the positioning technology. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_GNSS_GALILEO_V02 ((qmiLocNiSuplVer2ExtGnssTypeMaskT_v02)0x0004) /**< Galileo is allowed to be used as the positioning technology. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_GNSS_SBAS_V02 ((qmiLocNiSuplVer2ExtGnssTypeMaskT_v02)0x0008) /**< SBAS is allowed to be used as the positioning technology. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_GNSS_QZSS_V02 ((qmiLocNiSuplVer2ExtGnssTypeMaskT_v02)0x0010) /**< QZSS is allowed to be used as the positioning technology. */
+#define QMI_LOC_SUPL_VER_2_EXT_MASK_GNSS_MODERN_GPS_V02 ((qmiLocNiSuplVer2ExtGnssTypeMaskT_v02)0x0020) /**< Modern GPS is allowed to be used as the positioning technology. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocNiSuplVer2ExtSupportedNetworksMaskT_v02 supportedNetworksMask;
+ /**< Specifies which type of network measurements are allowed to be sent as
+ part of the Location ID or Multiple Location IDs parameter in the
+ SUPL_POS_INIT message (see \hyperref[S4]{[S4]}).
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x0001 -- SUPPORTED_NETWORK_ WLAN
+ \item 0x0002 -- SUPPORTED_NETWORK_ GSM
+ \item 0x0004 -- SUPPORTED_NETWORK_ WCDMA
+ \item 0x0008 -- SUPPORTED_NETWORK_ CDMA
+ \item 0x0010 -- SUPPORTED_NETWORK_ HRDP
+ \item 0x0020 -- SUPPORTED_NETWORK_ UMB
+ \item 0x0040 -- SUPPORTED_NETWORK_ LTE
+ \item 0x0080 -- SUPPORTED_NETWORK_ WIMAX
+ \item 0x0100 -- SUPPORTED_NETWORK_ HISTORIC
+ \item 0x0200 -- SUPPORTED_NETWORK_ NONSVRV
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocNiSuplVer2ExtTriggerTypeEnumT_v02 triggerType;
+ /**< Specifies the type of session trigger requested in the
+ SUPL_POS_INIT message (refer to \hyperref[S4]{[S4]}).
+
+ Valid values: \begin{itemize1}
+ \item 0xFFFFFFFF -- TRIGGER_TYPE_ SINGLE_SHOT
+ \item 0x00000000 -- TRIGGER_TYPE_ PERIODIC
+ \item 0x00000001 -- TRIGGER_TYPE_ AREA_EVENT
+ \vspace{-0.18in} \end{itemize1} */
+
+ qmiLocNiSuplVer2ExtGnssTypeMaskT_v02 gnssType;
+ /**< Specifies which GNSS technologies are allowed as positioning
+ technologies.
+
+ Valid bitmasks: \n
+ - 0x0001 -- GNSS_GPS \n
+ - 0x0002 -- GNSS_GLONASS \n
+ - 0x0004 -- GNSS_GALILEO \n
+ - 0x0008 -- GNSS_SBAS \n
+ - 0x0010 -- GNSS_QZSS \n
+ - 0x0020 -- GNSS_MODERN_GPS
+ */
+}qmiLocNiSuplVer2ExtStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ char eslpUrl[QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02 + 1];
+ /**< ESLP URL. \n
+ Maximum length: 255 bytes */
+}qmiLocEmergencyNotificationStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Indicates an NI Notify/Verify request to the control point. */
+typedef struct {
+
+ /* Mandatory */
+ /* Notification Type */
+ qmiLocNiNotifyVerifyEnumT_v02 notificationType;
+ /**< Type of notification/verification performed.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- NO_NOTIFY_NO_ VERIFY
+ \item 0x00000002 -- NOTIFY_ONLY
+ \item 0x00000003 -- ALLOW_NO_RESP
+ \item 0x00000004 -- NOT_ALLOW_NO_ RESP
+ \item 0x00000005 -- PRIVACY_ OVERRIDE
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Network Initiated Vx Request */
+ uint8_t NiVxInd_valid; /**< Must be set to true if NiVxInd is being passed */
+ qmiLocNiVxNotifyVerifyStructT_v02 NiVxInd;
+ /**< \vspace{0.06in} \n Optional NI Vx request payload. */
+
+ /* Optional */
+ /* Network Initiated SUPL Request */
+ uint8_t NiSuplInd_valid; /**< Must be set to true if NiSuplInd is being passed */
+ qmiLocNiSuplNotifyVerifyStructT_v02 NiSuplInd;
+ /**< \vspace{0.06in} \n Optional NI SUPL request payload. */
+
+ /* Optional */
+ /* Network Initiated UMTS Control Plane Request */
+ uint8_t NiUmtsCpInd_valid; /**< Must be set to true if NiUmtsCpInd is being passed */
+ qmiLocNiUmtsCpNotifyVerifyStructT_v02 NiUmtsCpInd;
+ /**< \vspace{0.06in} \n Optional NI UMTS-CP request payload. */
+
+ /* Optional */
+ /* Network Initiated Service Interaction Request */
+ uint8_t NiVxServiceInteractionInd_valid; /**< Must be set to true if NiVxServiceInteractionInd is being passed */
+ qmiLocNiVxServiceInteractionStructT_v02 NiVxServiceInteractionInd;
+ /**< \vspace{0.06in} \n Optional NI service interaction payload. */
+
+ /* Optional */
+ /* Network Initiated SUPL Version 2 Extension */
+ uint8_t NiSuplVer2ExtInd_valid; /**< Must be set to true if NiSuplVer2ExtInd is being passed */
+ qmiLocNiSuplVer2ExtStructT_v02 NiSuplVer2ExtInd;
+ /**< \vspace{0.06in} \n Optional NI SUPL Version 2 Extension payload. When present,
+ this payload is to be used in conjunction with the SUPL
+ indication payload. */
+
+ /* Optional */
+ /* SUPL Emergency Notification */
+ uint8_t suplEmergencyNotification_valid; /**< Must be set to true if suplEmergencyNotification is being passed */
+ qmiLocEmergencyNotificationStructT_v02 suplEmergencyNotification;
+ /**< \vspace{0.06in} \n This specifies that the corresponding NI notification is an
+ emergency notification. Emergency notification
+ can be given even without an Emergency SUPL Location Platform (ESLP)
+ address. */
+}qmiLocEventNiNotifyVerifyReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ char serverUrl[QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02 + 1];
+ /**< Assistance server URL.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 256
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocAssistanceServerUrlStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t delayThreshold;
+ /**< The time server is to be skipped if a one-way delay to the server
+ exceeds this threshold. \n
+ - Units: Milliseconds */
+
+ uint32_t timeServerList_len; /**< Must be set to # of elements in timeServerList */
+ qmiLocAssistanceServerUrlStructT_v02 timeServerList[QMI_LOC_MAX_NTP_SERVERS_V02];
+ /**< List of Time Server URL's that are recommended by the service for time
+ information, the list is ordered, the client is to use the first
+ server specified in the list as the primary URL to fetch NTP time,
+ the second one as secondary, and so on. \n
+ - Maximum server list items: 3 */
+}qmiLocTimeServerListStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Requests the control point to inject time information. */
+typedef struct {
+
+ /* Optional */
+ /* Time Server Info */
+ uint8_t timeServerInfo_valid; /**< Must be set to true if timeServerInfo is being passed */
+ qmiLocTimeServerListStructT_v02 timeServerInfo;
+ /**< \vspace{0.06in} \n Contains information about the time servers recommended by the
+ location service for NTP time. */
+}qmiLocEventInjectTimeReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t maxFileSizeInBytes;
+ /**< Maximum allowable predicted orbits file size (in bytes). */
+
+ uint32_t maxPartSize;
+ /**< Maximum allowable predicted orbits file chunk size (in bytes). */
+}qmiLocPredictedOrbitsAllowedSizesStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t serverList_len; /**< Must be set to # of elements in serverList */
+ qmiLocAssistanceServerUrlStructT_v02 serverList[QMI_LOC_MAX_PREDICTED_ORBITS_SERVERS_V02];
+ /**< List of predicted orbits URLs. The list is ordered, so the client
+ must use the first server specified in the list as the primary URL
+ from which to download predicted orbits data, the second one as
+ secondary, and so on. \n
+ - Maximum number of servers that can be specified: 3 */
+}qmiLocPredictedOrbitsServerListStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Requests the control point to inject predicted orbits data. */
+typedef struct {
+
+ /* Mandatory */
+ /* Allowed Sizes */
+ qmiLocPredictedOrbitsAllowedSizesStructT_v02 allowedSizes;
+ /**< \vspace{0.06in} \n Maximum part and file size allowed to be injected in the engine. */
+
+ /* Optional */
+ /* Server List */
+ uint8_t serverList_valid; /**< Must be set to true if serverList is being passed */
+ qmiLocPredictedOrbitsServerListStructT_v02 serverList;
+ /**< \vspace{0.06in} \n List of servers that can be used by the client to download
+ predicted orbits data. */
+}qmiLocEventInjectPredictedOrbitsReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Requests the control point to inject a position. */
+typedef struct {
+
+ /* Mandatory */
+ /* Latitude */
+ double latitude;
+ /**< Latitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -90.0 to 90.0 \begin{itemize1}
+ \item Positive values indicate northern latitude
+ \item Negative values indicate southern latitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Mandatory */
+ /* Longitude */
+ double longitude;
+ /**< Longitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -180.0 to 180.0 \begin{itemize1}
+ \item Positive values indicate eastern longitude
+ \item Negative values indicate western longitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Mandatory */
+ /* Circular Horizontal Uncertainty */
+ float horUncCircular;
+ /**< Horizontal position uncertainty (circular).\n
+ - Units: Meters */
+
+ /* Mandatory */
+ /* UTC Timestamp */
+ uint64_t timestampUtc;
+ /**< UTC timestamp.
+ \begin{itemize1}
+ \item Units: Milliseconds since Jan. 1, 1970
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocEventInjectPositionReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCENGINESTATEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_ENGINE_STATE_ON_V02 = 1, /**< Location engine is on. */
+ eQMI_LOC_ENGINE_STATE_OFF_V02 = 2, /**< Location engine is off. */
+ QMILOCENGINESTATEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocEngineStateEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends the engine state to the control point. */
+typedef struct {
+
+ /* Mandatory */
+ /* Engine State */
+ qmiLocEngineStateEnumT_v02 engineState;
+ /**< Location engine state.
+
+ Valid values: \n
+ - 0x00000001 -- ON \n
+ - 0x00000002 -- OFF
+ */
+}qmiLocEventEngineStateIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCFIXSESSIONSTATEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_FIX_SESSION_STARTED_V02 = 1, /**< Location fix session has started. */
+ eQMI_LOC_FIX_SESSION_FINISHED_V02 = 2, /**< Location fix session has ended. */
+ QMILOCFIXSESSIONSTATEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocFixSessionStateEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends the fix session state to the control point. */
+typedef struct {
+
+ /* Mandatory */
+ /* Session State */
+ qmiLocFixSessionStateEnumT_v02 sessionState;
+ /**< LOC fix session state.
+
+ Valid values: \n
+ - 0x00000001 -- STARTED \n
+ - 0x00000002 -- FINISHED
+ */
+
+ /* Optional */
+ /* Session ID */
+ uint8_t sessionId_valid; /**< Must be set to true if sessionId is being passed */
+ uint8_t sessionId;
+ /**< ID of the session that was specified in the Start request.
+ This may not be specified for a fix session corresponding to
+ a network-initiated request. \n
+ - Range: 0 to 255 */
+}qmiLocEventFixSessionStateIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCWIFIREQUESTENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_WIFI_START_PERIODIC_HI_FREQ_FIXES_V02 = 0, /**< Start periodic fixes with high frequency. */
+ eQMI_LOC_WIFI_START_PERIODIC_KEEP_WARM_V02 = 1, /**< Keep warm for low frequency fixes without data downloads. */
+ eQMI_LOC_WIFI_STOP_PERIODIC_FIXES_V02 = 2, /**< Stop periodic fixes request. */
+ QMILOCWIFIREQUESTENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocWifiRequestEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends a WiFi request to the control point. */
+typedef struct {
+
+ /* Mandatory */
+ /* Request Type */
+ qmiLocWifiRequestEnumT_v02 requestType;
+ /**< Request type as specified in qmiWifiRequestEnumT.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- START_PERIODIC_ HI_FREQ_FIXES
+ \item 0x00000001 -- START_PERIODIC_ KEEP_WARM
+ \item 0x00000002 -- STOP_PERIODIC_ FIXES
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Time Between Fixes */
+ uint8_t tbfInMs_valid; /**< Must be set to true if tbfInMs is being passed */
+ uint16_t tbfInMs;
+ /**< Time between fixes for a periodic request.\n
+ - Units: Milliseconds */
+}qmiLocEventWifiReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint16_t samplesPerBatch;
+ /**< Specifies the number of samples per batch the GNSS location engine is to
+ receive. The sensor sampling frequency can be computed as follows: \vspace{-0.06in} \n
+
+ samplingFrequency = samplesPerBatch * batchesPerSecond \vspace{-0.06in} \n
+
+ samplesPerBatch must be a nonzero positive value.
+ */
+
+ uint16_t batchesPerSecond;
+ /**< Number of sensor-data batches the GNSS location engine is to receive
+ per second. The rate is specified in an integral number of batches per
+ second (Hz). \vspace{-0.06in} \n
+
+ batchesPerSecond must be a nonzero positive value.
+ */
+}qmiLocSensorControlConfigSamplingSpecStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint8_t injectEnable;
+ /**< Indicates whether the GNSS location engine is ready to accept data from this
+ sensor.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- GNSS location engine is ready to accept sensor
+ data
+ \item 0x00 (FALSE) -- GNSS location engine is not ready to accept
+ sensor data
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 dataFrequency;
+ /**< Rate at which the GNSS engine would like the sensor to be sampled. \n
+ The rate is specified in integral number of samples per second (Hz)\n
+ and batches per second.
+ */
+}qmiLocSensorReadyStatusStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Notifies the control point if the GNSS location engine is
+ ready to accept sensor data. */
+typedef struct {
+
+ /* Optional */
+ /* Accelerometer Accept Ready */
+ uint8_t accelReady_valid; /**< Must be set to true if accelReady is being passed */
+ qmiLocSensorReadyStatusStructT_v02 accelReady;
+ /**< \vspace{0.06in} \n Indicates whether the GNSS location engine is ready
+ to accept accelerometer sensor data.
+ */
+
+ /* Optional */
+ /* Gyroscope Accept Ready */
+ uint8_t gyroReady_valid; /**< Must be set to true if gyroReady is being passed */
+ qmiLocSensorReadyStatusStructT_v02 gyroReady;
+ /**< \vspace{0.06in} \n Indicates whether the GNSS location engine is ready
+ to accept gyroscope sensor data.
+ */
+
+ /* Optional */
+ /* Accelerometer Temperature Accept Ready */
+ uint8_t accelTemperatureReady_valid; /**< Must be set to true if accelTemperatureReady is being passed */
+ qmiLocSensorReadyStatusStructT_v02 accelTemperatureReady;
+ /**< \vspace{0.06in} \n Indicates whether the GNSS location engine is ready
+ to accept accelerometer temperature data.
+ */
+
+ /* Optional */
+ /* Gyroscope Temperature Accept Ready */
+ uint8_t gyroTemperatureReady_valid; /**< Must be set to true if gyroTemperatureReady is being passed */
+ qmiLocSensorReadyStatusStructT_v02 gyroTemperatureReady;
+ /**< \vspace{0.06in} \n Indicates whether the GNSS location engine is ready
+ to accept gyroscope temperature data.
+ */
+}qmiLocEventSensorStreamingReadyStatusIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Notifies the control point to inject time synchronization
+ data. */
+typedef struct {
+
+ /* Mandatory */
+ /* Opaque Time Sync Reference Counter */
+ uint32_t refCounter;
+ /**< This TLV is sent to registered control points. It is sent by
+ the location engine when it needs to synchronize location engine and
+ control point (sensor processor) times.
+ This TLV must be echoed back in the Time Sync Inject request. */
+}qmiLocEventTimeSyncReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Requests the control point to enable Stationary Position
+ Indicator (SPI) streaming reports. */
+typedef struct {
+
+ /* Mandatory */
+ /* Enable/Disable SPI Requests */
+ uint8_t enable;
+ /**< Indicates whether the client is to start or stop sending an SPI status stream.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Client is to start sending an SPI status stream
+ \item 0x00 (FALSE) -- Client is to stop sending an SPI status stream
+ \vspace{-0.18in} \end{itemize1}*/
+}qmiLocEventSetSpiStreamingReportIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCWWANTYPEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_WWAN_TYPE_INTERNET_V02 = 0, /**< Bring up the WWAN type used for an Internet connection. */
+ eQMI_LOC_WWAN_TYPE_AGNSS_V02 = 1, /**< Bring up the WWAN type used for AGNSS connections. */
+ eQMI_LOC_WWAN_TYPE_AGNSS_EMERGENCY_V02 = 2, /**< Bring up the WWAN type used for AGNSS Emergency connections. */
+ QMILOCWWANTYPEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocWWANTypeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSERVERREQUESTENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SERVER_REQUEST_OPEN_V02 = 1, /**< Open a connection to the location server. */
+ eQMI_LOC_SERVER_REQUEST_CLOSE_V02 = 2, /**< Close a connection to the location server. */
+ QMILOCSERVERREQUESTENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocServerRequestEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Requests the client to open or close a connection
+ to the assisted GPS location server. */
+typedef struct {
+
+ /* Mandatory */
+ /* Connection Handle */
+ uint32_t connHandle;
+ /**< Identifies a connection across Open and Close request events. */
+
+ /* Mandatory */
+ /* Request Type */
+ qmiLocServerRequestEnumT_v02 requestType;
+ /**< Open or close a connection to the location server.
+
+ Valid values: \n
+ - 0x00000001 -- OPEN \n
+ - 0x00000002 -- CLOSE
+ */
+
+ /* Mandatory */
+ /* WWAN Type */
+ qmiLocWWANTypeEnumT_v02 wwanType;
+ /**< Identifies the WWAN type for this request.
+ Valid values: \n
+ - eQMI_LOC_WWAN_TYPE_INTERNET (0) -- Bring up the WWAN type used for an Internet connection.
+ - eQMI_LOC_WWAN_TYPE_AGNSS (1) -- Bring up the WWAN type used for AGNSS connections.
+ - eQMI_LOC_WWAN_TYPE_AGNSS_EMERGENCY (2) -- Bring up the WWAN type used for AGNSS Emergency connections.
+ */
+}qmiLocEventLocationServerConnectionReqIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNIGEOFENCEOPERATIONENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_GEOFENCE_ADDED_V02 = 1, /**< An NI Geofence was added. */
+ eQMI_LOC_NI_GEOFENCE_DELETED_V02 = 2, /**< An NI Geofence was deleted. */
+ eQMI_LOC_NI_GEOFENCE_EDITED_V02 = 3, /**< An NI Geofence was edited. The control point can query the
+ Geofence to find the its current state. */
+ QMILOCNIGEOFENCEOPERATIONENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiGeofenceOperationEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Informs the control point about
+ network-initiated Geofences. */
+typedef struct {
+
+ /* Mandatory */
+ /* Geofence ID */
+ uint32_t geofenceId;
+ /**< ID of the Geofence for which this
+ notification was generated. */
+
+ /* Mandatory */
+ /* Operation Type */
+ qmiLocNiGeofenceOperationEnumT_v02 operationType;
+ /**< Operation for which this notification was generated.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- NI_GEOFENCE_ ADDED
+ \item 0x00000002 -- NI_GEOFENCE_ DELETED
+ \item 0x00000003 -- NI_GEOFENCE_ EDITED
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocEventNiGeofenceNotificationIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCEGENALERTENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_GEN_ALERT_GNSS_UNAVAILABLE_V02 = 1, /**< GNSS is unavailable and GNSS position fixes
+ cannot be used to monitor Geofences. */
+ eQMI_LOC_GEOFENCE_GEN_ALERT_GNSS_AVAILABLE_V02 = 2, /**< GNSS is now available and GNSS postion fixes can
+ be used to monitor Geofences. */
+ eQMI_LOC_GEOFENCE_GEN_ALERT_OOS_V02 = 3, /**< The engine is out of service and no cell ID coverage
+ information is available. */
+ eQMI_LOC_GEOFENCE_GEN_ALERT_TIME_INVALID_V02 = 4, /**< The engine has an invalid time. */
+ QMILOCGEOFENCEGENALERTENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofenceGenAlertEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Notifies the control point of the
+ Geofence status. */
+typedef struct {
+
+ /* Mandatory */
+ /* Geofence General Alert */
+ qmiLocGeofenceGenAlertEnumT_v02 geofenceAlert;
+ /**< Specifies the Geofence general alert type.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_GEN_ ALERT_GNSS_UNAVAILABLE
+ \item 0x00000002 -- GEOFENCE_GEN_ ALERT_GNSS_AVAILABLE
+ \item 0x00000003 -- GEOFENCE_GEN_ ALERT_OOS
+ \item 0x00000004 -- GEOFENCE_GEN_ ALERT_TIME_INVALID
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocEventGeofenceGenAlertIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCEBREACHTYPEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_BREACH_TYPE_ENTERING_V02 = 1, /**< Denotes that a client entered the Geofence. */
+ eQMI_LOC_GEOFENCE_BREACH_TYPE_LEAVING_V02 = 2, /**< Denotes that a client left the Geofence. */
+ QMILOCGEOFENCEBREACHTYPEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofenceBreachTypeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ /* UTC Timestamp */
+ uint64_t timestampUtc;
+ /**< UTC timestamp.
+ \begin{itemize1}
+ \item Units: Milliseconds since Jan. 1, 1970
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Latitude */
+ double latitude;
+ /**< Latitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -90.0 to 90.0 \begin{itemize1}
+ \item Positive values indicate northern latitude
+ \item Negative values indicate southern latitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Longitude */
+ double longitude;
+ /**< Longitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -180.0 to 180.0 \begin{itemize1}
+ \item Positive values indicate eastern longitude
+ \item Negative values indicate western longitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Horizontal Elliptical Uncertainty (Semi-Minor Axis) */
+ float horUncEllipseSemiMinor;
+ /**< Semi-minor axis of horizontal elliptical uncertainty.\n
+ - Units: Meters */
+
+ /* Horizontal Elliptical Uncertainty (Semi-Major Axis) */
+ float horUncEllipseSemiMajor;
+ /**< Semi-major axis of horizontal elliptical uncertainty.\n
+ - Units: Meters */
+
+ /* Elliptical Horizontal Uncertainty Azimuth */
+ float horUncEllipseOrientAzimuth;
+ /**< Elliptical horizontal uncertainty azimuth of orientation.\n
+ - Units: Decimal degrees \n
+ - Range: 0 to 180 */
+
+ /* Horizontal Speed validity bit */
+ uint8_t speedHorizontal_valid;
+ /**< Indicates whether the Horizontal speed field contains valid
+ information.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Horizontal speed is valid
+ \item 0x00 (FALSE) -- Horizontal speed is invalid
+ and is to be ignored
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Horizontal Speed */
+ float speedHorizontal;
+ /**< Horizontal speed.\n
+ - Units: Meters/second */
+
+ /* Altitude validity bit */
+ uint8_t altitudeWrtEllipsoid_valid;
+ /**< Indicates whether the altitude field contains valid
+ information.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Altitude field is valid
+ \item 0x00 (FALSE) -- Altitude field is invalid
+ and is to be ignored
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Altitude With Respect to Ellipsoid */
+ float altitudeWrtEllipsoid;
+ /**< Altitude with respect to the WGS84 ellipsoid.\n
+ - Units: Meters \n
+ - Range: -500 to 15883 */
+
+ /* Vertical Uncertainty validity bit */
+ uint8_t vertUnc_valid;
+ /**< Indicates whether the Vertical Uncertainty field contains valid
+ information.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Vertical Uncertainty field is valid
+ \item 0x00 (FALSE) -- Vertical Uncertainty field is invalid
+ and is to be ignored
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Vertical Uncertainty */
+ float vertUnc;
+ /**< Vertical uncertainty.\n
+ - Units: Meters */
+
+ /* Vertical Speed validity bit */
+ uint8_t speedVertical_valid;
+ /**< Indicates whether the Vertical Speed field contains valid
+ information.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Vertical Speed field is valid
+ \item 0x00 (FALSE) -- Vertical Speed field is invalid
+ and is to be ignored
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Vertical Speed */
+ float speedVertical;
+ /**< Vertical speed.\n
+ - Units: Meters/second */
+
+ /* heading validity bit */
+ uint8_t heading_valid;
+ /**< Indicates whether the Heading field contains valid
+ information.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Heading field is valid
+ \item 0x00 (FALSE) -- Heading field is invalid
+ and is to be ignored
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Heading */
+ float heading;
+ /**< Heading.\n
+ - Units: Degrees \n
+ - Range: 0 to 359.999 */
+}qmiLocGeofencePositionStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Notifies the control point of
+ a Geofence breach event. */
+typedef struct {
+
+ /* Mandatory */
+ /* Geofence ID */
+ uint32_t geofenceId;
+ /**< ID of the Geofence for which this
+ notification was generated. */
+
+ /* Mandatory */
+ /* Geofence Breach Type */
+ qmiLocGeofenceBreachTypeEnumT_v02 breachType;
+ /**< The type of breach that generated this event.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_ BREACH_TYPE_ENTERING
+ \item 0x00000002 -- GEOFENCE_ BREACH_TYPE_LEAVING
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Geofence Position */
+ uint8_t geofencePosition_valid; /**< Must be set to true if geofencePosition is being passed */
+ qmiLocGeofencePositionStructT_v02 geofencePosition;
+ /**< \vspace{0.06in} \n Position of the client when it breached the Geofence.
+ This TLV is included if the client configures the
+ Geofence to report position. The position is reported
+ at the same confidence level that was specified in the
+ Add Circular Geofence request. */
+}qmiLocEventGeofenceBreachIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Recommends how pedometer reports are to be
+ sent to the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Request Pedometer Data */
+ uint8_t requestPedometerData;
+ /**< Indicates whether the GNSS location engine is requesting the client to
+ send pedometer data.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- GNSS location engine is requesting
+ pedometer data
+ \item 0x00 (FALSE) -- GNSS location engine is not requesting
+ pedometer data
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Reset Step Count */
+ uint8_t resetStepCount_valid; /**< Must be set to true if resetStepCount is being passed */
+ uint8_t resetStepCount;
+ /**< Indicates whether the location engine is to reset the step count.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Pedometer step count is to be reset.
+ \item 0x00 (FALSE) -- Pedometer step count is not to be reset.
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Step Count Threshold */
+ uint8_t stepCountThreshold_valid; /**< Must be set to true if stepCountThreshold is being passed */
+ uint32_t stepCountThreshold;
+ /**< Specifies the number of steps to be sampled in a pedometer report,
+ as recommended by the the location engine. If the threshold is set to 0,
+ the location engine wants a pedometer report at every step event.
+ */
+}qmiLocEventPedometerControlIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Recommends how motion data reports are to be
+ sent to the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Request Motion Data */
+ uint8_t requestMotionData;
+ /**< Indicates whether the GNSS location engine is requesting
+ the client to send motion data.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- GNSS location engine is requesting
+ motion data
+ \item 0x00 (FALSE) -- GNSS location engine is not requesting
+ motion data
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocEventMotionDataControlIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSTATUSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SUCCESS_V02 = 0, /**< Request was completed successfully. */
+ eQMI_LOC_GENERAL_FAILURE_V02 = 1, /**< Request failed because of a general failure. */
+ eQMI_LOC_UNSUPPORTED_V02 = 2, /**< Request failed because it is not supported. */
+ eQMI_LOC_INVALID_PARAMETER_V02 = 3, /**< Request failed because it contained invalid parameters. */
+ eQMI_LOC_ENGINE_BUSY_V02 = 4, /**< Request failed because the engine is busy. */
+ eQMI_LOC_PHONE_OFFLINE_V02 = 5, /**< Request failed because the phone is offline. */
+ eQMI_LOC_TIMEOUT_V02 = 6, /**< Request failed because it timed out. */
+ eQMI_LOC_CONFIG_NOT_SUPPORTED_V02 = 7, /**< Request failed because an undefined configuration was requested */
+ eQMI_LOC_INSUFFICIENT_MEMORY_V02 = 8, /**< Request failed because the engine could not allocate sufficent
+ memory for the request. */
+ QMILOCSTATUSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocStatusEnumT_v02;
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetServiceRevisionReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetServiceRevisionReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Client can query the service revision using this message. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Revision Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Revision request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Mandatory */
+ /* Interface Definition Minor Revision */
+ uint32_t revision;
+ /**< Revision of the service. This is the minor revision of the interface that
+ the service implements. Minor revision updates of the service are always
+ backward compatible. */
+
+ /* Optional */
+ /* GNSS Measurement Engine Firmware Version String */
+ uint8_t gnssMeFWVerString_valid; /**< Must be set to true if gnssMeFWVerString is being passed */
+ char gnssMeFWVerString[QMI_LOC_GNSS_ME_VERSION_STRING_MAX_LENGTH_V02 + 1];
+ /**< Version of the GNSS measurement engine software running under the LOC API.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 128
+ \vspace{0.1in} \end{itemize1}
+
+ \textbf{Note:} This string is only provided on platforms that have
+ a measurement engine that supports this version string. On all other
+ platforms, this optional TLV is not provided. */
+
+ /* Optional */
+ /* GNSS Hosted Software Version String */
+ uint8_t gnssHostSWVerString_valid; /**< Must be set to true if gnssHostSWVerString is being passed */
+ char gnssHostSWVerString[QMI_LOC_GNSS_HOSTED_SW_VERSION_STRING_MAX_LENGTH_V02 + 1];
+ /**< Version of the GNSS hosted software running under the LOC API.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 128
+ \vspace{0.1in}\end{itemize1}
+
+ \textbf{Note:} This string is only provided on hosted architectures
+ (measurement and position engine running on different processors) that
+ support this version string. On all other platforms, this optional TLV
+ is not provided. */
+
+ /* Optional */
+ /* GNSS Software Version String */
+ uint8_t gnssSWVerString_valid; /**< Must be set to true if gnssSWVerString is being passed */
+ char gnssSWVerString[QMI_LOC_GNSS_SW_VERSION_STRING_MAX_LENGTH_V02 + 1];
+ /**< Aggregate version of the GNSS software.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 256
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocGetServiceRevisionIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetFixCriteriaReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetFixCriteriaReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the fix criteria from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Fix Criteria Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Fix Criteria request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Horizontal Accuracy */
+ uint8_t horizontalAccuracyLevel_valid; /**< Must be set to true if horizontalAccuracyLevel is being passed */
+ qmiLocAccuracyLevelEnumT_v02 horizontalAccuracyLevel;
+ /**< Horizontal accuracy level.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- LOW: Client requires low horizontal accuracy
+ \item 0x00000002 -- MED: Client requires medium horizontal accuracy
+ \item 0x00000003 -- HIGH: Client requires high horizontal accuracy
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Enable/Disable Intermediate Fixes */
+ uint8_t intermediateReportState_valid; /**< Must be set to true if intermediateReportState is being passed */
+ qmiLocIntermediateReportStateEnumT_v02 intermediateReportState;
+ /**< Intermediate Report state (ON, OFF).\n
+ The client must explicitly set this field to OFF to stop receiving
+ intermediate position reports. Intermediate position reports are
+ generated at \n 1 Hz and are ON by default. If intermediate reports
+ are turned ON, the client receives position reports even if the
+ accuracy criteria is not met. The status in the position report is
+ set to IN_PROGRESS for intermediate reports.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- ON: Client is interested in receiving intermediate
+ reports
+ \item 0x00000002 -- OFF: Client is not interested in receiving
+ intermediate reports
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Minimum Interval Between Fixes */
+ uint8_t minInterval_valid; /**< Must be set to true if minInterval is being passed */
+ uint32_t minInterval;
+ /**< Time that must elapse before alerting the client. \n
+ - Units: Milliseconds */
+
+ /* Optional */
+ /* ID of the Application that Sent the Position Request */
+ uint8_t applicationId_valid; /**< Must be set to true if applicationId is being passed */
+ qmiLocApplicationIdStructT_v02 applicationId;
+ /**< \vspace{0.06in} \n Application provider, name, and version.*/
+}qmiLocGetFixCriteriaIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCNIUSERRESPENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_NI_LCS_NOTIFY_VERIFY_ACCEPT_V02 = 1, /**< User accepted the Notify/Verify request. */
+ eQMI_LOC_NI_LCS_NOTIFY_VERIFY_DENY_V02 = 2, /**< User denied the Notify/Verify request. */
+ eQMI_LOC_NI_LCS_NOTIFY_VERIFY_NORESP_V02 = 3, /**< User did not respond to the Notify/Verify request. */
+ QMILOCNIUSERRESPENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocNiUserRespEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Sends the NI user response back to the engine; success or
+ failure is reported in a separate indication. */
+typedef struct {
+
+ /* Mandatory */
+ /* User Response */
+ qmiLocNiUserRespEnumT_v02 userResp;
+ /**< User accepted or denied.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- NOTIFY_VERIFY_ ACCEPT
+ \item 0x00000002 -- NOTIFY_VERIFY_ DENY
+ \item 0x00000003 -- NOTIFY_VERIFY_ NORESP
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Mandatory */
+ /* Notification Type */
+ qmiLocNiNotifyVerifyEnumT_v02 notificationType;
+ /**< Type of notification/verification performed.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- NO_NOTIFY_NO_ VERIF
+ \item 0x00000002 -- NOTIFY_ONLY
+ \item 0x00000003 -- ALLOW_NO_RESP
+ \item 0x00000004 -- NOT_ALLOW_NO_ RESP
+ \item 0x00000005 -- PRIVACY_ OVERRIDE
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Network Initiated Vx Request */
+ uint8_t NiVxPayload_valid; /**< Must be set to true if NiVxPayload is being passed */
+ qmiLocNiVxNotifyVerifyStructT_v02 NiVxPayload;
+ /**< \vspace{0.06in} \n Optional NI VX request payload. */
+
+ /* Optional */
+ /* Network Initiated SUPL Request */
+ uint8_t NiSuplPayload_valid; /**< Must be set to true if NiSuplPayload is being passed */
+ qmiLocNiSuplNotifyVerifyStructT_v02 NiSuplPayload;
+ /**< \vspace{0.06in} \n Optional NI SUPL request payload. */
+
+ /* Optional */
+ /* Network Initiated UMTS Control Plane Request */
+ uint8_t NiUmtsCpPayload_valid; /**< Must be set to true if NiUmtsCpPayload is being passed */
+ qmiLocNiUmtsCpNotifyVerifyStructT_v02 NiUmtsCpPayload;
+ /**< \vspace{0.06in} \n Optional NI UMTS-CP request payload. */
+
+ /* Optional */
+ /* Network Initiated Service Interaction Request */
+ uint8_t NiVxServiceInteractionPayload_valid; /**< Must be set to true if NiVxServiceInteractionPayload is being passed */
+ qmiLocNiVxServiceInteractionStructT_v02 NiVxServiceInteractionPayload;
+ /**< \vspace{0.06in} \n Optional NI service interaction payload. */
+
+ /* Optional */
+ /* Network Initiated SUPL Version 2 Extension */
+ uint8_t NiSuplVer2ExtPayload_valid; /**< Must be set to true if NiSuplVer2ExtPayload is being passed */
+ qmiLocNiSuplVer2ExtStructT_v02 NiSuplVer2ExtPayload;
+ /**< \vspace{0.06in} \n Optional SUPL Version 2 Extension payload. */
+
+ /* Optional */
+ /* SUPL Emergency Notification */
+ uint8_t suplEmergencyNotification_valid; /**< Must be set to true if suplEmergencyNotification is being passed */
+ qmiLocEmergencyNotificationStructT_v02 suplEmergencyNotification;
+ /**< \vspace{0.06in} \n SUPL emergency notification payload. Emergency notification
+ can be given even without an ESLP address */
+}qmiLocNiUserRespReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sends the NI user response back to the engine; success or
+ failure is reported in a separate indication. */
+typedef struct {
+
+ /* Mandatory */
+ /* NI User Response Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the NI User Response request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocNiUserRespIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCPREDICTEDORBITSDATAFORMATENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_PREDICTED_ORBITS_XTRA_V02 = 0, /**< Default is QCOM-XTRA format. */
+ QMILOCPREDICTEDORBITSDATAFORMATENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocPredictedOrbitsDataFormatEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects predicted orbits data. */
+typedef struct {
+
+ /* Mandatory */
+ /* Total Size */
+ uint32_t totalSize;
+ /**< Total size of the predicted orbits data to be injected. \n
+ - Units: Bytes */
+
+ /* Mandatory */
+ /* Total Parts */
+ uint16_t totalParts;
+ /**< Total number of parts into which the predicted orbits data is
+ divided. */
+
+ /* Mandatory */
+ /* Part Number */
+ uint16_t partNum;
+ /**< Number of the current predicted orbits data part; starts at 1. */
+
+ /* Mandatory */
+ /* Data */
+ uint32_t partData_len; /**< Must be set to # of elements in partData */
+ char partData[QMI_LOC_MAX_PREDICTED_ORBITS_PART_LEN_V02];
+ /**< Predicted orbits data. \n
+ - Type: Array of bytes \n
+ - Maximum length of the array: 1024
+ */
+
+ /* Optional */
+ /* Format Type */
+ uint8_t formatType_valid; /**< Must be set to true if formatType is being passed */
+ qmiLocPredictedOrbitsDataFormatEnumT_v02 formatType;
+ /**< Predicted orbits data format.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- PREDICTED_ ORBITS_XTRA
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectPredictedOrbitsDataReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects predicted orbits data. */
+typedef struct {
+
+ /* Mandatory */
+ /* Data Injection Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Data Injection request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Part Number */
+ uint8_t partNum_valid; /**< Must be set to true if partNum is being passed */
+ uint16_t partNum;
+ /**< Number of the predicted orbits data part for which this indication
+ is sent; starts at 1. */
+}qmiLocInjectPredictedOrbitsDataIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetPredictedOrbitsDataSourceReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetPredictedOrbitsDataSourceReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the predicted orbits data source. */
+typedef struct {
+
+ /* Mandatory */
+ /* Predicted Orbits Data Source Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the query request for a predicted orbits data source.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Allowed Sizes */
+ uint8_t allowedSizes_valid; /**< Must be set to true if allowedSizes is being passed */
+ qmiLocPredictedOrbitsAllowedSizesStructT_v02 allowedSizes;
+ /**< \n Maximum part and file size allowed to be injected in the engine. */
+
+ /* Optional */
+ /* Server List */
+ uint8_t serverList_valid; /**< Must be set to true if serverList is being passed */
+ qmiLocPredictedOrbitsServerListStructT_v02 serverList;
+ /**< \n List of servers that can be used by the client to download
+ predicted orbits data. */
+}qmiLocGetPredictedOrbitsDataSourceIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetPredictedOrbitsDataValidityReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetPredictedOrbitsDataValidityReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint64_t startTimeInUTC;
+ /**< Predicted orbits data is valid starting from this time. \n
+ - Units: Seconds (since Jan. 1, 1970)
+ */
+
+ uint16_t durationHours;
+ /**< Duration from the start time for which the data is valid.\n
+ - Units: Hours
+ */
+}qmiLocPredictedOrbitsDataValidityStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the predicted orbits data validity. */
+typedef struct {
+
+ /* Mandatory */
+ /* Predicted Orbits Data Validity Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the query request for predicted orbits data validity.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Validity Info */
+ uint8_t validityInfo_valid; /**< Must be set to true if validityInfo is being passed */
+ qmiLocPredictedOrbitsDataValidityStructT_v02 validityInfo;
+}qmiLocGetPredictedOrbitsDataValidityIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects UTC time in the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* UTC Time */
+ uint64_t timeUtc;
+ /**< UTC time since Jan. 1, 1970.\n
+ - Units: Milliseconds */
+
+ /* Mandatory */
+ /* Time Uncertainty */
+ uint32_t timeUnc;
+ /**< Time uncertainty.\n
+ - Units: Milliseconds */
+}qmiLocInjectUtcTimeReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects UTC time in the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* UTC Time Injection Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the UTC Time Injection request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectUtcTimeIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCALTSRCENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_ALT_SRC_UNKNOWN_V02 = 0, /**< Source is unknown. */
+ eQMI_LOC_ALT_SRC_GPS_V02 = 1, /**< GPS is the source. */
+ eQMI_LOC_ALT_SRC_CELL_ID_V02 = 2, /**< Cell ID provided the source. */
+ eQMI_LOC_ALT_SRC_ENHANCED_CELL_ID_V02 = 3, /**< Source is enhanced cell ID. */
+ eQMI_LOC_ALT_SRC_WIFI_V02 = 4, /**< WiFi is the source. */
+ eQMI_LOC_ALT_SRC_TERRESTRIAL_V02 = 5, /**< Terrestrial source. */
+ eQMI_LOC_ALT_SRC_TERRESTRIAL_HYBRID_V02 = 6, /**< Hybrid terrestrial source. */
+ eQMI_LOC_ALT_SRC_ALTITUDE_DATABASE_V02 = 7, /**< Altitude database is the source. */
+ eQMI_LOC_ALT_SRC_BAROMETRIC_ALTIMETER_V02 = 8, /**< Barometric altimeter is the source. */
+ eQMI_LOC_ALT_SRC_OTHER_V02 = 9, /**< Other sources. */
+ QMILOCALTSRCENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocAltSrcEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCALTSRCLINKAGEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_ALT_SRC_LINKAGE_NOT_SPECIFIED_V02 = 0, /**< Not specified. */
+ eQMI_LOC_ALT_SRC_LINKAGE_FULLY_INTERDEPENDENT_V02 = 1, /**< Fully interdependent. */
+ eQMI_LOC_ALT_SRC_LINKAGE_DEPENDS_ON_LAT_LONG_V02 = 2, /**< Depends on latitude and longitude. */
+ eQMI_LOC_ALT_SRC_LINKAGE_FULLY_INDEPENDENT_V02 = 3, /**< Fully independent. */
+ QMILOCALTSRCLINKAGEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocAltSrcLinkageEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCALTSRCUNCERTAINTYCOVERAGEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_ALT_UNCERTAINTY_NOT_SPECIFIED_V02 = 0, /**< Not specified. */
+ eQMI_LOC_ALT_UNCERTAINTY_POINT_V02 = 1, /**< Altitude uncertainty is valid at the injected horizontal
+ position coordinates only. */
+ eQMI_LOC_ALT_UNCERTAINTY_FULL_V02 = 2, /**< Altitude uncertainty applies to the position of the device
+ regardless of horizontal position (within the horizontal
+ uncertainty region, if provided). */
+ QMILOCALTSRCUNCERTAINTYCOVERAGEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocAltSrcUncertaintyCoverageEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocAltSrcEnumT_v02 source;
+ /**< Specifies the source of the altitude.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- ALT_SRC_ UNKNOWN
+ \item 0x00000001 -- ALT_SRC_GPS
+ \item 0x00000002 -- ALT_SRC_CELL_ID
+ \item 0x00000003 -- ALT_SRC_ ENHANCED_CELL_ID
+ \item 0x00000004 -- ALT_SRC_WIFI
+ \item 0x00000005 -- ALT_SRC_ TERRESTRIAL
+ \item 0x00000006 -- ALT_SRC_ TERRESTRIAL_HYBRID
+ \item 0x00000007 -- ALT_SRC_ ALTITUDE_DATABASE
+ \item 0x00000008 -- ALT_SRC_ BAROMETRIC_ALTIMETER
+ \item 0x00000009 -- ALT_SRC_OTHER
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocAltSrcLinkageEnumT_v02 linkage;
+ /**< Specifies the dependency between the horizontal and
+ altitude position components.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SRC_LINKAGE_ NOT_SPECIFIED
+ \item 0x00000001 -- SRC_LINKAGE_ FULLY_INTERDEPENDENT
+ \item 0x00000002 -- SRC_LINKAGE_ DEPENDS_ON_LAT_LONG
+ \item 0x00000003 -- SRC_LINKAGE_ FULLY_INDEPENDENT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocAltSrcUncertaintyCoverageEnumT_v02 coverage;
+ /**< Specifies the region of uncertainty.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- UNCERTAINTY_ NOT_SPECIFIED
+ \item 0x00000001 -- UNCERTAINTY_ POINT: Altitude uncertainty is valid
+ at the injected horizontal position coordinates
+ only.
+ \item 0x00000002 -- UNCERTAINTY_ FULL: Altitude uncertainty applies to
+ the position of the device regardless of
+ horizontal position (within the horizontal
+ uncertainty region, if provided).
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocAltitudeSrcInfoStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCPOSITIONSRCENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_POSITION_SRC_GNSS_V02 = 0, /**< Position source is GNSS. */
+ eQMI_LOC_POSITION_SRC_CELLID_V02 = 1, /**< Position source is Cell ID. */
+ eQMI_LOC_POSITION_SRC_ENH_CELLID_V02 = 2, /**< Position source is Enhanced Cell ID. */
+ eQMI_LOC_POSITION_SRC_WIFI_V02 = 3, /**< Position source is WiFi. */
+ eQMI_LOC_POSITION_SRC_TERRESTRIAL_V02 = 4, /**< Position source is Terrestrial. */
+ eQMI_LOC_POSITION_SRC_GNSS_TERRESTRIAL_HYBRID_V02 = 5, /**< Position source is GNSS Terrestrial Hybrid. */
+ eQMI_LOC_POSITION_SRC_OTHER_V02 = 6, /**< Other sources. */
+ QMILOCPOSITIONSRCENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocPositionSrcEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects a position to the location engine. */
+typedef struct {
+
+ /* Optional */
+ /* Latitude */
+ uint8_t latitude_valid; /**< Must be set to true if latitude is being passed */
+ double latitude;
+ /**< Latitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -90.0 to 90.0 \begin{itemize1}
+ \item Positive values indicate northern latitude
+ \item Negative values indicate southern latitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Longitude */
+ uint8_t longitude_valid; /**< Must be set to true if longitude is being passed */
+ double longitude;
+ /**< Longitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -180.0 to 180.0 \begin{itemize1}
+ \item Positive values indicate eastern longitude
+ \item Negative values indicate western longitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Circular Horizontal Uncertainty */
+ uint8_t horUncCircular_valid; /**< Must be set to true if horUncCircular is being passed */
+ float horUncCircular;
+ /**< Horizontal position uncertainty (circular).\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Horizontal Confidence */
+ uint8_t horConfidence_valid; /**< Must be set to true if horConfidence is being passed */
+ uint8_t horConfidence;
+ /**< Horizontal confidence, as defined by ETSI TS 101 109 (\hyperref[S4]{[S4]}).
+ \begin{itemize1}
+ \item Units: Percent (0 to 99)
+ \item 0 -- invalid value
+ \item 100 to 256 -- not used
+ \item If 100 is received, reinterpret to 99
+ \end{itemize1}
+ This field must be specified together with horizontal uncertainty.
+ If not specified, the default value will be 50. */
+
+ /* Optional */
+ /* Horizontal Reliability */
+ uint8_t horReliability_valid; /**< Must be set to true if horReliability is being passed */
+ qmiLocReliabilityEnumT_v02 horReliability;
+ /**< Specifies the reliability of the horizontal position.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- eQMI_LOC_ RELIABILITY_NOT_SET
+ \item 0x00000001 -- eQMI_LOC_ RELIABILITY_VERY_LOW
+ \item 0x00000002 -- eQMI_LOC_ RELIABILITY_LOW
+ \item 0x00000003 -- eQMI_LOC_ RELIABILITY_MEDIUM
+ \item 0x00000004 -- eQMI_LOC_ RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Altitude With Respect to Ellipsoid */
+ uint8_t altitudeWrtEllipsoid_valid; /**< Must be set to true if altitudeWrtEllipsoid is being passed */
+ float altitudeWrtEllipsoid;
+ /**< Altitude with respect to the WGS84 ellipsoid.
+ \begin{itemize1}
+ \item Units: Meters \begin{itemize1}
+ \item Positive = height
+ \item Negative = depth
+ \vspace{-0.18in} \end{itemize1} \end{itemize1}*/
+
+ /* Optional */
+ /* Altitude With Respect to Sea Level */
+ uint8_t altitudeWrtMeanSeaLevel_valid; /**< Must be set to true if altitudeWrtMeanSeaLevel is being passed */
+ float altitudeWrtMeanSeaLevel;
+ /**< Altitude with respect to mean sea level.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Vertical Uncertainty */
+ uint8_t vertUnc_valid; /**< Must be set to true if vertUnc is being passed */
+ float vertUnc;
+ /**< Vertical uncertainty. This is mandatory if either altitudeWrtEllipsoid
+ or altitudeWrtMeanSeaLevel is specified.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Vertical Confidence */
+ uint8_t vertConfidence_valid; /**< Must be set to true if vertConfidence is being passed */
+ uint8_t vertConfidence;
+ /**< Vertical confidence, as defined by ETSI TS 101 109 (\hyperref[S4]{[S4]}).
+ \begin{itemize1}
+ \item Units: Percent (0-99)
+ \item 0 -- invalid value
+ \item 100 to 256 -- not used
+ \item If 100 is received, reinterpret to 99
+ \end{itemize1}
+ This field must be specified together with the vertical uncertainty.
+ If not specified, the default value will be 50. */
+
+ /* Optional */
+ /* Vertical Reliability */
+ uint8_t vertReliability_valid; /**< Must be set to true if vertReliability is being passed */
+ qmiLocReliabilityEnumT_v02 vertReliability;
+ /**< Specifies the reliability of the vertical position.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- eQMI_LOC_ RELIABILITY_NOT_SET
+ \item 0x00000001 -- eQMI_LOC_ RELIABILITY_VERY_LOW
+ \item 0x00000002 -- eQMI_LOC_ RELIABILITY_LOW
+ \item 0x00000003 -- eQMI_LOC_ RELIABILITY_MEDIUM
+ \item 0x00000004 -- eQMI_LOC_ RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Altitude Source Info */
+ uint8_t altSourceInfo_valid; /**< Must be set to true if altSourceInfo is being passed */
+ qmiLocAltitudeSrcInfoStructT_v02 altSourceInfo;
+ /**< \vspace{0.06in} \n Specifies information regarding the altitude source. */
+
+ /* Optional */
+ /* UTC Timestamp */
+ uint8_t timestampUtc_valid; /**< Must be set to true if timestampUtc is being passed */
+ uint64_t timestampUtc;
+ /**< UTC timestamp. \n
+ - Units: Milliseconds (since Jan. 1, 1970) */
+
+ /* Optional */
+ /* Position Age */
+ uint8_t timestampAge_valid; /**< Must be set to true if timestampAge is being passed */
+ int32_t timestampAge;
+ /**< Position age, which is an estimate of how long ago this fix was made. \n
+ - Units: Milliseconds */
+
+ /* Optional */
+ /* Position Source */
+ uint8_t positionSrc_valid; /**< Must be set to true if positionSrc is being passed */
+ qmiLocPositionSrcEnumT_v02 positionSrc;
+ /**< Source from which this position was obtained.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- eQMI_LOC_ POSITION_SRC_GNSS
+ \item 0x00000001 -- eQMI_LOC_ POSITION_SRC_CELLID
+ \item 0x00000002 -- eQMI_LOC_ POSITION_SRC_ENH_CELLID
+ \item 0x00000003 -- eQMI_LOC_ POSITION_SRC_WIFI
+ \item 0x00000004 -- eQMI_LOC_ POSITION_SRC_TERRESTRIAL
+ \item 0x00000005 -- eQMI_LOC_ POSITION_SRC_GNSS_ TERRESTRIAL_HYBRID
+ \item 0x00000006 -- eQMI_LOC_ POSITION_SRC_OTHER
+ \end{itemize1} \vspace{0.05in}
+
+ If altitude is specified and the altitude source is not specified, the engine
+ assumes that the altitude was obtained using the specified position source. \n
+ If both altitude and altitude source are specified, the engine assumes
+ that only latitude and longitude were obtained using the specified position
+ source.
+ */
+}qmiLocInjectPositionReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects a position to the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* UTC Position Injection Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the UTC Position Injection request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectPositionIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCLOCKENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_LOCK_NONE_V02 = 1, /**< Do not lock any position sessions. */
+ eQMI_LOC_LOCK_MI_V02 = 2, /**< Lock mobile-initiated position sessions. */
+ eQMI_LOC_LOCK_MT_V02 = 3, /**< Lock mobile-terminated position sessions. */
+ eQMI_LOC_LOCK_ALL_V02 = 4, /**< Lock all position sessions. */
+ QMILOCLOCKENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocLockEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Sets the location engine lock. */
+typedef struct {
+
+ /* Mandatory */
+ /* Lock Type */
+ qmiLocLockEnumT_v02 lockType;
+ /**< Type of lock.
+
+ Valid values: \n
+ - 0x00000001 -- LOCK_NONE \n
+ - 0x00000002 -- LOCK_MI \n
+ - 0x00000003 -- LOCK_MT \n
+ - 0x00000004 -- LOCK_ALL
+
+ */
+}qmiLocSetEngineLockReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sets the location engine lock. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Engine Lock Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Engine Lock request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetEngineLockIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetEngineLockReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetEngineLockReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the location engine lock. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Engine Lock Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Engine Lock request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Lock Type */
+ uint8_t lockType_valid; /**< Must be set to true if lockType is being passed */
+ qmiLocLockEnumT_v02 lockType;
+ /**< Type of lock.
+
+ Valid values: \n
+ - 0x00000001 -- LOCK_NONE \n
+ - 0x00000002 -- LOCK_MI \n
+ - 0x00000003 -- LOCK_MT \n
+ - 0x00000004 -- LOCK_ALL
+ */
+}qmiLocGetEngineLockIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Sets the SBAS configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* SBAS Config */
+ uint8_t sbasConfig;
+ /**< Indicates whether SBAS configuration is enabled.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- SBAS configuration is enabled
+ \item 0x00 (FALSE) -- SBAS configuration is disabled
+ \vspace{-0.18in} \end{itemize1}*/
+}qmiLocSetSbasConfigReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sets the SBAS configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set SBAS Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set SBAS Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetSbasConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetSbasConfigReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetSbasConfigReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the SBAS configuration from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get SBAS Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get SBAS Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* SBAS Config */
+ uint8_t sbasConfig_valid; /**< Must be set to true if sbasConfig is being passed */
+ uint8_t sbasConfig;
+ /**< Indicates whether SBAS configuration is enabled.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- SBAS configuration is enabled
+ \item 0x00 (FALSE) -- SBAS configuration is disabled
+ \vspace{-0.18in} \end{itemize1}*/
+}qmiLocGetSbasConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocNmeaSentenceMaskT_v02;
+#define QMI_LOC_NMEA_MASK_GGA_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000001) /**< Enable GGA type. */
+#define QMI_LOC_NMEA_MASK_RMC_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000002) /**< Enable RMC type. */
+#define QMI_LOC_NMEA_MASK_GSV_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000004) /**< Enable GSV type. */
+#define QMI_LOC_NMEA_MASK_GSA_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000008) /**< Enable GSA type. */
+#define QMI_LOC_NMEA_MASK_VTG_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000010) /**< Enable VTG type. */
+#define QMI_LOC_NMEA_MASK_PQXFI_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000020) /**< Enable PQXFI type. */
+#define QMI_LOC_NMEA_MASK_PSTIS_V02 ((qmiLocNmeaSentenceMaskT_v02)0x00000040) /**< Enable PSTIS type. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Sets the NMEA types. */
+typedef struct {
+
+ /* Mandatory */
+ /* NMEA Sentence Types */
+ qmiLocNmeaSentenceMaskT_v02 nmeaSentenceType;
+ /**< Bitmasks of NMEA types to enable.
+
+ Valid bitmasks: \n
+ - 0x00000001 -- NMEA_MASK_GGA \n
+ - 0x00000002 -- NMEA_MASK_RMC \n
+ - 0x00000004 -- NMEA_MASK_GSV \n
+ - 0x00000008 -- NMEA_MASK_GSA \n
+ - 0x00000010 -- NMEA_MASK_VTG \n
+ - 0x00000020 -- NMEA_MASK_PQXFI \n
+ - 0x00000040 -- NMEA_MASK_PSTIS
+ */
+}qmiLocSetNmeaTypesReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sets the NMEA types. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set NMEA Types Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of Set NMEA Types request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetNmeaTypesIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetNmeaTypesReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetNmeaTypesReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the NMEA types from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get NMEA Types Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get NMEA Types request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* NMEA Sentence Types */
+ uint8_t nmeaSentenceType_valid; /**< Must be set to true if nmeaSentenceType is being passed */
+ qmiLocNmeaSentenceMaskT_v02 nmeaSentenceType;
+ /**< NMEA types to enable.
+
+ Valid bitmasks: \n
+ - 0x0000ffff -- NMEA_MASK_ALL \n
+ - 0x00000001 -- NMEA_MASK_GGA \n
+ - 0x00000002 -- NMEA_MASK_RMC \n
+ - 0x00000004 -- NMEA_MASK_GSV \n
+ - 0x00000008 -- NMEA_MASK_GSA \n
+ - 0x00000010 -- NMEA_MASK_VTG \n
+ - 0x00000020 -- NMEA_MASK_PQXFI \n
+ - 0x00000040 -- NMEA_MASK_PSTIS
+ */
+}qmiLocGetNmeaTypesIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Enables/disables Low Power Mode (LPM) configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Enable Low Power Mode */
+ uint8_t lowPowerMode;
+ /**< Indicates whether to enable Low Power mode:\n
+ - 0x01 (TRUE) -- Enable LPM \n
+ - 0x00 (FALSE) -- Disable LPM */
+}qmiLocSetLowPowerModeReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Enables/disables Low Power Mode (LPM) configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set LPM Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Low Power Mode request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetLowPowerModeIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetLowPowerModeReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetLowPowerModeReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the LPM status from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get LPM Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get LPM request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Enable/Disable LPM */
+ uint8_t lowPowerMode_valid; /**< Must be set to true if lowPowerMode is being passed */
+ uint8_t lowPowerMode;
+ /**< Indicates whether to enable Low Power mode:\n
+ - 0x01 (TRUE) -- Enable LPM \n
+ - 0x00 (FALSE) -- Disable LPM */
+}qmiLocGetLowPowerModeIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSERVERTYPEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SERVER_TYPE_CDMA_PDE_V02 = 1, /**< Server type is CDMA PDE. */
+ eQMI_LOC_SERVER_TYPE_CDMA_MPC_V02 = 2, /**< Server type is CDMA MPC. */
+ eQMI_LOC_SERVER_TYPE_UMTS_SLP_V02 = 3, /**< Server type is UMTS SLP. */
+ eQMI_LOC_SERVER_TYPE_CUSTOM_PDE_V02 = 4, /**< Server type is custom PDE. */
+ QMILOCSERVERTYPEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocServerTypeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Specifies the A-GPS server type and address. */
+typedef struct {
+
+ /* Mandatory */
+ /* Server Type */
+ qmiLocServerTypeEnumT_v02 serverType;
+ /**< Type of server.
+
+ Valid values: \n
+ - 0x00000001 -- CDMA_PDE \n
+ - 0x00000002 -- CDMA_MPC \n
+ - 0x00000003 -- UMTS_SLP \n
+ - 0x00000004 -- CUSTOM_PDE
+ */
+
+ /* Optional */
+ /* IPV4 Address */
+ uint8_t ipv4Addr_valid; /**< Must be set to true if ipv4Addr is being passed */
+ qmiLocIpV4AddrStructType_v02 ipv4Addr;
+ /**< \vspace{0.06in} \n IPV4 address and port. */
+
+ /* Optional */
+ /* IPV6 Address */
+ uint8_t ipv6Addr_valid; /**< Must be set to true if ipv6Addr is being passed */
+ qmiLocIpV6AddrStructType_v02 ipv6Addr;
+ /**< \vspace{0.06in} \n IPV6 address and port. */
+
+ /* Optional */
+ /* Uniform Resource Locator */
+ uint8_t urlAddr_valid; /**< Must be set to true if urlAddr is being passed */
+ char urlAddr[QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02 + 1];
+ /**< URL address.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 256
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetServerReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Specifies the A-GPS server type and address. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Server Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Server request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetServerIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Gets the location server from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Server Type */
+ qmiLocServerTypeEnumT_v02 serverType;
+ /**< Type of server, as defined in qmiLocServerTypeEnumT.
+
+ Valid values: \n
+ - 0x00000001 -- CDMA_PDE \n
+ - 0x00000002 -- CDMA_MPC \n
+ - 0x00000003 -- UMTS_SLP \n
+ - 0x00000004 -- CUSTOM_PDE
+ */
+
+ /* Optional */
+ /* Server Address Type */
+ uint8_t serverAddrTypeMask_valid; /**< Must be set to true if serverAddrTypeMask is being passed */
+ qmiLocServerAddrTypeMaskT_v02 serverAddrTypeMask;
+ /**< Type of address the client wants. If unspecified, the
+ indication will contain all the types of addresses
+ it has for the specified server type.
+
+ Valid bitmasks: \n
+ - 0x01 -- IPV4 \n
+ - 0x02 -- IPV6 \n
+ - 0x04 -- URL
+ */
+}qmiLocGetServerReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the location server from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Server Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Server request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Mandatory */
+ /* Server Type */
+ qmiLocServerTypeEnumT_v02 serverType;
+ /**< Type of server, as defined in qmiLocServerTypeEnumT.
+
+ Valid values: \n
+ - 0x00000001 -- CDMA_PDE \n
+ - 0x00000002 -- CDMA_MPC \n
+ - 0x00000003 -- UMTS_SLP \n
+ - 0x00000004 -- CUSTOM_PDE
+ */
+
+ /* Optional */
+ /* IPV4 Address */
+ uint8_t ipv4Addr_valid; /**< Must be set to true if ipv4Addr is being passed */
+ qmiLocIpV4AddrStructType_v02 ipv4Addr;
+ /**< \vspace{0.06in} \n IPV4 address and port. */
+
+ /* Optional */
+ /* IPV6 Address */
+ uint8_t ipv6Addr_valid; /**< Must be set to true if ipv6Addr is being passed */
+ qmiLocIpV6AddrStructType_v02 ipv6Addr;
+ /**< \vspace{0.06in} \n IPV6 address and port. */
+
+ /* Optional */
+ /* Uniform Resource Locator */
+ uint8_t urlAddr_valid; /**< Must be set to true if urlAddr is being passed */
+ char urlAddr[QMI_LOC_MAX_SERVER_ADDR_LENGTH_V02 + 1];
+ /**< URL.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 256
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocGetServerIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint64_t qmiLocDeleteGnssDataMaskT_v02;
+#define QMI_LOC_MASK_DELETE_GPS_SVDIR_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000001ull) /**< Mask to delete GPS SVDIR. */
+#define QMI_LOC_MASK_DELETE_GPS_SVSTEER_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000002ull) /**< Mask to delete GPS SVSTEER. */
+#define QMI_LOC_MASK_DELETE_GPS_TIME_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000004ull) /**< Mask to delete GPS time. */
+#define QMI_LOC_MASK_DELETE_GPS_ALM_CORR_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000008ull) /**< Mask to delete almanac correlation. */
+#define QMI_LOC_MASK_DELETE_GLO_SVDIR_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000010ull) /**< Mask to delete GLONASS SVDIR. */
+#define QMI_LOC_MASK_DELETE_GLO_SVSTEER_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000020ull) /**< Mask to delete GLONASS SVSTEER. */
+#define QMI_LOC_MASK_DELETE_GLO_TIME_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000040ull) /**< Mask to delete GLONASS time. */
+#define QMI_LOC_MASK_DELETE_GLO_ALM_CORR_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000080ull) /**< Mask to delete GLONASS almanac correlation */
+#define QMI_LOC_MASK_DELETE_SBAS_SVDIR_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000100ull) /**< Mask to delete SBAS SVDIR */
+#define QMI_LOC_MASK_DELETE_SBAS_SVSTEER_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000200ull) /**< Mask to delete SBAS SVSTEER */
+#define QMI_LOC_MASK_DELETE_POSITION_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000400ull) /**< Mask to delete position estimate */
+#define QMI_LOC_MASK_DELETE_TIME_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00000800ull) /**< Mask to delete time estimate */
+#define QMI_LOC_MASK_DELETE_IONO_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00001000ull) /**< Mask to delete IONO */
+#define QMI_LOC_MASK_DELETE_UTC_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00002000ull) /**< Mask to delete UTC estimate */
+#define QMI_LOC_MASK_DELETE_HEALTH_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00004000ull) /**< Mask to delete SV health record */
+#define QMI_LOC_MASK_DELETE_SADATA_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00008000ull) /**< Mask to delete SADATA */
+#define QMI_LOC_MASK_DELETE_RTI_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00010000ull) /**< Mask to delete RTI */
+#define QMI_LOC_MASK_DELETE_SV_NO_EXIST_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00020000ull) /**< Mask to delete SV_NO_EXIST */
+#define QMI_LOC_MASK_DELETE_FREQ_BIAS_EST_V02 ((qmiLocDeleteGnssDataMaskT_v02)0x00040000ull) /**< Mask to delete frequency bias estimate */
+typedef uint32_t qmiLocDeleteCelldbDataMaskT_v02;
+#define QMI_LOC_MASK_DELETE_CELLDB_POS_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000001) /**< Mask to delete cell database position */
+#define QMI_LOC_MASK_DELETE_CELLDB_LATEST_GPS_POS_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000002) /**< Mask to delete cell database latest GPS position */
+#define QMI_LOC_MASK_DELETE_CELLDB_OTA_POS_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000004) /**< Mask to delete cell database OTA position */
+#define QMI_LOC_MASK_DELETE_CELLDB_EXT_REF_POS_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000008) /**< Mask to delete cell database external reference position */
+#define QMI_LOC_MASK_DELETE_CELLDB_TIMETAG_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000010) /**< Mask to delete cell database time tag */
+#define QMI_LOC_MASK_DELETE_CELLDB_CELLID_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000020) /**< Mask to delete cell database cell ID */
+#define QMI_LOC_MASK_DELETE_CELLDB_CACHED_CELLID_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000040) /**< Mask to delete cell database cached cell ID */
+#define QMI_LOC_MASK_DELETE_CELLDB_LAST_SRV_CELL_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000080) /**< Mask to delete cell database last service cell */
+#define QMI_LOC_MASK_DELETE_CELLDB_CUR_SRV_CELL_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000100) /**< Mask to delete cell database current service cell */
+#define QMI_LOC_MASK_DELETE_CELLDB_NEIGHBOR_INFO_V02 ((qmiLocDeleteCelldbDataMaskT_v02)0x00000200) /**< Mask to delete cell database neighbor information */
+typedef uint32_t qmiLocDeleteClockInfoMaskT_v02;
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_TIME_EST_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000001) /**< Mask to delete time estimate from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_FREQ_EST_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000002) /**< Mask to delete frequency estimate from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_WEEK_NUMBER_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000004) /**< Mask to delete week number from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_RTC_TIME_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000008) /**< Mask to delete RTC time from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_TIME_TRANSFER_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000010) /**< Mask to delete time transfer from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_GPSTIME_EST_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000020) /**< Mask to delete GPS time estimate from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_GLOTIME_EST_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000040) /**< Mask to delete GLONASS time estimate from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_GLODAY_NUMBER_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000080) /**< Mask to delete GLONASS day number from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_GLO4YEAR_NUMBER_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000100) /**< Mask to delete GLONASS four year number from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_GLO_RF_GRP_DELAY_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000200) /**< Mask to delete GLONASS RF GRP delay from clock information */
+#define QMI_LOC_MASK_DELETE_CLOCK_INFO_DISABLE_TT_V02 ((qmiLocDeleteClockInfoMaskT_v02)0x00000400) /**< Mask to delete disable TT from clock information */
+typedef uint8_t qmiLocDeleteSvInfoMaskT_v02;
+#define QMI_LOC_MASK_DELETE_EPHEMERIS_V02 ((qmiLocDeleteSvInfoMaskT_v02)0x01) /**< Delete ephemeris for the satellite */
+#define QMI_LOC_MASK_DELETE_ALMANAC_V02 ((qmiLocDeleteSvInfoMaskT_v02)0x02) /**< Delete almanac for the satellite */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint16_t gnssSvId;
+ /**< SV ID of the satellite whose data is to be deleted.
+ \begin{itemize1}
+ \item Range: \begin{itemize1}
+ \item For GPS: 1 to 32
+ \item For SBAS: 33 to 64
+ \item For GLONASS: 65 to 96
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ qmiLocSvSystemEnumT_v02 system;
+ /**< Indicates to which constellation this SV belongs.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- eQMI_LOC_SV_ SYSTEM_GPS
+ \item 0x00000002 -- eQMI_LOC_SV_ SYSTEM_GALILEO
+ \item 0x00000003 -- eQMI_LOC_SV_ SYSTEM_SBAS
+ \item 0x00000004 -- eQMI_LOC_SV_ SYSTEM_COMPASS
+ \item 0x00000005 -- eQMI_LOC_SV_ SYSTEM_GLONASS
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ qmiLocDeleteSvInfoMaskT_v02 deleteSvInfoMask;
+ /**< Indicates if the ephemeris or almanac for a satellite
+ is to be deleted. \n
+ Valid values: \n
+ - 0x01 -- DELETE_EPHEMERIS \n
+ - 0x02 -- DELETE_ALMANAC
+ */
+}qmiLocDeleteSvInfoStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; This command is used to delete the location engine
+ assistance data */
+typedef struct {
+
+ /* Mandatory */
+ /* Delete All */
+ uint8_t deleteAllFlag;
+ /**< Indicates whether all assistance data is to be deleted.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- All assistance data is to be deleted; if
+ this flag is set, all the other information
+ contained in the optional fields for this
+ message are ignored
+ \item 0x00 (FALSE) -- The optional fields in the message are to be
+ used to determine which data is to be deleted
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Delete SV Info */
+ uint8_t deleteSvInfoList_valid; /**< Must be set to true if deleteSvInfoList is being passed */
+ uint32_t deleteSvInfoList_len; /**< Must be set to # of elements in deleteSvInfoList */
+ qmiLocDeleteSvInfoStructT_v02 deleteSvInfoList[QMI_LOC_DELETE_MAX_SV_INFO_LENGTH_V02];
+ /**< \vspace{0.06in} \n List of satellites for which the assistance data is to be deleted.
+ */
+
+ /* Optional */
+ /* Delete GNSS Data */
+ uint8_t deleteGnssDataMask_valid; /**< Must be set to true if deleteGnssDataMask is being passed */
+ qmiLocDeleteGnssDataMaskT_v02 deleteGnssDataMask;
+ /**< Mask for the GNSS data that is to be deleted.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- DELETE_GPS_SVDIR
+ \item 0x00000002 -- DELETE_GPS_ SVSTEER
+ \item 0x00000004 -- DELETE_GPS_TIME
+ \item 0x00000008 -- DELETE_GPS_ALM_ CORR
+ \item 0x00000010 -- DELETE_GLO_ SVDIR
+ \item 0x00000020 -- DELETE_GLO_ SVSTEER
+ \item 0x00000040 -- DELETE_GLO_TIME
+ \item 0x00000080 -- DELETE_GLO_ALM_ CORR
+ \item 0x00000100 -- DELETE_SBAS_ SVDIR
+ \item 0x00000200 -- DELETE_SBAS_ SVSTEER
+ \item 0x00000400 -- DELETE_POSITION
+ \item 0x00000800 -- DELETE_TIME
+ \item 0x00001000 -- DELETE_IONO
+ \item 0x00002000 -- DELETE_UTC
+ \item 0x00004000 -- DELETE_HEALTH
+ \item 0x00008000 -- DELETE_SADATA
+ \item 0x00010000 -- DELETE_RTI
+ \item 0x00020000 -- DELETE_SV_NO_ EXIST
+ \item 0x00040000 -- DELETE_FREQ_ BIAS_EST
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Delete Cell Database */
+ uint8_t deleteCellDbDataMask_valid; /**< Must be set to true if deleteCellDbDataMask is being passed */
+ qmiLocDeleteCelldbDataMaskT_v02 deleteCellDbDataMask;
+ /**< Mask for the cell database assistance data that is to be deleted.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- DELETE_CELLDB_ POS
+ \item 0x00000002 -- DELETE_CELLDB_ LATEST_GPS_POS
+ \item 0x00000004 -- DELETE_CELLDB_ OTA_POS
+ \item 0x00000008 -- DELETE_CELLDB_ EXT_REF_POS
+ \item 0x00000010 -- DELETE_CELLDB_ TIMETAG
+ \item 0x00000020 -- DELETE_CELLDB_ CELLID
+ \item 0x00000040 -- DELETE_CELLDB_ CACHED_CELLID
+ \item 0x00000080 -- DELETE_CELLDB_ LAST_SRV_CELL
+ \item 0x00000100 -- DELETE_CELLDB_ CUR_SRV_CELL
+ \item 0x00000200 -- DELETE_CELLDB_ NEIGHBOR_INFO
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Delete Clock Info */
+ uint8_t deleteClockInfoMask_valid; /**< Must be set to true if deleteClockInfoMask is being passed */
+ qmiLocDeleteClockInfoMaskT_v02 deleteClockInfoMask;
+ /**< Mask for the clock information assistance data that is to be deleted.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- DELETE_CLOCK_ INFO_TIME_EST
+ \item 0x00000002 -- DELETE_CLOCK_ INFO_FREQ_EST
+ \item 0x00000004 -- DELETE_CLOCK_ INFO_WEEK_NUMBER
+ \item 0x00000008 -- DELETE_CLOCK_ INFO_RTC_TIME
+ \item 0x00000010 -- DELETE_CLOCK_ INFO_TIME_TRANSFER
+ \item 0x00000020 -- DELETE_CLOCK_ INFO_GPSTIME_EST
+ \item 0x00000040 -- DELETE_CLOCK_ INFO_GLOTIME_EST
+ \item 0x00000080 -- DELETE_CLOCK_ INFO_GLODAY_NUMBER
+ \item 0x00000100 -- DELETE_CLOCK_ INFO_GLO4YEAR_NUMBER
+ \item 0x00000200 -- DELETE_CLOCK_ INFO_GLO_RF_GRP_DELAY
+ \item 0x00000400 -- DELETE_CLOCK_ INFO_DISABLE_TT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocDeleteAssistDataReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; This command is used to delete the location engine
+ assistance data */
+typedef struct {
+
+ /* Mandatory */
+ /* Delete Assist Data Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Delete Assist Data request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocDeleteAssistDataIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Enables/disables XTRA-T session control. */
+typedef struct {
+
+ /* Mandatory */
+ /* Enable XTRA-T */
+ uint8_t xtraTSessionControl;
+ /**< Indicates whether to enable XTRA-T:\n
+ - 0x01 (TRUE) -- Enable XTRA-T \n
+ - 0x00 (FALSE) -- Disable XTRA-T */
+}qmiLocSetXtraTSessionControlReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Enables/disables XTRA-T session control. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set XTRA-T Session Control Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set XTRA-T Session Control request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetXtraTSessionControlIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetXtraTSessionControlReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetXtraTSessionControlReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the XTRA-T session control value from the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get XTRA-T Session Control Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get XTRA-T Session Control request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Enable/Disable XTRA-T */
+ uint8_t xtraTSessionControl_valid; /**< Must be set to true if xtraTSessionControl is being passed */
+ uint8_t xtraTSessionControl;
+ /**< Indicates whether to enable XTRA-T:\n
+ - 0x01 (TRUE) -- Enable XTRA-T \n
+ - 0x00 (FALSE) -- Disable XTRA-T */
+}qmiLocGetXtraTSessionControlIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t wifiPositionTime;
+ /**< Common counter (typically, the number of milliseconds since bootup).
+ This field is only to be provided if the modem and host processors are
+ synchronized. */
+}qmiLocWifiFixTimeStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCWIFIFIXERRORCODEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_WIFI_FIX_ERROR_SUCCESS_V02 = 0, /**< WiFi fix is successful. */
+ eQMI_LOC_WIFI_FIX_ERROR_WIFI_NOT_AVAILABLE_V02 = 1, /**< WiFi fix failed because WiFi is not available on the device. */
+ eQMI_LOC_WIFI_FIX_ERROR_NO_AP_FOUND_V02 = 2, /**< WiFi fix failed because no access points were found. */
+ eQMI_LOC_WIFI_FIX_ERROR_UNAUTHORIZED_V02 = 3, /**< WiFi fix failed because the server denied access due to bad authorization
+ code. */
+ eQMI_LOC_WIFI_FIX_ERROR_SERVER_UNAVAILABLE_V02 = 4, /**< WiFi fix failed because the WiFi server was unavailable. */
+ eQMI_LOC_WIFI_FIX_ERROR_LOCATION_CANNOT_BE_DETERMINED_V02 = 5, /**< WiFi fix failed even though APs were found and the server could be reached.
+ This may be because the APs found are not in the database. */
+ eQMI_LOC_WIFI_FIX_ERROR_UNKNOWN_V02 = 6, /**< WiFi fix failed, but the cause could not be determined. */
+ QMILOCWIFIFIXERRORCODEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocWifiFixErrorCodeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ double lat;
+ /**< WiFi position latitude. \n
+ - Type: Floating point \n
+ - Units: Degrees */
+
+ double lon;
+ /**< WiFi position longitude. \n
+ - Type: Floating point \n
+ - Units: Degrees */
+
+ uint16_t hepe;
+ /**< WiFi position HEPE.\n
+ - Units: Meters */
+
+ uint8_t numApsUsed;
+ /**< Number of Access Points (AP) used to generate a fix. */
+
+ qmiLocWifiFixErrorCodeEnumT_v02 fixErrorCode;
+ /**< WiFi position error code; set to 0 if the fix succeeds. This position
+ is only used by a module if the value is 0. If there was a failure,
+ the error code provided by the WiFi positioning system can be provided
+ here.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- ERROR_SUCCESS
+ \item 0x00000001 -- ERROR_WIFI_NOT_ AVAILABLE
+ \item 0x00000002 -- ERROR_NO_AP_ FOUND
+ \item 0x00000003 -- ERROR_ UNAUTHORIZED
+ \item 0x00000004 -- ERROR_SERVER_ UNAVAILABLE
+ \item 0x00000005 -- ERROR_LOCATION_ CANNOT_BE_DETERMINED
+ \item 0x00000006 -- ERROR_UNKNOWN
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocWifiFixPosStructT_v02; /* Type */
+/**
+ @}
+ */
+
+typedef uint8_t qmiLocWifiApQualifierMaskT_v02;
+#define QMI_LOC_WIFI_AP_QUALIFIER_BEING_USED_V02 ((qmiLocWifiApQualifierMaskT_v02)0x01) /**< Access point is being used by the WPS. */
+#define QMI_LOC_WIFI_AP_QUALIFIER_HIDDEN_SSID_V02 ((qmiLocWifiApQualifierMaskT_v02)0x02) /**< AP does not broadcast SSID. */
+#define QMI_LOC_WIFI_AP_QUALIFIER_PRIVATE_V02 ((qmiLocWifiApQualifierMaskT_v02)0x04) /**< AP has encryption turned on. */
+#define QMI_LOC_WIFI_AP_QUALIFIER_INFRASTRUCTURE_MODE_V02 ((qmiLocWifiApQualifierMaskT_v02)0x08) /**< AP is in infrastructure mode and not in ad-hoc/unknown mode. */
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint8_t macAddr[QMI_LOC_WIFI_MAC_ADDR_LENGTH_V02];
+ /**< Associated MAC address of the AP. \n
+ - Type: Array of unsigned integers \n
+ - Address length: 6
+ */
+
+ int32_t rssi;
+ /**< Receive signal strength indicator.\n
+ - Units: dBm (offset with +100 dB) */
+
+ uint16_t channel;
+ /**< WiFi channel on which a beacon was received. */
+
+ qmiLocWifiApQualifierMaskT_v02 apQualifier;
+ /**< A bitmask of Boolean qualifiers for APs.
+ All unused bits in this mask must be set to 0.
+
+ Valid values: \n
+ - 0x01 -- BEING_USED \n
+ - 0x02 -- HIDDEN_SSID \n
+ - 0x04 -- PRIVATE \n
+ - 0x08 -- INFRASTRUCTURE_MODE
+ */
+}qmiLocWifiApInfoStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects the WiFi position. */
+typedef struct {
+
+ /* Optional */
+ /* WiFi Fix Time */
+ uint8_t wifiFixTime_valid; /**< Must be set to true if wifiFixTime is being passed */
+ qmiLocWifiFixTimeStructT_v02 wifiFixTime;
+ /**< \vspace{0.06in} \n Time of WiFi position fix. */
+
+ /* Optional */
+ /* WiFi Position */
+ uint8_t wifiFixPosition_valid; /**< Must be set to true if wifiFixPosition is being passed */
+ qmiLocWifiFixPosStructT_v02 wifiFixPosition;
+ /**< \vspace{0.06in} \n WiFi position fix. */
+
+ /* Optional */
+ /* WiFi Access Point Information */
+ uint8_t apInfo_valid; /**< Must be set to true if apInfo is being passed */
+ uint32_t apInfo_len; /**< Must be set to # of elements in apInfo */
+ qmiLocWifiApInfoStructT_v02 apInfo[QMI_LOC_WIFI_MAX_REPORTED_APS_PER_MSG_V02];
+ /**< \vspace{0.06in} \n AP scan list. */
+
+ /* Optional */
+ /* Horizontal Reliability */
+ uint8_t horizontalReliability_valid; /**< Must be set to true if horizontalReliability is being passed */
+ qmiLocReliabilityEnumT_v02 horizontalReliability;
+ /**< Specifies the reliability of the horizontal position.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- eQMI_LOC_ RELIABILITY_NOT_SET
+ \item 0x00000001 -- eQMI_LOC_ RELIABILITY_VERY_LOW
+ \item 0x00000002 -- eQMI_LOC_ RELIABILITY_LOW
+ \item 0x00000003 -- eQMI_LOC_ RELIABILITY_MEDIUM
+ \item 0x00000004 -- eQMI_LOC_ RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectWifiPositionReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects the WiFi position. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject WiFi Position Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject WiFi Position request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectWifiPositionIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCWIFISTATUSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_WIFI_STATUS_AVAILABLE_V02 = 1, /**< WiFi is available. */
+ eQMI_LOC_WIFI_STATUS_UNAVAILABLE_V02 = 2, /**< WiFi is not available. */
+ QMILOCWIFISTATUSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocWifiStatusEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Notifies the location engine of the WiFi status. */
+typedef struct {
+
+ /* Mandatory */
+ /* Availablility of WiFi */
+ qmiLocWifiStatusEnumT_v02 wifiStatus;
+ /**< WiFi status information.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- WIFI_STATUS_ AVAILABLE
+ \item 0x00000002 -- WIFI_STATUS_ UNAVAILABLE
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocNotifyWifiStatusReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Notifies the location engine of the WiFi status. */
+typedef struct {
+
+ /* Mandatory */
+ /* Status of Notify WiFi Status Request */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Notify WiFi Status request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocNotifyWifiStatusIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetRegisteredEventsReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetRegisteredEventsReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the mask of the events for which a client has
+ registered. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Registered Events Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Registered Events request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Event Registration Mask */
+ uint8_t eventRegMask_valid; /**< Must be set to true if eventRegMask is being passed */
+ qmiLocEventRegMaskT_v02 eventRegMask;
+ /**< Event registration mask.
+ Valid bitmasks: \n
+ - QMI_LOC_EVENT_MASK_POSITION_REPORT (0x00000001) -- The control point must enable this mask to receive position report
+ event indications.
+ - QMI_LOC_EVENT_MASK_GNSS_SV_INFO (0x00000002) -- The control point must enable this mask to receive satellite report
+ event indications. These reports are sent at a 1 Hz rate.
+ - QMI_LOC_EVENT_MASK_NMEA (0x00000004) -- The control point must enable this mask to receive NMEA reports for
+ position and satellites in view. The report is at a 1 Hz rate.
+ - QMI_LOC_EVENT_MASK_NI_NOTIFY_VERIFY_REQ (0x00000008) -- The control point must enable this mask to receive NI Notify/Verify request
+ event indications.
+ - QMI_LOC_EVENT_MASK_INJECT_TIME_REQ (0x00000010) -- The control point must enable this mask to receive time injection request
+ event indications.
+ - QMI_LOC_EVENT_MASK_INJECT_PREDICTED_ORBITS_REQ (0x00000020) -- The control point must enable this mask to receive predicted orbits request
+ event indications.
+ - QMI_LOC_EVENT_MASK_INJECT_POSITION_REQ (0x00000040) -- The control point must enable this mask to receive position injection request
+ event indications.
+ - QMI_LOC_EVENT_MASK_ENGINE_STATE (0x00000080) -- The control point must enable this mask to receive engine state report
+ event indications.
+ - QMI_LOC_EVENT_MASK_FIX_SESSION_STATE (0x00000100) -- The control point must enable this mask to receive fix session status report
+ event indications.
+ - QMI_LOC_EVENT_MASK_WIFI_REQ (0x00000200) -- The control point must enable this mask to receive WiFi position request
+ event indications.
+ - QMI_LOC_EVENT_MASK_SENSOR_STREAMING_READY_STATUS (0x00000400) -- The control point must enable this mask to receive notifications from the
+ GPS engine indicating its readiness to accept data from the
+ sensors (accelerometer, gyroscope, etc.).
+ - QMI_LOC_EVENT_MASK_TIME_SYNC_REQ (0x00000800) -- The control point must enable this mask to receive time sync requests
+ from the GPS engine. Time sync enables the GPS engine to synchronize
+ its clock with the sensor processor's clock.
+ - QMI_LOC_EVENT_MASK_SET_SPI_STREAMING_REPORT (0x00001000) -- The control point must enable this mask to receive Stationary Position
+ Indicator (SPI) streaming report indications.
+ - QMI_LOC_EVENT_MASK_LOCATION_SERVER_CONNECTION_REQ (0x00002000) -- The control point must enable this mask to receive location server
+ requests. These requests are generated when the service wishes to
+ establish a connection with a location server.
+ - QMI_LOC_EVENT_MASK_NI_GEOFENCE_NOTIFICATION (0x00004000) -- The control point must enable this mask to receive notifications
+ related to network-initiated Geofences. These events notify the client
+ when a network-initiated Geofence is added, deleted, or edited.
+ - QMI_LOC_EVENT_MASK_GEOFENCE_GEN_ALERT (0x00008000) -- The control point must enable this mask to receive Geofence alerts.
+ These alerts are generated to inform the client of the changes that may
+ affect Geofence, e.g., if GPS is turned off or if the network is
+ unavailable.
+ - QMI_LOC_EVENT_MASK_GEOFENCE_BREACH_NOTIFICATION (0x00010000) -- The control point must enable this mask to receive notifications when
+ a Geofence is breached. These events are generated when the UE enters
+ or leaves the perimeter of a Geofence.
+ - QMI_LOC_EVENT_MASK_PEDOMETER_CONTROL (0x00020000) -- The control point must enable this mask to register for pedometer
+ control requests from the location engine. The location engine sends
+ this event to control the injection of pedometer reports.
+ - QMI_LOC_EVENT_MASK_MOTION_DATA_CONTROL (0x00040000) -- The control point must enable this mask to register for motion data
+ control requests from the location engine. The location engine sends
+ this event to control the injection of motion data.
+ */
+}qmiLocGetRegisteredEventsIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCOPERATIONMODEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_OPER_MODE_DEFAULT_V02 = 1, /**< Use the default engine mode. */
+ eQMI_LOC_OPER_MODE_MSB_V02 = 2, /**< Use the MS-based mode. */
+ eQMI_LOC_OPER_MODE_MSA_V02 = 3, /**< Use the MS-assisted mode. */
+ eQMI_LOC_OPER_MODE_STANDALONE_V02 = 4, /**< Use Standalone mode. */
+ eQMI_LOC_OPER_MODE_CELL_ID_V02 = 5, /**< Use cell ID. This mode is valid only for a GSM/UMTS network. */
+ eQMI_LOC_OPER_MODE_WWAN_V02 = 6, /**< Use WWAN measurements to calculate the position. If this mode is
+ set, AFLT will be used for 1x networks and OTDOA will be used
+ for LTE networks. */
+ QMILOCOPERATIONMODEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocOperationModeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Tells the engine to use the specified operation mode while
+ making the position fixes. This command is not to be used
+ by multiple clients concurrently. */
+typedef struct {
+
+ /* Mandatory */
+ /* Operation Mode */
+ qmiLocOperationModeEnumT_v02 operationMode;
+ /**< Preferred operation mode.
+ \label{operationMode}
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- OPER_MODE_ DEFAULT
+ \item 0x00000002 -- OPER_MODE_MSB
+ \item 0x00000003 -- OPER_MODE_MSA
+ \item 0x00000004 -- OPER_MODE_ STANDALONE
+ \item 0x00000005 -- OPER_MODE_ CELL_ID
+ \item 0x00000006 -- OPER_MODE_ WWAN
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetOperationModeReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Tells the engine to use the specified operation mode while
+ making the position fixes. This command is not to be used
+ by multiple clients concurrently. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Operation Mode Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Operation Mode request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetOperationModeIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetOperationModeReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetOperationModeReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Gets the current operation mode from the engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Operation Mode Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Operation Mode request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Operation Mode */
+ uint8_t operationMode_valid; /**< Must be set to true if operationMode is being passed */
+ qmiLocOperationModeEnumT_v02 operationMode;
+ /**< Current operation mode.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- OPER_MODE_ DEFAULT
+ \item 0x00000002 -- OPER_MODE_MSB
+ \item 0x00000003 -- OPER_MODE_MSA
+ \item 0x00000004 -- OPER_MODE_ STANDALONE
+ \item 0x00000005 -- OPER_MODE_ CELL_ID
+ \item 0x00000006 -- OPER_MODE_ WWAN
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocGetOperationModeIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to set the SPI status, which
+ indicates whether the device is stationary. */
+typedef struct {
+
+ /* Mandatory */
+ /* Stationary Status */
+ uint8_t stationary;
+ /**< Indicates whether the device is stationary:
+ \begin{itemize1}
+ \item 0x00 (FALSE) -- Device is not stationary
+ \item 0x01 (TRUE) -- Device is stationary
+ \vspace{-0.18in} \end{itemize1}*/
+
+ /* Optional */
+ /* Confidence */
+ uint8_t confidenceStationary_valid; /**< Must be set to true if confidenceStationary is being passed */
+ uint8_t confidenceStationary;
+ /**< Confidence in the Stationary state expressed as a percentage.\n
+ - Range: 0 to 100 */
+}qmiLocSetSpiStatusReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to set the SPI status, which
+ indicates whether the device is stationary. */
+typedef struct {
+
+ /* Mandatory */
+ /* Status of SPI Status Request */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the SPI Status request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetSpiStatusIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint8_t qmiLocSensorDataFlagMaskT_v02;
+#define QMI_LOC_SENSOR_DATA_FLAG_SIGN_REVERSAL_V02 ((qmiLocSensorDataFlagMaskT_v02)0x01) /**< Bitmask to specify that a sign reversal is required while interpreting
+ the sensor data. Only applies to the accelerometer samples. */
+#define QMI_LOC_SENSOR_DATA_FLAG_SENSOR_TIME_IS_MODEM_TIME_V02 ((qmiLocSensorDataFlagMaskT_v02)0x02) /**< Bitmask to specify that the sensor time stamp is the same as the modem
+ time stamp. */
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSENSORDATATIMESOURCEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SENSOR_TIME_SOURCE_UNSPECIFIED_V02 = 0, /**< The sensor time source is unspecified. */
+ eQMI_LOC_SENSOR_TIME_SOURCE_COMMON_V02 = 1, /**< The time source is common between the sensors and
+ the location engine. */
+ QMILOCSENSORDATATIMESOURCEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSensorDataTimeSourceEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint16_t timeOffset;
+ /**< Sample time offset. This time offset must be
+ relative to the timestamp of the first sensor data sample.\n
+ - Units: Milliseconds */
+
+ float xAxis;
+ /**< Sensor x-axis sample. \n
+ - Units Accelerometer: ( (meters)/(seconds^2) ) \n
+ - Units Gyroscope: ( (rads)/(seconds) ) */
+
+ float yAxis;
+ /**< Sensor y-axis sample. \n
+ - Units Accelerometer: ( (meters)/(seconds^2) ) \n
+ - Units Gyroscope: ( (rads)/(seconds) ) */
+
+ float zAxis;
+ /**< Sensor z-axis sample. \n
+ - Units Accelerometer: ( (meters)/(seconds^2) ) \n
+ - Units Gyroscope: ( (rads)/(seconds) ) */
+}qmiLoc3AxisSensorSampleStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t timeOfFirstSample;
+ /**< Denotes a full 32-bit timestamp of the first (oldest) sample in this
+ message.The timestamp is in the time reference scale that is
+ used by the sensor time source.\n
+ - Units: Milliseconds */
+
+ qmiLocSensorDataFlagMaskT_v02 flags;
+ /**< Flags to indicate any deviation from the default measurement
+ assumptions. All unused bits in this field must be set to 0.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x01 -- SIGN_REVERSAL
+ \item 0X02 -- SENSOR_TIME_IS_ MODEM_TIME
+ \vspace{-0.18in} \end{itemize1} */
+
+ uint32_t sensorData_len; /**< Must be set to # of elements in sensorData */
+ qmiLoc3AxisSensorSampleStructT_v02 sensorData[QMI_LOC_SENSOR_DATA_MAX_SAMPLES_V02];
+ /**< Variable length array to specify sensor samples. \n
+ - Maximum length of the array: 50 */
+}qmiLoc3AxisSensorSampleListStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint16_t timeOffset;
+ /**< Sample time offset. This time offset must be
+ relative to the timestamp of the first sensor sample.\n
+ - Units: Milliseconds */
+
+ float temperature;
+ /**< Sensor temperature. \n
+ - Type: Floating point \n
+ - Units: Degrees Celsius \n
+ - Range: -50 to +100.00 */
+}qmiLocSensorTemperatureSampleStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocSensorDataTimeSourceEnumT_v02 timeSource;
+ /**< Denotes the time source of the sensor data. Location service will use
+ this field to identify the time reference used in the
+ sensor data timestamps. Values :\n
+ - eQMI_LOC_SENSOR_TIME_SOURCE_UNSPECIFIED (0) -- The sensor time source is unspecified.
+ - eQMI_LOC_SENSOR_TIME_SOURCE_COMMON (1) -- The time source is common between the sensors and
+ the location engine.
+ */
+
+ uint32_t timeOfFirstSample;
+ /**< Denotes a full 32-bit timestamp of the first (oldest) sample in this
+ message. The timestamp is in the time reference scale that is
+ used by the sensor time source.\n
+ - Units: Milliseconds */
+
+ uint32_t temperatureData_len; /**< Must be set to # of elements in temperatureData */
+ qmiLocSensorTemperatureSampleStructT_v02 temperatureData[QMI_LOC_SENSOR_DATA_MAX_SAMPLES_V02];
+ /**< Variable length array to specify sensor temperature samples. \n
+ - Maximum length of the array: 50 */
+}qmiLocSensorTemperatureSampleListStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to inject sensor data into the
+ GNSS location engine. */
+typedef struct {
+
+ /* Optional */
+ /* Opaque Identifier */
+ uint8_t opaqueIdentifier_valid; /**< Must be set to true if opaqueIdentifier is being passed */
+ uint32_t opaqueIdentifier;
+ /**< An opaque identifier that is sent in by the client that will be echoed
+ in the indication so the client can relate the indication to the
+ request. */
+
+ /* Optional */
+ /* 3-Axis Accelerometer Data */
+ uint8_t threeAxisAccelData_valid; /**< Must be set to true if threeAxisAccelData is being passed */
+ qmiLoc3AxisSensorSampleListStructT_v02 threeAxisAccelData;
+ /**< \vspace{0.06in} \n Accelerometer sensor samples. */
+
+ /* Optional */
+ /* 3-Axis Gyroscope Data */
+ uint8_t threeAxisGyroData_valid; /**< Must be set to true if threeAxisGyroData is being passed */
+ qmiLoc3AxisSensorSampleListStructT_v02 threeAxisGyroData;
+ /**< \vspace{0.06in} \n Gyroscope sensor samples. */
+
+ /* Optional */
+ /* 3-Axis Accelerometer Data Time Source */
+ uint8_t threeAxisAccelDataTimeSource_valid; /**< Must be set to true if threeAxisAccelDataTimeSource is being passed */
+ qmiLocSensorDataTimeSourceEnumT_v02 threeAxisAccelDataTimeSource;
+ /**< Time source for the 3-axis accelerometer data. The location service uses
+ this field to identify the time reference used in the accelerometer data
+ timestamps. If not specified, the location service assumes that the
+ time source for the accelereometer data is unknown. \n
+ Values: \n
+ - eQMI_LOC_SENSOR_TIME_SOURCE_UNSPECIFIED (0) -- The sensor time source is unspecified.
+ - eQMI_LOC_SENSOR_TIME_SOURCE_COMMON (1) -- The time source is common between the sensors and
+ the location engine.
+ */
+
+ /* Optional */
+ /* 3-Axis Gyroscope Data Time Source */
+ uint8_t threeAxisGyroDataTimeSource_valid; /**< Must be set to true if threeAxisGyroDataTimeSource is being passed */
+ qmiLocSensorDataTimeSourceEnumT_v02 threeAxisGyroDataTimeSource;
+ /**< Time source for the 3-axis gyroscope data. The location service uses
+ this field to identify the time reference used in the gyroscope data
+ timestamps. If not specified, the location service assumes that the
+ time source for the gyroscope data is unknown. \n
+ Values: \n
+ - eQMI_LOC_SENSOR_TIME_SOURCE_UNSPECIFIED (0) -- The sensor time source is unspecified.
+ - eQMI_LOC_SENSOR_TIME_SOURCE_COMMON (1) -- The time source is common between the sensors and
+ the location engine.
+ */
+
+ /* Optional */
+ /* Accelerometer Temperature Data */
+ uint8_t accelTemperatureData_valid; /**< Must be set to true if accelTemperatureData is being passed */
+ qmiLocSensorTemperatureSampleListStructT_v02 accelTemperatureData;
+ /**< \vspace{0.06in} \nAccelerometer temperature samples. This data is optional and does not
+ have to be included in the message along with accelerometer data. */
+
+ /* Optional */
+ /* Gyroscope Temperature Data */
+ uint8_t gyroTemperatureData_valid; /**< Must be set to true if gyroTemperatureData is being passed */
+ qmiLocSensorTemperatureSampleListStructT_v02 gyroTemperatureData;
+ /**< \vspace{0.06in} \n Gyroscope temperature samples. This data is optional and does not
+ have to be included in the message along with gyroscope data. */
+}qmiLocInjectSensorDataReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to inject sensor data into the
+ GNSS location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject Sensor Data Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject Sensor Data request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Opaque Identifier */
+ uint8_t opaqueIdentifier_valid; /**< Must be set to true if opaqueIdentifier is being passed */
+ uint32_t opaqueIdentifier;
+ /**< Opaque identifier that was sent in by the client echoed
+ so the client can relate the indication to the request. */
+
+ /* Optional */
+ /* Accelerometer Samples Accepted */
+ uint8_t threeAxisAccelSamplesAccepted_valid; /**< Must be set to true if threeAxisAccelSamplesAccepted is being passed */
+ uint8_t threeAxisAccelSamplesAccepted;
+ /**< Lets the client know how many 3-axis accelerometer samples
+ were accepted. This field is present only if the accelerometer
+ samples were sent in the request. */
+
+ /* Optional */
+ /* Gyroscope Samples Accepted */
+ uint8_t threeAxisGyroSamplesAccepted_valid; /**< Must be set to true if threeAxisGyroSamplesAccepted is being passed */
+ uint8_t threeAxisGyroSamplesAccepted;
+ /**< Lets the client know how many 3-axis gyroscope samples were
+ accepted. This field is present only if the gyroscope
+ samples were sent in the request. */
+
+ /* Optional */
+ /* Accelerometer Temperature Samples Accepted */
+ uint8_t accelTemperatureSamplesAccepted_valid; /**< Must be set to true if accelTemperatureSamplesAccepted is being passed */
+ uint8_t accelTemperatureSamplesAccepted;
+ /**< Lets the client know how many accelerometer temperature
+ samples were accepted. This field is present only if the accelerometer
+ temperature samples were sent in the request. */
+
+ /* Optional */
+ /* Gyroscope Temperature Samples Accepted */
+ uint8_t gyroTemperatureSamplesAccepted_valid; /**< Must be set to true if gyroTemperatureSamplesAccepted is being passed */
+ uint8_t gyroTemperatureSamplesAccepted;
+ /**< Lets the client know how many gyroscope temperature samples
+ were accepted. This field is present only if the gyroscope
+ temperature samples were sent in the request. */
+}qmiLocInjectSensorDataIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to inject time sync data. */
+typedef struct {
+
+ /* Mandatory */
+ /* Reference Time Sync Counter */
+ uint32_t refCounter;
+ /**< Must be set to the value that was sent to the control point when the
+ GNSS location engine requested time sync injection. */
+
+ /* Mandatory */
+ /* Sensor Receive Time */
+ uint32_t sensorProcRxTime;
+ /**< Value of the sensor time when the control point received the
+ Time Sync Inject request from the GNSS location engine.
+
+ Must be monotonically increasing, jitter @latexonly $\leq$ @endlatexonly 1
+ millisecond, never stopping until the process is rebooted.\n
+ - Units: Milliseconds */
+
+ /* Mandatory */
+ /* Sensor Transmit Time */
+ uint32_t sensorProcTxTime;
+ /**< Value of the sensor time when the control point injects this message
+ for use by the GNSS location engine.
+
+ Must be monotonically increasing, jitter @latexonly $\leq$ @endlatexonly 1
+ millisecond, never stopping until the process is rebooted.\n
+ - Units: Milliseconds */
+}qmiLocInjectTimeSyncDataReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to inject time sync data. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject Time Sync Data Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject Time Sync Data request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectTimeSyncDataIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCCRADLEMOUNTSTATEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_CRADLE_STATE_NOT_MOUNTED_V02 = 0, /**< Device is mounted on the cradle */
+ eQMI_LOC_CRADLE_STATE_MOUNTED_V02 = 1, /**< Device is not mounted on the cradle */
+ eQMI_LOC_CRADLE_STATE_UNKNOWN_V02 = 2, /**< Unknown cradle mount state */
+ QMILOCCRADLEMOUNTSTATEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocCradleMountStateEnumT_v02;
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetCradleMountConfigReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetCradleMountConfigReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to get the current
+ cradle mount configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Cradle Mount Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Cradle Mount Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Cradle Mount State */
+ uint8_t cradleMountState_valid; /**< Must be set to true if cradleMountState is being passed */
+ qmiLocCradleMountStateEnumT_v02 cradleMountState;
+ /**< Cradle Mount state set by the control point.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- CRADLE_STATE_ NOT_MOUNTED
+ \item 0x00000001 -- CRADLE_STATE_ MOUNTED
+ \item 0x00000002 -- CRADLE_STATE_ UNKNOWN
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Cradle Mount Confidence */
+ uint8_t confidenceCradleMountState_valid; /**< Must be set to true if confidenceCradleMountState is being passed */
+ uint8_t confidenceCradleMountState;
+ /**< Confidence of the Cradle Mount state expressed as a percentage.\n
+ - Range: 0 to 100 */
+}qmiLocGetCradleMountConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to set the current
+ cradle mount configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Cradle Mount State */
+ qmiLocCradleMountStateEnumT_v02 cradleMountState;
+ /**< Cradle Mount state set by the control point.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- CRADLE_STATE_ NOT_MOUNTED
+ \item 0x00000001 -- CRADLE_STATE_ MOUNTED
+ \item 0x00000002 -- CRADLE_STATE_ UNKNOWN
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Cradle Mount Confidence */
+ uint8_t confidenceCradleMountState_valid; /**< Must be set to true if confidenceCradleMountState is being passed */
+ uint8_t confidenceCradleMountState;
+ /**< Confidence in the Cradle Mount state expressed as a percentage.\n
+ - Range: 0 to 100 */
+}qmiLocSetCradleMountConfigReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to set the current
+ cradle mount configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Cradle Mount Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Cradle Mount Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetCradleMountConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCEXTERNALPOWERCONFIGENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_EXTERNAL_POWER_NOT_CONNECTED_V02 = 0, /**< Device is not connected to an external power source. */
+ eQMI_LOC_EXTERNAL_POWER_CONNECTED_V02 = 1, /**< Device is connected to an external power source. */
+ eQMI_LOC_EXTERNAL_POWER_UNKNOWN_V02 = 2, /**< Unknown external power state. */
+ QMILOCEXTERNALPOWERCONFIGENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocExternalPowerConfigEnumT_v02;
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetExternalPowerConfigReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetExternalPowerConfigReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to get the current
+ external power configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Ext Power Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get External Power Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* External Power State */
+ uint8_t externalPowerState_valid; /**< Must be set to true if externalPowerState is being passed */
+ qmiLocExternalPowerConfigEnumT_v02 externalPowerState;
+ /**< Power state; injected by the control point.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- EXTERNAL_ POWER_NOT_CONNECTED
+ \item 0x00000001 -- EXTERNAL_ POWER_CONNECTED
+ \item 0x00000002 -- EXTERNAL_ POWER_UNKNOWN
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocGetExternalPowerConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to set the current
+ external power configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* External Power State */
+ qmiLocExternalPowerConfigEnumT_v02 externalPowerState;
+ /**< Power state; injected by the control point.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- EXTERNAL_ POWER_NOT_CONNECTED
+ \item 0x00000001 -- EXTERNAL_ POWER_CONNECTED
+ \item 0x00000002 -- EXTERNAL_ POWER_UNKNOWN
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetExternalPowerConfigReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to set the current
+ external power configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Ext Power Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set External Power Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetExternalPowerConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSERVERPDNENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV4_V02 = 0x01, /**< IPV4 PDN type. */
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV6_V02 = 0x02, /**< IPV6 PDN type. */
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_IPV4V6_V02 = 0x03, /**< IPV4V6 PDN type. */
+ eQMI_LOC_APN_PROFILE_PDN_TYPE_PPP_V02 = 0x04, /**< PPP PDN type. */
+ QMILOCSERVERPDNENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocServerPDNEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocServerPDNEnumT_v02 pdnType;
+ /**< PDN type of the APN profile.
+
+ Valid values: \n
+ - 0x00000001 -- PDN_TYPE_IPV4 \n
+ - 0x00000002 -- PDN_TYPE_IPV6 \n
+ - 0x00000003 -- PDN_TYPE_IPV4V6 \n
+ - 0x00000004 -- PDN_TYPE_PPP
+ */
+
+ char apnName[QMI_LOC_MAX_APN_NAME_LENGTH_V02 + 1];
+ /**< APN name.
+ \begin{itemize1}
+ \item Type: NULL-terminated string
+ \item Maximum string length (including NULL terminator): 101
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocApnProfilesStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSERVERREQSTATUSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SERVER_REQ_STATUS_SUCCESS_V02 = 1, /**< Location server request was successful. */
+ eQMI_LOC_SERVER_REQ_STATUS_FAILURE_V02 = 2, /**< Location server request failed. */
+ QMILOCSERVERREQSTATUSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocServerReqStatusEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to inform the service about the
+ status of the location server connection request that the
+ service may have sent via the
+ QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND event. */
+typedef struct {
+
+ /* Mandatory */
+ /* Connection Handle */
+ uint32_t connHandle;
+ /**< Connection handle that the service specified in the
+ Location Server Connection request event. */
+
+ /* Mandatory */
+ /* Request Type */
+ qmiLocServerRequestEnumT_v02 requestType;
+ /**< Type of connection request service that was specified in the
+ Location Server Connection Request event.
+
+ Valid values: \n
+ - 0x00000001 -- OPEN \n
+ - 0x00000002 -- CLOSE
+ */
+
+ /* Mandatory */
+ /* Connection Status */
+ qmiLocServerReqStatusEnumT_v02 statusType;
+ /**< Status of the Connection request.
+
+ Valid values: \n
+ - 0x00000001 -- STATUS_SUCCESS = 1 \n
+ - 0x00000002 -- STATUS_FAILURE = 2
+
+ */
+
+ /* Optional */
+ /* APN Profile */
+ uint8_t apnProfile_valid; /**< Must be set to true if apnProfile is being passed */
+ qmiLocApnProfilesStructT_v02 apnProfile;
+ /**< \vspace{0.06in} \n Access Point Name (APN) profile information is present only when
+ requestType is OPEN and statusType is SUCCESS. */
+}qmiLocInformLocationServerConnStatusReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to inform the service about the
+ status of the location server connection request that the
+ service may have sent via the
+ QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND event. */
+typedef struct {
+
+ /* Mandatory */
+ /* Status of Inform Loc Server Conn Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inform Location Server Connection Status request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInformLocationServerConnStatusIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCVXVERSIONENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_VX_VERSION_V1_ONLY_V02 = 1, /**< V1 VX version. */
+ eQMI_LOC_VX_VERSION_V2_ONLY_V02 = 2, /**< V2 VX version. */
+ QMILOCVXVERSIONENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocVxVersionEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSUPLVERSIONENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SUPL_VERSION_1_0_V02 = 1, /**< SUPL version 1.0. */
+ eQMI_LOC_SUPL_VERSION_2_0_V02 = 2, /**< SUPL version 2.0. */
+ QMILOCSUPLVERSIONENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSuplVersionEnumT_v02;
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocLppConfigMaskT_v02;
+#define QMI_LOC_LPP_CONFIG_ENABLE_USER_PLANE_V02 ((qmiLocLppConfigMaskT_v02)0x00000001) /**< Enable user plane configuration for LTE Positioning Profile (LPP). */
+#define QMI_LOC_LPP_CONFIG_ENABLE_CONTROL_PLANE_V02 ((qmiLocLppConfigMaskT_v02)0x00000002) /**< Enable control plane configuration for LPP. */
+typedef uint32_t qmiLocAssistedGlonassProtocolMaskT_v02;
+#define QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_RRC_CP_V02 ((qmiLocAssistedGlonassProtocolMaskT_v02)0x00000001) /**< Assisted GLONASS is supported over RRC in the control plane. */
+#define QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_RRLP_UP_V02 ((qmiLocAssistedGlonassProtocolMaskT_v02)0x00000002) /**< Assisted GLONASS is supported over RRLP in the user plane. */
+#define QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_LPP_UP_V02 ((qmiLocAssistedGlonassProtocolMaskT_v02)0x00000004) /**< Assisted GLONASS is supported over LPP in the user plane.
+ QMI_LOC_LPP_CONFIG_ENABLE_USER_PLANE must be set
+ in the LPP configuration for this to take effect. */
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSUPLHASHALGOENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SUPL_HASH_ALGO_SHA1_V02 = 0, /**< SHA-1 hash algorithm for SUPL version 2.0 or later. */
+ eQMI_LOC_SUPL_HASH_ALGO_SHA256_V02 = 1, /**< SHA-256 hash algorithm for SUPL version 2.0 or later. */
+ QMILOCSUPLHASHALGOENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSuplHashAlgoEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSUPLTLSVERSIONENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SUPL_TLS_VERSION_1_0_V02 = 0, /**< SUPL TLS version 1.0. */
+ eQMI_LOC_SUPL_TLS_VERSION_1_1_V02 = 1, /**< SUPL TLS version 1.1. */
+ QMILOCSUPLTLSVERSIONENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSuplTlsVersionEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCEMERGENCYPROTOCOLENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_EMERGENCY_PROTOCOL_WCDMA_CP_V02 = 0, /**< Use Control Plane protocol during an emergency while on WCDMA. */
+ eQMI_LOC_EMERGENCY_PROTOCOL_WCDMA_UP_V02 = 1, /**< Use SUPL 2.0 emergency services during an emergency while on WCDMA. */
+ QMILOCEMERGENCYPROTOCOLENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocEmergencyProtocolEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to configure parameters stored
+ in the nonvolatile memory. */
+typedef struct {
+
+ /* Optional */
+ /* SUPL Security */
+ uint8_t suplSecurity_valid; /**< Must be set to true if suplSecurity is being passed */
+ uint8_t suplSecurity;
+ /**< Indicates whether SUPL security is enabled.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- SUPL security is enabled
+ \item 0x00 (FALSE) -- SUPL security is disabled
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* VX Version */
+ uint8_t vxVersion_valid; /**< Must be set to true if vxVersion is being passed */
+ qmiLocVxVersionEnumT_v02 vxVersion;
+ /**< VX version.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- VX_VERSION_ V1_ONLY
+ \item 0x00000002 -- VX_VERSION_ V2_ONLY
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* SUPL Version */
+ uint8_t suplVersion_valid; /**< Must be set to true if suplVersion is being passed */
+ qmiLocSuplVersionEnumT_v02 suplVersion;
+ /**< SUPL version.
+
+ Valid values: \n
+ - 0x00000001 -- SUPL_VERSION_1_0 \n
+ - 0x00000002 -- SUPL_VERSION_2_0
+ */
+
+ /* Optional */
+ /* LPP Configuration */
+ uint8_t lppConfig_valid; /**< Must be set to true if lppConfig is being passed */
+ qmiLocLppConfigMaskT_v02 lppConfig;
+ /**< LTE Positioning Profile (LPP) configuration.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- LPP_CONFIG_ ENABLE_USER_PLANE
+ \item 0x00000002 -- LPP_CONFIG_ ENABLE_CONTROL_PLANE
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Assisted GLONASS Protocol Mask */
+ uint8_t assistedGlonassProtocolMask_valid; /**< Must be set to true if assistedGlonassProtocolMask is being passed */
+ qmiLocAssistedGlonassProtocolMaskT_v02 assistedGlonassProtocolMask;
+ /**< Configures the protocols that the location service supports
+ for assisted GLONASS.
+
+ Valid bitmasks: \n
+ - QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_RRC_CP (0x00000001) -- Assisted GLONASS is supported over RRC in the control plane.
+ - QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_RRLP_UP (0x00000002) -- Assisted GLONASS is supported over RRLP in the user plane.
+ - QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_LPP_UP (0x00000004) -- Assisted GLONASS is supported over LPP in the user plane.
+ QMI_LOC_LPP_CONFIG_ENABLE_USER_PLANE must be set
+ in the LPP configuration for this to take effect.
+ */
+
+ /* Optional */
+ /* SUPL Hash Algorithm */
+ uint8_t suplHashAlgo_valid; /**< Must be set to true if suplHashAlgo is being passed */
+ qmiLocSuplHashAlgoEnumT_v02 suplHashAlgo;
+ /**< SUPL hash algorithm to be used. Values: \n
+ - eQMI_LOC_SUPL_HASH_ALGO_SHA1 (0) -- SHA-1 hash algorithm for SUPL version 2.0 or later.
+ - eQMI_LOC_SUPL_HASH_ALGO_SHA256 (1) -- SHA-256 hash algorithm for SUPL version 2.0 or later.
+ */
+
+ /* Optional */
+ /* SUPL TLS Version */
+ uint8_t suplTlsVersion_valid; /**< Must be set to true if suplTlsVersion is being passed */
+ qmiLocSuplTlsVersionEnumT_v02 suplTlsVersion;
+ /**< SUPL Transport Layer Security (TLS) version. This configuration is only
+ applicable to SUPL 2.0 or later, as SUPL 1.0 always uses TLS version 1.0.
+ Values: \n
+ - eQMI_LOC_SUPL_TLS_VERSION_1_0 (0) -- SUPL TLS version 1.0.
+ - eQMI_LOC_SUPL_TLS_VERSION_1_1 (1) -- SUPL TLS version 1.1.
+ */
+
+ /* Optional */
+ /* Emergency Protocol */
+ uint8_t emergencyProtocol_valid; /**< Must be set to true if emergencyProtocol is being passed */
+ qmiLocEmergencyProtocolEnumT_v02 emergencyProtocol;
+ /**< Configures the protocol to be used during emergency. \n
+ \textbf{Note:} Currently, this can only be selected on WCDMA. For GSM
+ and 1x, the UE only allows a control plane NI trigger for positioning.
+ For LTE, the UE allows either a SUPL or a control plane NI trigger. \n
+ Values: \n
+ - eQMI_LOC_EMERGENCY_PROTOCOL_WCDMA_CP (0) -- Use Control Plane protocol during an emergency while on WCDMA.
+ - eQMI_LOC_EMERGENCY_PROTOCOL_WCDMA_UP (1) -- Use SUPL 2.0 emergency services during an emergency while on WCDMA.
+ */
+}qmiLocSetProtocolConfigParametersReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint64_t qmiLocProtocolConfigParamMaskT_v02;
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_SECURITY_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000001ull) /**< Mask for the SUPL security configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_VX_VERSION_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000002ull) /**< Mask for the VX version configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_VERSION_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000004ull) /**< Mask for the SUPL version configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_LPP_CONFIG_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000008ull) /**< Mask for the LPP configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_ASSISTED_GLONASS_PROTOCOL_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000010ull) /**< Mask for the assisted GLONASS configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_HASH_ALGO_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000020ull) /**< Mask for the SUPL hash algorithm configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_TLS_VERSION_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000040ull) /**< Mask for the SUPL TLS version configuration parameter. */
+#define QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_EMERGENCY_PROTOCOL_V02 ((qmiLocProtocolConfigParamMaskT_v02)0x0000000000000080ull) /**< Mask for the emergency protocol configuration parameter. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to configure parameters stored
+ in the nonvolatile memory. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Config Params Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Configuration Parameters request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Failed Parameters */
+ uint8_t failedProtocolConfigParamMask_valid; /**< Must be set to true if failedProtocolConfigParamMask is being passed */
+ qmiLocProtocolConfigParamMaskT_v02 failedProtocolConfigParamMask;
+ /**< Identifies parameters that were not set successfully. This field
+ is sent only if the status is not SUCCESS.
+
+ Valid bitmasks: \n
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_SECURITY (0x0000000000000001) -- Mask for the SUPL security configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_VX_VERSION (0x0000000000000002) -- Mask for the VX version configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_VERSION (0x0000000000000004) -- Mask for the SUPL version configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_LPP_CONFIG (0x0000000000000008) -- Mask for the LPP configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_ASSISTED_GLONASS_PROTOCOL (0x0000000000000010) -- Mask for the assisted GLONASS configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_HASH_ALGO (0x0000000000000020) -- Mask for the SUPL hash algorithm configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_TLS_VERSION (0x0000000000000040) -- Mask for the SUPL TLS version configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_EMERGENCY_PROTOCOL (0x0000000000000080) -- Mask for the emergency protocol configuration parameter.
+ */
+}qmiLocSetProtocolConfigParametersIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to get the configuration
+ parameters stored in the nonvolatile memory. */
+typedef struct {
+
+ /* Mandatory */
+ /* Config Parameters */
+ qmiLocProtocolConfigParamMaskT_v02 getProtocolConfigParamMask;
+ /**< Mask denoting the configuration parameters to be retrieved.
+
+ Valid bitmasks: \n
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_SECURITY (0x0000000000000001) -- Mask for the SUPL security configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_VX_VERSION (0x0000000000000002) -- Mask for the VX version configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_VERSION (0x0000000000000004) -- Mask for the SUPL version configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_LPP_CONFIG (0x0000000000000008) -- Mask for the LPP configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_ASSISTED_GLONASS_PROTOCOL (0x0000000000000010) -- Mask for the assisted GLONASS configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_HASH_ALGO (0x0000000000000020) -- Mask for the SUPL hash algorithm configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_SUPL_TLS_VERSION (0x0000000000000040) -- Mask for the SUPL TLS version configuration parameter.
+ - QMI_LOC_PROTOCOL_CONFIG_PARAM_MASK_EMERGENCY_PROTOCOL (0x0000000000000080) -- Mask for the emergency protocol configuration parameter.
+ */
+}qmiLocGetProtocolConfigParametersReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to get the configuration
+ parameters stored in the nonvolatile memory. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Config Params Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Configuration Parameters request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* SUPL Security */
+ uint8_t suplSecurity_valid; /**< Must be set to true if suplSecurity is being passed */
+ uint8_t suplSecurity;
+ /**< Indicates whether SUPL security is enabled.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- SUPL security is enabled
+ \item 0x00 (FALSE) -- SUPL security is disabled
+ \vspace{-0.18in} \end{itemize1}*/
+
+ /* Optional */
+ /* VX Version */
+ uint8_t vxVersion_valid; /**< Must be set to true if vxVersion is being passed */
+ qmiLocVxVersionEnumT_v02 vxVersion;
+ /**< VX version.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- VX_VERSION_V1_ ONLY
+ \item 0x00000002 -- VX_VERSION_V2_ ONLY
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* SUPL Version */
+ uint8_t suplVersion_valid; /**< Must be set to true if suplVersion is being passed */
+ qmiLocSuplVersionEnumT_v02 suplVersion;
+ /**< SUPL version.
+
+ Valid values: \n
+ - 0x00000001 -- SUPL_VERSION_1_0 \n
+ - 0x00000002 -- SUPL_VERSION_2_0
+ */
+
+ /* Optional */
+ /* LPP Configuration */
+ uint8_t lppConfig_valid; /**< Must be set to true if lppConfig is being passed */
+ qmiLocLppConfigMaskT_v02 lppConfig;
+ /**< LTE Positioning Profile (LPP) configuration.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- LPP_CONFIG_ ENABLE_USER_PLANE
+ \item 0x00000002 -- LPP_CONFIG_ ENABLE_CONTROL_PLANE
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Assisted GLONASS Protocol Mask */
+ uint8_t assistedGlonassProtocolMask_valid; /**< Must be set to true if assistedGlonassProtocolMask is being passed */
+ qmiLocAssistedGlonassProtocolMaskT_v02 assistedGlonassProtocolMask;
+ /**< Assisted GLONASS Protocol mask.
+
+ Valid bitmasks: \n
+ - QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_RRC_CP (0x00000001) -- Assisted GLONASS is supported over RRC in the control plane.
+ - QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_RRLP_UP (0x00000002) -- Assisted GLONASS is supported over RRLP in the user plane.
+ - QMI_LOC_ASSISTED_GLONASS_PROTOCOL_MASK_LPP_UP (0x00000004) -- Assisted GLONASS is supported over LPP in the user plane.
+ QMI_LOC_LPP_CONFIG_ENABLE_USER_PLANE must be set
+ in the LPP configuration for this to take effect.
+ */
+
+ /* Optional */
+ /* SUPL Hash Algorithm */
+ uint8_t suplHashAlgo_valid; /**< Must be set to true if suplHashAlgo is being passed */
+ qmiLocSuplHashAlgoEnumT_v02 suplHashAlgo;
+ /**< SUPL hash algorithm to be used. Values: \n
+ - eQMI_LOC_SUPL_HASH_ALGO_SHA1 (0) -- SHA-1 hash algorithm for SUPL version 2.0 or later.
+ - eQMI_LOC_SUPL_HASH_ALGO_SHA256 (1) -- SHA-256 hash algorithm for SUPL version 2.0 or later.
+ */
+
+ /* Optional */
+ /* SUPL TLS Version */
+ uint8_t suplTlsVersion_valid; /**< Must be set to true if suplTlsVersion is being passed */
+ qmiLocSuplTlsVersionEnumT_v02 suplTlsVersion;
+ /**< SUPL TLS version. This configuration is only
+ applicable to SUPL 2.0 or later, as SUPL 1.0 always uses TLS version 1.0.
+ Values: \n
+ - eQMI_LOC_SUPL_TLS_VERSION_1_0 (0) -- SUPL TLS version 1.0.
+ - eQMI_LOC_SUPL_TLS_VERSION_1_1 (1) -- SUPL TLS version 1.1.
+ */
+
+ /* Optional */
+ /* Emergency Protocol */
+ uint8_t emergencyProtocol_valid; /**< Must be set to true if emergencyProtocol is being passed */
+ qmiLocEmergencyProtocolEnumT_v02 emergencyProtocol;
+ /**< Protocol to be used during emergency.
+ Values: \n
+ - eQMI_LOC_EMERGENCY_PROTOCOL_WCDMA_CP (0) -- Use Control Plane protocol during an emergency while on WCDMA.
+ - eQMI_LOC_EMERGENCY_PROTOCOL_WCDMA_UP (1) -- Use SUPL 2.0 emergency services during an emergency while on WCDMA.
+ */
+}qmiLocGetProtocolConfigParametersIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSENSORSCONTROLCONFIGSENSORUSEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SENSOR_CONFIG_SENSOR_USE_ENABLE_V02 = 0, /**< Sensors data should be requested whenever a position request is
+ received. If sensor data are injected, the positioning engine
+ attempts to improve the heading and positioning performance using sensors.
+ This is the default.
+ */
+ eQMI_LOC_SENSOR_CONFIG_SENSOR_USE_DISABLE_V02 = 1, /**< Inertial sensors are not to be used to aid heading and position
+ improvement. */
+ QMILOCSENSORSCONTROLCONFIGSENSORUSEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSensorsControlConfigSensorUseEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Sets the sensor control configuration. */
+typedef struct {
+
+ /* Optional */
+ /* Sensors Usage */
+ uint8_t sensorsUsage_valid; /**< Must be set to true if sensorsUsage is being passed */
+ qmiLocSensorsControlConfigSensorUseEnumT_v02 sensorsUsage;
+ /**< Controls how sensors are used to aid heading and positioning
+ performance.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SENSORS_USE_ ENABLED:
+ Sensors data is to be requested whenever a position request is
+ received. If sensors data is injected, the GNSS location engine
+ attempts to improve the heading and positioning performance using
+ sensors. This is the default.
+ \item 0x00000001 -- SENSORS_USE_ DISABLED:
+ Inertial sensors are not to be used to aid in heading and
+ position improvement.
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetSensorControlConfigReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sets the sensor control configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Sensor Control Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Sensor Control Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetSensorControlConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetSensorControlConfigReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetSensorControlConfigReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Retrieves the current sensor control configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Sensor Control Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Sensors Control Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Sensors Usage */
+ uint8_t sensorsUsage_valid; /**< Must be set to true if sensorsUsage is being passed */
+ qmiLocSensorsControlConfigSensorUseEnumT_v02 sensorsUsage;
+ /**< Controls how sensors are used to aid the heading and positioning
+ performance.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SENSORS_USE_ ENABLED:
+ Sensors data is to be requested whenever a position request is
+ received. If sensors data is injected, the GNSS location engine
+ attempts to improve the heading and positioning performance using
+ sensors. This is the default.
+ \item 0x00000001 -- SENSORS_USE_ DISABLED:
+ Inertial sensors are not to be used to aid in the heading and
+ position improvement.
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocGetSensorControlConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocSensorPropertiesMaskT_v02;
+#define QMI_LOC_SENSOR_PROPERTIES_MASK_GYRO_BIAS_VARIANCE_RANDOM_WALK_V02 ((qmiLocSensorPropertiesMaskT_v02)0x00000001) /**< Denotes the gyro bias variance random walk parameter. */
+#define QMI_LOC_SENSOR_PROPERTIES_MASK_VELOCITY_RANDOM_WALK_SPECTRAL_DENSITY_V02 ((qmiLocSensorPropertiesMaskT_v02)0x00000002) /**< Denotes the velocity random walk spectral density parameter. */
+#define QMI_LOC_SENSOR_PROPERTIES_MASK_ACCELERATION_RANDOM_WALK_SPECTRAL_DENSITY_V02 ((qmiLocSensorPropertiesMaskT_v02)0x00000004) /**< Denotes the acceleration random walk spectral density parameter. */
+#define QMI_LOC_SENSOR_PROPERTIES_MASK_ANGLE_RANDOM_WALK_SPECTRAL_DENSITY_V02 ((qmiLocSensorPropertiesMaskT_v02)0x00000008) /**< Denotes the angle random walk spectral density parameter. */
+#define QMI_LOC_SENSOR_PROPERTIES_MASK_RATE_RANDOM_WALK_SPECTRAL_DENSITY_V02 ((qmiLocSensorPropertiesMaskT_v02)0x00000010) /**< Denotes the rate random walk spectral density parameter. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Sets the properties specific to the type of sensor used.
+ The control point must set sensor properties before they can be
+ used to aid in heading and positioning performance improvement.
+ */
+typedef struct {
+
+ /* Optional */
+ /* Gyro Bias Random Walk Variance */
+ uint8_t gyroBiasVarianceRandomWalk_valid; /**< Must be set to true if gyroBiasVarianceRandomWalk is being passed */
+ float gyroBiasVarianceRandomWalk;
+ /**< Specifies the gyro bias random walk variance parameter as a positive
+ floating-point value. This value has internal default value 1.0e-5 radian^2/second^4.
+ The gyro bias variance random walk parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Radians^2/seconds^4
+
+ */
+
+ /* Optional */
+ /* Velocity Random Walk Spectral Density */
+ uint8_t velocityRandomWalkSpectralDensity_valid; /**< Must be set to true if velocityRandomWalkSpectralDensity is being passed */
+ float velocityRandomWalkSpectralDensity;
+ /**< Specifies the velocity random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The velocity random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Meters/seconds^2/Hertz^0.5
+
+ */
+
+ /* Optional */
+ /* Acceleration Random Walk Spectral Density */
+ uint8_t accelerationRandomWalkSpectralDensity_valid; /**< Must be set to true if accelerationRandomWalkSpectralDensity is being passed */
+ float accelerationRandomWalkSpectralDensity;
+ /**< Specifies the acceleration random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The acceleration random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Meters/seconds^3/Hertz^0.5
+
+ */
+
+ /* Optional */
+ /* Angle Random Walk Spectral Density */
+ uint8_t angleRandomWalkSpectralDensity_valid; /**< Must be set to true if angleRandomWalkSpectralDensity is being passed */
+ float angleRandomWalkSpectralDensity;
+ /**< Specifies the angle random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The angle random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Radians/seconds/Hertz^0.5
+
+ */
+
+ /* Optional */
+ /* Rate Random Walk Spectral Density */
+ uint8_t rateRandomWalkSpectralDensity_valid; /**< Must be set to true if rateRandomWalkSpectralDensity is being passed */
+ float rateRandomWalkSpectralDensity;
+ /**< Specifies the rate random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The rate random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Radians/seconds^2/Hertz^0.5
+
+ */
+}qmiLocSetSensorPropertiesReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Sets the properties specific to the type of sensor used.
+ The control point must set sensor properties before they can be
+ used to aid in heading and positioning performance improvement.
+ */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Sensor Properties Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Sensor Properties request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \item 0x00000007 -- CONFIG_NOT_ SUPPORTED
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Failed Set Sensor Properties */
+ uint8_t failedSensorPropertiesMask_valid; /**< Must be set to true if failedSensorPropertiesMask is being passed */
+ qmiLocSensorPropertiesMaskT_v02 failedSensorPropertiesMask;
+ /**< This field is sent only if the status is not SUCCESS.
+ Identifies the parameters that were not set successfully.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- GYRO_BIAS_ VARIANCE_RANDOM_WALK
+ \item 0x00000002 -- VELOCITY_ RANDOM_WALK_SPECTRAL_ DENSITY
+ \item 0x00000004 -- ACCELERATION_ RANDOM_WALK_SPECTRAL_ DENSITY
+ \item 0x00000008 -- ANGLE_RANDOM_ WALK_SPECTRAL_DENSITY
+ \item 0x00000010 -- RATE_RANDOM_ WALK_SPECTRAL_DENSITY
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetSensorPropertiesIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Retrieves the current sensor properties. */
+typedef struct {
+
+ /* Mandatory */
+ /* Sensor Properties Config Parameters */
+ qmiLocSensorPropertiesMaskT_v02 getSensorPropertiesMask;
+ /**< Mask denoting the sensor properties parameters to be retrieved.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- GYRO_BIAS_ VARIANCE_RANDOM_WALK
+ \item 0x00000002 -- VELOCITY_ RANDOM_WALK_SPECTRAL_ DENSITY
+ \item 0x00000004 -- ACCELERATION_ RANDOM_WALK_SPECTRAL_ DENSITY
+ \item 0x00000008 -- ANGLE_RANDOM_ WALK_SPECTRAL_DENSITY
+ \item 0x00000010 -- RATE_RANDOM_ WALK_SPECTRAL_DENSITY
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocGetSensorPropertiesReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Retrieves the current sensor properties. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Sensor Properties Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Sensors Properties request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \item 0x00000007 -- CONFIG_NOT_ SUPPORTED
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Gyro Bias Random Walk Variance */
+ uint8_t gyroBiasVarianceRandomWalk_valid; /**< Must be set to true if gyroBiasVarianceRandomWalk is being passed */
+ float gyroBiasVarianceRandomWalk;
+ /**< Specifies the gyro bias random walk variance parameter as a positive
+ floating-point value. This value has internal default value 1.0e-5 radian^2/second^4.
+ The gyro bias variance random walk parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Radians^2/seconds^4
+
+ */
+
+ /* Optional */
+ /* Velocity Random Walk Spectral Density */
+ uint8_t velocityRandomWalkSpectralDensity_valid; /**< Must be set to true if velocityRandomWalkSpectralDensity is being passed */
+ float velocityRandomWalkSpectralDensity;
+ /**< Specifies the velocity random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The velocity random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Meters/seconds^2/Hertz^0.5
+
+ */
+
+ /* Optional */
+ /* Acceleration Random Walk Spectral Density */
+ uint8_t accelerationRandomWalkSpectralDensity_valid; /**< Must be set to true if accelerationRandomWalkSpectralDensity is being passed */
+ float accelerationRandomWalkSpectralDensity;
+ /**< Specifies the acceleration random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The acceleration random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Meters/seconds^3/Hertz^0.5
+
+ */
+
+ /* Optional */
+ /* Angle Random Walk Spectral Density */
+ uint8_t angleRandomWalkSpectralDensity_valid; /**< Must be set to true if angleRandomWalkSpectralDensity is being passed */
+ float angleRandomWalkSpectralDensity;
+ /**< Specifies the angle random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The angle random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Radians/seconds/Hertz^0.5
+
+ */
+
+ /* Optional */
+ /* Rate Random Walk Spectral Density */
+ uint8_t rateRandomWalkSpectralDensity_valid; /**< Must be set to true if rateRandomWalkSpectralDensity is being passed */
+ float rateRandomWalkSpectralDensity;
+ /**< Specifies the rate random walk spectral density parameter as a positive
+ floating-point value. This value does not have any internal defaults.
+ The rate random walk spectral density parameter is derived from either the
+ sensors data sheet or a sensors conformance test. \n
+ - Units: Radians/seconds^2/Hertz^0.5
+
+ */
+}qmiLocGetSensorPropertiesIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCSENSORPERFORMANCECONTROLMODEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_SENSOR_PERFORMANCE_CONTROL_MODE_AUTO_V02 = 0, /**< Sensors usage is to be determined by the GNSS location engine.
+ This mode can optimize power consumption and give a
+ power-balanced positioning and heading enhancement using
+ inertial sensors */
+ eQMI_LOC_SENSOR_PERFORMANCE_CONTROL_MODE_FORCED_V02 = 1, /**< Sensors usage is to be forced ON.
+ This mode can be requested by the control point when
+ power consumption is not a restriction to the use of
+ inertial sensors. */
+ QMILOCSENSORPERFORMANCECONTROLMODEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocSensorPerformanceControlModeEnumT_v02;
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocSensorAlgorithmMaskT_v02;
+#define QMI_LOC_SENSOR_ALGORITHM_MASK_DISABLE_INS_POSITIONING_FILTER_V02 ((qmiLocSensorAlgorithmMaskT_v02)0x00000001) /**< Inertial sensors are not to be used in Accelerometer-integrated fashion with
+ GNSS. They can still be used for aiding in heading improvements. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Provides fine-grained control of sensor based positioning
+ performance. */
+typedef struct {
+
+ /* Optional */
+ /* Sensor Performance Control Mode */
+ uint8_t performanceControlMode_valid; /**< Must be set to true if performanceControlMode is being passed */
+ qmiLocSensorPerformanceControlModeEnumT_v02 performanceControlMode;
+ /**< Controls when sensors data is requested during GNSS fix processing.
+ This field is relevant only when sensors have been enabled using the
+ sensors control configuration.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- AUTO: \n
+ The GNSS location engine can decide when to request sensor data
+ injection based on internal criteria. This is the default.
+ \item 0x00000001 -- FORCED: \n
+ The GNSS location engine must request use of sensors every time
+ the GNSS location engine turns on.
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Accelerometer Sampling Specification */
+ uint8_t accelSamplingSpec_valid; /**< Must be set to true if accelSamplingSpec is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 accelSamplingSpec;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location
+ engine is to request acceleration data to be used by the low data rate
+ filter. The sensor data rate is specified in terms of the nominal number
+ of samples per batch and the number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 10 Hz sampling rate and 2 Hz batching rate.
+ */
+
+ /* Optional */
+ /* Gyroscope Sampling Specification */
+ uint8_t gyroSamplingSpec_valid; /**< Must be set to true if gyroSamplingSpec is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 gyroSamplingSpec;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location
+ engine is to request gyro data to be used by the high data rate filter.
+ The sensor data rate is specified in terms of the nominal number of
+ samples per batch and the number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 10 Hz sampling rate and 2 Hz batching rate.
+ */
+
+ /* Optional */
+ /* Algorithm Configuration */
+ uint8_t algorithmConfig_valid; /**< Must be set to true if algorithmConfig is being passed */
+ qmiLocSensorAlgorithmMaskT_v02 algorithmConfig;
+ /**< Sets which sensor algorithms are to be used when processing sensor data.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- DISABLE_INS_ POSITIONING_FILTER
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* High Data Rate Filter Accelerometer Sampling Specification */
+ uint8_t accelSamplingSpecHigh_valid; /**< Must be set to true if accelSamplingSpecHigh is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 accelSamplingSpecHigh;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location engine is to request
+ acceleration data to be used by the high data rate filter. The sensor
+ data rate is specified in terms of the nominal number of samples per
+ batch and the number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 100 Hz sampling rate and 4 Hz batching rate.
+ */
+
+ /* Optional */
+ /* High Data Rate Filter Gyroscope Sampling Specification */
+ uint8_t gyroSamplingSpecHigh_valid; /**< Must be set to true if gyroSamplingSpecHigh is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 gyroSamplingSpecHigh;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location engine is to request
+ gyro data to be used by the high data rate filter. The sensor data rate
+ is specified in terms of the nominal number of samples per batch and the
+ number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 100 Hz sampling rate and 4 Hz batching rate.
+ */
+}qmiLocSetSensorPerformanceControlConfigReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocSensorPerformanceControlConfigFailureMaskT_v02;
+#define QMI_LOC_SENSOR_PERFORMANCE_CONTROL_CONFIG_PARAM_MASK_PERFORMANCE_MODE_V02 ((qmiLocSensorPerformanceControlConfigFailureMaskT_v02)0x00000001) /**< Failed to set the performance mode. */
+#define QMI_LOC_SENSOR_PERFORMANCE_CONTROL_CONFIG_PARAM_MASK_ACCEL_SAMPLING_SPEC_V02 ((qmiLocSensorPerformanceControlConfigFailureMaskT_v02)0x00000002) /**< Failed to set the accelerometer sampling specification. */
+#define QMI_LOC_SENSOR_PERFORMANCE_CONTROL_CONFIG_PARAM_MASK_GYRO_SAMPLING_SPEC_V02 ((qmiLocSensorPerformanceControlConfigFailureMaskT_v02)0x00000004) /**< Failed to set the gyroscope sampling specification. */
+#define QMI_LOC_SENSOR_PERFORMANCE_CONTROL_CONFIG_PARAM_MASK_ALGORITHM_CONFIG_V02 ((qmiLocSensorPerformanceControlConfigFailureMaskT_v02)0x00000008) /**< Failed to set the algorithm configuration */
+#define QMI_LOC_SENSOR_PERFORMANCE_CONTROL_CONFIG_PARAM_MASK_ACCEL_SAMPLING_SPEC_HIGH_V02 ((qmiLocSensorPerformanceControlConfigFailureMaskT_v02)0x00000010) /**< Failed to set the accelerometer sampling specification. */
+#define QMI_LOC_SENSOR_PERFORMANCE_CONTROL_CONFIG_PARAM_MASK_GYRO_SAMPLING_SPEC_HIGH_V02 ((qmiLocSensorPerformanceControlConfigFailureMaskT_v02)0x00000020) /**< Failed to set the gyroscope sampling specification. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Provides fine-grained control of sensor based positioning
+ performance. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Sensor Perf Control Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Sensor Performance Control Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Failed Configuration */
+ uint8_t failedConfiguration_valid; /**< Must be set to true if failedConfiguration is being passed */
+ qmiLocSensorPerformanceControlConfigFailureMaskT_v02 failedConfiguration;
+ /**< Identifies parameters that were not configured successfully. This field
+ is sent only if the status is not a success.
+
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- PERFORMANCE_ MODE
+ \item 0x00000002 -- ACCEL_SAMPLING_ SPEC
+ \item 0x00000004 -- GYRO_SAMPLING_ SPEC
+ \item 0x00000008 -- ALGORITHM_ CONFIG
+ \item 0x00000010 -- ACCEL_SAMPLING_ SPEC_HIGH
+ \item 0x00000020 -- GYRO_SAMPLING_ SPEC_HIGH
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocSetSensorPerformanceControlConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocGetSensorPerformanceControlConfigReqMsgT is empty
+ * typedef struct {
+ * }qmiLocGetSensorPerformanceControlConfigReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Retrieves the current sensor performance control
+ configuration. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Sensor Perf Control Config Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Sensor Performance Control Configuration request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Performance Control Mode */
+ uint8_t performanceControlMode_valid; /**< Must be set to true if performanceControlMode is being passed */
+ qmiLocSensorPerformanceControlModeEnumT_v02 performanceControlMode;
+ /**< Controls when sensor data is requested during GNSS fix processing.
+ This field is relevant only when sensors have been enabled using the
+ sensor control configuration.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- AUTO: \n
+ The GNSS location engine can decide when to request sensor data
+ injection based on internal criteria. This is the default.
+ \item 0x0000001 -- FORCED: \n
+ The GNSS location engine must request use of the sensors every time
+ the GNSS location engine turns on.
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Accelerometer Sampling Specification */
+ uint8_t accelSamplingSpec_valid; /**< Must be set to true if accelSamplingSpec is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 accelSamplingSpec;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location engine is to request
+ acceleration data to be used by the high data rate filter. The sensor
+ data rate is specified in terms of the nominal number of samples per
+ batch and the number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 10 Hz sampling rate and 2Hz batching rate.
+ */
+
+ /* Optional */
+ /* Gyroscope Sampling Specification */
+ uint8_t gyroSamplingSpec_valid; /**< Must be set to true if gyroSamplingSpec is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 gyroSamplingSpec;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location engine is to request
+ gyro data to be used by the high data rate filter. The sensor data
+ rate is specified in terms of the nominal number of samples per batch
+ and the number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 10 Hz sampling rate and 2 Hz batching rate.
+ */
+
+ /* Optional */
+ /* Algorithm Configuration */
+ uint8_t algorithmConfig_valid; /**< Must be set to true if algorithmConfig is being passed */
+ qmiLocSensorAlgorithmMaskT_v02 algorithmConfig;
+ /**< Informs which sensor algorithms are currently set.
+
+ Valid bitmasks: \begin{itemize1}
+ \item 0x00000001 -- DISABLE_INS_ POSITIONING_FILTER
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* High Data Rate Filter Accelerometer Sampling Specification */
+ uint8_t accelSamplingSpecHigh_valid; /**< Must be set to true if accelSamplingSpecHigh is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 accelSamplingSpecHigh;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location engine is to request
+ acceleration data to be used by the high data rate filter. The sensor
+ data rate is specified in terms of the nominal number of samples per
+ batch and the number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 100 Hz sampling rate and 4 Hz batching rate.
+ */
+
+ /* Optional */
+ /* High Data Rate Filter Gyroscope Sampling Specification */
+ uint8_t gyroSamplingSpecHigh_valid; /**< Must be set to true if gyroSamplingSpecHigh is being passed */
+ qmiLocSensorControlConfigSamplingSpecStructT_v02 gyroSamplingSpecHigh;
+ /**< \vspace{0.06in} \n Sets the nominal rate at which the GNSS location engine is to request
+ gyro data to be used by the high data rate filter. The sensor data rate
+ is specified in terms of the nominal number of samples per batch and the
+ number of batches per second.
+ However, the final control of the actual requested rate resides with
+ the Sensors Manager Module/GNSS location engine. \n
+ Default: 100 Hz sampling rate and 4 Hz batching rate.
+ */
+}qmiLocGetSensorPerformanceControlConfigIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects a SUPL certificate to be used in AGNSS sessions. */
+typedef struct {
+
+ /* Mandatory */
+ /* SUPL Certificate ID */
+ uint8_t suplCertId;
+ /**< Certificate ID of the SUPL certificate. \n
+ - Units: Bytes \n
+ - Range: 0 to 9 */
+
+ /* Mandatory */
+ /* SUPL Certificate Data */
+ uint32_t suplCertData_len; /**< Must be set to # of elements in suplCertData */
+ uint8_t suplCertData[QMI_LOC_MAX_SUPL_CERT_LENGTH_V02];
+ /**< SUPL certificate contents. \n
+ - Type: Array of bytes. \n
+ - Maximum certificate size: 2000 bytes */
+}qmiLocInjectSuplCertificateReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects a SUPL certificate to be used in AGNSS sessions. */
+typedef struct {
+
+ /* Mandatory */
+ /* SUPL Certificate Injection Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject SUPL Certificate request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectSuplCertificateIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Deletes a SUPL certificate. */
+typedef struct {
+
+ /* Optional */
+ /* SUPL Certificate ID */
+ uint8_t suplCertId_valid; /**< Must be set to true if suplCertId is being passed */
+ uint8_t suplCertId;
+ /**< Certificate ID of the SUPL certificate to be deleted. \n
+ - Units: Bytes \n
+ - Range: 0 to 9 \n
+ If suplCertId is not specified,
+ all SUPL certificates are deleted. */
+}qmiLocDeleteSuplCertificateReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Deletes a SUPL certificate. */
+typedef struct {
+
+ /* Mandatory */
+ /* SUPL Certificate Deletion Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Delete SUPL Certificate request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocDeleteSuplCertificateIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocPositionEngineConfigParamMaskT_v02;
+#define QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_INJECTED_POSITION_CONTROL_V02 ((qmiLocPositionEngineConfigParamMaskT_v02)0x00000001) /**< Denotes whether the position engine uses the
+ injected position in a direct position calculation. */
+#define QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_FILTER_SV_USAGE_V02 ((qmiLocPositionEngineConfigParamMaskT_v02)0x00000002) /**< Denotes whether the position engine filters the
+ SV usage in the fix. */
+#define QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_STORE_ASSIST_DATA_V02 ((qmiLocPositionEngineConfigParamMaskT_v02)0x00000004) /**< Denotes whether the position engine stores assistance data
+ in persistent memory. */
+#define QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_ENABLE_FASTER_TTFF_V02 ((qmiLocPositionEngineConfigParamMaskT_v02)0x00000008) /**< Denotes whether the position engine stays on to optimize
+ the TTFF for the subsequent position fix. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to configure position engine
+ functionality. */
+typedef struct {
+
+ /* Optional */
+ /* Injected Position Control */
+ uint8_t injectedPositionControl_valid; /**< Must be set to true if injectedPositionControl is being passed */
+ uint8_t injectedPositionControl;
+ /**< Controls how the injected position is used in the position engine.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Use the injected position in a direct position
+ calculation
+ \item 0x00 (FALSE) -- Do not use the injected position in a direct
+ position calculation
+ \end{itemize1}
+ The default value is TRUE.
+ */
+
+ /* Optional */
+ /* Filter SV Usage */
+ uint8_t filterSvUsage_valid; /**< Must be set to true if filterSvUsage is being passed */
+ uint8_t filterSvUsage;
+ /**< Controls whether SV usage is filtered in a position fix.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Filter the usage of SVs in the fix
+ \item 0x00 (FALSE) -- Do not filter the usage of SVs in the fix
+ \end{itemize1}
+ The default value is FALSE.
+ */
+
+ /* Optional */
+ /* Store Assist Data */
+ uint8_t storeAssistData_valid; /**< Must be set to true if storeAssistData is being passed */
+ uint8_t storeAssistData;
+ /**< Controls whether assistance data is to be stored in
+ persistent memory.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Store assistance data in persistent memory
+ \item 0x00 (FALSE) -- Do not store assistance data in persistent memory
+ \end{itemize1}
+ The default value is TRUE.
+ */
+
+ /* Optional */
+ /* Enable Faster TTFF */
+ uint8_t enableFasterTTFF_valid; /**< Must be set to true if enableFasterTTFF is being passed */
+ uint8_t enableFasterTTFF;
+ /**< Allows the receiver to stay on after a position session in order to
+ collect information that will help reduce the Time To First Fix (TTFF)
+ when the next position request is made. The receiver will stay
+ on only if the engine determines that it needs to collect some
+ information. The receiver will stay on for the duration needed to
+ collect the information.
+ If enabled, the clients may see a delay in receiving the Engine Off
+ event after the position session ends.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Allow the engine to stay on for reduced TTFF
+ \item 0x00 (FALSE) -- Do not allow the engine to stay on for reduced
+ TTFF
+ \end{itemize1}
+ The default value is TRUE.*/
+}qmiLocSetPositionEngineConfigParametersReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to configure position engine
+ functionality. */
+typedef struct {
+
+ /* Mandatory */
+ /* Set Position Engine Configuration Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Set Configuration Parameters request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Failed Parameters */
+ uint8_t failedPositionEngineConfigParamMask_valid; /**< Must be set to true if failedPositionEngineConfigParamMask is being passed */
+ qmiLocPositionEngineConfigParamMaskT_v02 failedPositionEngineConfigParamMask;
+ /**< Identifies the parameters that were not set successfully.
+ This field is sent only if the status is other than SUCCESS.
+
+ Valid bitmasks:\n
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_INJECTED_POSITION_CONTROL (0x00000001) -- Denotes whether the position engine uses the
+ injected position in a direct position calculation.
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_FILTER_SV_USAGE (0x00000002) -- Denotes whether the position engine filters the
+ SV usage in the fix.
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_STORE_ASSIST_DATA (0x00000004) -- Denotes whether the position engine stores assistance data
+ in persistent memory.
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_ENABLE_FASTER_TTFF (0x00000008) -- Denotes whether the position engine stays on to optimize
+ the TTFF for the subsequent position fix.
+ */
+}qmiLocSetPositionEngineConfigParametersIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to get the position engine
+ configuration parameters. */
+typedef struct {
+
+ /* Mandatory */
+ /* Config Parameters */
+ qmiLocPositionEngineConfigParamMaskT_v02 getPositionEngineConfigParamMask;
+ /**< Mask denoting the configuration parameters to be retrieved.
+
+ Valid bitmasks:
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_INJECTED_POSITION_CONTROL (0x00000001) -- Denotes whether the position engine uses the
+ injected position in a direct position calculation.
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_FILTER_SV_USAGE (0x00000002) -- Denotes whether the position engine filters the
+ SV usage in the fix.
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_STORE_ASSIST_DATA (0x00000004) -- Denotes whether the position engine stores assistance data
+ in persistent memory.
+ - QMI_LOC_POSITION_ENGINE_CONFIG_PARAM_MASK_ENABLE_FASTER_TTFF (0x00000008) -- Denotes whether the position engine stays on to optimize
+ the TTFF for the subsequent position fix.
+ */
+}qmiLocGetPositionEngineConfigParametersReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to get the position engine
+ configuration parameters. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Position Engine Configuration Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Configuration Parameters request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Injected Position Control */
+ uint8_t injectedPositionControl_valid; /**< Must be set to true if injectedPositionControl is being passed */
+ uint8_t injectedPositionControl;
+ /**< Specifies whether the injected position is used for a direct calculation
+ in the position engine.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- The injected position is used in a direct
+ position calculation
+ \item 0x00 (FALSE) -- The injected position is not used in a direct
+ position calculation
+ \end{itemize1}
+ The default value is TRUE.
+ */
+
+ /* Optional */
+ /* Filter SV Usage */
+ uint8_t filterSvUsage_valid; /**< Must be set to true if filterSvUsage is being passed */
+ uint8_t filterSvUsage;
+ /**< Specifies whether SV usage is filtered in a position fix.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- SV usage is filtered in the fix
+ \item 0x00 (FALSE) -- SV usage is not filtered in the fix
+ \end{itemize1}
+ The default value is FALSE.
+ */
+
+ /* Optional */
+ /* Store Assist Data */
+ uint8_t storeAssistData_valid; /**< Must be set to true if storeAssistData is being passed */
+ uint8_t storeAssistData;
+ /**< Specifies whether assistance data is stored in persistent memory.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Assistance data is stored in persistent memory
+ \item 0x00 (FALSE) -- Assistance data is not stored in persistent
+ memory
+ \end{itemize1}
+ The default value is TRUE.
+ */
+
+ /* Optional */
+ /* Enable Faster TTFF */
+ uint8_t enableFasterTTFF_valid; /**< Must be set to true if enableFasterTTFF is being passed */
+ uint8_t enableFasterTTFF;
+ /**< Allows the receiver to stay on after a position session in order to
+ collect information that will help reduce the TTFF
+ when the next position request is made. The receiver will stay
+ on only if the engine determines that it needs to collect some
+ information. The receiver will stay on for the duration needed to
+ collect the information.
+ If enabled, the clients may see a delay in receiving the Engine Off
+ event after the position session ends.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Allow the engine to stay on for reduced TTFF
+ \item 0x00 (FALSE) -- Do not allow the engine to stay on for reduced
+ TTFF
+ \end{itemize1}
+ The default value is TRUE.*/
+}qmiLocGetPositionEngineConfigParametersIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint8_t qmiLocGeofenceBreachMaskT_v02;
+#define QMI_LOC_GEOFENCE_BREACH_ENTERING_MASK_V02 ((qmiLocGeofenceBreachMaskT_v02)0x01) /**< If this mask is set, a breach event is reported
+ when the Geofence is entered. */
+#define QMI_LOC_GEOFENCE_BREACH_LEAVING_MASK_V02 ((qmiLocGeofenceBreachMaskT_v02)0x02) /**< If this mask is set, a breach event is reported
+ when the Geofence is exited. */
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCERESPONSIVENESSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_RESPONSIVENESS_LOW_V02 = 0x01, /**< The Geofence is monitored for a breach at a
+ lower rate. The gap between actual breach and
+ the time it is reported is higher. This
+ setting results in lower power usage. */
+ eQMI_LOC_GEOFENCE_RESPONSIVENESS_MED_V02 = 0x02, /**< The Geofence is monitored for a breach at a
+ medium rate. This is the default setting. */
+ eQMI_LOC_GEOFENCE_RESPONSIVENESS_HIGH_V02 = 0x03, /**< The Geofence is monitored for a breach at a
+ high rate. The gap between actual breach and
+ the time it is reported is low. This results
+ in higher power usage. */
+ QMILOCGEOFENCERESPONSIVENESSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofenceResponsivenessEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCECONFIDENCEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_CONFIDENCE_LOW_V02 = 0x01, /**< The Geofence engine indicates a breach with
+ low confidence. This setting results in lower
+ power usage. This setting can impact the "yield" because
+ incorrect breach events may be sent. */
+ eQMI_LOC_GEOFENCE_CONFIDENCE_MED_V02 = 0x02, /**< The Geofence engine indicates a breach with
+ medium confidence. This is the default setting. */
+ eQMI_LOC_GEOFENCE_CONFIDENCE_HIGH_V02 = 0x03, /**< The Geofence engine indicates a breach with
+ high confidence. This setting results in higher
+ power usage. */
+ QMILOCGEOFENCECONFIDENCEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofenceConfidenceEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ double latitude;
+ /**< Latitude of the center of the Geofence.*/
+
+ double longitude;
+ /**< Longitude of the center of the Geofence.*/
+
+ uint32_t radius;
+ /**< Radius of the circular Geofence in meters. */
+}qmiLocCircularGeofenceArgsStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCEPOSITIONENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_POSITION_INSIDE_V02 = 0x01, /**< Position inside a Geofence. */
+ eQMI_LOC_GEOFENCE_POSITION_OUTSIDE_V02 = 0x02, /**< Position outside a Geofence. */
+ QMILOCGEOFENCEPOSITIONENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofencePositionEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to add a circular Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Transaction ID */
+ uint32_t transactionId;
+ /**< Identifies the transaction. The transaction ID
+ is returned in the Add Circular Geofence
+ indication. */
+
+ /* Mandatory */
+ /* Circular Geofence Arguments */
+ qmiLocCircularGeofenceArgsStructT_v02 circularGeofenceArgs;
+
+ /* Mandatory */
+ /* Breach Event Mask */
+ qmiLocGeofenceBreachMaskT_v02 breachMask;
+ /**< Specifies the breach events in which the client is interested.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 -- GEOFENCE_BREACH_ ENTERING_MASK
+ \item 0x02 -- GEOFENCE_BREACH_ LEAVING_MASK
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Mandatory */
+ /* Include Position in Breach Event */
+ uint8_t includePosition;
+ /**< Specifies whether the Geofence engine is to include the position
+ in a breach event.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 (TRUE) -- Position will be reported with the breach event
+ \item 0x00 (FALSE) -- Position will not be reported with the breach
+ event
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Responsiveness */
+ uint8_t responsiveness_valid; /**< Must be set to true if responsiveness is being passed */
+ qmiLocGeofenceResponsivenessEnumT_v02 responsiveness;
+ /**< Specifies the rate of detection for a Geofence breach.
+ This may impact the time lag between the actual breach event and
+ when it is reported. This parameter has power implications
+ and is to be fine-tuned to optimize power savings.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_ RESPONSIVENESS_LOW
+ \item 0x00000002 -- GEOFENCE_ RESPONSIVENESS_MED
+ \item 0x00000003 -- GEOFENCE_ RESPONSIVENESS_HIGH
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Confidence */
+ uint8_t confidence_valid; /**< Must be set to true if confidence is being passed */
+ qmiLocGeofenceConfidenceEnumT_v02 confidence;
+ /**< Given a breach event, the confidence determines the probability
+ that the breach happened at the Geofence boundary.
+ This parameter has power implications and
+ is to be fine-tuned to optimize power savings.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_ CONFIDENCE_LOW
+ \item 0x00000002 -- GEOFENCE_ CONFIDENCE_MED
+ \item 0x00000003 -- GEOFENCE_ CONFIDENCE_HIGH
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocAddCircularGeofenceReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to add a circular Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Add Circular Geofence Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Add Circular Geofence request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \item 0x00000008 -- INSUFFICIENT_ MEMORY
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Transaction ID */
+ uint8_t transactionId_valid; /**< Must be set to true if transactionId is being passed */
+ uint32_t transactionId;
+ /**< Transaction ID that was specified in the Add Circular
+ Geofence request. This parameter will always be present
+ if the status field is set to SUCCESS. */
+
+ /* Optional */
+ /* Geofence ID */
+ uint8_t geofenceId_valid; /**< Must be set to true if geofenceId is being passed */
+ uint32_t geofenceId;
+ /**< Geofence identifier allocated by the engine.
+ The client must include this identifier in all transactions
+ pertaining to this Geofence. */
+}qmiLocAddCircularGeofenceIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to delete a Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Geofence ID */
+ uint32_t geofenceId;
+ /**< Identifier for the Geofence that is to be deleted. */
+
+ /* Mandatory */
+ /* Transaction ID */
+ uint32_t transactionId;
+ /**< Identifies the transaction. The transaction ID
+ is returned in the Delete Geofence
+ indication. */
+}qmiLocDeleteGeofenceReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to delete a Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Delete Geofence Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Delete Geofence request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Geofence ID */
+ uint8_t geofenceId_valid; /**< Must be set to true if geofenceId is being passed */
+ uint32_t geofenceId;
+ /**< Identifier for the Geofence that was deleted. */
+
+ /* Optional */
+ /* Transaction ID */
+ uint8_t transactionId_valid; /**< Must be set to true if transactionId is being passed */
+ uint32_t transactionId;
+ /**< Transaction ID that was specified in the Delete
+ Geofence request. This parameter will always be present
+ if the status field is set to SUCCESS. */
+}qmiLocDeleteGeofenceIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCEORIGINENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_ORIGIN_NETWORK_V02 = 1, /**< The Geofence was initiated by a network-initiated client. */
+ eQMI_LOC_GEOFENCE_ORIGIN_DEVICE_V02 = 2, /**< The Geofence was initiated by the device. */
+ QMILOCGEOFENCEORIGINENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofenceOriginEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCGEOFENCESTATEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_GEOFENCE_STATE_ACTIVE_V02 = 1, /**< The Geofence is being actively monitored. */
+ eQMI_LOC_GEOFENCE_STATE_SUSPEND_V02 = 2, /**< The Geofence monitoring is suspended. */
+ QMILOCGEOFENCESTATEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocGeofenceStateEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to query a Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Geofence ID */
+ uint32_t geofenceId;
+ /**< Identifier for the Geofence that is to be queried. */
+
+ /* Mandatory */
+ /* Transaction ID */
+ uint32_t transactionId;
+ /**< Identifies the transaction. The transaction ID
+ is returned with the Query Geofence
+ indication. */
+}qmiLocQueryGeofenceReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to query a Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Query Geofence Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Query Geofence request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Geofence ID */
+ uint8_t geofenceId_valid; /**< Must be set to true if geofenceId is being passed */
+ uint32_t geofenceId;
+ /**< Identifier for the Geofence that was queried. */
+
+ /* Optional */
+ /* Transaction ID */
+ uint8_t transactionId_valid; /**< Must be set to true if transactionId is being passed */
+ uint32_t transactionId;
+ /**< Transaction ID that was specified in the Query
+ Geofence request. This parameter will always be present
+ if the status field is set to SUCCESS. */
+
+ /* Optional */
+ /* Geofence Origin */
+ uint8_t geofenceOrigin_valid; /**< Must be set to true if geofenceOrigin is being passed */
+ qmiLocGeofenceOriginEnumT_v02 geofenceOrigin;
+ /**< Originator of the Geofence.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_ ORIGIN_NETWORK
+ \item 0x00000002 -- GEOFENCE_ ORIGIN_DEVICE
+ \vspace{-0.18in} \end{itemize1}
+ */
+
+ /* Optional */
+ /* Position with Respect to Geofence */
+ uint8_t posWrtGeofence_valid; /**< Must be set to true if posWrtGeofence is being passed */
+ qmiLocGeofencePositionEnumT_v02 posWrtGeofence;
+ /**< Indicates if the client is currently inside or outside
+ the Geofence.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_ POSITION_INSIDE
+ \item 0x00000002 -- GEOFENCE_ POSITION_OUTSIDE
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Circular Geofence Parameters */
+ uint8_t circularGeofenceArgs_valid; /**< Must be set to true if circularGeofenceArgs is being passed */
+ qmiLocCircularGeofenceArgsStructT_v02 circularGeofenceArgs;
+
+ /* Optional */
+ /* Geofence State */
+ uint8_t geofenceState_valid; /**< Must be set to true if geofenceState is being passed */
+ qmiLocGeofenceStateEnumT_v02 geofenceState;
+ /**< Specifies whether the Geofence is to be actively monitored.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_STATE_ ACTIVE
+ \item 0x00000002 -- GEOFENCE_STATE_ SUSPEND
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocQueryGeofenceIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to edit a Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Geofence ID */
+ uint32_t geofenceId;
+ /**< Identifier for the Geofence to be edited. */
+
+ /* Mandatory */
+ /* Transaction ID */
+ uint32_t transactionId;
+ /**< Transaction ID that was specified in the Edit Geofence
+ request. This parameter will always be present if the
+ status field is set to SUCCESS.
+ */
+
+ /* Optional */
+ /* Geofence State */
+ uint8_t geofenceState_valid; /**< Must be set to true if geofenceState is being passed */
+ qmiLocGeofenceStateEnumT_v02 geofenceState;
+ /**< Specifies whether the Geofence is to be actively monitored.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_STATE_ ACTIVE
+ \item 0x00000002 -- GEOFENCE_STATE_ SUSPEND
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Breach Event Mask */
+ uint8_t breachMask_valid; /**< Must be set to true if breachMask is being passed */
+ qmiLocGeofenceBreachMaskT_v02 breachMask;
+ /**< Specifies the breach events in which the client is interested.
+
+ Valid values: \begin{itemize1}
+ \item 0x01 -- GEOFENCE_BREACH_ ENTERING_MASK
+ \item 0x02 -- GEOFENCE_BREACH_ LEAVING_MASK
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocEditGeofenceReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+typedef uint32_t qmiLocGeofenceConfigParamMaskT_v02;
+#define QMI_LOC_GEOFENCE_PARAM_MASK_GEOFENCE_STATE_V02 ((qmiLocGeofenceConfigParamMaskT_v02)0x00000001) /**< Mask for the Geofence state parameter. */
+#define QMI_LOC_GEOFENCE_PARAM_MASK_BREACH_MASK_V02 ((qmiLocGeofenceConfigParamMaskT_v02)0x00000002) /**< Mask for Geofence breach mask parameter. */
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to edit a Geofence. */
+typedef struct {
+
+ /* Mandatory */
+ /* Edit Geofence Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Edit Geofence request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Geofence ID */
+ uint8_t geofenceId_valid; /**< Must be set to true if geofenceId is being passed */
+ uint32_t geofenceId;
+ /**< Identifier for the Geofence that was edited. */
+
+ /* Optional */
+ /* Transaction ID */
+ uint8_t transactionId_valid; /**< Must be set to true if transactionId is being passed */
+ uint32_t transactionId;
+ /**< Identifies the transaction. The transaction ID
+ is specified in the Edit Geofence request. */
+
+ /* Optional */
+ /* Failed Parameters */
+ uint8_t failedParams_valid; /**< Must be set to true if failedParams is being passed */
+ qmiLocGeofenceConfigParamMaskT_v02 failedParams;
+ /**< Specified only when the status is not set to SUCCESS. If
+ the mask corresponding to a field is set, it indicates that
+ the Geofence parameter could not be edited.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000001 -- GEOFENCE_PARAM_ MASK_GEOFENCE_STATE
+ \item 0x00000002 -- GEOFENCE_PARAM_ MASK_BREACH_MASK
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocEditGeofenceIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to get the best available
+ position estimate from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Transaction ID */
+ uint32_t transactionId;
+ /**< Identifies the transaction. The transaction ID
+ is returned in the Get Best Available Position indication. */
+}qmiLocGetBestAvailablePositionReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to get the best available
+ position estimate from the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get Best Available Position Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get Best Available Position request.
+
+ Valid values: \n
+ - 0x00000000 -- SUCCESS \n
+ - 0x00000001 -- GENERAL_FAILURE \n
+ - 0x00000002 -- UNSUPPORTED \n
+ - 0x00000004 -- ENGINE_BUSY \n
+ - 0x00000006 -- TIMEOUT */
+
+ /* Optional */
+ /* Transaction ID */
+ uint8_t transactionId_valid; /**< Must be set to true if transactionId is being passed */
+ uint32_t transactionId;
+ /**< Transaction ID that was specified in the Get Best
+ Available Position request. This parameter will
+ always be present if the status field is set to
+ SUCCESS. */
+
+ /* Optional */
+ /* Latitude */
+ uint8_t latitude_valid; /**< Must be set to true if latitude is being passed */
+ double latitude;
+ /**< Latitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -90.0 to 90.0 \begin{itemize1}
+ \item Positive values indicate northern latitude
+ \item Negative values indicate southern latitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Optional */
+ /* Longitude */
+ uint8_t longitude_valid; /**< Must be set to true if longitude is being passed */
+ double longitude;
+ /**< Longitude (specified in WGS84 datum).
+ \begin{itemize1}
+ \item Type: Floating point
+ \item Units: Degrees
+ \item Range: -180.0 to 180.0 \begin{itemize1}
+ \item Positive values indicate eastern longitude
+ \item Negative values indicate western longitude
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+
+ /* Optional */
+ /* Circular Horizontal Position Uncertainty */
+ uint8_t horUncCircular_valid; /**< Must be set to true if horUncCircular is being passed */
+ float horUncCircular;
+ /**< Horizontal position uncertainty (circular).\n
+ - Units: Meters */
+
+ /* Optional */
+ /* Altitude With Respect to Ellipsoid */
+ uint8_t altitudeWrtEllipsoid_valid; /**< Must be set to true if altitudeWrtEllipsoid is being passed */
+ float altitudeWrtEllipsoid;
+ /**< Altitude with respect to the WGS84 ellipsoid.\n
+ - Units: Meters \n
+ - Range: -500 to 15883 */
+
+ /* Optional */
+ /* Vertical Uncertainty */
+ uint8_t vertUnc_valid; /**< Must be set to true if vertUnc is being passed */
+ float vertUnc;
+ /**< Vertical uncertainty.\n
+ - Units: Meters */
+
+ /* Optional */
+ /* UTC Timestamp */
+ uint8_t timestampUtc_valid; /**< Must be set to true if timestampUtc is being passed */
+ uint64_t timestampUtc;
+ /**< UTC timestamp.
+ \begin{itemize1}
+ \item Units: Milliseconds since Jan. 1, 1970
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Time Uncertainty */
+ uint8_t timeUnc_valid; /**< Must be set to true if timeUnc is being passed */
+ float timeUnc;
+ /**< Time uncertainty. \n
+ - Units: Milliseconds */
+
+ /* Optional */
+ /* Horizontal Elliptical Uncertainty Semi-Minor Axis */
+ uint8_t horUncEllipseSemiMinor_valid; /**< Must be set to true if horUncEllipseSemiMinor is being passed */
+ float horUncEllipseSemiMinor;
+ /**< Semi-minor axis of horizontal elliptical uncertainty. \n
+ - Units: Meters */
+
+ /* Optional */
+ /* Horizontal Elliptical Uncertainty Semi-Major Axis */
+ uint8_t horUncEllipseSemiMajor_valid; /**< Must be set to true if horUncEllipseSemiMajor is being passed */
+ float horUncEllipseSemiMajor;
+ /**< Semi-major axis of horizontal elliptical uncertainty. \n
+ - Units: Meters */
+
+ /* Optional */
+ /* Horizontal Elliptical Uncertainty Azimuth */
+ uint8_t horUncEllipseOrientAzimuth_valid; /**< Must be set to true if horUncEllipseOrientAzimuth is being passed */
+ float horUncEllipseOrientAzimuth;
+ /**< Elliptical horizontal uncertainty azimuth of orientation. \n
+ - Units: Decimal degrees \n
+ - Range: 0 to 180 */
+
+ /* Optional */
+ /* Horizontal Circular Confidence */
+ uint8_t horCircularConfidence_valid; /**< Must be set to true if horCircularConfidence is being passed */
+ uint8_t horCircularConfidence;
+ /**< Horizontal circular uncertainty confidence. \n
+ - Units: Percent \n
+ - Range: 0 to 99 */
+
+ /* Optional */
+ /* Horizontal Elliptical Confidence */
+ uint8_t horEllipticalConfidence_valid; /**< Must be set to true if horEllipticalConfidence is being passed */
+ uint8_t horEllipticalConfidence;
+ /**< Horizontal elliptical uncertainty confidence. \n
+ - Units: Percent \n
+ - Range: 0 to 99 */
+
+ /* Optional */
+ /* Horizontal Reliability */
+ uint8_t horReliability_valid; /**< Must be set to true if horReliability is being passed */
+ qmiLocReliabilityEnumT_v02 horReliability;
+ /**< Specifies the reliability of the horizontal position.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- RELIABILITY_NOT_ SET
+ \item 0x00000001 -- RELIABILITY_ VERY_LOW
+ \item 0x00000002 -- RELIABILITY_LOW
+ \item 0x00000003 -- RELIABILITY_ MEDIUM
+ \item 0x00000004 -- RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Horizontal Speed */
+ uint8_t horSpeed_valid; /**< Must be set to true if horSpeed is being passed */
+ float horSpeed;
+ /**< Horizontal speed. \n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Horizontal Speed Uncertainty */
+ uint8_t horSpeedUnc_valid; /**< Must be set to true if horSpeedUnc is being passed */
+ float horSpeedUnc;
+ /**< Horizontal speed uncertainty. \n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Altitude With Respect to Sea Level */
+ uint8_t altitudeWrtMeanSeaLevel_valid; /**< Must be set to true if altitudeWrtMeanSeaLevel is being passed */
+ float altitudeWrtMeanSeaLevel;
+ /**< Altitude with respect to mean sea level. \n
+ - Units: Meters */
+
+ /* Optional */
+ /* Vertical Confidence */
+ uint8_t vertConfidence_valid; /**< Must be set to true if vertConfidence is being passed */
+ uint8_t vertConfidence;
+ /**< Vertical uncertainty confidence. \n
+ - Units: Percent \n
+ - Range: 0 to 99 */
+
+ /* Optional */
+ /* Vertical Reliability */
+ uint8_t vertReliability_valid; /**< Must be set to true if vertReliability is being passed */
+ qmiLocReliabilityEnumT_v02 vertReliability;
+ /**< Specifies the reliability of the vertical position.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- RELIABILITY_NOT_ SET
+ \item 0x00000001 -- RELIABILITY_ VERY_LOW
+ \item 0x00000002 -- RELIABILITY_LOW
+ \item 0x00000003 -- RELIABILITY_ MEDIUM
+ \item 0x00000004 -- RELIABILITY_HIGH
+ \vspace{-0.18in} \end{itemize1}*/
+
+ /* Optional */
+ /* Vertical Speed */
+ uint8_t vertSpeed_valid; /**< Must be set to true if vertSpeed is being passed */
+ float vertSpeed;
+ /**< Vertical speed. \n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Vertical Speed Uncertainty */
+ uint8_t vertSpeedUnc_valid; /**< Must be set to true if vertSpeedUnc is being passed */
+ float vertSpeedUnc;
+ /**< Vertical speed uncertainty. \n
+ - Units: Meters/second */
+
+ /* Optional */
+ /* Heading */
+ uint8_t heading_valid; /**< Must be set to true if heading is being passed */
+ float heading;
+ /**< Heading. \n
+ - Units: Degrees \n
+ - Range: 0 to 359.999 */
+
+ /* Optional */
+ /* Heading Uncertainty */
+ uint8_t headingUnc_valid; /**< Must be set to true if headingUnc is being passed */
+ float headingUnc;
+ /**< Heading uncertainty. \n
+ - Type: Floating point \n
+ - Range: 0 to 359.999 */
+
+ /* Optional */
+ /* Magnetic Deviation */
+ uint8_t magneticDeviation_valid; /**< Must be set to true if magneticDeviation is being passed */
+ float magneticDeviation;
+ /**< Difference between the bearing to true north and the bearing shown
+ on a magnetic compass. The deviation is positive when the magnetic
+ north is east of true north. */
+
+ /* Optional */
+ /* Technology Used Mask */
+ uint8_t technologyMask_valid; /**< Must be set to true if technologyMask is being passed */
+ qmiLocPosTechMaskT_v02 technologyMask;
+ /**< Technology used in computing this fix.
+ Valid bitmasks: \n
+ - QMI_LOC_POS_TECH_MASK_SATELLITE (0x00000001) -- Satellites were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_CELLID (0x00000002) -- Cell towers were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_WIFI (0x00000004) -- WiFi access points were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_SENSORS (0x00000008) -- Sensors were used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_REFERENCE_LOCATION (0x00000010) -- Reference Location was used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_INJECTED_COARSE_POSITION (0x00000020) -- Coarse position injected into the location engine was used to
+ generate the fix.
+ - QMI_LOC_POS_TECH_MASK_AFLT (0x00000040) -- AFLT was used to generate the fix.
+ - QMI_LOC_POS_TECH_MASK_HYBRID (0x00000080) -- GNSS and network-provided measurements were used to
+ generate the fix.
+ */
+
+ /* Optional */
+ /* Dilution of Precision */
+ uint8_t DOP_valid; /**< Must be set to true if DOP is being passed */
+ qmiLocDOPStructT_v02 DOP;
+
+ /* Optional */
+ /* GPS Time */
+ uint8_t gpsTime_valid; /**< Must be set to true if gpsTime is being passed */
+ qmiLocGPSTimeStructT_v02 gpsTime;
+
+ /* Optional */
+ /* Time Source */
+ uint8_t timeSrc_valid; /**< Must be set to true if timeSrc is being passed */
+ qmiLocTimeSourceEnumT_v02 timeSrc;
+ /**< Time source.
+ Valid values: \n
+ - eQMI_LOC_TIME_SRC_INVALID (0) -- Invalid time.
+ - eQMI_LOC_TIME_SRC_NETWORK_TIME_TRANSFER (1) -- Time is set by the 1x system.
+ - eQMI_LOC_TIME_SRC_NETWORK_TIME_TAGGING (2) -- Time is set by WCDMA/GSM time tagging (i.e.,
+ associating network time with GPS time).
+ - eQMI_LOC_TIME_SRC_EXTERNAL_INPUT (3) -- Time is set by an external injection.
+ - eQMI_LOC_TIME_SRC_TOW_DECODE (4) -- Time is set after decoding over-the-air GPS navigation data
+ from one GPS satellite.
+ - eQMI_LOC_TIME_SRC_TOW_CONFIRMED (5) -- Time is set after decoding over-the-air GPS navigation data
+ from multiple satellites.
+ - eQMI_LOC_TIME_SRC_TOW_AND_WEEK_CONFIRMED (6) -- Both time of the week and the GPS week number are known.
+ - eQMI_LOC_TIME_SRC_NAV_SOLUTION (7) -- Time is set by the position engine after the fix is obtained.
+ - eQMI_LOC_TIME_SRC_SOLVE_FOR_TIME (8) -- Time is set by the position engine after performing SFT.
+ This is done when the clock time uncertainty is large.
+ - eQMI_LOC_TIME_SRC_GLO_TOW_DECODE (9) -- Time is set after decoding GLO satellites
+ - eQMI_LOC_TIME_SRC_TIME_TRANSFORM (10) -- Time is set after transforming the GPS to GLO time
+ - eQMI_LOC_TIME_SRC_WCDMA_SLEEP_TIME_TAGGING (11) -- Time is set by the sleep time tag provided by the WCDMA network
+ - eQMI_LOC_TIME_SRC_GSM_SLEEP_TIME_TAGGING (12) -- Time is set by the sleep time tag provided by the GSM network
+ - eQMI_LOC_TIME_SRC_UNKNOWN (13) -- Source of the time is unknown
+ - eQMI_LOC_TIME_SRC_SYSTEM_TIMETICK (14) -- Time is derived from the system clock (better known as the slow clock);
+ GNSS time is maintained irrespective of the GNSS receiver state
+ */
+
+ /* Optional */
+ /* Sensor Data Usage */
+ uint8_t sensorDataUsage_valid; /**< Must be set to true if sensorDataUsage is being passed */
+ qmiLocSensorUsageIndicatorStructT_v02 sensorDataUsage;
+
+ /* Optional */
+ /* SVs Used to Calculate the Fix */
+ uint8_t gnssSvUsedList_valid; /**< Must be set to true if gnssSvUsedList is being passed */
+ uint32_t gnssSvUsedList_len; /**< Must be set to # of elements in gnssSvUsedList */
+ uint16_t gnssSvUsedList[QMI_LOC_MAX_SV_USED_LIST_LENGTH_V02];
+ /**< Each entry in the list contains the SV ID of a satellite
+ used for calculating this position report. The following
+ information is associated with each SV ID: \begin{itemize1}
+ \item Range: \begin{itemize1}
+ \item For GPS: 1 to 32
+ \item For SBAS: 33 to 64
+ \item For GLONASS: 65 to 96
+ \item For QZSS: 193 to 197
+ \vspace{-0.18in} \end{itemize1} \end{itemize1} */
+}qmiLocGetBestAvailablePositionIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCMOTIONSTATEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_MOTION_STATE_UNKNOWN_V02 = 0, /**< Device state is not known. */
+ eQMI_LOC_MOTION_STATE_STATIONARY_V02 = 1, /**< Device state is Stationary. */
+ eQMI_LOC_MOTION_STATE_IN_MOTION_V02 = 2, /**< Device state is In Motion. */
+ QMILOCMOTIONSTATEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocMotionStateEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCMOTIONMODEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_MOTION_MODE_UNKNOWN_V02 = 0, /**< Device movement is not known. */
+ eQMI_LOC_MOTION_MODE_STATIONARY_V02 = 1, /**< Device is not moving. */
+ eQMI_LOC_MOTION_MODE_PEDESTRIAN_UNKNOWN_V02 = 200, /**< Device movement is in Pedestrian mode; nothing else is known about the movement. */
+ eQMI_LOC_MOTION_MODE_PEDESTRIAN_WALKING_V02 = 201, /**< Device movement is in pedestrian Walking mode. */
+ eQMI_LOC_MOTION_MODE_PEDESTRIAN_RUNNING_V02 = 202, /**< Device movement is in pedestrian Running mode. */
+ eQMI_LOC_MOTION_MODE_VEHICLE_UNKNOWN_V02 = 300, /**< Device movement is in Vehicular mode; nothing else is known about the movement. */
+ QMILOCMOTIONMODEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocMotionModeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ qmiLocMotionStateEnumT_v02 motion_state;
+ /**< Current motion state of the user.
+
+ Valid values: \begin{itemize1}
+ \item eQMI_LOC_MOTION_ STATE_UNKNOWN (0) -- Device state is not known.
+ \item eQMI_LOC_MOTION_ STATE_STATIONARY (1) -- Device state is Stationary.
+ \item eQMI_LOC_MOTION_ STATE_IN_MOTION (2) -- Device state is In Motion.
+ \vspace{0.1in} \end{itemize1}
+
+ Absolute rest and relative rest are both indicated by setting motion_state
+ to Stationary. The relative rest state can be distinguished from absolute
+ rest by reducing probability_of_state.
+ */
+
+ qmiLocMotionModeEnumT_v02 motion_mode;
+ /**< Modes of user motion.
+
+ Valid values: \begin{itemize1}
+ \item eQMI_LOC_MOTION_MODE_ UNKNOWN (0) -- Device movement is not known.
+ \item eQMI_LOC_MOTION_MODE_ STATIONARY (1) -- Device is not moving.
+ \item eQMI_LOC_MOTION_MODE_ PEDESTRIAN_UNKNOWN (200) -- Device movement
+ is in Pedestrian mode; nothing else is known about the movement.
+ \item eQMI_LOC_MOTION_MODE_ PEDESTRIAN_WALKING (201) -- Device movement
+ is in Pedestrian Walking mode.
+ \item eQMI_LOC_MOTION_MODE_ PEDESTRIAN_RUNNING (202) -- Device movement
+ is in Pedestrian Running mode.
+ \item eQMI_LOC_MOTION_MODE_ VEHICLE_UNKNOWN (300) -- Device movement is
+ in Vehicular mode; nothing else is known about the movement.
+ \vspace{0.1in} \end{itemize1}
+
+ The motion_mode value is independent of the motion_state value.
+ */
+
+ float probability_of_state;
+ /**< Probability that the device is actually undergoing the motion state
+ specified by the combination of the values of motion_state, motion_mode,
+ and motion_sub_mode. \vspace{0.1in}
+
+ This value is a floating point number in the range of 0 to 100, in
+ units of percent probability. Any value greater than 99.9999 is
+ applied as 99.9999. \vspace{0.1in}
+
+ It is recommended that if a particular combination of motion_state and
+ motion_mode cannot be determined with more than 50 percent confidence,
+ that a more general statement of user motion be made.
+ For example, if the mode of In-Motion + Pedestrian-Running can only be
+ determined with 50 percent probability, and the simpler statement of In-Motion
+ can be determined with 90 percent probability, it is recommended that this field
+ be used to simply state In-Motion with 90 percent probability. \vspace{0.1in}
+
+ If the motion_state is not known, the value in this field is not used.
+ */
+
+ uint16_t age;
+ /**< Age of the motion data in milliseconds at the time of injection.
+ */
+
+ uint16_t timeout;
+ /**< If the age of the motion data input exceeds the timeout value, the data
+ will no longer be used. The timeout value is in units of milliseconds.
+ Values in the range of 0 to 10000 are accepted. If 65535 is provided,
+ the motion data input is applied until the next input is
+ received. \n
+
+ If the determination of motion data is an instantaneous observation
+ and no notice is guaranteed to be given via the QMI on a change in the
+ state of the motion data, it is recommended that this field be set to 0. \vspace{0.1in}
+
+ If the determination of motion data is continuously monitored
+ external to the QMI and an update is always applied to the QMI upon any
+ change in state, a value of 65535 is used for this field.
+ Note that in this case, if a certain mode is set and is not later
+ unset (e.g., by sending in the request message with a user motion
+ state of Unknown), the value is applied indefinitely.
+ */
+}qmiLocMotionDataStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects motion data for MSM GPS service use. */
+typedef struct {
+
+ /* Mandatory */
+ /* Motion Data */
+ qmiLocMotionDataStructT_v02 motion_data;
+}qmiLocInjectMotionDataReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects motion data for MSM GPS service use. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject Motion Data Request Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject Motion Data request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocInjectMotionDataIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to retrieve the list of network
+ initiated Geofence IDs. */
+typedef struct {
+
+ /* Mandatory */
+ /* Transaction ID */
+ uint32_t transactionId;
+ /**< Identifies the transaction. The same transaction ID
+ will be returned in the Get NI Geofence ID List indication. */
+}qmiLocGetNiGeofenceIdListReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to retrieve the list of network
+ initiated Geofence IDs. */
+typedef struct {
+
+ /* Mandatory */
+ /* Get NI Geofence ID List Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Get NI Geofence ID List request.
+ Valid values: \n
+ - 0x00000000 -- SUCCESS \n
+ - 0x00000001 -- GENERAL_FAILURE \n
+ - 0x00000002 -- UNSUPPORTED \n
+ - 0x00000004 -- ENGINE_BUSY \n
+ - 0x00000006 -- TIMEOUT */
+
+ /* Optional */
+ /* Transaction ID */
+ uint8_t transactionId_valid; /**< Must be set to true if transactionId is being passed */
+ uint32_t transactionId;
+ /**< Transaction ID that was specified in the Get NI
+ Geofence ID List request. */
+
+ /* Optional */
+ /* NI Geofence ID List */
+ uint8_t niGeofenceIdList_valid; /**< Must be set to true if niGeofenceIdList is being passed */
+ uint32_t niGeofenceIdList_len; /**< Must be set to # of elements in niGeofenceIdList */
+ uint32_t niGeofenceIdList[QMI_LOC_MAX_NI_GEOFENCE_ID_LIST_LENGTH_V02];
+ /**< List containing the NI Geofence IDs.
+ - Type: Array of unsigned 32-bit integers \n
+ - Maximum NI Geofence ID List length: 16 */
+}qmiLocGetNiGeofenceIdListIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t MCC;
+ /**< GSM mobile country code. Refer to ITU-T E.212 \hyperref[S6]{[S6]}. */
+
+ uint32_t MNC;
+ /**< GSM mobile network code. Refer to \hyperref[S6]{[S6]}. */
+
+ uint32_t LAC;
+ /**< GSM location area code. Refer to \hyperref[S6]{[S6]}. */
+
+ uint32_t CID;
+ /**< GSM cell identification. Refer to \hyperref[S6]{[S6]}. */
+}qmiLocGSMCellIdStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects GSM cell information into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* GSM Cell ID */
+ qmiLocGSMCellIdStructT_v02 gsmCellId;
+ /**< \vspace{0.06in} \n Identifies the GSM cell on which the device is currently camped. */
+
+ /* Mandatory */
+ /* Roaming Status */
+ uint8_t roamingStatus;
+ /**< Indicates whether the device is roaming.
+ \begin{itemize1}
+ \item 0x01 (TRUE) -- Device is roaming
+ \item 0x00 (FALSE) -- Device is not roaming
+ \vspace{-0.18in} \end{itemize1}*/
+
+ /* Optional */
+ /* Timing Advance */
+ uint8_t timingAdvance_valid; /**< Must be set to true if timingAdvance is being passed */
+ uint32_t timingAdvance;
+ /**< Round trip delay between the MS and the BS, in units of 3.69 microseconds.
+ Refer to 3GPP TS 05.10 and TS 45.010. */
+}qmiLocInjectGSMCellInfoReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects GSM cell information into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject GSM Cell Info Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject GSM Cell Info request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocInjectGSMCellInfoIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCROAMINGSTATUSENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_PHONE_NOT_ROAMING_V02 = 1, /**< Modem is camped on a home network. */
+ eQMI_LOC_PHONE_ROAMING_V02 = 2, /**< Modem is camped on a roaming network. */
+ QMILOCROAMINGSTATUSENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocRoamingStatusEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t mcc;
+ /**< WCDMA mobile country code. Refer to ITU-T E.212 \hyperref[S6]{[S6]}. */
+
+ uint32_t mnc;
+ /**< WCDMA mobile network code. Refer to \hyperref[S6]{[S6]}. */
+
+ uint32_t cid;
+ /**< WCDMA cell identity. Refer to \hyperref[S6]{[S6]}. */
+}qmiLocWCDMACellIdStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects WCDMA cell information into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* WCDMA Cell ID */
+ qmiLocWCDMACellIdStructT_v02 wcdmaCellId;
+ /**< \n Identifies the WCDMA cell on which the device is currently camped. */
+
+ /* Mandatory */
+ /* Roaming Status */
+ qmiLocRoamingStatusEnumT_v02 roamingStatus;
+ /**< Indicates whether the device is roaming.
+ Valid values: \begin{itemize1}
+ \item eQMI_LOC_PHONE_NOT_ROAMING -- Device not roaming, i.e., it is camped on
+ its home network
+ \item eQMI_LOC_PHONE_ROAMING -- Device is currently roaming, i.e., it is camped
+ on a roaming network.
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Cell Frequency */
+ uint8_t freq_valid; /**< Must be set to true if freq is being passed */
+ uint32_t freq;
+ /**< Frequency information of the serving cell. \n
+ Valid range: 0 to 16383 \n
+ Refer to TS 25.331 \hyperref[S7]{[S7]}. */
+
+ /* Optional */
+ /* Primary Scrambling Code */
+ uint8_t psc_valid; /**< Must be set to true if psc is being passed */
+ uint32_t psc;
+ /**< Primary scrambling code of the serving cell. \n
+ Valid range: 0 to 511 \n
+ Refer to \hyperref[S7]{[S7]}. */
+}qmiLocInjectWCDMACellInfoReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects WCDMA cell information into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject WCDMA Cell Info Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject WCDMA Cell Info request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocInjectWCDMACellInfoIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_aggregates
+ @{
+ */
+typedef struct {
+
+ uint32_t mcc;
+ /**< TDSCDMA mobile country code. Refer to ITU-T E.212 \hyperref[S6]{[S6]}. */
+
+ uint32_t mnc;
+ /**< TDSCDMA mobile network code. Refer to \hyperref[S6]{[S6]}. */
+
+ uint32_t cid;
+ /**< TDSCDMA cell identity. Refer to TS 25.331 \hyperref[S7]{[S7]}. */
+
+ uint32_t lac;
+ /**< TDSCDMA location area code. Refer to \hyperref[S6]{[S6]}. */
+}qmiLocTDSCDMACellIdStructT_v02; /* Type */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects TDSCDMA cell information into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* TDSCDMA Cell ID */
+ qmiLocTDSCDMACellIdStructT_v02 tdscdmaCellId;
+ /**< \n Identifies the TDSCDMA cell on which the device is currently camped. */
+
+ /* Mandatory */
+ /* Roaming Status */
+ qmiLocRoamingStatusEnumT_v02 roamingStatus;
+ /**< Indicates whether the device is roaming.
+ Valid values: \begin{itemize1}
+ \item eQMI_LOC_PHONE_NOT_ROAMING -- Device not roaming, i.e., it is camped on
+ its home network
+ \item eQMI_LOC_PHONE_ROAMING -- Device is currently roaming, i.e., it is camped
+ on a roaming network
+ \vspace{-0.18in} \end{itemize1} */
+
+ /* Optional */
+ /* Cell Frequency */
+ uint8_t freq_valid; /**< Must be set to true if freq is being passed */
+ uint32_t freq;
+ /**< Frequency information of the serving cell. \n
+ Valid range: 0 to 16383 \n
+ Refer to \hyperref[S7]{[S7]}. */
+}qmiLocInjectTDSCDMACellInfoReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects TDSCDMA cell information into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject TDSCDMA Cell Info Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject TDSCDMA Cell Info request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocInjectTDSCDMACellInfoIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects the phone's subscriber ID into the location engine. */
+typedef struct {
+
+ /* Optional */
+ /* Preferred IMSI */
+ uint8_t preferredIMSI_valid; /**< Must be set to true if preferredIMSI is being passed */
+ uint64_t preferredIMSI;
+ /**< IMSI number of the preferred RAT. Refer to \hyperref[S6]{[S6]}.*/
+
+ /* Optional */
+ /* Preferred MSISDN */
+ uint8_t preferredMSISDN_valid; /**< Must be set to true if preferredMSISDN is being passed */
+ uint64_t preferredMSISDN;
+ /**< MSISDN number of the preferred RAT. Refer to \hyperref[S6]{[S6]}.*/
+}qmiLocInjectSubscriberIDReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects the phone's subscriber ID into the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject Subscriber ID Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject Subscriber ID request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocInjectSubscriberIDIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_enums
+ @{
+ */
+typedef enum {
+ QMILOCINJECTEDNETWORKINITIATEDMESSAGETYPEENUMT_MIN_ENUM_VAL_V02 = -2147483647, /**< To force a 32 bit signed enum. Do not change or use*/
+ eQMI_LOC_INJECTED_NETWORK_INITIATED_MESSAGE_TYPE_SUPL_V02 = 0, /**< SUPL network-initiated message is being injected. */
+ QMILOCINJECTEDNETWORKINITIATEDMESSAGETYPEENUMT_MAX_ENUM_VAL_V02 = 2147483647 /**< To force a 32 bit signed enum. Do not change or use*/
+}qmiLocInjectedNetworkInitiatedMessageTypeEnumT_v02;
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Injects a network-initiated message into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Injected Network Initiated Message Type */
+ qmiLocInjectedNetworkInitiatedMessageTypeEnumT_v02 injectedNIMessageType;
+ /**< Type of the network-initiated message being injected.
+
+ Valid values:
+ - eQMI_LOC_INJECTED_NETWORK_INITIATED_MESSAGE_TYPE_SUPL (0) -- SUPL network-initiated message is being injected. */
+
+ /* Mandatory */
+ /* Injected Network Initiated Message */
+ uint32_t injectedNIMessage_len; /**< Must be set to # of elements in injectedNIMessage */
+ uint8_t injectedNIMessage[QMI_LOC_MAX_INJECTED_NETWORK_INITIATED_MESSAGE_LENGTH_V02];
+ /**< Network-initiated message body.
+ If the inject NI message type is TYPE_SUPL, the message contains
+ a SUPL INIT message as defined in OMA-TS-ULP-V2_0-20110527-C \hyperref[S5]{[S5]}. */
+}qmiLocInjectNetworkInitiatedMessageReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Injects a network-initiated message into the location
+ engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Inject Network Initiated Message Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Inject Network Initiated Message request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \item 0x00000008 -- INSUFFICIENT_ MEMORY
+ \vspace{-0.18in} \end{itemize1} */
+}qmiLocInjectNetworkInitiatedMessageIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*
+ * qmiLocWWANOutOfServiceNotificationReqMsgT is empty
+ * typedef struct {
+ * }qmiLocWWANOutOfServiceNotificationReqMsgT_v02;
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Notifies the location engine that the device is out of
+ service. */
+typedef struct {
+
+ /* Mandatory */
+ /* Notify WWAN Out of Service Status */
+ qmiLocStatusEnumT_v02 status;
+ /**< Status of the Notify WWAN Out of Service request.
+
+ Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_ PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocWWANOutOfServiceNotificationIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Request Message; Used by the control point to inject pedometer data
+ into the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Time Source */
+ qmiLocSensorDataTimeSourceEnumT_v02 timeSource;
+ /**< Time source for the pedometer. The location service uses
+ this field to identify the time reference used in the
+ pedometer data time stamp. Values: \n
+ - eQMI_LOC_SENSOR_TIME_SOURCE_UNSPECIFIED (0) -- The sensor time source is unspecified.
+ - eQMI_LOC_SENSOR_TIME_SOURCE_COMMON (1) -- The time source is common between the sensors and
+ the location engine. */
+
+ /* Mandatory */
+ /* Pedometer Report Timestamp */
+ uint32_t timestamp;
+ /**< Time stamp of the last step event in this report, i.e., the time stamp
+ of the step event that caused this report to be generated.
+ The time stamp is in the time reference scale that is
+ used by the pedometer time source. \n
+ - Units: Milliseconds */
+
+ /* Mandatory */
+ /* Time Interval */
+ uint32_t timeInterval;
+ /**< Time interval during which the step count was calculated. Subtracting
+ timeInterval from the timestamp field yields the time when
+ the step detection for the first step in this report started. \n
+ - Units: Milliseconds */
+
+ /* Mandatory */
+ /* Step Count */
+ uint32_t stepCount;
+ /**< Number of steps counted during the time interval. */
+
+ /* Optional */
+ /* Step Confidence */
+ uint8_t stepConfidence_valid; /**< Must be set to true if stepConfidence is being passed */
+ uint8_t stepConfidence;
+ /**< Confidence associated with the step. This field is only applicable
+ for a single step report, i.e., if the step count is one. \n
+ - Range: 0 to 100 \n
+ \textbf{Note:} The report is ignored if confidence is 0. */
+
+ /* Optional */
+ /* Step Count Uncertainty */
+ uint8_t stepCountUncertainty_valid; /**< Must be set to true if stepCountUncertainty is being passed */
+ float stepCountUncertainty;
+ /**< Uncertainty (in steps) associated with the step count. */
+
+ /* Optional */
+ /* Step Rate */
+ uint8_t stepRate_valid; /**< Must be set to true if stepRate is being passed */
+ float stepRate;
+ /**< Current estimate for the rate of steps per second. \n
+ - Units: steps/second \n
+ - Range: >= 0.0 */
+}qmiLocPedometerReportReqMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/** @addtogroup loc_qmi_messages
+ @{
+ */
+/** Indication Message; Used by the control point to inject pedometer data
+ into the location engine. */
+typedef struct {
+
+ /* Mandatory */
+ /* Status of Pedometer Report Request */
+ qmiLocStatusEnumT_v02 status;
+ /**< Valid values: \begin{itemize1}
+ \item 0x00000000 -- SUCCESS
+ \item 0x00000001 -- GENERAL_FAILURE
+ \item 0x00000002 -- UNSUPPORTED
+ \item 0x00000003 -- INVALID_PARAMETER
+ \item 0x00000004 -- ENGINE_BUSY
+ \item 0x00000005 -- PHONE_OFFLINE
+ \item 0x00000006 -- TIMEOUT
+ \vspace{-0.18in} \end{itemize1}
+ */
+}qmiLocPedometerReportIndMsgT_v02; /* Message */
+/**
+ @}
+ */
+
+/*Service Message Definition*/
+/** @addtogroup loc_qmi_msg_ids
+ @{
+ */
+#define QMI_LOC_GET_SUPPORTED_MSGS_REQ_V02 0x001E
+#define QMI_LOC_GET_SUPPORTED_MSGS_RESP_V02 0x001E
+#define QMI_LOC_GET_SUPPORTED_FIELDS_REQ_V02 0x001F
+#define QMI_LOC_GET_SUPPORTED_FIELDS_RESP_V02 0x001F
+#define QMI_LOC_INFORM_CLIENT_REVISION_REQ_V02 0x0020
+#define QMI_LOC_INFORM_CLIENT_REVISION_RESP_V02 0x0020
+#define QMI_LOC_REG_EVENTS_REQ_V02 0x0021
+#define QMI_LOC_REG_EVENTS_RESP_V02 0x0021
+#define QMI_LOC_START_REQ_V02 0x0022
+#define QMI_LOC_START_RESP_V02 0x0022
+#define QMI_LOC_STOP_REQ_V02 0x0023
+#define QMI_LOC_STOP_RESP_V02 0x0023
+#define QMI_LOC_EVENT_POSITION_REPORT_IND_V02 0x0024
+#define QMI_LOC_EVENT_GNSS_SV_INFO_IND_V02 0x0025
+#define QMI_LOC_EVENT_NMEA_IND_V02 0x0026
+#define QMI_LOC_EVENT_NI_NOTIFY_VERIFY_REQ_IND_V02 0x0027
+#define QMI_LOC_EVENT_INJECT_TIME_REQ_IND_V02 0x0028
+#define QMI_LOC_EVENT_INJECT_PREDICTED_ORBITS_REQ_IND_V02 0x0029
+#define QMI_LOC_EVENT_INJECT_POSITION_REQ_IND_V02 0x002A
+#define QMI_LOC_EVENT_ENGINE_STATE_IND_V02 0x002B
+#define QMI_LOC_EVENT_FIX_SESSION_STATE_IND_V02 0x002C
+#define QMI_LOC_EVENT_WIFI_REQ_IND_V02 0x002D
+#define QMI_LOC_EVENT_SENSOR_STREAMING_READY_STATUS_IND_V02 0x002E
+#define QMI_LOC_EVENT_TIME_SYNC_REQ_IND_V02 0x002F
+#define QMI_LOC_EVENT_SET_SPI_STREAMING_REPORT_IND_V02 0x0030
+#define QMI_LOC_EVENT_LOCATION_SERVER_CONNECTION_REQ_IND_V02 0x0031
+#define QMI_LOC_GET_SERVICE_REVISION_REQ_V02 0x0032
+#define QMI_LOC_GET_SERVICE_REVISION_RESP_V02 0x0032
+#define QMI_LOC_GET_SERVICE_REVISION_IND_V02 0x0032
+#define QMI_LOC_GET_FIX_CRITERIA_REQ_V02 0x0033
+#define QMI_LOC_GET_FIX_CRITERIA_RESP_V02 0x0033
+#define QMI_LOC_GET_FIX_CRITERIA_IND_V02 0x0033
+#define QMI_LOC_NI_USER_RESPONSE_REQ_V02 0x0034
+#define QMI_LOC_NI_USER_RESPONSE_RESP_V02 0x0034
+#define QMI_LOC_NI_USER_RESPONSE_IND_V02 0x0034
+#define QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_REQ_V02 0x0035
+#define QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_RESP_V02 0x0035
+#define QMI_LOC_INJECT_PREDICTED_ORBITS_DATA_IND_V02 0x0035
+#define QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_REQ_V02 0x0036
+#define QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_RESP_V02 0x0036
+#define QMI_LOC_GET_PREDICTED_ORBITS_DATA_SOURCE_IND_V02 0x0036
+#define QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_REQ_V02 0x0037
+#define QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_RESP_V02 0x0037
+#define QMI_LOC_GET_PREDICTED_ORBITS_DATA_VALIDITY_IND_V02 0x0037
+#define QMI_LOC_INJECT_UTC_TIME_REQ_V02 0x0038
+#define QMI_LOC_INJECT_UTC_TIME_RESP_V02 0x0038
+#define QMI_LOC_INJECT_UTC_TIME_IND_V02 0x0038
+#define QMI_LOC_INJECT_POSITION_REQ_V02 0x0039
+#define QMI_LOC_INJECT_POSITION_RESP_V02 0x0039
+#define QMI_LOC_INJECT_POSITION_IND_V02 0x0039
+#define QMI_LOC_SET_ENGINE_LOCK_REQ_V02 0x003A
+#define QMI_LOC_SET_ENGINE_LOCK_RESP_V02 0x003A
+#define QMI_LOC_SET_ENGINE_LOCK_IND_V02 0x003A
+#define QMI_LOC_GET_ENGINE_LOCK_REQ_V02 0x003B
+#define QMI_LOC_GET_ENGINE_LOCK_RESP_V02 0x003B
+#define QMI_LOC_GET_ENGINE_LOCK_IND_V02 0x003B
+#define QMI_LOC_SET_SBAS_CONFIG_REQ_V02 0x003C
+#define QMI_LOC_SET_SBAS_CONFIG_RESP_V02 0x003C
+#define QMI_LOC_SET_SBAS_CONFIG_IND_V02 0x003C
+#define QMI_LOC_GET_SBAS_CONFIG_REQ_V02 0x003D
+#define QMI_LOC_GET_SBAS_CONFIG_RESP_V02 0x003D
+#define QMI_LOC_GET_SBAS_CONFIG_IND_V02 0x003D
+#define QMI_LOC_SET_NMEA_TYPES_REQ_V02 0x003E
+#define QMI_LOC_SET_NMEA_TYPES_RESP_V02 0x003E
+#define QMI_LOC_SET_NMEA_TYPES_IND_V02 0x003E
+#define QMI_LOC_GET_NMEA_TYPES_REQ_V02 0x003F
+#define QMI_LOC_GET_NMEA_TYPES_RESP_V02 0x003F
+#define QMI_LOC_GET_NMEA_TYPES_IND_V02 0x003F
+#define QMI_LOC_SET_LOW_POWER_MODE_REQ_V02 0x0040
+#define QMI_LOC_SET_LOW_POWER_MODE_RESP_V02 0x0040
+#define QMI_LOC_SET_LOW_POWER_MODE_IND_V02 0x0040
+#define QMI_LOC_GET_LOW_POWER_MODE_REQ_V02 0x0041
+#define QMI_LOC_GET_LOW_POWER_MODE_RESP_V02 0x0041
+#define QMI_LOC_GET_LOW_POWER_MODE_IND_V02 0x0041
+#define QMI_LOC_SET_SERVER_REQ_V02 0x0042
+#define QMI_LOC_SET_SERVER_RESP_V02 0x0042
+#define QMI_LOC_SET_SERVER_IND_V02 0x0042
+#define QMI_LOC_GET_SERVER_REQ_V02 0x0043
+#define QMI_LOC_GET_SERVER_RESP_V02 0x0043
+#define QMI_LOC_GET_SERVER_IND_V02 0x0043
+#define QMI_LOC_DELETE_ASSIST_DATA_REQ_V02 0x0044
+#define QMI_LOC_DELETE_ASSIST_DATA_RESP_V02 0x0044
+#define QMI_LOC_DELETE_ASSIST_DATA_IND_V02 0x0044
+#define QMI_LOC_SET_XTRA_T_SESSION_CONTROL_REQ_V02 0x0045
+#define QMI_LOC_SET_XTRA_T_SESSION_CONTROL_RESP_V02 0x0045
+#define QMI_LOC_SET_XTRA_T_SESSION_CONTROL_IND_V02 0x0045
+#define QMI_LOC_GET_XTRA_T_SESSION_CONTROL_REQ_V02 0x0046
+#define QMI_LOC_GET_XTRA_T_SESSION_CONTROL_RESP_V02 0x0046
+#define QMI_LOC_GET_XTRA_T_SESSION_CONTROL_IND_V02 0x0046
+#define QMI_LOC_INJECT_WIFI_POSITION_REQ_V02 0x0047
+#define QMI_LOC_INJECT_WIFI_POSITION_RESP_V02 0x0047
+#define QMI_LOC_INJECT_WIFI_POSITION_IND_V02 0x0047
+#define QMI_LOC_NOTIFY_WIFI_STATUS_REQ_V02 0x0048
+#define QMI_LOC_NOTIFY_WIFI_STATUS_RESP_V02 0x0048
+#define QMI_LOC_NOTIFY_WIFI_STATUS_IND_V02 0x0048
+#define QMI_LOC_GET_REGISTERED_EVENTS_REQ_V02 0x0049
+#define QMI_LOC_GET_REGISTERED_EVENTS_RESP_V02 0x0049
+#define QMI_LOC_GET_REGISTERED_EVENTS_IND_V02 0x0049
+#define QMI_LOC_SET_OPERATION_MODE_REQ_V02 0x004A
+#define QMI_LOC_SET_OPERATION_MODE_RESP_V02 0x004A
+#define QMI_LOC_SET_OPERATION_MODE_IND_V02 0x004A
+#define QMI_LOC_GET_OPERATION_MODE_REQ_V02 0x004B
+#define QMI_LOC_GET_OPERATION_MODE_RESP_V02 0x004B
+#define QMI_LOC_GET_OPERATION_MODE_IND_V02 0x004B
+#define QMI_LOC_SET_SPI_STATUS_REQ_V02 0x004C
+#define QMI_LOC_SET_SPI_STATUS_RESP_V02 0x004C
+#define QMI_LOC_SET_SPI_STATUS_IND_V02 0x004C
+#define QMI_LOC_INJECT_SENSOR_DATA_REQ_V02 0x004D
+#define QMI_LOC_INJECT_SENSOR_DATA_RESP_V02 0x004D
+#define QMI_LOC_INJECT_SENSOR_DATA_IND_V02 0x004D
+#define QMI_LOC_INJECT_TIME_SYNC_DATA_REQ_V02 0x004E
+#define QMI_LOC_INJECT_TIME_SYNC_DATA_RESP_V02 0x004E
+#define QMI_LOC_INJECT_TIME_SYNC_DATA_IND_V02 0x004E
+#define QMI_LOC_SET_CRADLE_MOUNT_CONFIG_REQ_V02 0x004F
+#define QMI_LOC_SET_CRADLE_MOUNT_CONFIG_RESP_V02 0x004F
+#define QMI_LOC_SET_CRADLE_MOUNT_CONFIG_IND_V02 0x004F
+#define QMI_LOC_GET_CRADLE_MOUNT_CONFIG_REQ_V02 0x0050
+#define QMI_LOC_GET_CRADLE_MOUNT_CONFIG_RESP_V02 0x0050
+#define QMI_LOC_GET_CRADLE_MOUNT_CONFIG_IND_V02 0x0050
+#define QMI_LOC_SET_EXTERNAL_POWER_CONFIG_REQ_V02 0x0051
+#define QMI_LOC_SET_EXTERNAL_POWER_CONFIG_RESP_V02 0x0051
+#define QMI_LOC_SET_EXTERNAL_POWER_CONFIG_IND_V02 0x0051
+#define QMI_LOC_GET_EXTERNAL_POWER_CONFIG_REQ_V02 0x0052
+#define QMI_LOC_GET_EXTERNAL_POWER_CONFIG_RESP_V02 0x0052
+#define QMI_LOC_GET_EXTERNAL_POWER_CONFIG_IND_V02 0x0052
+#define QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_REQ_V02 0x0053
+#define QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_RESP_V02 0x0053
+#define QMI_LOC_INFORM_LOCATION_SERVER_CONN_STATUS_IND_V02 0x0053
+#define QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02 0x0054
+#define QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_RESP_V02 0x0054
+#define QMI_LOC_SET_PROTOCOL_CONFIG_PARAMETERS_IND_V02 0x0054
+#define QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_REQ_V02 0x0055
+#define QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_RESP_V02 0x0055
+#define QMI_LOC_GET_PROTOCOL_CONFIG_PARAMETERS_IND_V02 0x0055
+#define QMI_LOC_SET_SENSOR_CONTROL_CONFIG_REQ_V02 0x0056
+#define QMI_LOC_SET_SENSOR_CONTROL_CONFIG_RESP_V02 0x0056
+#define QMI_LOC_SET_SENSOR_CONTROL_CONFIG_IND_V02 0x0056
+#define QMI_LOC_GET_SENSOR_CONTROL_CONFIG_REQ_V02 0x0057
+#define QMI_LOC_GET_SENSOR_CONTROL_CONFIG_RESP_V02 0x0057
+#define QMI_LOC_GET_SENSOR_CONTROL_CONFIG_IND_V02 0x0057
+#define QMI_LOC_SET_SENSOR_PROPERTIES_REQ_V02 0x0058
+#define QMI_LOC_SET_SENSOR_PROPERTIES_RESP_V02 0x0058
+#define QMI_LOC_SET_SENSOR_PROPERTIES_IND_V02 0x0058
+#define QMI_LOC_GET_SENSOR_PROPERTIES_REQ_V02 0x0059
+#define QMI_LOC_GET_SENSOR_PROPERTIES_RESP_V02 0x0059
+#define QMI_LOC_GET_SENSOR_PROPERTIES_IND_V02 0x0059
+#define QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02 0x005A
+#define QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_RESP_V02 0x005A
+#define QMI_LOC_SET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02 0x005A
+#define QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_REQ_V02 0x005B
+#define QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_RESP_V02 0x005B
+#define QMI_LOC_GET_SENSOR_PERFORMANCE_CONTROL_CONFIGURATION_IND_V02 0x005B
+#define QMI_LOC_INJECT_SUPL_CERTIFICATE_REQ_V02 0x005C
+#define QMI_LOC_INJECT_SUPL_CERTIFICATE_RESP_V02 0x005C
+#define QMI_LOC_INJECT_SUPL_CERTIFICATE_IND_V02 0x005C
+#define QMI_LOC_DELETE_SUPL_CERTIFICATE_REQ_V02 0x005D
+#define QMI_LOC_DELETE_SUPL_CERTIFICATE_RESP_V02 0x005D
+#define QMI_LOC_DELETE_SUPL_CERTIFICATE_IND_V02 0x005D
+#define QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02 0x005E
+#define QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_RESP_V02 0x005E
+#define QMI_LOC_SET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02 0x005E
+#define QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_REQ_V02 0x005F
+#define QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_RESP_V02 0x005F
+#define QMI_LOC_GET_POSITION_ENGINE_CONFIG_PARAMETERS_IND_V02 0x005F
+#define QMI_LOC_EVENT_NI_GEOFENCE_NOTIFICATION_IND_V02 0x0060
+#define QMI_LOC_EVENT_GEOFENCE_GEN_ALERT_IND_V02 0x0061
+#define QMI_LOC_EVENT_GEOFENCE_BREACH_NOTIFICATION_IND_V02 0x0062
+#define QMI_LOC_ADD_CIRCULAR_GEOFENCE_REQ_V02 0x0063
+#define QMI_LOC_ADD_CIRCULAR_GEOFENCE_RESP_V02 0x0063
+#define QMI_LOC_ADD_CIRCULAR_GEOFENCE_IND_V02 0x0063
+#define QMI_LOC_DELETE_GEOFENCE_REQ_V02 0x0064
+#define QMI_LOC_DELETE_GEOFENCE_RESP_V02 0x0064
+#define QMI_LOC_DELETE_GEOFENCE_IND_V02 0x0064
+#define QMI_LOC_QUERY_GEOFENCE_REQ_V02 0x0065
+#define QMI_LOC_QUERY_GEOFENCE_RESP_V02 0x0065
+#define QMI_LOC_QUERY_GEOFENCE_IND_V02 0x0065
+#define QMI_LOC_EDIT_GEOFENCE_REQ_V02 0x0066
+#define QMI_LOC_EDIT_GEOFENCE_RESP_V02 0x0066
+#define QMI_LOC_EDIT_GEOFENCE_IND_V02 0x0066
+#define QMI_LOC_GET_BEST_AVAILABLE_POSITION_REQ_V02 0x0067
+#define QMI_LOC_GET_BEST_AVAILABLE_POSITION_RESP_V02 0x0067
+#define QMI_LOC_GET_BEST_AVAILABLE_POSITION_IND_V02 0x0067
+#define QMI_LOC_INJECT_MOTION_DATA_REQ_V02 0x0068
+#define QMI_LOC_INJECT_MOTION_DATA_RESP_V02 0x0068
+#define QMI_LOC_INJECT_MOTION_DATA_IND_V02 0x0068
+#define QMI_LOC_GET_NI_GEOFENCE_ID_LIST_REQ_V02 0x0069
+#define QMI_LOC_GET_NI_GEOFENCE_ID_LIST_RESP_V02 0x0069
+#define QMI_LOC_GET_NI_GEOFENCE_ID_LIST_IND_V02 0x0069
+#define QMI_LOC_INJECT_GSM_CELL_INFO_REQ_V02 0x006A
+#define QMI_LOC_INJECT_GSM_CELL_INFO_RESP_V02 0x006A
+#define QMI_LOC_INJECT_GSM_CELL_INFO_IND_V02 0x006A
+#define QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_REQ_V02 0x006B
+#define QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_RESP_V02 0x006B
+#define QMI_LOC_INJECT_NETWORK_INITIATED_MESSAGE_IND_V02 0x006B
+#define QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_REQ_V02 0x006C
+#define QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_RESP_V02 0x006C
+#define QMI_LOC_WWAN_OUT_OF_SERVICE_NOTIFICATION_IND_V02 0x006C
+#define QMI_LOC_EVENT_PEDOMETER_CONTROL_IND_V02 0x006D
+#define QMI_LOC_EVENT_MOTION_DATA_CONTROL_IND_V02 0x006E
+#define QMI_LOC_PEDOMETER_REPORT_REQ_V02 0x006F
+#define QMI_LOC_PEDOMETER_REPORT_RESP_V02 0x006F
+#define QMI_LOC_PEDOMETER_REPORT_IND_V02 0x006F
+#define QMI_LOC_INJECT_WCDMA_CELL_INFO_REQ_V02 0x0070
+#define QMI_LOC_INJECT_WCDMA_CELL_INFO_RESP_V02 0x0070
+#define QMI_LOC_INJECT_WCDMA_CELL_INFO_IND_V02 0x0070
+#define QMI_LOC_INJECT_TDSCDMA_CELL_INFO_REQ_V02 0x0071
+#define QMI_LOC_INJECT_TDSCDMA_CELL_INFO_RESP_V02 0x0071
+#define QMI_LOC_INJECT_TDSCDMA_CELL_INFO_IND_V02 0x0071
+#define QMI_LOC_INJECT_SUBSCRIBER_ID_REQ_V02 0x0072
+#define QMI_LOC_INJECT_SUBSCRIBER_ID_RESP_V02 0x0072
+#define QMI_LOC_INJECT_SUBSCRIBER_ID_IND_V02 0x0072
+/**
+ @}
+ */
+
+/* Service Object Accessor */
+/** @addtogroup wms_qmi_accessor
+ @{
+ */
+/** This function is used internally by the autogenerated code. Clients should use the
+ macro loc_get_service_object_v02( ) that takes in no arguments. */
+qmi_idl_service_object_type loc_get_service_object_internal_v02
+ ( int32_t idl_maj_version, int32_t idl_min_version, int32_t library_version );
+
+/** This macro should be used to get the service object */
+#define loc_get_service_object_v02( ) \
+ loc_get_service_object_internal_v02( \
+ LOC_V02_IDL_MAJOR_VERS, LOC_V02_IDL_MINOR_VERS, \
+ LOC_V02_IDL_TOOL_VERS )
+/**
+ @}
+ */
+
+
+#ifdef __cplusplus
+}
+#endif
+#endif
diff --git a/platform_lib_abstractions/elapsed_millis_since_boot.cpp b/platform_lib_abstractions/elapsed_millis_since_boot.cpp
new file mode 100644
index 0000000..e8cb93a
--- /dev/null
+++ b/platform_lib_abstractions/elapsed_millis_since_boot.cpp
@@ -0,0 +1,46 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <stdlib.h>
+#include <sys/time.h>
+#include "platform_lib_time.h"
+
+int64_t systemTime(int clock)
+{
+ struct timeval t;
+ t.tv_sec = t.tv_usec = 0;
+ gettimeofday(&t, NULL);
+ return t.tv_sec*1000000LL + t.tv_usec;
+}
+
+
+int64_t elapsedMillisSinceBoot()
+{
+ int64_t t_us = systemTime(0);
+ return (int64_t) t_us / 1000LL;
+}
diff --git a/platform_lib_abstractions/platform_lib_includes.h b/platform_lib_abstractions/platform_lib_includes.h
new file mode 100644
index 0000000..5858674
--- /dev/null
+++ b/platform_lib_abstractions/platform_lib_includes.h
@@ -0,0 +1,35 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _PLATFORM_LIB_INCLUDES_H_
+#define _PLATFORM_LIB_INCLUDES_H_
+
+#include "platform_lib_time.h"
+#include "platform_lib_macros.h"
+
+#endif
diff --git a/platform_lib_abstractions/platform_lib_macros.h b/platform_lib_abstractions/platform_lib_macros.h
new file mode 100644
index 0000000..bc48dd9
--- /dev/null
+++ b/platform_lib_abstractions/platform_lib_macros.h
@@ -0,0 +1,81 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef __PLATFORM_LIB_MACROS_H__
+#define __PLATFORM_LIB_MACROS_H__
+
+#include <sys/time.h>
+
+#define TS_PRINTF(format, x...) \
+{ \
+ struct timeval tv; \
+ struct timezone tz; \
+ int hh, mm, ss; \
+ gettimeofday(&tv, &tz); \
+ hh = tv.tv_sec/3600%24; \
+ mm = (tv.tv_sec%3600)/60; \
+ ss = tv.tv_sec%60; \
+ fprintf(stdout,"%02d:%02d:%02d.%06ld]" format "\n", hh, mm, ss, tv.tv_usec,##x); \
+}
+
+
+#ifdef USE_GLIB
+
+#define strlcat g_strlcat
+#define strlcpy g_strlcpy
+
+#define ALOGE(format, x...) TS_PRINTF("E/%s (%d): " format , LOG_TAG, getpid(), ##x)
+#define ALOGW(format, x...) TS_PRINTF("W/%s (%d): " format , LOG_TAG, getpid(), ##x)
+#define ALOGI(format, x...) TS_PRINTF("I/%s (%d): " format , LOG_TAG, getpid(), ##x)
+#define ALOGD(format, x...) TS_PRINTF("D/%s (%d): " format , LOG_TAG, getpid(), ##x)
+#define ALOGV(format, x...) TS_PRINTF("V/%s (%d): " format , LOG_TAG, getpid(), ##x)
+
+#define GETTID_PLATFORM_LIB_ABSTRACTION (syscall(SYS_gettid))
+
+#define LOC_EXT_CREATE_THREAD_CB_PLATFORM_LIB_ABSTRACTION createPthread
+#define ELAPSED_MILLIS_SINCE_BOOT_PLATFORM_LIB_ABSTRACTION (elapsedMillisSinceBoot())
+
+
+#else
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+pid_t gettid(void);
+
+#ifdef __cplusplus
+}
+#endif
+
+#define GETTID_PLATFORM_LIB_ABSTRACTION (gettid())
+#define LOC_EXT_CREATE_THREAD_CB_PLATFORM_LIB_ABSTRACTION android::AndroidRuntime::createJavaThread
+#define ELAPSED_MILLIS_SINCE_BOOT_PLATFORM_LIB_ABSTRACTION (android::elapsedRealtime())
+
+#endif
+
+#endif
diff --git a/platform_lib_abstractions/platform_lib_time.h b/platform_lib_abstractions/platform_lib_time.h
new file mode 100644
index 0000000..ce013af
--- /dev/null
+++ b/platform_lib_abstractions/platform_lib_time.h
@@ -0,0 +1,35 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#ifndef _PLATFORM_LIB_TIME_H_
+#define _PLATFORM_LIB_TIME_H_
+
+int64_t systemTime(int clock);
+int64_t elapsedMillisSinceBoot();
+
+#endif
diff --git a/utils/Android.mk b/utils/Android.mk
index 912dcae..24ab8a1 100644
--- a/utils/Android.mk
+++ b/utils/Android.mk
@@ -17,7 +17,10 @@ LOCAL_SRC_FILES += \
loc_cfg.cpp \
msg_q.c \
linked_list.c \
- loc_target.cpp
+ loc_target.cpp \
+ loc_timer.c \
+ ../platform_lib_abstractions/elapsed_millis_since_boot.cpp
+
LOCAL_CFLAGS += \
-fno-short-enums \
@@ -26,7 +29,8 @@ LOCAL_CFLAGS += \
LOCAL_LDFLAGS += -Wl,--export-dynamic
## Includes
-LOCAL_C_INCLUDES:=
+LOCAL_C_INCLUDES:= \
+ $(LOCAL_PATH)/../platform_lib_abstractions
LOCAL_COPY_HEADERS_TO:= gps.utils/
LOCAL_COPY_HEADERS:= \
@@ -35,7 +39,12 @@ LOCAL_COPY_HEADERS:= \
log_util.h \
linked_list.h \
msg_q.h \
- loc_target.h
+ loc_target.h \
+ loc_timer.h \
+ ../platform_lib_abstractions/platform_lib_includes.h \
+ ../platform_lib_abstractions/platform_lib_time.h \
+ ../platform_lib_abstractions/platform_lib_macros.h
+
LOCAL_MODULE := libgps.utils
diff --git a/utils/Makefile.am b/utils/Makefile.am
new file mode 100644
index 0000000..e5935f0
--- /dev/null
+++ b/utils/Makefile.am
@@ -0,0 +1,44 @@
+AM_CFLAGS = -Wundef \
+ -MD \
+ -Wno-trigraphs \
+ -g -O0 \
+ -fno-inline \
+ -fno-short-enums \
+ -fpic \
+ -I../platform_lib_abstractions
+
+libgps_utils_so_la_h_sources = log_util.h \
+ msg_q.h \
+ linked_list.h \
+ loc_cfg.h \
+ loc_log.h \
+ ../platform_lib_abstractions/platform_lib_includes.h \
+ ../platform_lib_abstractions/platform_lib_time.h \
+ ../platform_lib_abstractions/platform_lib_macros.h
+
+libgps_utils_so_la_c_sources = linked_list.c \
+ msg_q.c \
+ loc_cfg.cpp \
+ loc_log.cpp \
+ ../platform_lib_abstractions/elapsed_millis_since_boot.cpp
+
+library_includedir = $(pkgincludedir)/utils
+
+library_include_HEADERS = $(libgps_utils_so_la_h_sources)
+
+libgps_utils_so_la_SOURCES = $(libgps_utils_so_la_c_sources)
+
+if USE_GLIB
+libgps_utils_so_la_CFLAGS = -DUSE_GLIB $(AM_CFLAGS) @GLIB_CFLAGS@
+libgps_utils_so_la_LDFLAGS = -lstdc++ -lpthread @GLIB_LIBS@ -shared -version-info 1:0:0
+libgps_utils_so_la_CPPFLAGS = -DUSE_GLIB $(AM_CFLAGS) $(AM_CPPFLAGS) @GLIB_CFLAGS@
+else
+libgps_utils_so_la_CFLAGS = $(AM_CFLAGS)
+libgps_utils_so_la_LDFLAGS = -lpthread -shared -version-info 1:0:0
+libgps_utils_so_la_CPPFLAGS = $(AM_CFLAGS) $(AM_CPPFLAGS)
+endif
+
+libgps_utils_so_la_LIBADD = -lstdc++ -lcutils
+
+#Create and Install libraries
+lib_LTLIBRARIES = libgps_utils_so.la
diff --git a/utils/linked_list.c b/utils/linked_list.c
index 31ec52d..92617fe 100644
--- a/utils/linked_list.c
+++ b/utils/linked_list.c
@@ -32,7 +32,7 @@
#define LOG_TAG "LocSvc_utils_ll"
#include "log_util.h"
-
+#include "platform_lib_includes.h"
#include <stdlib.h>
#include <stdint.h>
diff --git a/utils/loc_cfg.cpp b/utils/loc_cfg.cpp
index e4a4772..73d1ca4 100644
--- a/utils/loc_cfg.cpp
+++ b/utils/loc_cfg.cpp
@@ -39,6 +39,10 @@
#include <time.h>
#include <loc_cfg.h>
#include <log_util.h>
+#ifdef USE_GLIB
+#include <glib.h>
+#endif
+#include "platform_lib_includes.h"
/*=============================================================================
*
@@ -47,7 +51,7 @@
*============================================================================*/
/* Parameter data */
-static uint8_t DEBUG_LEVEL = 3;
+static uint8_t DEBUG_LEVEL = 0xff;
static uint8_t TIMESTAMP = 0;
/* Parameter spec table */
diff --git a/utils/loc_log.cpp b/utils/loc_log.cpp
index ecdfc8f..533fabd 100644
--- a/utils/loc_log.cpp
+++ b/utils/loc_log.cpp
@@ -34,8 +34,11 @@
#include <sys/time.h>
#include "loc_log.h"
#include "msg_q.h"
+#ifdef USE_GLIB
+#include <time.h>
+#endif /* USE_GLIB */
#include "log_util.h"
-
+#include "platform_lib_includes.h"
// Logging Improvements
const char *loc_logger_boolStr[]={"False","True"};
const char VOID_RET[] = "None";
diff --git a/utils/loc_timer.c b/utils/loc_timer.c
new file mode 100644
index 0000000..13f7786
--- /dev/null
+++ b/utils/loc_timer.c
@@ -0,0 +1,157 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#include<stdio.h>
+#include<stdlib.h>
+#include<sys/time.h>
+#include "loc_timer.h"
+#include<time.h>
+#include<errno.h>
+
+#define MAX_DELAY_RETRIES 3
+
+typedef struct {
+ loc_timer_callback callback_func;
+ void *user_data;
+ unsigned int time_msec;
+}timer_data;
+
+static void *timer_thread(void *thread_data)
+{
+ int ret;
+ unsigned char retries=0;
+ struct timespec ts;
+ struct timeval tv;
+ timer_data t;
+ t.callback_func = ((timer_data *)thread_data)->callback_func;
+ t.user_data = ((timer_data *)thread_data)->user_data;
+ t.time_msec = ((timer_data *)thread_data)->time_msec;
+ pthread_cond_t timer_cond;
+ pthread_mutex_t timer_mutex;
+
+ LOC_LOGD("%s:%d]: Enter. Delay = %d\n", __func__, __LINE__, t.time_msec);
+ //Copied over all info into local variable. Do not need allocated struct
+ free(thread_data);
+
+ if(pthread_cond_init(&timer_cond, NULL)) {
+ LOC_LOGE("%s:%d]: Pthread cond init failed\n", __func__, __LINE__);
+ ret = -1;
+ goto err;
+ }
+ if(pthread_mutex_init(&timer_mutex, NULL)) {
+ LOC_LOGE("%s:%d]: Pthread mutex init failed\n", __func__, __LINE__);
+ ret = -1;
+ goto mutex_err;
+ }
+ while(retries < MAX_DELAY_RETRIES) {
+ gettimeofday(&tv, NULL);
+ clock_gettime(CLOCK_REALTIME, &ts);
+ if(t.time_msec >= 1000) {
+ ts.tv_sec += t.time_msec/1000;
+ t.time_msec = t.time_msec % 1000;
+ }
+ if(t.time_msec)
+ ts.tv_nsec += t.time_msec * 1000000;
+ if(ts.tv_nsec > 999999999) {
+ LOC_LOGD("%s:%d]: Large nanosecs\n", __func__, __LINE__);
+ ts.tv_sec += 1;
+ ts.tv_nsec -= 1000000000;
+ }
+ LOC_LOGD("%s:%d]: ts.tv_sec:%d; ts.tv_nsec:%d\n",
+ __func__, __LINE__, (int)ts.tv_sec, (int)ts.tv_nsec);
+ LOC_LOGD("%s:%d]: Current time: %d sec; %d nsec\n",
+ __func__, __LINE__, (int)tv.tv_sec, (int)tv.tv_usec*1000);
+ pthread_mutex_lock(&(timer_mutex));
+ ret = pthread_cond_timedwait(&timer_cond, &timer_mutex, &ts);
+ pthread_mutex_unlock(&(timer_mutex));
+ if(ret != ETIMEDOUT) {
+ LOC_LOGE("%s:%d]: Call to pthread timedwait failed; ret=%d\n",
+ __func__, __LINE__,ret);
+ ret = -1;
+ retries++;
+ }
+ else {
+ ret = 0;
+ break;
+ }
+ }
+
+ pthread_mutex_destroy(&timer_mutex);
+mutex_err:
+ pthread_cond_destroy(&timer_cond);
+err:
+ if(!ret)
+ t.callback_func(t.user_data, ret);
+ LOC_LOGD("%s:%d]: Exit\n", __func__, __LINE__);
+ return NULL;
+}
+
+int loc_timer_start(unsigned int msec, loc_timer_callback cb_func,
+ void* caller_data)
+{
+ int ret=0;
+ timer_data *t=NULL;
+ pthread_attr_t tattr;
+ pthread_t id;
+ LOC_LOGD("%s:%d]: Enter\n", __func__, __LINE__);
+ if(cb_func == NULL || msec == 0) {
+ LOC_LOGE("%s:%d]: Error: Wrong parameters\n", __func__, __LINE__);
+ ret = -1;
+ goto err;
+ }
+ t = (timer_data *)calloc(1, sizeof(timer_data));
+ if(t == NULL) {
+ LOC_LOGE("%s:%d]: Could not allocate memory. Failing.\n",
+ __func__, __LINE__);
+ ret = -1;
+ goto err;
+ }
+
+ t->callback_func = cb_func;
+ t->user_data = caller_data;
+ t->time_msec = msec;
+
+ pthread_attr_init(&tattr);
+ pthread_attr_setdetachstate(&tattr, PTHREAD_CREATE_DETACHED);
+ if(pthread_create(&(id), &tattr, timer_thread, (void *)t)) {
+ LOC_LOGE("%s:%d]: Could not create thread\n", __func__, __LINE__);
+ ret = -1;
+ goto attr_err;
+ }
+ else {
+ LOC_LOGD("%s:%d]: Created thread with id: %d\n",
+ __func__, __LINE__, (int)id);
+ }
+
+attr_err:
+ pthread_attr_destroy(&tattr);
+err:
+ LOC_LOGD("%s:%d]: Exit\n", __func__, __LINE__);
+ return ret;
+}
diff --git a/utils/loc_timer.h b/utils/loc_timer.h
new file mode 100644
index 0000000..213da20
--- /dev/null
+++ b/utils/loc_timer.h
@@ -0,0 +1,54 @@
+/* Copyright (c) 2013, The Linux Foundation. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ * * Neither the name of The Linux Foundation, nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
+ * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
+ * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
+ * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef __LOC_DELAY_H__
+#define __LOC_DELAY_H__
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+#include<pthread.h>
+#include "log_util.h"
+
+/*
+ Return values:
+ Success = 0
+ Failure = Non zero
+*/
+typedef void(*loc_timer_callback)(void *user_data, int result);
+
+//int loc_timer_start(loc_timer_client_data *p_thread);
+int loc_timer_start(unsigned int delay_msec,
+ loc_timer_callback,
+ void* user_data);
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif //__LOC_DELAY_H__
diff --git a/utils/log_util.h b/utils/log_util.h
index 56dca62..7fb0c78 100644
--- a/utils/log_util.h
+++ b/utils/log_util.h
@@ -30,6 +30,23 @@
#ifndef __LOG_UTIL_H__
#define __LOG_UTIL_H__
+#ifndef USE_GLIB
+#include <utils/Log.h>
+#endif /* USE_GLIB */
+
+#ifdef USE_GLIB
+
+#include <stdio.h>
+#include <sys/types.h>
+#include <unistd.h>
+
+#ifndef LOG_TAG
+#define LOG_TAG "GPS_UTILS"
+
+#endif // LOG_TAG
+
+#endif /* USE_GLIB */
+
#ifdef __cplusplus
extern "C"
{
@@ -72,29 +89,32 @@ extern const char ENTRY_TAG[];
extern void loc_logger_init(unsigned long debug, unsigned long timestamp);
extern char* get_timestamp(char* str, unsigned long buf_size);
-
-#include <utils/Log.h>
-
#ifndef DEBUG_DMN_LOC_API
/* LOGGING MACROS */
-#define LOC_LOGE(...) ALOGE("E/"__VA_ARGS__)
+/*loc_logger.DEBUG_LEVEL is initialized to 0xff in loc_cfg.cpp
+ if that value remains unchanged, it means gps.conf did not
+ provide a value and we default to the initial value to use
+ Android's logging levels*/
+#define LOC_LOGE(...) \
+if ((loc_logger.DEBUG_LEVEL >= 1) && (loc_logger.DEBUG_LEVEL <= 5)) { ALOGE("W/"__VA_ARGS__); } \
+else if (loc_logger.DEBUG_LEVEL == 0xff) { ALOGE("W/"__VA_ARGS__); }
#define LOC_LOGW(...) \
-if (loc_logger.DEBUG_LEVEL >= 2) { ALOGE("W/"__VA_ARGS__); } \
-else if (loc_logger.DEBUG_LEVEL <= 0) { ALOGW("W/"__VA_ARGS__); }
+if ((loc_logger.DEBUG_LEVEL >= 2) && (loc_logger.DEBUG_LEVEL <= 5)) { ALOGE("W/"__VA_ARGS__); } \
+else if (loc_logger.DEBUG_LEVEL == 0xff) { ALOGW("W/"__VA_ARGS__); }
#define LOC_LOGI(...) \
-if (loc_logger.DEBUG_LEVEL >= 3) { ALOGE("I/"__VA_ARGS__); } \
-else if (loc_logger.DEBUG_LEVEL <= 0) { ALOGI("I/"__VA_ARGS__); }
+if ((loc_logger.DEBUG_LEVEL >= 3) && (loc_logger.DEBUG_LEVEL <= 5)) { ALOGE("I/"__VA_ARGS__); } \
+else if (loc_logger.DEBUG_LEVEL == 0xff) { ALOGI("I/"__VA_ARGS__); }
#define LOC_LOGD(...) \
-if (loc_logger.DEBUG_LEVEL >= 4) { ALOGE("D/"__VA_ARGS__); } \
-else if (loc_logger.DEBUG_LEVEL <= 0) { ALOGD("D/"__VA_ARGS__); }
+if ((loc_logger.DEBUG_LEVEL >= 4) && (loc_logger.DEBUG_LEVEL <= 5)) { ALOGE("D/"__VA_ARGS__); } \
+else if (loc_logger.DEBUG_LEVEL == 0xff) { ALOGD("D/"__VA_ARGS__); }
#define LOC_LOGV(...) \
-if (loc_logger.DEBUG_LEVEL >= 5) { ALOGE("V/"__VA_ARGS__); } \
-else if (loc_logger.DEBUG_LEVEL <= 0) { ALOGV("V/"__VA_ARGS__); }
+if ((loc_logger.DEBUG_LEVEL >= 5) && (loc_logger.DEBUG_LEVEL <= 5)) { ALOGE("V/"__VA_ARGS__); } \
+else if (loc_logger.DEBUG_LEVEL == 0xff) { ALOGV("V/"__VA_ARGS__); }
#else /* DEBUG_DMN_LOC_API */
diff --git a/utils/msg_q.c b/utils/msg_q.c
index 2c26417..c4f3b9d 100644
--- a/utils/msg_q.c
+++ b/utils/msg_q.c
@@ -30,7 +30,7 @@
#define LOG_TAG "LocSvc_utils_q"
#include "log_util.h"
-
+#include "platform_lib_includes.h"
#include "linked_list.h"
#include <stdio.h>
#include <stdlib.h>