blob: 5c67f97de33da63c4c57c3cd7d550dbdfee01a7e [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) 2005
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 *
38 * Filename:
39 * ---------
40 * dcmgr.h
41 *
42 * Project:
43 * --------
44 *
45 *
46 * Description:
47 * ------------
48 * Dynamic Section Manager for dynamic section relocation into TCM(internal SRAM)
49 *
50 * Author:
51 * -------
52 * -------
53 *
54 *==============================================================================
55 * HISTORY
56 * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
57 *------------------------------------------------------------------------------
58 * removed!
59 * removed!
60 * removed!
61 *
62 * removed!
63 * removed!
64 * removed!
65 * removed!
66 *------------------------------------------------------------------------------
67 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
68 *==============================================================================
69 *******************************************************************************/
70
71#ifndef __DCMGR_H__
72#define __DCMGR_H__
73
74
75/*******************************************************************************
76 * Included header files
77 *******************************************************************************/
78
79
80
81/*******************************************************************************
82 * definition
83 *******************************************************************************/
84typedef enum {
85 DYNAMIC_L2CACHE_SECTION_3GW = 0,
86 DYNAMIC_L2CACHE_SECTION_3GW_IDLE,
87 /* insert id before this line*/
88 DYNAMIC_CACHE_SECTION_NUM /* 2 */
89} dcm_section_id;
90
91
92/* make sure to define TOTAL_DCM_SECTION as valuse of DYNAMIC_CACHE_SECTION_NUM */
93#define TOTAL_DCM_SECTION (1)
94#define DCM_MAX_NUM (32)
95
96
97/* define dcm function return status */
98typedef enum {
99 DCM_STATUS_SUCCESS, /* the operation is succeeded */
100 DCM_STATUS_LOAD_BEFORE, /* the section has been load before*/
101 DCM_STATUS_UNLOAD_NOTHING, /* the section has been load before */
102} dcm_status;
103
104
105/* define dcm section status */
106typedef enum {
107 DCM_SECTION_LOAD, /* the section is loaded */
108 DCM_SECTION_UNLOAD, /* the section is not loaded */
109} dcm_section_status;
110
111
112
113
114/*******************************************************************************
115 * External Function Declaration
116 *******************************************************************************/
117dcm_status DCM_Load(kal_uint32 dynamic_section_id);
118
119dcm_status DCM_Unload(kal_uint32 dynamic_section_id);
120
121dcm_section_status DCM_QuerySectionStatus(dcm_section_id dynamic_section_id);
122
123kal_bool DCM_IsLoad(kal_uint32 dynamic_section_id);
124
125
126
127#endif /* __DCMGR_H__ */