[Feature]Upload Modem source code

Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/service/mtf/inc/mt.h b/mcu/service/mtf/inc/mt.h
new file mode 100644
index 0000000..57cfb92
--- /dev/null
+++ b/mcu/service/mtf/inc/mt.h
@@ -0,0 +1,95 @@
+/*****************************************************************************
+*  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) 2012
+*
+*  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:
+ * ---------
+ * mt.h
+ *
+ * Project:
+ * --------
+ * UMOLYA
+ *
+ * Description:
+ * ------------
+ * MT Framework data structures
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$ 
+ *
+ * 
+ ****************************************************************************/
+#ifndef _MT_H_
+#define _MT_H_
+
+#include "kal_public_api.h"
+#include "kal_general_types.h"
+#include "syscomp_config.h"
+#include "mtf_if.h"
+
+
+#define MSG_ID_OF_INCOMING_ICD (999)
+#define MTF_USER_TIMER_ID (0)
+extern event_scheduler *mtf_event_scheduler;
+
+typedef struct _mt_context_t
+{
+    mt_formatter_t* formatter[MT_FMT_MAX];
+	mt_dispatcher_list_t formatter_list;
+} mt_context_t;
+
+typedef struct _mt_dispatcher_entry_head_t
+{
+    kal_uint16 magic;
+    kal_bool inited;
+    struct _mt_dispatcher_entry_head_t *next;
+    kal_uint32 dispatch_key;
+    kal_uint32 dispatch_key_mask;
+} mt_dispatcher_entry_head_t;
+
+/// enum for metric destination ID
+typedef enum _mt_dest_id {
+  MT_CIQ, ///< ilm_struct format
+  MT_DEST_MAX
+} mt_dest_id;
+
+#endif
+
diff --git a/mcu/service/mtf/inc/mt_dispatcher.h b/mcu/service/mtf/inc/mt_dispatcher.h
new file mode 100644
index 0000000..0a70d12
--- /dev/null
+++ b/mcu/service/mtf/inc/mt_dispatcher.h
@@ -0,0 +1,92 @@
+/*****************************************************************************
+*  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) 2012
+*
+*  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:
+ * ---------
+ * mt_dispathcer.h
+ *
+ * Project:
+ * --------
+ * UMOLYA
+ *
+ * Description:
+ * ------------
+ * MT Framework dispatcher prototyes
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$ 
+ *
+ * 
+ ****************************************************************************/
+#ifndef _MT_DISPATCHER_H_
+#define _MT_DISPATCHER_H_
+
+#include "kal_general_types.h"
+
+#ifdef __MTK_TARGET__
+#define MT_DISPATCHER_ENTRY_RESERVED_SIZE	(16)
+#else
+#define MT_DISPATCHER_ENTRY_RESERVED_SIZE	(20)
+#endif
+
+#define GET_RULE_CODE(type, code, protocol)   ( 0xFFFFFFFF & (protocol | code << 2 | type << 18) )
+#define GET_ICD_TYPE_FROM_RULE_CODE(code)     ( 0x00000003 & (code) >> 18)
+#define GET_ICD_CODE_FROM_RULE_CODE(code)     ( 0x0000FFFF & (code) >> 2)
+#define GET_ICD_PROTOCOL_FROM_RULE_CODE(code) ( 0x00000003 & (code) )
+#define RULE_CODE_MASK_ICD_TYPE_FLAG_ON       (0x1)    // check icd type match the rule code
+#define RULE_CODE_MASK_ICD_CODE_FLAG_ON       (0x10)   // check icd code match the rule code
+#define RULE_CODE_MASK_ICD_PROTOCOL_FLAG_ON   (0x100)  // check protocol match the rule code
+#define RULE_CODE_MASK_FLAG_ALL_ON            (0x1111) //default: type, icd code and protocol must match the rule code
+#define RULE_CODE_MASK_FLAG_ALL_OFF           (0x0000) // no need to check icd type, code and protocl match the rule code 
+
+typedef struct _mt_dispatcher_list_t {
+	void *head;
+	void *tail;
+} mt_dispatcher_list_t;
+
+int mt_dispatcher_entry_init(void* entry, kal_uint16 magic, kal_uint32 dispatch_key, kal_uint32 dispatch_key_mask);
+int mt_dispatcher_add_entry(mt_dispatcher_list_t *tbl, kal_uint32 code, void* entry);
+void* mt_dispatcher_find_entry(mt_dispatcher_list_t *tbl, kal_uint32 code, void* last_entry);
+void mt_dispatcher_init();
+void mt_dispatcher_verify(void* e, kal_uint16 magic);
+
+#endif // _MT_DISPATCHER_H_
\ No newline at end of file
diff --git a/mcu/service/mtf/inc/mte_if.h b/mcu/service/mtf/inc/mte_if.h
new file mode 100644
index 0000000..5754bcf
--- /dev/null
+++ b/mcu/service/mtf/inc/mte_if.h
@@ -0,0 +1,222 @@
+/*****************************************************************************
+*  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) 2012
+*
+*  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:
+ * ---------
+ * mte_if.h
+ *
+ * Project:
+ * --------
+ * UMOLYA
+ *
+ * Description:
+ * ------------
+ * MT Framework element prototyes
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$ 
+ *
+ * 
+ ****************************************************************************/
+
+ 
+#ifndef _MTE_IF_
+#define _MTE_IF_
+
+#include "mt.h"
+#include "mt_dispatcher.h" 
+
+
+#define MT_METRICS_UNIT_TEST
+
+/**
+ * @name mt_set_timer_event
+ *
+ * @brief set an timer event from mtf event scheduler
+ * 
+ * @param [in] callback         the callback function when event timeout
+ * @param [in] callbackparam    the user supplied argument for callback function
+ * @param [in] delaytime        how many system ticks elapses before this event timeout
+ *
+ * @retval ret                  Successful: return set eventid.
+ *                              Fail: return NULL.   
+ */
+#define mt_set_timer_event(callback, callbackparam, delaytime) \
+            evshed_set_event(mtf_event_scheduler, callback, callbackparam, delaytime)
+
+/**
+ * @name mt_cancel_timer_event
+ *
+ * @brief cancel a timer event freom mtf event scheduler
+ * 
+ * @param [in] eventID         pointer to eventID
+ *
+ * @retval ret                 Successful: remain ticks before this event expires
+ *                             Fail: -1 
+ */
+#define mt_cancel_timer_event(eventID) \
+            evshed_cancel_event(mtf_event_scheduler, eventID)
+
+/**
+ * @name mt_get_remaining_time
+ *
+ * @brief get remain ticks before this event expires
+ * 
+ * @param [in] eventID         pointer to eventID
+ *
+ * @retval ret                 Successful: remain ticks before this event expires
+ *
+ */
+#define mt_get_remaining_time(eventID) \
+            evshed_get_remaining_time(mtf_event_scheduler, eventID)
+    
+/**
+ * @name mte_execute_func
+ *
+ * @brief Prototype of MTE routine entry function, all MTE should implement this and pass as an argument in register call
+ * 
+ * @param [in] mte_rule  mte_rule_t instance of the matched rule which triggers this element
+ * @param [in] msg       Raw content of source message, use source to determine the format of this msg
+ * @param [in] msg_size  Length of the content in pointed by msg
+ *
+ */
+typedef struct _mte_rule_t mte_rule_t;
+ 
+typedef void (*mte_execute_func)(const mte_rule_t *mte_rule, void* msg, kal_uint32 msg_size);
+
+/// Structure of the Metrics Translation Element (MTE) rule descriptor
+typedef struct _mte_rule_t
+{
+    char reserved[MT_DISPATCHER_ENTRY_RESERVED_SIZE];  ///< reserved fields
+    
+    mt_fmt_id fmt_id;             ///< Source of the message to be registered with
+    kal_uint32 code;              ///< Code of the source. When incoming source message matches this code, 
+                                  ///  this MTE_execute_func will be called. See definition of each source for detail format of code
+    mte_execute_func execute;     ///< Pointer to the mte_execute_func which is called when incoming message matches
+    void* context;                ///< Context to be passed when calling mte_entry
+} mte_rule_t;
+
+/**
+ * @name mt_register_mte_rule
+ *
+ * @brief Register a metrics translation element (MTE) to framework. This function should be only called in mte_init()
+ *        The framework will dispatch message to the registered MTE based on the given source/code 
+ *
+ * @param [in] mte_rule   Pointer to the descriptor of the MTE rule to be registered
+ *                        Caller should allocate the memory pointed by this pointer and let callee to keep this memory
+ */
+void mt_register_mte_rule(mte_rule_t *mte_rule);
+/**
+ * @name mt_register_mte_rule_with_mask
+ *
+ * @brief Register a metrics translation element (MTE) to framework. This function should be only called in mte_init()
+ *        The framework will dispatch message to the registered MTE based on the given source/code and mask 
+ *
+ * @param [in] mte_rule   Pointer to the descriptor of the MTE rule to be registered
+ *                        Caller should allocate the memory pointed by this pointer and let callee to keep this memory
+ * @param [in] rule_code_mask  mask on will dispatch message when code match, mask off will dispatch all message.
+ *                                             also can only on of special flag, 
+ *                                             i.e RULE_CODE_MASK_ICD_TYPE_FLAG_ON, RULE_CODE_MASK_ICD_CODE_FLAG_ON
+ *                                                 RULE_CODE_MASK_ICD_PROTOCOL_FLAG_ON
+ */
+void mt_register_mte_rule_with_mask(mte_rule_t *mte_rule, kal_uint32 rule_code_mask);
+
+
+#define GEN_MSG_ID(destID, metricID)        MSG_ID_##destID##_##metricID##_IND
+
+extern int
+mt_ext_ut_submit_metrics(msg_type msg_id, void* payload, kal_uint32 payload_size);
+
+/**
+ * @name mt_submit_metric
+ *
+ * @brief Submit metric value to the dedicated destination module
+ *
+ * @param [in] dest_id    Destination module name
+ * @param [in] metric_id  Destination specified metric ID
+ * @param [in] payload    Pointer to the payload content
+ * @param [in] payload    Size of payload content pointed by payload
+ *
+ * @retval ret            Return value specified by the destination module
+ * 
+ * @code
+ * auto r = mt_submit_metric(MT_DEST_CIQ, 10, struct_for_metric_10);
+ */
+//#ifdef __MTK_TARGET__
+#define mt_submit_metric(_dest_id, _metric_id, _payload, _payload_size) mt_ext_ut_submit_metrics(GEN_MSG_ID(_dest_id, _metric_id), (_payload), (_payload_size))
+
+//#endif
+/**
+ * @name mt_format_return
+ *
+ * @brief Translate destination specified return code to standard result code
+ *
+ * @param [in] dest_id    Destination module ID
+ * @param [in] ret        Return code given by the destination module
+ *
+ * @retval 0              Success
+ * @retval EINVAL         Invalid argument
+ * @retval ENOMEM         Out of memory
+ * @retval EINVAL         Invalid argument
+ * @retval EAGAIN         Try again
+ * @retval EIO            I/O error (channeel error)
+ * @retval EPERM          Operation not permitted (all other errors)
+ *
+ * @code
+ * int ret = mt_format_return(MT_DEST_CIQ, mt_submit_metric(MT_DEST_CIQ, 10, struct_for_metric_10));
+ */
+#ifdef MT_METRICS_UNIT_TEST
+#define mt_format_return(_dest_id, _ret) (_ret)
+#else
+#define mt_format_return(_dest_id, _ret) \
+	_dest_id ## _format_return(_ret)
+#endif
+
+void mt_elements_reset();
+
+void mt_elements_init();
+
+void mt_elements_init_proc();
+void mt_nvram_write_cnf_hdlr(ilm_struct *ilm_ptr);
+
+
+#endif // _MTE_IF_
diff --git a/mcu/service/mtf/inc/mtf_if.h b/mcu/service/mtf/inc/mtf_if.h
new file mode 100644
index 0000000..16f0e90
--- /dev/null
+++ b/mcu/service/mtf/inc/mtf_if.h
@@ -0,0 +1,95 @@
+/*****************************************************************************
+*  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) 2012
+*
+*  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:
+ * ---------
+ * mtf_if.h
+ *
+ * Project:
+ * --------
+ * UMOLYA
+ *
+ * Description:
+ * ------------
+ * MT Framework formatter prototyes
+ *
+ * Author:
+ * -------
+ * -------
+ *
+ *
+ * ==========================================================================
+ * $Log$ 
+ *
+ * 
+ ****************************************************************************/
+#ifndef _MTF_IF_
+#define _MTF_IF_
+
+#include "mt_dispatcher.h"
+#include "syscomp_config.h"
+/// enum for metric source ID
+typedef enum _mt_fmt_id {
+  MT_FMT_ILM, ///< ilm_struct format
+  MT_FMT_ICD, ///< ICD packet format
+  MT_FMT_PEER_TRACE, ///< Peer Trace Format
+  MT_FMT_MAX
+} mt_fmt_id;
+
+typedef struct _mt_msginfo_t
+{
+	kal_uint32 code;
+	void* msg;
+	kal_uint32 msg_size;
+} mt_msginfo_t;
+
+typedef int (*mt_formatter_msginfo_extract_func)(const ilm_struct *ilm, mt_msginfo_t *msginfo);
+
+typedef struct _mt_formatter_t
+{
+	char reserved[MT_DISPATCHER_ENTRY_RESERVED_SIZE];  ///< reserved fields
+	
+	mt_fmt_id fmt_id;
+	kal_uint32 ilm_msg_id;
+	mt_dispatcher_list_t element_list;
+	mt_formatter_msginfo_extract_func extract_msginfo;
+} mt_formatter_t;
+
+void mt_formatters_init();
+void mt_register_formatter(mt_formatter_t *formatter);
+
+#endif
\ No newline at end of file