[Feature]Upload Modem source code
Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/driver/connectivity/usb_class/include/usbd.h b/mcu/driver/connectivity/usb_class/include/usbd.h
new file mode 100644
index 0000000..015357f
--- /dev/null
+++ b/mcu/driver/connectivity/usb_class/include/usbd.h
@@ -0,0 +1,437 @@
+/*****************************************************************************
+* 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) 2005
+*
+* 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:
+ * ---------
+ * usbd.h
+ *
+ * Project:
+ * --------
+ * Maui_Software
+ *
+ * Description:
+ * ------------
+ * This file intends for usb1.1 host definitions.
+ *
+ * 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!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * removed!
+ * removed!
+ * removed!
+ *
+ * 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 USBD_H
+#define USBD_H
+
+//#include "usb_hcd.h"
+#include "dcl.h"
+//#include "kal_non_specific_general_types.h"
+#include "usb.h"
+#include "usb_drv.h"
+#include "usb_custom_def.h"
+
+
+#define USBD_MAX_CFG_NUM 8
+#define USBD_MAX_IF_PER_CFG 4
+#define USBD_MAX_INTERFACE_NUM (USBD_MAX_CFG_NUM * USBD_MAX_IF_PER_CFG)
+#define USBD_MAX_EP_PER_IF 3
+#define USBD_MAX_EP_NUM (USBD_MAX_INTERFACE_NUM * USBD_MAX_EP_PER_IF)
+#define USBD_MAX_CLASS_DRIVER 2
+
+#define USBD_EP0_MAX_PKT_SIZE 64
+
+#define USBD_ERROR_DELAY 35 /* 10ms unit*/
+
+#define USBD_SET_ADDRESS_RECOVERY_DELAY 1
+
+#define USBD_TEST_MODE_DELAY 1500
+//#define USBD_TEST_MODE_DELAY 300
+
+
+#ifdef __OTG_ENABLE__
+#define USB_EXT_HOST_NUM 1
+#else
+#define USB_EXT_HOST_NUM 0
+#endif
+
+#ifdef __IC_USB_ENABLE__
+#define USB_INT_HOST_NUM 1
+#else
+#define USB_INT_HOST_NUM 0
+#endif
+
+
+#define USB_HOST_NUM (USB_EXT_HOST_NUM + USB_INT_HOST_NUM)
+
+
+/* USBD test mode */
+#define USBD_TEST_SE0_NAK 0x0101
+#define USBD_TEST_J 0x0102
+#define USBD_TEST_K 0x0103
+#define USBD_TEST_PACKET 0x0104
+#define USBD_TEST_HS_HOST_PORT_SUSPEND_RESUME 0x0106
+#define USBD_TEST_SINGLE_STEP_GET_DEV_DESC 0x0107
+#define USBD_TEST_SINGLE_STEP_SET_FEATURE 0x0108
+#define USBD_TEST_UNSUPPORTED_DEVICE 0xBADD
+
+
+
+
+#define EVENT_USBD_EP0_DONE ((kal_uint32)0x00000001)
+#define EVENT_USBD_EP0_DETACH ((kal_uint32)0x00000002)
+#define EVENT_USBD_EP0_ENUMERATION ((kal_uint32)0x00000004)
+#define EVENT_USBD_RESUME_DONE ((kal_uint32)0x00000008)
+
+typedef enum
+{
+ USBD_CH9_START,
+ USBD_CH9_STOP,
+ USBD_CH9_DELAY_SET_ADDR,
+ USBD_CH9_SET_ADDR,
+ USBD_CH9_GET_DEV_DESC_8,
+ USBD_CH9_GET_DEV_DESC,
+ USBD_CH9_GET_CONF_DESC_9,
+ USBD_CH9_GET_CONF_DESC,
+ USBD_CH9_SET_CONF,
+ USBD_CH9_SET_HNP_ENABLE,
+ USBD_CH9_ENUM_OK,
+ USBD_CH9_ENUM_FAIL
+}USBD_CH9_STATE;
+
+
+typedef enum
+{
+ USBD_EP0_SETUP,
+ USBD_EP0_DATA,
+ USBD_EP0_STATUS,
+ USBD_EP0_NONE
+}USBD_EP0_STATE;
+
+
+typedef enum
+{
+ USBD_EP0_DATA_RECV,
+ USBD_EP0_DATA_SEND,
+ USBD_EP0_DATA_NULL /* no data phase is needed */
+}USBD_EP0_DATA_DIR;
+
+
+typedef enum
+{
+ USBD_HNP_NOT_SUPPORT,
+ USBD_HNP_SUPPORT,
+ USBD_HNP_ENABLE_STALL
+}USBD_HNP_SUPPORT_TYPE;
+
+
+typedef enum
+{
+ USBD_TEST_MODE_NONE = 0,
+ USBD_TEST_MODE_TYPE_SE0,
+ USBD_TEST_MODE_TYPE_J,
+ USBD_TEST_MODE_TYPE_K,
+ USBD_TEST_MODE_TYPE_TEST_PACKET,
+ USBD_TEST_MODE_TYPE_HS_HOST_PORT_SUSPEND_RESUME,
+ USBD_TEST_MODE_TYPE_SINGLE_STEP_GET_DEV_DESC,
+ USBD_TEST_MODE_TYPE_SINGLE_STEP_SET_FEATURE,
+ USBD_TEST_MODE_TYPE_UNSUPPORTED_DEVICE
+}USBD_TEST_MODE_TYPE;
+
+
+/* EP0 status */
+typedef struct
+{
+ kal_uint8 device_addr; /* new function address */
+// kal_uint8 max_packet_size;
+ Usb_Command setup_cmd; /* setup packet address */
+ kal_uint8 *data_ptr; /* data packet address */
+ USBD_EP0_DATA_DIR ep0_data_dir; /* data phase direction */
+ kal_uint32 sofar; /* number of bytes sent/recv'd so far */
+ kal_uint32 todo; /* number of bytes to send/recv */
+}USBD_EP0_Status;
+
+
+/* Bulk IN endpoint status */
+typedef struct
+{
+ kal_uint8 max_packet_size;
+ kal_uint8 *data_ptr; /* data packet address */
+ kal_uint32 sofar; /* number of bytes sent/recv'd so far */
+ kal_uint32 todo; /* number of bytes to send/recv */
+}USBD_EPIN_Status;
+
+
+/* Bulk OUT endpoint status */
+typedef struct
+{
+ kal_uint8 max_packet_size;
+ kal_uint8 *data_ptr; /* data packet address */
+ kal_uint32 sofar; /* number of bytes sent/recv'd so far */
+ kal_uint32 todo; /* number of bytes to send/recv */
+}USBD_EPOUT_Status;
+
+/* endpoint information, including endpoint status */
+typedef struct
+{
+ Usb_Ep_Dscr *p_stdep; /* ep descriptor */
+ union
+ {
+ USBD_EPIN_Status epin_status;
+ USBD_EPOUT_Status epout_status;
+ }ep_status;
+}USBD_EP_Info;
+
+
+typedef struct
+{
+ Usb_If_Dscr *p_interface_desc;
+ USBD_EP_Info *p_ep_info[USBD_MAX_EP_PER_IF];
+ kal_uint8 ep_number;
+}USBD_IF_Info;
+
+
+typedef struct
+{
+ Usb_Cfg_Dscr *p_cfg_desc;
+ USBD_IF_Info *p_interface_info[USBD_MAX_IF_PER_CFG];
+ kal_uint8 match_class_driver_index[USBD_MAX_IF_PER_CFG]; /* To store the class driver index for each interface */
+ kal_uint8 match_class_driver_point; /* To store the weighting of class driver index for each configuration */
+ kal_uint8 active_if_index_map; /* the index mapping that the active interface */
+ kal_uint8 interface_number;
+ kal_uint8 match_class_num; /* the number that match class drivers, exclude default driver */
+}USBD_CFG_Info;
+
+
+typedef struct
+{
+ Usb_Dev_Dscr dev_desc;
+ USBD_CFG_Info cfg_info[USBD_MAX_CFG_NUM];
+// Usb_IAD_Dscr *iad_desc;
+ USBD_IF_Info interface_info[USBD_MAX_INTERFACE_NUM];
+ USBD_EP_Info ep_info[USBD_MAX_EP_NUM];
+ Usb_String_Dscr *string_desc;
+ Usb_Otg_Dscr *p_otg_desc[USBD_MAX_CFG_NUM];
+ Usb_Dev_Qual_Dscr *dev_qual_dscr;
+ Usb_Other_Speed_Cfg_Dscr *other_speed_cfg_dscr;
+// Usb_OS_String_Dscr *os_string_desc;
+// Usb_Ext_Compat_ID_OS_Feature_Dscr *os_feature_desc;
+ kal_uint8 *p_conf_data[USBD_MAX_CFG_NUM];
+ kal_uint8 cfg_number;
+}USBD_Desc_Info;
+
+
+typedef struct
+{
+ kal_bool (* match)(kal_uint8 usb_ip_port, USBD_Desc_Info *p_desc_info, kal_uint32 cfg_num, kal_uint32 if_num);
+ void (* startup)(kal_uint8 usb_ip_port, USBD_Desc_Info *p_desc_info, kal_uint32 cfg_num, kal_uint32 if_num);
+ void (* detach)(kal_uint8 usb_ip_port);
+ void (* suspend)(kal_uint8 usb_ip_port);
+ void (* resume)(kal_uint8 usb_ip_port);
+}USBD_ClassDriver_Struct;
+
+
+typedef void (*usbd_ep0_callback)(kal_uint8 usb_ip_port, USB_HCD_STATUS result, kal_uint32 param);
+
+
+typedef struct
+{
+ USBD_Desc_Info desc_info;
+ USBD_EP0_STATE ep0_state; //states machine
+ USBD_EP0_Status ep0_status;
+ USBD_CH9_STATE ch9_state;
+ USBD_ClassDriver_Struct *class_driver_ptr[USBD_MAX_CLASS_DRIVER];
+ usbd_ep0_callback ep0_callback;
+ kal_uint8 ch9_error_count;
+ USBD_HNP_SUPPORT_TYPE support_hnp;
+ kal_uint8 default_class_driver_index;
+ kal_bool b_is_match_hub;
+ kal_uint32 gpt_handle; /*GPT handle*/
+ kal_mutexid usbd_ep0_mutex_id; /* mutex used to protect ep0 setup command. */
+ kal_mutexid usbd_resume_mutex_id; /* mutex used to protect ep0 setup command. */
+ kal_eventgrpid usbd_ep0_event_id; /* event used for ep0 command */
+ kal_eventgrpid usbd_resume_event_id; /* event used for ep0 command */
+ kal_bool b_suspend_mode;
+ kal_uint8 set_cfg_number;
+ kal_uint8 usb_ip_port;
+}USBD_Struct;
+
+
+typedef struct
+{
+ kal_mutexid usbd_com_ep0_mutex_id; /* mutex used to let multiple IPs can be enumerated one by one*/
+ kal_eventgrpid usbd_com_ep0_event_id; /* event used for waiting enumeration done */
+ /* Customizable variables */
+ const USB_HOST_MATCH_PARAM *host_match_param;
+}USBD_Common_Struct;
+
+
+
+//extern void USBD_Deregister_Port_Info(kal_uint8 *usb_ip_port_ptr);
+extern void USBD_Init_Status(kal_uint8 usb_ip_port);
+extern void USBD_Init(kal_uint8 usb_ip_port);
+extern void USBD_Release_Status(kal_uint8 usb_ip_port);
+extern void USBD_Release(kal_uint8 usb_ip_port);
+extern void USBD_Attatch_Hdlr(kal_uint8 usb_ip_port, USB_HCD_STATUS result, kal_uint32 param);
+extern void USBD_Detach_Hdlr(kal_uint8 usb_ip_port, USB_HCD_STATUS result, kal_uint32 param);
+extern void USBD_Suspend_Hdlr(kal_uint8 usb_ip_port, USB_HCD_STATUS result, kal_uint32 param);
+extern USBD_HNP_SUPPORT_TYPE USBD_Get_HNP_Support(kal_uint8 usb_ip_port);
+extern kal_bool USBD_Is_Match_Hub(kal_uint8 usb_ip_port);
+extern void ICUSB_Drv_Init(void);
+extern void USBD_Register_Port_Info(kal_uint8 usb_ip_port, kal_bool b_is_ext_ip);
+
+// Class layer usage API
+extern void USBD_Clear_Feature(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str,kal_bool b_is_from_class_drv, usbd_ep0_callback callback);
+extern void USBD_Start_Setup_Cmd(USBH_Common_Struct common_str, Usb_Command *usbd_cmd, kal_uint8* data_ptr, USBD_EP0_DATA_DIR direction, kal_uint32 length, kal_bool b_is_from_class_drv, usbd_ep0_callback callback);
+extern kal_bool USBD_Send_Req(USBH_Common_Struct common_str,USBH_EP_Struct ep_str, kal_uint16 nBytes, void *pSrc);
+extern kal_bool USBD_Recv_Req(USBH_Common_Struct common_str,USBH_EP_Struct ep_str, kal_uint16 nBytes, void *pDst);
+extern void USBD_Suspend_Req(USBH_Common_Struct common_str);
+extern void USBD_Reset_Req(USBH_Common_Struct common_str);
+extern void USBD_Register_Drv_Info(USBH_Common_Struct common_str,USB_HCD_HDLR_TYPE type, USBH_EP_Struct usb_ep_str, usb_hcd_intr_handler_ptr hdlr);
+extern kal_uint8 USBD_HW_Mapping_EP(USBH_Common_Struct common_str,USB_EP_DIRECTION direction);
+extern void USBD_Dis_Attach(USBH_Common_Struct common_str);
+extern void USBD_En_Attach(USBH_Common_Struct common_str);
+extern void USBD_Config_TxEP_Type(USBH_Common_Struct common_str,USBH_EP_Struct ep_str,kal_bool b_is_switch_to_dma);
+extern void USBD_Config_RxEP_Type(USBH_Common_Struct common_str,USBH_EP_Struct ep_str,kal_bool b_is_switch_to_dma);
+extern void USBD_EP_Interval(USBH_Common_Struct common_str,USBH_EP_Struct ep_str,kal_uint8 interval);
+extern void USBD_RxEPInit(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str);
+extern void USBD_TxEPInit(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str);
+extern void USBD_RxEPEn(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str, kal_uint8 interval, kal_bool bDMA);
+extern void USBD_TxEPEn(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str, kal_uint8 interval, kal_bool bDMA);
+extern void USBD_TxEPDis(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str, kal_bool bDMA);
+extern void USBD_RxEPDis(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str, kal_bool bDMA);
+extern void USBD_EPFIFORead(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str, kal_uint16 nBytes, void *pDst);
+extern void USBD_EPFIFOWrite(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str, kal_uint16 nBytes, void *pDst);
+extern kal_uint16 USBD_EP0_Data_Length(USBH_Common_Struct common_str);
+extern kal_uint32 USBD_EP_Rx_Pkt_Len(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str);
+extern void USBD_Clear_Data01(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str);
+extern void USBD_Get_DMA_Channel(USBH_Common_Struct common_str,USBH_EP_Struct usb_tx_str, USBH_EP_Struct usb_rx_str, USB_EP_DIRECTION direction, kal_bool same_chan);
+extern void USBD_Free_DMA_Channel(USBH_Common_Struct common_str,USBH_EP_Struct usb_tx_str, USBH_EP_Struct usb_rx_str, USB_EP_DIRECTION direction, kal_bool same_chan);
+extern void USBD_DMA_Setup(USBH_Common_Struct common_str,USBH_EP_Struct ep_str,kal_uint32 addr, kal_uint32 length,usb_dma_callback callback,kal_bool callback_upd_run, kal_bool known_size, USB_DMA_TYPE dma_type);
+extern void USBD_Set_EP_Max_Pkt(USBH_Common_Struct common_str,USBH_EP_Struct usb_ep_str);
+extern kal_bool USBD_Get_UnMask_Irq(USBH_Common_Struct common_str);
+extern kal_bool USBD_Is_High_Speed(USBH_Common_Struct common_str);
+extern void USBD_VBusEnable(USBH_Common_Struct common_str,kal_bool enable);
+extern kal_bool USBD_Bootup_Mode(void);
+
+
+#endif /* USBD_H*/
+