blob: 0f65fbdb78a24d29c723dceb71ac73933150e270 [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 * dsp_boot_public.h
41 *
42 * Project:
43 * --------
44 * Maui_Software
45 *
46 * Description:
47 * ------------
48 * This Module defines the HW initialization.
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 *
59 *
60 *
61 * removed!
62 * removed!
63 *------------------------------------------------------------------------------
64 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
65 *============================================================================
66 ****************************************************************************/
67#ifndef DSP_FILE_PUBLIC_H
68#define DSP_FILE_PUBLIC_H
69
70#include "kal_general_types.h"
71
72
73/*******************************************************************************
74 * Macro definitions
75 *******************************************************************************/
76#define DSP_VER_SZ 32
77#define DSP_VER_STR_OVHD 512
78#define DSP_VER_STR_TTL_SZ (DSP_VER_SZ * 4 * 6 + DSP_VER_STR_OVHD)
79
80#define ERROR_DUMP_CORE_TYPE_UNDEFINED 0xDEADBEEF
81#define ERROR_DUMP_CORE_TYPE_NOT_USIP_SCQ16 0xDEAD0000
82#define ERROR_DUMP_NO_USIP_SCQ16_MAPPING 0xDEAD0010
83#define ERROR_DUMP_CORE_TYPE_NOT_RAKE 0xDEAD0006
84#define ERROR_DUMP_NO_RAKE_MAPPING 0xDEAD0016
85#define ERROR_DUMP_CORE_TYPE_NOT_SONIC 0xDEAD0026
86#define ERROR_DUMP_NO_SONIC_MAPPING 0xDEAD0036
87
88/*******************************************************************************
89 * Function prototypes
90 *******************************************************************************/
91kal_uint32 DSP_Init(void);
92kal_bool DSP_IsVersionMismatched(void);
93const kal_char *DSP_GetVersionString(void);
94
95/* TO DO: refine this to adapt to MIPS */
96//#ifdef __L1CORE__
97
98typedef enum {
99 DSP_DUMP_USIP0,
100 DSP_DUMP_USIP1,
101 DSP_DUMP_SCQ16_0,
102 DSP_DUMP_SCQ16_1,
103 DSP_DUMP_RAKE,
104 DSP_DUMP_SCQ16_2,
105 DSP_DUMP_SCQ16_3,
106#if defined(__MD97__)
107 DSP_DUMP_MSONIC0,
108 DSP_DUMP_VSONIC0,
109 DSP_DUMP_MSONIC0_PHASE2,
110#endif
111 DSP_DUMP_INVALID
112} DSP_DUMP_CORE_TYPE;
113
114
115typedef enum {
116 DSP_MD32_BRP,
117 DSP_MD32_DFE,
118 DSP_MD32_RAKE,
119 DSP_CS_ICC,
120 DSP_CS_IMC,
121 DSP_CS_MPC,
122 DSP_CORE_NUM,
123} DSP_CORE_TYPE;
124
125void DSP_OutputVersionInfo();
126const kal_char *DSP_GetProject(DSP_CORE_TYPE dsp_type);
127const kal_char *DSP_GetFlavor(DSP_CORE_TYPE dsp_type);
128const kal_char *DSP_GetLabel(DSP_CORE_TYPE dsp_type);
129const kal_char *DSP_GetBuildTime(DSP_CORE_TYPE dsp_type);
130//#endif /* __L1CORE__ */
131
132#endif /* DSP_FILE_PUBLIC_H */
133