blob: f1f44626db55077d9e46efc05684ea1bf3d3c9d2 [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001/*****************************************************************************
2* Copyright Statement:
3* --------------------
4* This software is protected by Copyright and the information contained
5* herein is confidential. The software may not be copied and the information
6* contained herein may not be used or disclosed except with the written
7* permission of MediaTek Inc. (C) 2016
8*
9* BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
10* THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS (""MEDIATEK SOFTWARE"")
11* RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
12* AN ""AS-IS"" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
13* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
14* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
15* NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
16* SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
17* SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
18* THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
19* NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
20* SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
21*
22* BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
23* LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
24* AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
25* OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
26* MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
27*
28* THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
29* WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
30* LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
31* RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
32* THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
33*
34*****************************************************************************/
35/*************************************************************
36*
37* This Software is the property of VIA Telecom, Inc. and may only be used pursuant to a license from VIA Telecom, Inc.
38*
39* Any unauthorized use inconsistent with the terms of such license is strictly prohibited.
40*
41* Copyright (c) 2007-2010 VIA Telecom, Inc. All rights reserved.
42*
43*************************************************************/
44#ifndef VALLBSAPI_H
45#define VALLBSAPI_H
46/*************************************************************************************************
47*
48* FILE NAME : vallbsapi.h
49*
50* DESCRIPTION : This file contains the declarations, definitions
51* and data structures used to interface to the
52* VAL for the location based services (LBS) API.
53*
54*
55* HISTORY :
56* See Log at end of file
57*
58**************************************************************************************************/
59
60#include "sysdefs.h"
61#include "valapi.h"
62
63#define VAL_LBS_MAX_REG_TASK 2
64
65
66/* values match return values in Brew AEEError.h API */
67#define LBS_SUCCESS 0 /* Success */
68#define LBS_FAIL 1 /* General failure */
69#define LBS_CLASSNOTSUPPORT 3 /* Specified class unsupported */
70
71typedef enum
72{
73 VAL_LBS_GET_GPS_INFO_MSG,
74 VAL_LBS_GET_SECTOR_INFO_MSG,
75 VAL_EVT_MAX
76} ValLbsEventIdT;
77
78typedef struct
79{
80 RegIdT RegId;
81 kal_uint16 Result;
82 ValLbsSectorInfo Data;
83} ValLbsGetSectorInfoT;
84
85typedef struct
86{
87 kal_uint32 dwTimeStamp; /* Time, seconds since 1/6/1980 */
88 kal_uint32 status; /* Response status; */
89 kal_int32 dwLat; /* Lat, 180/2^25 degrees, WGS-84 ellipsoid */
90 kal_int32 dwLon; /* Lon, 360/2^26 degrees, WGS-84 ellipsoid */
91 kal_int16 wAltitude; /* Alt, meters, WGS-84 ellipsoid */
92 kal_uint16 wHeading; /* Heading, 360/2^10 degrees */
93 kal_uint16 wVelocityHor; /* Horizontal velocity, 0.25 meters/second */
94 kal_int8 bVelocityVer; /* Horizontal velocity, 0.25 meters/second */
95 kal_uint8 accuracy; /* Accuracy of the data */
96 kal_uint16 fValid; /* Flags indicating valid fields in the struct. */
97 kal_uint8 bHorUnc; /* Horizontal uncertainity */
98 kal_uint8 bHorUncAngle; /* Hor. Uncertainity at angle */
99 kal_uint8 bHorUncPerp; /* Hor. uncertainty perpendicular */
100 kal_uint16 wVerUnc; /* Vertical uncertainity. */
101} ValLbsGPSInfo;
102
103typedef struct
104{
105 RegIdT RegId;
106 kal_uint16 Result;
107 ValLbsGPSInfo Data;
108} ValLbsGetGpsInfoT;
109
110typedef struct
111{
112 kal_uint32 mode; /* See AEEGPSMode (one shot, download first, track local ...) */
113 kal_uint16 nFixes;
114 kal_uint16 nInterval;
115 kal_uint32 optim; /* See AEEGPSOpt (speed, accuracy, default) */
116 kal_uint32 qos; /* See AEEGPSQos (0 -> 255, with 255 being highest quality of service. */
117 kal_uint32 svrType; /* Default: 0 / Server IP: 1 (Address provided below) */
118 kal_uint32 addr; /* IP Address */
119 kal_uint16 port; /* port number */
120} ValGPSConfig;
121
122typedef struct
123{
124 kal_uint32 Is801_IpAddr;
125 kal_uint16 Is801_PortNum;
126 kal_uint8 Is801_UserId[HLP_MAX_USRID_LEN];
127 kal_uint8 Is801_Pswd[HLP_MAX_PSWD_LEN];
128 kal_uint8 Is801_CalledNumber[HLP_MAX_BWSR_DIG_LEN];
129} ValLbsNvmParmT;
130
131typedef enum
132{
133 VAL_LBS_PPP_SUCESS_STATUS,
134 VAL_LBS_PPP_FAIL_STATUS,
135 VAL_LBS_PPP_NOT_SUPPORTED_STATUS,
136 VAL_LBS_TCP_FAIL_STATUS,
137 VAL_LBS_NOT_SUPPORTED_STATUS,
138 NUM_LBS_STATUS
139}ValLbsStatusE;
140
141#ifdef __cplusplus
142extern "C" {
143#endif /* __cplusplus */
144
145/*===========================================================================
146
147FUNCTION ValLbsInit()
148
149DESCRIPTION Initialize the LBS Val Module
150
151PARAMETERS None
152
153RETURN VALUE None
154
155===========================================================================*/
156void ValLbsInit( void );
157
158/***************************************************************************
159
160FUNCTION ValLbsRegister
161
162DESCRIPTION This function registers a callback for all LBS related events.
163
164PARAMETERS NetCallback - The callback function to be called for the notification of LBS
165 services events.
166
167RETURN VALUE The assigned registration ID of the subscriber.
168
169*****************************************************************************/
170RegIdT ValLbsRegister( ValEventFunc Callback );
171
172/***************************************************************************
173
174FUNCTION ValLbsUnregister
175
176DESCRIPTION This function unregisters the given client so that it won't receive additional
177 LBS services related events.
178
179PARAMETERS RegId - The assigned registration ID of the subscriber.
180
181RETURN VALUE None
182
183*****************************************************************************/
184void ValLbsUnregister( RegIdT RegId );
185
186/*===========================================================================
187
188FUNCTION: ValLbsGetGPSInfo()
189
190DESCRIPTION: Val API to begin LBS session over TCP/IP.
191 Same as IPOSDET_GetGPSInfo() in Brew AEE API.
192
193PARAMETERS: RegIdT RegId
194
195RETURN VALUE: None
196
197===========================================================================*/
198void ValLbsGetGPSInfo( RegIdT RegId, ValGPSConfig* Config );
199
200#ifdef SYS_OPTION_HL
201/*===========================================================================
202
203FUNCTION: ValLbsGetSectorInfo()
204
205DESCRIPTION: Same as IPOSDET_GetSectorInfo() in Brew AEE API.
206
207PARAMETERS: RegIdT RegId
208
209RETURN VALUE: None
210
211===========================================================================*/
212void ValLbsGetSectorInfo( RegIdT RegId );
213#endif
214
215/*===========================================================================
216
217FUNCTION: ValLbsGetSap()
218
219DESCRIPTION: Return ValLocSapId
220
221PARAMETERS: None
222
223RETURN VALUE: kal_uint8 ValLocSapId
224
225===========================================================================*/
226kal_uint8 ValLbsGetSap( void );
227
228/*===========================================================================
229
230FUNCTION: ValLbsProcessEvent
231
232DESCRIPTION: This function processes the event received and calls the
233 registered call back.
234
235PARAMETERS: ValLbsEventIdT EventId, void *EventMsgP
236
237RETURN VALUE: None
238
239===========================================================================*/
240void ValLbsProcessEvent( ValLbsEventIdT EventId, void* EventMsgP );
241
242/*===========================================================================
243
244FUNCTION: ValLbsProcessDbmInfo
245
246DESCRIPTION: This function processes Dbm Nvm information
247
248PARAMETERS: ValLocGetSectorInfoRspMsgT* Msg
249
250RETURN VALUE: None
251
252===========================================================================*/
253void ValLbsProcessDbmInfo(ValLbsNvmParmT *Parm);
254
255#ifdef __cplusplus
256}
257#endif
258
259#endif /*__VAL_LBS_H__*/
260
261/*****************************************************************************
262* $Log: vallbsapi.h $
263* Revision 1.1 2007/05/19 14:11:49 mclee
264* Initial revision
265* Initial Version
266*****************************************************************************/
267
268/*****************************************************************************
269* End of File
270*****************************************************************************/
271
272