blob: 9819d178a0509e353610e3033ecb53db05534d43 [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 * dcl_sim_gpio.h
41 *
42 * Project:
43 * --------
44 * Maui_Software
45 *
46 * Description:
47 * ------------
48 * This file defines structures and functions for SIM GPIO DCL interface.
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 * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
62 *============================================================================
63 ****************************************************************************/
64#ifdef DCL_DEFINITION_STRUCT
65
66#ifndef __DCL_SIM_GPIO_H_STRUCT__
67#define __DCL_SIM_GPIO_H_STRUCT__
68
69/*RHR*/
70//#include "kal_non_specific_general_types.h"
71#include "dcl.h"
72/*RHR*/
73
74typedef enum{
75 MT6306_SIM_GPIO1 = 0,
76 MT6306_SIM_GPIO2,
77 MT6306_SIM_GPIO3,
78 MT6306_SIM_GPIO4,
79 MT6306_SIM_GPIO5,
80 MT6306_SIM_GPIO6,
81 MT6306_SIM_GPIO7,
82 MT6306_SIM_GPIO8,
83 MT6306_SIM_GPIO9,
84 MT6306_SIM_GPIO10,
85 MT6306_SIM_GPIO11,
86 MT6306_SIM_GPIO12,
87 MT6306_SIM_GPI13,
88 MT6306_SIM_GPI14,
89 MT6306_SIM_GPI15,
90 MT6306_SIM_GPI16,
91 MT6306_SIM_GPI17,
92 MT6306_SIM_GPI18,
93}DCL_SIMGPIO_PIN_DEF;
94
95#define SIMGPIO_PULL_HIGH 1
96#define SIMGPIO_PULL_LOW 0
97#define SIMGPIO_DIR_IN 0
98#define SIMGPIO_DIR_OUT 1
99#define SIMGPIO_VOLT_18V 0
100#define SIMGPIO_VOLT_28V 1
101#define SIMGPIO_VOLT_30V 2
102
103
104/*******************************************************************************
105 * DCL_OPTIONS for SIMGPIO
106 *******************************************************************************/
107#define SIMGPIO_OPTIONS
108
109/*******************************************************************************
110 * DCL_CONFIGURE_T
111 *******************************************************************************/
112
113/*******************************************************************************
114 * DCL_EVENT for GPIO
115 *******************************************************************************/
116#define SIMGPIO_EVENTS
117
118/*******************************************************************************
119 * DCL_CTRL_CMD for GPIO
120 *******************************************************************************/
121#define SIMGPIO_CMDS \
122 SIMGPIO_CMD_READ, \
123 SIMGPIO_CMD_WRITE, \
124 SIMGPIO_CMD_SET_DIR, \
125 SIMGPIO_CMD_TRUN_ON_VCC, \
126 SIMGPI_CMD_READ,
127
128/*******************************************************************************
129 * DCL_CTRL_DATA_T: Define the Control data structure for each module's command
130 *******************************************************************************/
131/* FOR GPIO_CMD_READ control command. */
132typedef struct
133{
134 DCL_UINT8 u1IOData; // GPIO_IO_HIGH or GPIO_IO_LOW
135} SIMGPIO_CTRL_READ_T;
136
137/* FOR SIMGPIO_CMD_WRITE control command. */
138typedef struct
139{
140 DCL_UINT8 u1IOData;// GPIO_IO_HIGH or GPIO_IO_LOW
141} SIMGPIO_CTRL_WRITE_T;
142
143/* FOR SIMGPIO_CMD_SET_DIR control command. */
144typedef struct
145{
146 DCL_UINT16 u2Dir;
147} SIMGPIO_CTRL_SET_DIR_T;
148
149/* FOR SIMGPIO_CMD_TRUN_ON_VCC control command. */
150typedef struct
151{
152 kal_bool on;
153 kal_uint8 volt;
154} SIMGPIO_CTRL_TRUN_ON_POWER;
155
156#define SIMGPIO_CTRLS \
157 SIMGPIO_CTRL_READ_T rSGRead; \
158 SIMGPIO_CTRL_WRITE_T rSGWrite; \
159 SIMGPIO_CTRL_SET_DIR_T rSGSetDir; \
160 SIMGPIO_CTRL_TRUN_ON_POWER rSGTurnOnPower; \
161 SIMGPIO_CTRL_READ_T rSGIRead;
162
163#endif /*__DCL_SIM_GPIO_H_STRUCT__*/
164
165#endif /*DCL_DEFINITION_STRUCT*/
166
167#ifdef DCL_DEFINITION_PROTOTYPE
168#ifndef __DCL_SIM_GPIO_H_PROTOTYPE__
169#define __DCL_SIM_GPIO_H_PROTOTYPE__
170DCL_STATUS DclSIMGPIO_Initialize(void);
171DCL_HANDLE DclSIMGPIO_Open(DCL_DEV dev, DCL_FLAGS flags);
172DCL_STATUS DclSIMGPIO_Control(DCL_HANDLE handle, DCL_CTRL_CMD cmd, DCL_CTRL_DATA_T *data);
173DCL_STATUS DclSIMGPIO_Close(DCL_HANDLE handle);
174#endif /*__DCL_SIM_GPIO_H_PROTOTYPE__*/
175#endif //DCL_DEFINITION_PROTOTYPE
176
177