[Feature]Upload Modem source code

Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/interface/driver/hwdrv/ds_if.h b/mcu/interface/driver/hwdrv/ds_if.h
new file mode 100644
index 0000000..245bca1
--- /dev/null
+++ b/mcu/interface/driver/hwdrv/ds_if.h
@@ -0,0 +1,260 @@
+/*****************************************************************************
+*  Copyright Statement:
+*  --------------------
+*  This software is protected by Copyright and the information contained
+*  herein is confidential. The software may not be copied and the information
+*  contained herein may not be used or disclosed except with the written
+*  permission of MediaTek Inc. (C) 2010
+*
+*  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
+*  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
+*  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
+*  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
+*  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
+*  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
+*  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
+*  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
+*  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
+*  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
+*  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
+*  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
+*
+*  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
+*  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
+*  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
+*  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
+*  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE. 
+*
+*  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
+*  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
+*  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
+*  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
+*  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
+*
+*****************************************************************************/
+
+/*******************************************************************************
+ * Filename:
+ * ---------
+ *	ds_if.h
+ *
+ * Project:
+ * --------
+ *   ALL
+ *
+ * Description:
+ * ------------
+ *   This file is intends for direct sensor interface driver.
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *============================================================================
+ *             HISTORY
+ * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+ *------------------------------------------------------------------------------
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ *
+ *------------------------------------------------------------------------------
+ * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+ *============================================================================
+ ****************************************************************************/
+#ifndef __DS_IF_H__
+#define __DS_IF_H__
+
+//RHR #include "kal_release.h"
+//MSBB remove #include "kal_non_specific_general_types.h"
+
+
+//Action Id
+#define DS_IF_DATA_BUS_CONTL  0x01 
+#define DS_IF_SEN2LCM_SET  0x02
+#define DS_IF_FRAME_DONE_CB_REGISTER  0x04
+#define DS_IF_SENSOR_PAUSE_CB_REGISTER  0x08
+#define DS_IF_SENSOR_RESUME_CB_REGISTER  0x10
+
+
+//Error code
+#define DS_IF_SUCCEED                                               0x0000
+#define DS_IF_ERR_INVALID_HANDLE                          0x0001 
+#define DS_IF_ERR_INVALID_ACTION                          0x0002
+#define DS_IF_ERR_INVALID_PARA                              0x0004
+#define DS_IF_ERR_NOT_ALLOWED_STATE                  0x0008
+#define DS_IF_ERR_CALLER_CONTEXT_NOT_ALLOW    0x0010
+#define DS_IF_ERR_CAL_NOT_DIRECT_SENSOR           0x0020
+#define DS_IF_ERR_CAL_NOT_CONFIG_HW_TIMING    0x0040
+#define DS_IF_ERR_NOT_REGISTERED_CB                    0x0080
+#define DS_IF_ERR_TOO_MANY_USERS                        0x8000
+
+
+
+#define USER_HANDLE_FOR_NON_DIRECT_SENSOR                  0x0
+#define DUMMY_USER_HANDLE_FOR_TOO_MANY_USERS          0xF1
+
+
+typedef void (*DS_CB_FUNC)(void * cb_para);
+
+typedef enum
+{
+   DS_IF_STATE_INIT= 0, 
+   DS_IF_STATE_READY = 1, 
+   DS_IF_STATE_BUS = 2, 
+   DS_IF_STATE_BUSY = 3 
+} DS_IF_STATE_E;
+
+
+typedef enum
+{
+   UNKNOWN_SENSOR = 0, 
+   DIRECT_SENSOR = 1, 
+   SERIAL_SENSOR = 2, 
+   PARALLEL_SENSOR= 3 
+} SENSOR_IF_TYPE;
+
+typedef enum
+{
+   CAL_DS_IF_USER = 0, 
+   LCD_DS_IF_USER, 
+   MAX_DS_IF_USERS 
+} DS_IF_USER;
+
+
+typedef struct
+{
+   kal_uint16 para_1;
+   kal_uint16 para_2;
+   kal_uint16 para_3;
+   kal_uint16 para_4;
+   kal_uint16 para_5;
+   kal_uint16 para_6;
+   kal_bool para_7;
+   kal_bool para_8;
+   kal_bool para_9;
+   kal_uint32 para_10;
+} DS_SEN2LCM_T;
+
+
+typedef struct
+{
+//only valid for action DS_DATA_BUS_CONTL been asserted.
+kal_bool    data_bus_control_take; // KAL_TRUE for taken, KAL_FALSE for release, 
+// only valid for DS_SEN2LCM_SET been asserted.
+DS_SEN2LCM_T    sen2lcm_setting; 
+// only valid for DS_FRAME_DONE_CB_REGISTER been asserted.
+kal_bool    repeat_callback; // KAL_TRUE for repeat, KAL_FALSE for first frame only
+DS_CB_FUNC    frame_done_cb_func;
+// only valid for DS_SENSOR_PAUSE_CB_REGISTER been asserted.
+DS_CB_FUNC    sensor_pause;
+// only valid for DS_SENSOR_RESUME_CB_REGISTER been asserted.
+DS_CB_FUNC    sensor_resume;
+} DS_CONFG_T;
+
+
+/**
+ *  Get user handle for other function call usage afterwards.
+ *  @param sensor      : sensor type
+ *  @param user_id      : predefine user id
+ *  @return kal_uint32 : user handle
+ *  @remarks This function return user handle, which is valid on for DIRECT_SENSOR.
+ *           Other sensor type returned handle is not effective in following call.
+ */
+kal_uint32 ds_if_open(SENSOR_IF_TYPE sensor, DS_IF_USER user_id);
+
+
+/**
+ *  release user handle and close usage privilege.
+ *  @param handle      : user handle
+ *  @return kal_uint32 : error code
+ *  @remarks This function must call after ds_if_open() and can not call in HW interface busy state.
+ *  
+ */
+kal_uint32 ds_if_close(kal_uint32 handle);
+
+
+/**
+ *  configure the HW parameters or others
+ *  @param handle      : user handle
+ *  @param action       : action id
+ *  @param para         : parameters corresponding to action id
+ *  @return kal_uint32 : error code
+ *  @remarks This function must call after ds_if_open() and can not call in HW interface busy state.
+ *  
+ */
+kal_uint32 ds_if_config(kal_uint32 handle, kal_uint32 action, DS_CONFG_T* para);
+
+
+/**
+ *  start HW for direct sensor mode display 
+ *  @param handle      : user handle
+ *  @return kal_uint32 : error code
+ *  @remarks This function must call after ds_if_open() and can not call in HW interface busy state.
+ *  
+ */
+kal_uint32 ds_if_start (kal_uint32 handle);
+
+
+/**
+ *  stop HW which is in direct sensor mode display 
+ *  @param handle      : user handle
+ *  @return kal_uint32 : error code
+ *  @remarks This function must call after ds_if_open() and after ds_if_start( ). That is, only stop HW when HW is in busy state
+ *  
+ */
+kal_uint32 ds_if_stop (kal_uint32 handle);
+
+
+
+/**
+ *  query current HW(direct sensor interface) state
+ *  @param 
+ *  @return DS_IF_STATE_E : HW state
+ *  @remarks After first call ds_if_open() the state change from INIT to READY. Afterwards, BUS, or BUSY states transition depends on data bus and hw status.
+ *  
+ */
+DS_IF_STATE_E ds_if_query_state (void);
+
+//only for lcd driver
+kal_uint32 ds_if_pause_sensor_cb (kal_uint32 handle);
+
+//only for lcd driver
+kal_uint32 ds_if_resume_sensor_cb (kal_uint32 handle);
+
+//only call from lcd_Hisr
+kal_uint32 ds_if_hisr(kal_uint32 intr_status);
+
+//only for lcd driver
+void lcd_set_ds_a0_polarity(unsigned long a0);
+
+//only for lcd driver
+kal_uint32 ds_if_enable_per_frame_lcm_roi_coms (kal_uint32 handle, kal_bool on_Noff);
+
+#endif   /*__DS_IF_H__*/
+