blob: 0f2cf2745e156904c28371d12344ff1788d90d83 [file] [log] [blame]
yu.dongc33b3072024-08-21 23:14:49 -07001/*****************************************************************************
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#ifndef _CPHSYSTIME_H_
36#define _CPHSYSTIME_H_
37
38#include "cl1common.h"
39#include "cphsystemtimer.h"
40#include "kal_general_types.h"
41#include "sysdefs.h"
42#include "sysapi.h"
43
44#define CphSysStIntClr(Airinterface, Mask) HwdWrite32(ST_CPINT_CLR(Airinterface), Mask)
45#define CphSysStHalfIntClr(Airinterface, Mask) HwdWrite32(ST_HALF_CPINT_CLR(Airinterface), Mask)
46
47
48
49/* System Timer Common Part*/
50extern void CphSysTimeInit(void);
51extern void CphSysTimeAdvRet (SysAirInterfaceT Airinterface, kal_uint16 Echips, kal_bool Advance);
52extern void CphSysTimeSyncTime (SysAirInterfaceT Airinterface, kal_uint32 SyncEchip, kal_uint32 EchipIni, kal_uint8 SupfrmIniH, kal_uint32 SupfrmIniL);
53extern void CphSysTimeSetSupfrmCnt (SysAirInterfaceT Airinterface, kal_uint8 SupfrmIniH, kal_uint32 SupfrmIniL);
54extern void CphSysSetFrameSize (SysAirInterfaceT Airinterface, SysFrameSizeT FrameSize);
55extern void CphSysStIntDisable (SysAirInterfaceT Airinterface, kal_uint16 Mask);
56extern void CphSysStIntEnable (SysAirInterfaceT Airinterface, kal_uint16 Mask);
57extern void CphSysStHalfIntDisable (SysAirInterfaceT Airinterface, kal_uint32 Mask);
58extern void CphSysStHalfIntEnable (SysAirInterfaceT Airinterface, kal_uint32 Mask);
59extern void CphSysSetStIntOffset (SysAirInterfaceT Airinterface, kal_uint32 ChipOffset2x);
60extern kal_uint32 CphSysGetStIntOffset (SysAirInterfaceT Airinterface);
61extern void CphSysSetStHalfIntOffset (SysAirInterfaceT Airinterface, kal_uint32 ChipOffset2x);
62extern kal_uint32 CphSysGetStHalfIntOffset (SysAirInterfaceT Airinterface);
63extern void CphSysTimeSetSfo (SysAirInterfaceT Airinterface, kal_int16 AfcPpb);
64extern kal_int16 CphSysTimeGetSfo (SysAirInterfaceT Airinterface);
65extern kal_uint32 CphSysTimeEchipCnt(SysAirInterfaceT Airinterface);
66extern kal_uint64 CphSysTimeSupfrmCnt(SysAirInterfaceT Airinterface);
67extern kal_uint16 CphSysTimeSymbNum(SysAirInterfaceT Airinterface);
68extern kal_int32 CphSysTime1xDiffToDo(void);
69#if defined __MD95__
70extern kal_int64 CphSysTime1xTotalDiffToDo(void);
71#endif
72extern kal_int32 CphSysTimeTxDiffToRx(SysAirInterfaceT Airinterface);
73extern void CphSysTimeWait(SysAirInterfaceT Airinterface, kal_uint32 EchipWait);
74extern kal_int32 CphSysTimeTxDiffToRxInWin(SysAirInterfaceT Airinterface);
75extern void CphSysTimeTxTimerAdj(SysAirInterfaceT Airinterface, kal_int32 Adj32x);
76extern void CphSysTimeTxSyncToRx(SysAirInterfaceT Airinterface);
77
78#if defined(MTK_C2K_COSIM)
79extern void Sys1xPcgLisr(void);
80extern void SysDoSlotLisr(void);
81extern kal_uint64 CphSysTimeInSlotGet(SysAirInterfaceT Airinterface);
82#endif
83
84extern kal_uint32 CphReadSyncTime(SysAirInterfaceT Airinterface);
85
86
87#endif
88