blob: bd310ca67635bde6092f1ff181be81afecab04e7 [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 _SLCTIMER_H_
45#define _SLCTIMER_H_ 1
46/*****************************************************************************
47*
48* FILE NAME : slctimer.h
49*
50* DESCRIPTION : Timer Controller interface for the SLC Task
51*
52*****************************************************************************/
53#include "tasktimer.h"
54
55
56/*----------------------------------------------------------------------------
57 Global Defines and Macros
58----------------------------------------------------------------------------*/
59/*----------------------------------------------------------------------------
60 Global Typedefs
61----------------------------------------------------------------------------*/
62
63/* define the timer ID for timers in SLC, match following function */
64/*
65static const ProtocolTimerHandlerT protocolTimerHandlerTable[NUM_SLCTMRs] = {
66 GcpTimerHandler,
67 DScpGaupTimerHandler,
68 DScpReconfigCnfWaitTimerHandler,
69 DScpANInitStWaitReqTimerHandler,
70 ProcessAmpAddrTimeout,
71 ProcessAmpWaitUATIRspTimeout,
72 ProcessSmpKeepAliveTransTimeout,
73 ProcessAmpUATICompleteTimeout,
74 ProcessAmpReSendUATIReqTimeOut
75};
76
77*/
78typedef enum
79{
80 GCP_TRANSACTION_TICK_TIMER_ID = 0,
81 DSCP_GAUP_TURNAROUND_TIMER_ID,
82 DSCP_RECONFIG_CNF_WAIT_TIMER_ID,
83 DSCP_AN_INIT_ST_WAIT_REQ_TIMER_ID,
84 AMP_ADDRESS_TIMER_ID,
85 AMP_WAIT_UATI_RSP_TIMER_ID,
86 SMP_KEEPALIVE_TRANS_TIMER_ID,
87 AMP_UATICOMPLETE_DURATION_TIMER_ID,
88 AMP_RESEND_UATIREQ_TIMER_ID,
89 NUM_SLCTMRs
90} slcTimerIdT;
91
92/* SLC timer TRACE code */
93typedef enum
94{
95 SCP_TIMER_START = 0,
96 SCP_TIMER_STOP,
97 SCP_TIMER_EXPIRE
98} SlcTimerTraceT;
99
100
101
102/*----------------------------------------------------------------------------
103 Global Data
104----------------------------------------------------------------------------*/
105
106/*----------------------------------------------------------------------------
107 Global Function Prototypes
108----------------------------------------------------------------------------*/
109/* the following Macro defines the API of SLC timer management as followings:
110
111 void slcTimerInit(void);
112 void slcStartTimer(slcTimerIdT TimerId, kal_uint32 duration, kal_bool periodic, kal_uint16 prot);
113 void slcStopTimer(slcTimerIdT TimerId);
114 void slcStopAllProtocolTimers(void);
115 void slcStopProtProtocolTimers(kal_uint16 prot);
116 kal_bool slcIsTimerActive(slcTimerIdT TimerId);
117 void slcProcessTimerExpiredMsg(void* MsgP);
118
119 Note: slc is the Macro parameter, it corresponds to the "slc" in the names
120 of each API function. Note: no ; is needed at the line end
121 */
122
123TaskTimerAPIDef(slc)
124
125/*****************************************************************************
126* End of File
127*****************************************************************************/
128#endif /*_SLCTIMER_H_*/
129
130