[Feature][Modem]Update MTK MODEM V1.6 baseline version: MOLY.NR15.R3.MD700.IVT.MP1MR3.MP.V1.6

MTK modem version: MT2735_IVT_MOLY.NR15.R3.MD700.IVT.MP1MR3.MP.V1.6.tar.gz
RF  modem version: NA

Change-Id: I45a4c2752fa9d1a618beacd5d40737fb39ab64fb
diff --git a/mcu/interface/middleware/hif/nmu_util.h b/mcu/interface/middleware/hif/nmu_util.h
new file mode 100644
index 0000000..2f80937
--- /dev/null
+++ b/mcu/interface/middleware/hif/nmu_util.h
@@ -0,0 +1,582 @@
+/*!
+ *  @file nmu_util.h
+ *  @author Roger Huang <chaomin.haung@mediatek.com>
+ *  @version 1.0
+ *  @section LICENSE
+ *
+ *  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).
+ *
+ *  @section DESCRIPTION
+ *  This file provides utility interface of nmu ( network management unit )
+ */
+
+#ifndef _NMU_UTIL_H
+#define _NMU_UTIL_H
+
+#include "nmu.h"
+
+
+/*!
+ *  @brief  set ethernet interface up
+ *  @param  eth_id ethernet interface id
+ */
+void nmu_set_eth_up(kal_uint8 eth_id);
+
+
+/*
+ *  @brief  set ethernet interface down
+ *  @param  eth_id ethernet interface id
+ */
+void nmu_set_eth_down(kal_uint8 eth_id);
+
+
+/*
+ *  @brief  check if ethernet interface is up or not
+ *  @param  eth_id ethernet interface id
+ *  @return KAL_TRUE if ethernet interface is up, KAL_FALSE if it's down
+ *          attribute is set
+ */
+kal_bool nmu_check_eth_up(kal_uint8 eth_id);
+
+
+/*
+ *  @brief  set host mac address of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  mac_address mac address to be written
+ */
+void nmu_set_host_mac(kal_uint8 eth_id, void* mac_address);
+
+
+/*
+ *  @brief  get host mac address of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  mac_address mac address to be read
+ */
+void nmu_get_host_mac(kal_uint8 eth_id, void* mac_address);
+
+
+/*
+ *  @brief  set gateway mac address of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  mac_address mac address to be written
+ */
+void nmu_set_gateway_mac(kal_uint8 eth_id, void* mac_address);
+
+
+/*
+ *  @brief  get gateway mac address of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  mac_address mac address to be read
+ */
+void nmu_get_gateway_mac(kal_uint8 eth_id, void* mac_address);
+
+
+/*
+ *  @brief  set transmit packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_tx_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add transmit packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_tx_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get transmit packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_tx_pkt_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set receive packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_rx_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add receive packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_rx_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get receive packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_rx_pkt_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set transmit packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_tx_byte_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add transmit packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_tx_byte_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get transmit packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_tx_byte_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_rx_byte_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_rx_byte_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_rx_byte_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_tx_error_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_tx_error_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_tx_error_pkt_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_rx_error_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_rx_error_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_rx_error_pkt_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+/*
+ *  @brief  set transmit dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_tx_drop_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add transmit dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_tx_drop_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get transmit dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_tx_drop_pkt_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set receive dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_rx_drop_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add receive dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_rx_drop_pkt_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get receive dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_rx_drop_pkt_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set receive dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be written
+ */
+void nmu_set_eth_rx_frame_align_error_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  add receive dropped packet counts of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be added
+ */
+void nmu_add_eth_rx_frame_align_error_cnt(kal_uint8 eth_id, nmu_stat_t value);
+
+
+/*
+ *  @brief  get receive packet bytes of ethernet interface
+ *  @param  eth_id ethernet interface id
+ *  @param  value value to be read
+ */
+void nmu_get_eth_rx_frame_align_error_cnt(kal_uint8 eth_id, nmu_stat_t* value);
+
+
+/*
+ *  @brief  set ipv4 instance IPv4 up
+ *  @param  ip_id ip instance id
+ */
+void nmu_set_ip4_up(kal_uint8 ip_id);
+
+
+/*
+ *  @brief  set ip instance IPv4 down
+ *  @param  ip_id ip instance id
+ */
+void nmu_set_ip4_down(kal_uint8 ip_id);
+
+
+/*
+ *  @brief  check ip instance IPv4 is up or not
+ *  @param  ip_id ip instance id
+ *  @return KAL_TRUE if IPv4 is up, KAL_FALSE if not
+ */
+kal_bool nmu_check_ip4_up(kal_uint8 ip_id);
+
+
+/*
+ *  @brief  set IPv4 address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  ip_address IPv4 address to be written
+ */
+void nmu_set_ip4_ip(kal_uint8 ip_id, void* ip_address);
+
+
+/*
+ *  @brief  get IPv4 address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  ip_address IPv4 address to be read
+ */
+void nmu_get_ip4_ip(kal_uint8 ip_id, void* ip_address);
+
+
+/*
+ *  @brief  set IPv4 netmask of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  mask IPv4 netmask to be written
+ */
+void nmu_set_ip4_mask(kal_uint8 ip_id, void* mask);
+
+
+/*
+ *  @brief  set IPv4 netmask of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  mask IPv4 netmask to be written
+ */
+void nmu_get_ip4_mask(kal_uint8 ip_id, void* mask);
+
+
+/*
+ *  @brief  set IPv4 gateway address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  gateway IPv4 address to be written
+ */
+void nmu_set_ip4_gateway(kal_uint8 ip_id, void* gateway);
+
+
+/*
+ *  @brief  get IPv4 gateway address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  gateway IPv4 address to be read
+ */
+void nmu_get_ip4_gateway(kal_uint8 ip_id, void* gateway);
+
+
+/*
+ *  @brief  set IPv4 mtu size of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  mtu_size mtu size to be written
+ */
+void nmu_set_ip4_mtu_size(kal_uint8 ip_id, kal_uint16 mtu_size);
+
+
+/*
+ *  @brief  get IPv4 mtu size of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  mtu_size mtu size to be read
+ */
+void nmu_get_ip4_mtu_size(kal_uint8 ip_id, kal_uint16* mtu_size);
+
+
+/*
+ *  @brief  set total number of IPv4 DNS servers of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_num total number to be written
+ */
+void nmu_set_ip4_dns_num(kal_uint8 ip_id, kal_uint8 dns_num);
+
+
+/*
+ *  @brief  get total number of IPv4 DNS servers of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_num total number to be read
+ */
+void nmu_get_ip4_dns_num(kal_uint8 ip_id, kal_uint8* dns_num);
+
+
+/*
+ *  @brief  set DNS server IPv4 address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_id dns server no
+ *  @param  dns IPv4 address to be written
+ */
+void nmu_set_ip4_dns(kal_uint8 ip_id, kal_uint8 dns_id, void* dns);
+
+
+/*
+ *  @brief  get DNS server IPv4 address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_id dns server no
+ *  @param  dns IPv4 address to be read
+ */
+void nmu_get_ip4_dns(kal_uint8 ip_id, kal_uint8 dns_id, void* dns);
+
+
+/*
+ *  @brief  set ip instance IPv6 up
+ *  @param  ip_id ip instance id
+ */
+void nmu_set_ip6_up(kal_uint8 ip_id);
+
+
+/*
+ *  @brief  set ip instance IPv6 down
+ *  @param  ip_id ip instance id
+ */
+void nmu_set_ip6_down(kal_uint8 ip_id);
+
+
+/*
+ *  @brief  check ip instance IPv6 is up or not
+ *  @param  ip_id ip instance id
+ *  @return KAL_TRUE if IPv6 is up, KAL_FALSE if not
+ */
+kal_bool nmu_check_ip6_up(kal_uint8 ip_id);
+
+
+/*
+ *  @brief  set IPv6 mtu size of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  mtu_size mtu size to be written
+ */
+void nmu_set_ip6_mtu_size(kal_uint8 ip_id, kal_uint32 mtu_size);
+
+
+/*
+ *  @brief  get IPv6 mtu size of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  mtu_size mtu size to be read
+ */
+void nmu_get_ip6_mtu_size(kal_uint8 ip_id, kal_uint32* mtu_size);
+
+
+/*
+ *  @brief  set IPv6 prefix length of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  prefix_len prefix length to be written
+ */
+void nmu_set_ip6_prefix_len(kal_uint8 ip_id, kal_uint8 prefix_len);
+
+
+/*
+ *  @brief  get IPv6 prefix length of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  prefix_len prefix length to be read
+ */
+void nmu_get_ip6_prefix_len(kal_uint8 ip_id, kal_uint8* prefix_len);
+
+
+/*
+ *  @brief  set IPv6 prefix of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  prefix_len prefix to be written
+ */
+void nmu_set_ip6_prefix(kal_uint8 ip_id, void* prefix);
+
+
+/*
+ *  @brief  get IPv6 prefix of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  prefix_len prefix to be read
+ */
+void nmu_get_ip6_prefix(kal_uint8 ip_id, void* prefix);
+
+
+/*
+ *  @brief  set IPv6 interface identifier length of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  iid_len interface identifier length to be written
+ */
+void nmu_set_ip6_iid_len(kal_uint8 ip_id, kal_uint8 iid_len);
+
+
+/*
+ *  @brief  get IPv6 interface identifier length of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  iid_len interface identifier length to be read
+ */
+void nmu_get_ip6_iid_len(kal_uint8 ip_id, kal_uint8* iid_len);
+
+
+/*
+ *  @brief  set IPv6 interface identifier of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  iid_len interface identifier to be written
+ */
+void nmu_set_ip6_iid(kal_uint8 ip_id, void* iid);
+
+
+/*
+ *  @brief  get IPv6 interface identifier of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  iid_len interface identifier to be read
+ */
+void nmu_get_ip6_iid(kal_uint8 ip_id, void* iid);
+
+
+/*
+ *  @brief  set total number of IPv6 DNS servers of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_num total number to be written
+ */
+void nmu_set_ip6_dns_num(kal_uint8 ip_id, kal_uint8 dns_num);
+
+
+/*
+ *  @brief  get total number of IPv6 DNS servers of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_num total number to be read
+ */
+void nmu_get_ip6_dns_num(kal_uint8 ip_id, kal_uint8* dns_num);
+
+
+/*
+ *  @brief  set DNS server IPv6 address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_id dns server no
+ *  @param  dns IPv6 address to be written
+ */
+void nmu_set_ip6_dns(kal_uint8 ip_id, kal_uint8 dns_id, void* dns);
+
+
+/*
+ *  @brief  get DNS server IPv6 address of ip instance
+ *  @param  ip_id ip instance id
+ *  @param  dns_id dns server no
+ *  @param  dns IPv6 address to be read
+ */
+void nmu_get_ip6_dns(kal_uint8 ip_id, kal_uint8 dns_id, void* dns);
+
+
+/*
+ *  @brief  set fake netmask and gateway through real ip address
+ *  @param  ip_id ip instance id
+ *  @param  ip_address IPv4 address used to calculated fake netmask and gateway
+ */
+void nmu_set_ip4_fake_mask_and_gateway(kal_uint8 ip_id, void *ip_address);
+
+
+#endif  // _NMU_UTIL_H
+