[Feature]Upload Modem source code
Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/interface/driver/tfwk_drv/tfwk_public.h b/mcu/interface/driver/tfwk_drv/tfwk_public.h
new file mode 100644
index 0000000..a839347
--- /dev/null
+++ b/mcu/interface/driver/tfwk_drv/tfwk_public.h
@@ -0,0 +1,210 @@
+/*****************************************************************************
+* 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) 2017
+*
+* 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:
+ * ---------
+ * tfwk_public.h
+ *
+ * Project:
+ * --------
+ * VMOLY
+ *
+ * Description:
+ * ------------
+ * Thermal Framework public interface
+ *
+ * Author:
+ * -------
+ *
+ *
+ *============================================================================
+ * HISTORY
+ * Below this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+ *------------------------------------------------------------------------------
+ * removed!
+ * removed!
+ * removed!
+ *------------------------------------------------------------------------------
+ * Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+ *============================================================================
+ ****************************************************************************/
+#ifndef __TFWK_PUBLIC_H__
+#define __TFWK_PUBLIC_H__
+
+#include "kal_general_types.h"
+#include "thermal_public.h"
+
+/*=============================================================
+* TFWK enums
+*=============================================================*/
+// enum for sensor type
+typedef enum{
+ TFWK_LVTS = 0,
+ TFWK_TIA = 1,
+ MAX_SENSOR_TYPE
+} tfwk_mtk_stype_e;
+
+/*=============================================================
+* Error code
+*=============================================================*/
+#define TFWK_NO_FAILURE 0x00000000
+#define TFWK_FAILURE 0x00000002
+#define TFWK_ALARM_ID_NOT_SUPPORT 0x00000839
+#define TFWK_SENSOR_ID_NOT_SUPPORT 0x0000083C
+#define TFWK_THERSHOLD_OUT_OF_RANGE 0x0000083A
+
+/*=============================================================
+* TFWK structures
+*=============================================================*/
+// structure for threshold setting
+typedef struct{
+ kal_uint32 enable;
+ kal_uint32 sensor_id;
+ kal_uint32 alarm_id;
+ kal_int32 threshold_value;
+ kal_uint32 hysteresis_value;
+ kal_uint32 sampling_period;
+ kal_uint32 sensor_alarm_type;
+} tfwk_thermal_cfg_t;
+
+// stucture for thermal sensor info
+typedef struct{
+ kal_uint32 sensor_id;
+ kal_int32 min_temperature;
+ kal_uint32 max_temperature;
+ kal_int32 warning_temperature;
+ kal_uint32 accuracy;
+ kal_uint32 resolution;
+ kal_uint8 sensor_name[40];
+} tfwk_sensor_info_t;
+
+typedef kal_int32(*s_get_temp_fp)(kal_uint32 sensor_id, kal_int32 *temp);
+typedef kal_int32(*s_set_alarm_fp)(kal_uint32 ncfg, tfwk_thermal_cfg_t* tcfgs);
+
+typedef struct{
+ s_get_temp_fp get_temp_fp;
+ s_set_alarm_fp set_alarm_fp;
+} tfwk_sensor_if_t;
+
+
+/**
+ * @function tfwk_init
+ * @brief TFWK initialize
+ */
+extern void tfwk_init(void);
+
+/**
+ * @function tfwk_sensor_reg
+ * @brief API for driver regist TFWK before OS scheduling
+ *
+ * @param s_type driver sensor type
+ * @param n_sensor driver sensor number
+ * @param sensors driver sensor information
+ * @param sensor_if driver's callback function
+ */
+extern void tfwk_sensor_reg(tfwk_mtk_stype_e s_type, kal_uint32 n_sensor, tfwk_sensor_info_t* sensors, tfwk_sensor_if_t* sensor_if);
+
+
+/**
+ * @function tfwk_sensor_notify
+ * @brief API for driver ,notify MSG_ID: <MSG_ID_L5_THERMAL_STATE_INFO>, DO NOT PRINT LOG!
+ * @param sta_info sta_info pointer
+ *
+ * @return TFWK_NO_FAILURE ==> success
+ */
+extern kal_int32 tfwk_sensor_notify(thermal_sta_info_t* sta_info);
+
+
+/**
+ * @function tfwk_get_sensor_num
+ * @brief API for L5 querying sensor number
+ *
+ * @return total number of accessible sensors
+ */
+extern kal_uint32 tfwk_get_sensor_num(void);
+
+
+/**
+ * @function tfwk_get_sensor_info
+ * @brief API for L5 querying sensorID info
+ * @param sid sensor id
+ * @param sinfo sensor info pointer
+ *
+ * @return TFWK_NO_FAILURE ==> success
+ * TFWK_FAILURE ==> (sinfo pointer == NULL)
+ * TFWK_SENSOR_ID_NOT_SUPPORT ==> query invalid sensor id
+ */
+extern kal_uint32 tfwk_get_sensor_info (kal_uint32 sid, tfwk_sensor_info_t* sinfo);
+
+
+/**
+ * @function tfwk_set_sensor_cfg
+ * @brief API for L5 config sensor setting, pick LVTS error to return while both driver return error
+ * @param ncfg config number
+ * @param tcfgs config pointer
+ *
+ * @return TFWK_NO_FAILURE ==> success
+ * TFWK_FAILURE ==> (invalid config number) or (driver's callback func == NULL) or (tcfgs pointer == NULL)
+ * LVTS error code ==> pick LVTS error to return while both driver return error
+ * TIA error code ==> TIA return error
+ */
+extern kal_uint32 tfwk_set_sensor_cfg(kal_uint32 ncfg, tfwk_thermal_cfg_t* tcfgs);
+
+
+/**
+ * @function tfwk_get_sensor_state
+ * @brief API for L5 querying sensor temperature.
+ * @param sid query sensor id.
+ * @param temp temperature pointer.
+ *
+ * @return TFWK_NO_FAILURE ==> success
+ * TFWK_SENSOR_ID_NOT_SUPPORT ==> query invalid sensor id
+ * TFWK_FAILURE ==> (temperature pointer == NULL) or (driver's callback func == NULL)
+ */
+extern kal_uint32 tfwk_get_sensor_state(kal_uint32 sid, kal_int32* temp);
+
+
+/**
+ * @function tfwk_atcmd_public
+ * @brief API for tfwk public atcmd handler
+ * @data_len: atcmd data length
+ * @data_str: atcmd byte array pointer
+ * @return KAL_TRUE: success, KAL_FALSE: fail
+ */
+extern kal_bool tfwk_atcmd_public(kal_uint32 data_len, kal_uint8 *data_str);
+
+#endif