blob: d242a3c6e3e4e308e33766666707d6d0e2231ec6 [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) 2012
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 * Filename:
38 * ---------
39 * emacmch_rxlisr_interface.h
40 *
41 * Project:
42 * --------
43 * UMOLY
44 *
45 * Description:
46 * ------------
47 * Declare the structures/enum/functions(api)/global variables that are
48 * shared with or called by RX LISR.
49 *
50 * Author:
51 * -------
52 * -------
53 *
54 *
55 * ==========================================================================
56 * $Log$
57 *
58 * 03 31 2017 eddie.wang
59 * [MOLY00236421] [MT6293][UMOLYA][TRUNK]
60 * [EMACMCH][L+L] Add pidx for RXLISR query next mch interface
61 *
62 * 12 12 2016 eddie.wang
63 * [MOLY00210650] [MT6293][UMOLYA TRUNK] EMAC maintenance
64 * [EMUX][EMACMCH] Introduce debug mode
65 *
66 * 09 23 2016 eddie.wang
67 * [MOLY00194987] [MT6293][UMOLYA/PS DEV] EMAC maintenance
68 * Sync PS.DEV to TRUNK up to CL2868873
69 *
70 * 09 20 2016 eddie.wang
71 * [MOLY00197177] Code maintenance on UMOLYA.PS.DEV
72 * EMUX and EMACMCH code/trace maintenance
73 *
74 * 07 27 2016 jeremy.chen
75 * [MOLY00190683] [UMOLYA][6293] EL2 merge back to UMOLYA TRUNK & PS DEV
76 * [EL2][RD domain] Sync latest EL2 from LTE domain
77 *
78 ****************************************************************************/
79/**
80 * @file emacmch_rxlisr_interface.h
81 * @brief Declare the structures/enum/functions(api)/global variables that are
82 * shared with or called by RX LISR
83 * @author mtk04120
84 * @date 2016/2/22
85 *
86 **/
87#ifndef EMACMCH_RXLISR_INTERFACE_H
88#define EMACMCH_RXLISR_INTERFACE_H
89
90#include "kal_public_api.h"
91
92#include "el1_enum.h"
93
94/*---------------------------------------------------------------------------
95 * DEFINITION
96 *---------------------------------------------------------------------------*/
97/* Configurable */
98
99/* User-defined */
100
101/* Constant */
102
103/*---------------------------------------------------------------------------
104 * ENUM
105 *---------------------------------------------------------------------------*/
106
107
108/*---------------------------------------------------------------------------
109 * STRUCTURE
110 *---------------------------------------------------------------------------*/
111/*---------------------------------------------------------------------------
112 * STRUCTURE
113 *---------------------------------------------------------------------------*/
114/*------------------
115 * Structure Level 3
116 *------------------*/
117
118/*------------------
119 * Structure Level 2
120 *------------------*/
121
122/*------------------
123 * Structure Level 1
124 *------------------*/
125typedef struct{
126
127 kal_uint32 tid;
128 kal_bool b_valid;
129
130 kal_uint8 syncarea_id;
131 kal_uint8 area_id; //0-255
132 kal_uint8 pmch_id; //pmch_ie_idx
133#if 0
134/* under construction !*/
135/* under construction !*/
136/* under construction !*/
137/* under construction !*/
138/* under construction !*/
139/* under construction !*/
140/* under construction !*/
141#endif
142 kal_uint8 non_mbsfn_region_len;
143
144 kal_bool is_mch_reliable; // True when MCCH, MSI, UE-interested MTCH in MSI
145
146 kal_bool is_signal_mcs;
147 kal_bool is_higher_order_mcs; // FALSE if signalMCS
148 kal_uint8 mcs;
149
150 el1_embms_gemini_priority_enum gemini_priority;
151
152 kal_uint32 sf_no;
153 kal_uint64 abs_time;
154
155}emacmch_rxlisr_sched_mch_t;
156/*---------------------------------------------------------------------------
157 * Extern global variable declarations
158 *---------------------------------------------------------------------------*/
159
160/*---------------------------------------------------------------------------
161 * public methods prototype for RX LISR
162 *---------------------------------------------------------------------------*/
163
164void
165emacmch_rxlisr_query_next_sched_mch(kal_uint64 _abs_time, //IN
166 kal_uint8 _syncarea_id, //IN
167 emacmch_rxlisr_sched_mch_t* _next_sched, //OUT
168 kal_uint32 _pidx); //IN
169
170
171#endif