replace binary DrvGen with python 3 version.
scripts have been upgraded from python 2 to 3 using futurize.

diff --git a/scripts/drvgen/drvgen.mk b/scripts/drvgen/drvgen.mk
index cdc47873434..261174fa51e 100644
--- a/scripts/drvgen/drvgen.mk
+++ b/scripts/drvgen/drvgen.mk
@@ -20,7 +20,7 @@ DRVGEN_FILE_LIST := $(addprefix $(DRVGEN_OUT)/,$(ALL_DRVGEN_FILE))
 else
 DRVGEN_FILE_LIST :=
 endif
-DRVGEN_TOOL := $(srctree)/tools/dct/DrvGen
+DRVGEN_TOOL := $(srctree)/tools/dct/DrvGen.py
 DRVGEN_PREBUILT_PATH := $(srctree)/$(DRVGEN_PATH)
 DRVGEN_PREBUILT_CHECK := $(filter-out $(wildcard $(addprefix $(DRVGEN_PREBUILT_PATH)/,$(ALL_DRVGEN_FILE))),$(addprefix $(DRVGEN_PREBUILT_PATH)/,$(ALL_DRVGEN_FILE)))
 
@@ -29,7 +29,7 @@ drvgen: $(DRVGEN_FILE_LIST)
 ifneq ($(DRVGEN_PREBUILT_CHECK),)
 $(DRVGEN_OUT)/cust.dtsi: $(DRVGEN_TOOL) $(DWS_FILE)
 	@mkdir -p $(dir $@)
-	$(DRVGEN_TOOL) $(DWS_FILE) $(dir $@) $(dir $@) cust_dtsi
+	$(python) $(DRVGEN_TOOL) $(DWS_FILE) $(dir $@) $(dir $@) cust_dtsi
 
 else
 $(DRVGEN_FILE_LIST): $(DRVGEN_OUT)/% : $(DRVGEN_PREBUILT_PATH)/%
diff --git a/tools/dct/DrvGen.py b/tools/dct/DrvGen.py
new file mode 100755
index 00000000000..500ea40172c
--- /dev/null
+++ b/tools/dct/DrvGen.py
@@ -0,0 +1,147 @@
+#! /usr/bin/python3
+
+from __future__ import print_function
+import os, sys
+import getopt
+import traceback
+import subprocess
+import xml.dom.minidom
+
+sys.path.append('.')
+sys.path.append('..')
+
+from obj.ChipObj import ChipObj
+from obj.ChipObj import Everest
+from obj.ChipObj import Olympus
+from obj.ChipObj import KiboPlus
+from obj.ChipObj import Rushmore
+
+from utility.util import LogLevel
+from utility.util import log
+
+def usage():
+    print('''
+usage: DrvGen [dws_path] [file_path] [log_path] [paras]...
+
+options and arguments:
+
+dws_path    :    dws file path
+file_path   :    where you want to put generated files
+log_path    :    where to store the log files
+paras        :    parameter for generate wanted file
+''')
+
+def is_oldDws(path, gen_spec):
+    if not os.path.exists(path):
+        log(LogLevel.error, 'Can not find %s' %(path))
+        sys.exit(-1)
+
+    try:
+        root = xml.dom.minidom.parse(dws_path)
+    except Exception as e:
+        log(LogLevel.warn, '%s is not xml format, try to use old DCT!' %(dws_path))
+        if len(gen_spec) == 0:
+            log(LogLevel.warn, 'Please use old DCT UI to gen all files!')
+            return True
+        old_dct = os.path.join(sys.path[0], 'old_dct', 'DrvGen')
+        cmd = old_dct + ' ' + dws_path + ' ' + gen_path + ' ' + log_path + ' ' + gen_spec[0]
+        if 0 == subprocess.call(cmd, shell=True):
+            return True
+        else:
+            log(LogLevel.error, '%s format error!' %(dws_path))
+            sys.exit(-1)
+
+    return False
+
+if __name__ == '__main__':
+    opts, args = getopt.getopt(sys.argv[1:], '')
+
+    if len(args) == 0:
+        msg = 'Too less arguments!'
+        usage()
+        log(LogLevel.error, msg)
+        sys.exit(-1)
+
+    dws_path = ''
+    gen_path = ''
+    log_path = ''
+    gen_spec = []
+
+    # get DWS file path from parameters
+    dws_path = os.path.abspath(args[0])
+
+    # get parameters from input
+    if len(args) == 1:
+        gen_path = os.path.dirname(dws_path)
+        log_path = os.path.dirname(dws_path)
+
+    elif len(args) == 2:
+        gen_path = os.path.abspath(args[1])
+        log_path = os.path.dirname(dws_path)
+
+    elif len(args) == 3:
+        gen_path = os.path.abspath(args[1])
+        log_path = os.path.abspath(args[2])
+
+    elif len(args) >= 4:
+        gen_path = os.path.abspath(args[1])
+        log_path = os.path.abspath(args[2])
+        for i in range(3,len(args)):
+            gen_spec.append(args[i])
+
+    log(LogLevel.info, 'DWS file path is %s' %(dws_path))
+    log(LogLevel.info, 'Gen files path is %s' %(gen_path))
+    log(LogLevel.info, 'Log files path is %s' %(log_path))
+
+    for item in gen_spec:
+        log(LogLevel.info, 'Parameter is %s' %(item))
+
+
+
+    # check DWS file path
+    if not os.path.exists(dws_path):
+        log(LogLevel.error, 'Can not find "%s", file not exist!' %(dws_path))
+        sys.exit(-1)
+
+    if not os.path.exists(gen_path):
+        log(LogLevel.error, 'Can not find "%s", gen path not exist!' %(gen_path))
+        sys.exit(-1)
+
+    if not os.path.exists(log_path):
+        log(LogLevel.error, 'Can not find "%s", log path not exist!' %(log_path))
+        sys.exit(-1)
+
+    if is_oldDws(dws_path, gen_spec):
+        sys.exit(0)
+
+    chipId = ChipObj.get_chipId(dws_path)
+    chipObj = None
+    if cmp(chipId, 'MT6797') == 0:
+        chipObj = Everest(dws_path, gen_path)
+    elif cmp(chipId, 'MT6757') == 0:
+        chipObj = Olympus(dws_path, gen_path)
+    elif cmp(chipId, 'KIBOPLUS') == 0:
+        chipObj = KiboPlus(dws_path, gen_path)
+    elif cmp(chipId, 'MT6570') == 0:
+        chipObj = Rushmore(dws_path, gen_path)
+    else:
+        chipObj = ChipObj(dws_path, gen_path)
+
+    if not chipObj.parse():
+        log(LogLevel.error, 'Parse %s fail!' %(dws_path))
+        sys.exit(-1)
+
+    if not chipObj.generate(gen_spec):
+        log(LogLevel.error, 'Generate files fail!')
+        sys.exit(-1)
+
+    sys.exit(0)
+
+
+
+
+
+
+
+
+
diff --git a/tools/dct/config/PMIC_MT6335PMUMP.cmp b/tools/dct/config/PMIC_MT6335PMUMP.cmp
new file mode 100644
index 00000000000..1acb3a47ee1
--- /dev/null
+++ b/tools/dct/config/PMIC_MT6335PMUMP.cmp
@@ -0,0 +1,50 @@
+[PMIC_TABLE]
+CHIP = MT6335
+NUM_LDO = 11
+FUNCTION = pmic_set_register_value
+LDO_APPNAME_DEFAULT = MT65XX_POWER_NONE
+INCLUDE_HEADER = linux/types.h:mach/mt_typedefs.h:mach/upmu_common.h:mach/upmu_hw.h:mach/mt_pm_ldo.h
+
+[LDO_NAME1]
+LDO_NAME = VCAMA1
+PARAMETER_NAME = MT6335_PMIC_RG_VCAMA1_SW_EN
+
+[LDO_NAME2]
+LDO_NAME = VCAMA2
+PARAMETER_NAME = MT6335_PMIC_RG_VCAMA2_SW_EN
+
+[LDO_NAME3]
+LDO_NAME = VSIM1
+PARAMETER_NAME = MT6335_PMIC_RG_VSIM1_SW_EN
+
+[LDO_NAME4]
+LDO_NAME = VSIM2
+PARAMETER_NAME = MT6335_PMIC_RG_VSIM2_SW_EN
+
+[LDO_NAME5]
+LDO_NAME = VCAMAF
+PARAMETER_NAME = MT6335_PMIC_RG_VCAMAF_SW_EN
+
+[LDO_NAME6]
+LDO_NAME = VTOUCH
+PARAMETER_NAME = MT6335_PMIC_RG_VTOUCH_SW_EN
+
+[LDO_NAME7]
+LDO_NAME = VGP3
+PARAMETER_NAME = MT6335_PMIC_RG_VGP3_SW_EN
+
+[LDO_NAME8]
+LDO_NAME = VIBR
+PARAMETER_NAME = MT6335_PMIC_RG_VIBR_SW_EN
+
+[LDO_NAME9]
+LDO_NAME = VCAMD1
+PARAMETER_NAME = MT6335_PMIC_RG_VCAMD1_SW_EN
+
+[LDO_NAME10]
+LDO_NAME = VCAMD2
+PARAMETER_NAME = MT6335_PMIC_RG_VCAMD2_SW_EN
+
+[LDO_NAME11]
+LDO_NAME = VCAMIO
+PARAMETER_NAME = MT6335_PMIC_RG_VCAMIO_SW_EN
diff --git a/tools/dct/config/PMIC_MT6350PMUMP.cmp b/tools/dct/config/PMIC_MT6350PMUMP.cmp
new file mode 100644
index 00000000000..00692159051
--- /dev/null
+++ b/tools/dct/config/PMIC_MT6350PMUMP.cmp
@@ -0,0 +1,79 @@
+[PMIC_TABLE]
+CHIP = MT6350
+NUM_LDO = 18
+FUNCTION = pmic_set_register_value
+LDO_APPNAME_DEFAULT = MT65XX_POWER_NONE
+INCLUDE_HEADER = linux/types.h:mach/mt_typedefs.h:mach/upmu_common.h:mach/upmu_hw.h:mach/mt_pm_ldo.h
+
+
+[LDO_NAME1]
+LDO_NAME=VMC
+PARAMETER_NAME = PMIC_RG_VMC_EN
+
+[LDO_NAME2]
+LDO_NAME=VMCH
+PARAMETER_NAME = PMIC_RG_VMCH_EN
+
+[LDO_NAME3]
+LDO_NAME=VEMC_3V3
+PARAMETER_NAME = PMIC_RG_VEMC_3V3_EN
+
+[LDO_NAME4]
+LDO_NAME=VGP1
+PARAMETER_NAME = PMIC_RG_VGP1_EN
+
+[LDO_NAME5]
+LDO_NAME=VGP2
+PARAMETER_NAME = PMIC_RG_VGP2_EN
+
+[LDO_NAME6]
+LDO_NAME=VGP3
+PARAMETER_NAME = PMIC_RG_VGP3_EN
+
+[LDO_NAME7]
+LDO_NAME=VCN_1V8
+PARAMETER_NAME = PMIC_RG_VCN_1V8_EN
+
+[LDO_NAME8]
+LDO_NAME=VSIM1
+PARAMETER_NAME = PMIC_RG_VSIM1_EN
+
+[LDO_NAME9]
+LDO_NAME=VSIM2
+PARAMETER_NAME = PMIC_RG_VSIM2_EN
+
+[LDO_NAME10]
+LDO_NAME=VCAMAF
+PARAMETER_NAME = PMIC_RG_VCAM_AF_EN
+
+[LDO_NAME11]
+LDO_NAME=VIBR
+PARAMETER_NAME = PMIC_RG_VIBR_EN
+
+[LDO_NAME12]
+LDO_NAME=VM
+PARAMETER_NAME = PMIC_RG_VM_EN
+
+[LDO_NAME13]
+LDO_NAME=VRF18
+PARAMETER_NAME = PMIC_RG_VRF18_EN
+
+[LDO_NAME14]
+LDO_NAME=VCAMD
+PARAMETER_NAME = PMIC_RG_VCAMD_EN
+
+[LDO_NAME15]
+LDO_NAME=VCAMIO
+PARAMETER_NAME = PMIC_RG_VCAM_IO_EN
+
+[LDO_NAME16]
+LDO_NAME=VCAMA
+PARAMETER_NAME = PMIC_RG_VCAMA_EN
+
+[LDO_NAME17]
+LDO_NAME=VCN33_WIFI
+PARAMETER_NAME = PMIC_RG_VCN33_EN_WIFI
+
+[LDO_NAME18]
+LDO_NAME=VCN28
+PARAMETER_NAME = PMIC_RG_VCN28_EN
diff --git a/tools/dct/config/PMIC_MT6351PMUMP.cmp b/tools/dct/config/PMIC_MT6351PMUMP.cmp
new file mode 100644
index 00000000000..5177a0be983
--- /dev/null
+++ b/tools/dct/config/PMIC_MT6351PMUMP.cmp
@@ -0,0 +1,38 @@
+[PMIC_TABLE]
+CHIP = MT6351
+NUM_LDO = 8
+FUNCTION = pmic_set_register_value
+LDO_APPNAME_DEFAULT = MT65XX_POWER_NONE
+INCLUDE_HEADER = linux/types.h:mach/mt_typedefs.h:mach/upmu_common.h:mach/upmu_hw.h:mach/mt_pm_ldo.h
+
+[LDO_NAME1]
+LDO_NAME = VCAMA
+PARAMETER_NAME = MT6351_PMIC_RG_VCAMA_EN
+
+[LDO_NAME2]
+LDO_NAME = VSIM1
+PARAMETER_NAME = MT6351_PMIC_RG_VSIM1_EN
+
+[LDO_NAME3]
+LDO_NAME = VSIM2
+PARAMETER_NAME = MT6351_PMIC_RG_VSIM2_EN
+
+[LDO_NAME4]
+LDO_NAME = VLDO28
+PARAMETER_NAME = MT6351_PMIC_RG_VLDO28_EN_0
+
+[LDO_NAME5]
+LDO_NAME = VGP3
+PARAMETER_NAME = MT6351_PMIC_RG_VGP3_EN
+
+[LDO_NAME6]
+LDO_NAME = VIBR
+PARAMETER_NAME = MT6351_PMIC_RG_VIBR_EN
+
+[LDO_NAME7]
+LDO_NAME = VCAMD
+PARAMETER_NAME = MT6351_PMIC_RG_VCAMD_EN
+
+[LDO_NAME8]
+LDO_NAME = VCAMIO
+PARAMETER_NAME = MT6351_PMIC_RG_VCAMIO_EN
diff --git a/tools/dct/config/PMIC_NCPMUMP.cmp b/tools/dct/config/PMIC_NCPMUMP.cmp
new file mode 100644
index 00000000000..4e48b25cfab
--- /dev/null
+++ b/tools/dct/config/PMIC_NCPMUMP.cmp
@@ -0,0 +1,10 @@
+[PMIC_TABLE]
+CHIP =
+NUM_LDO =
+FUNCTION = pmic_set_register_value
+LDO_APPNAME_DEFAULT = MT65XX_POWER_NONE
+INCLUDE_HEADER = linux/types.h:mach/mt_typedefs.h:mach/upmu_common.h:mach/upmu_hw.h:mach/mt_pm_ldo.h
+
+[LDO_NAME1]
+LDO_NAME =
+PARAMETER_NAME =
diff --git a/tools/dct/config/YuSu.cmp b/tools/dct/config/YuSu.cmp
new file mode 100644
index 00000000000..35fd5227b0a
--- /dev/null
+++ b/tools/dct/config/YuSu.cmp
@@ -0,0 +1,989 @@
+[ADC_variables]
+TEMPERATURE
+TEMPERATURE1
+REF_CURRENT
+BATTERY_VOLTAGE
+CHARGER_VOLTAGE
+LCM_VOLTAGE
+HF_MIC
+UTMS
+BOARD_ID
+BOARD_ID_2
+BOARD_ID_3
+ADC_FDD_RF_PARAMS_DYNAMIC_CUSTOM_CH
+
+[EINT_variables]
+MT7118_WIMAX
+MT5921_WIFI
+BT
+KPD_PWRKEY
+KPD_SLIDE
+TOUCH
+TOUCH_PANEL
+MT6326_PMIC
+HEADSET
+MHALL
+HALL_1
+HALL_2
+HALL_3
+FM_RDS
+HALL_4
+ALS
+OFN
+WIFI
+COMBO_BGF
+COMBO_ALL
+GSE_1
+GSE_2
+MSE
+MHL
+GYRO
+ACCDET
+SWTP
+OTG_IDDIG
+CMMB
+NFC
+IRQ_NFC
+HEADSET_HOOK
+MT6329_PMIC
+EINT_HDMI_HPD
+DT_EXT_MD_EXP
+DT_EXT_MD_WDT
+DT_EXT_MD_WK_UP
+DT_EXT_MD_WK_UP_USB
+DT_EXT_MD_EXP
+EVDO_DT_EXT_MDM_RDY
+EVDO_DT_EXT_MDM_WAKE_AP
+EVDO_DT_EXT_MDM_RST_IND
+EVDO_DT_EXT_MDM_PWR_ON
+EVDO_DT_EXT_UART_MDM_WAKE_AP
+EVDO_DT_EXT_MDM_ACK
+EVDO_DT_EXT_MDM_FLOW_CTRL
+MT6280_USB_WAKEUP
+MT6280_WD
+SIM1_HOT_PLUG
+SIM2_HOT_PLUG
+SIM3_HOT_PLUG
+MSDC1_INS
+MSDC2_INS
+MT6322_PMIC
+MT6323_PMIC
+MT6333_PMIC
+MT6397_PMIC
+CHR_STAT
+LTE_SDIO
+LTE_WDT
+EXT_BUCK_OC
+EDP_INTN
+DSI_TE
+DSI_TE_1
+VBUS_DETECT_PIN_EINT
+FPC1145
+GOODIX_FP
+SENSORHUB
+MRDUMP_EXT_RST
+EXT_DBG_KEY
+EINT_SIL7033_INT
+EINT_FUSB300_DET_IN
+SMART_PA
+RT9465_SLAVE_CHR
+MT6336_CHR
+MT6311_PMIC
+MT6313_PMIC
+MT6351_PMIC
+MT6353_PMIC
+MT6335_PMIC
+MT6337_PMIC
+MT6350_PMIC
+RT1711H_PD
+
+[GPIO_variables]
+GPIO_AST_RST_PIN
+GPIO_AST_CS_PIN
+GPIO_AST_CLK32K_PIN
+GPIO_AST_WAKEUP_PIN
+GPIO_AST_INTR_PIN
+GPIO_AST_WAKEUP_INTR_PIN
+GPIO_AST_AFC_SWITCH_PIN
+GPIO_HEADSET_INSERT_PIN
+GPIO_HEADSET_REMOTE_BUTTON_PIN
+GPIO_EXTERNAL_AMPLIFIER_PIN
+GPIO_BT_POWREN_PIN
+GPIO_BT_RESET_PIN
+GPIO_BT_EINT_PIN
+GPIO_BT_CLK_PIN
+GPIO_BYPASS_BOOST_PIN
+GPIO_CMMB_EINT_PIN
+GPIO_CMMB_LDO_EN_PIN
+GPIO_CMMB_RST_PIN
+GPIO_I2C_APPM_SCA_PIN
+GPIO_I2C_APPM_SDA_PIN
+GPIO_I2C0_SCA_PIN
+GPIO_I2C0_SDA_PIN
+GPIO_I2C1_SCA_PIN
+GPIO_I2C1_SDA_PIN
+GPIO_I2C2_SCA_PIN
+GPIO_I2C2_SDA_PIN
+GPIO_I2C3_SCA_PIN
+GPIO_I2C3_SDA_PIN
+GPIO_I2C4_SCA_PIN
+GPIO_I2C4_SDA_PIN
+GPIO_I2C5_SDA_PIN
+GPIO_I2C5_SCA_PIN
+GPIO_I2C6_SDA_PIN
+GPIO_I2C6_SCA_PIN
+GPIO_I2C7_SDA_PIN
+GPIO_I2C7_SCA_PIN
+GPIO_NFC_FIRM_PIN
+GPIO_NFC_EINT_PIN
+GPIO_NFC_VENB_PIN
+GPIO_NFC_OSC_EN_PIN
+GPIO_IRQ_NFC_PIN
+GPIO_NFC_RST_PIN
+GPIO_SPI_CS_PIN
+GPIO_SPI_SCK_PIN
+GPIO_SPI_MISO_PIN
+GPIO_SPI_MOSI_PIN
+GPIO_SPI2_CS_PIN
+GPIO_SPI2_SCK_PIN
+GPIO_SPI2_MISO_PIN
+GPIO_SPI2_MOSI_PIN
+GPIO_PWM_1_PIN
+GPIO_PWM_2_PIN
+GPIO_PWM_3_PIN
+GPIO_PWM_4_PIN
+GPIO_PWM_5_PIN
+GPIO_PWM_6_PIN
+GPIO_PWM_7_PIN
+GPIO_PWR_AVAIL_WLC
+GPIO_PWR_BUTTON_PIN
+GPIO_PMIC_EINT_PIN
+GPIO_RFIC0_BSI_CK
+GPIO_RFIC0_BSI_CS
+GPIO_RFIC0_BSI_D0
+GPIO_RFIC0_BSI_D1
+GPIO_RFIC0_BSI_D2
+GPIO_SDHC_EINT_PIN
+GPIO_SDHC_MC2CM_PIN
+GPIO_SDHC_MC2DA2_PIN
+GPIO_SDHC_MC2DA3_PIN
+GPIO_SDHC_MC2WP_PIN
+GPIO_SDHC_MC2PWRON_PIN
+GPIO_SDHC_MC2INS_PIN
+GPIO_TDM_REQ
+GPIO_DISP_LSCK_PIN
+GPIO_DISP_LSA0_PIN
+GPIO_DISP_LSDA_PIN
+GPIO_DISP_LSCE_PIN
+GPIO_DISP_ID0_PIN
+GPIO_DISP_ID1_PIN
+GPIO_GPS_PWREN_PIN
+GPIO_GPS_SYNC_PIN
+GPIO_GPS_EINT_PIN
+GPIO_GPS_CLK_PIN
+GPIO_GPS_RST_PIN
+GPIO_GPS_LNA_PIN
+GPIO_UART_URXD0_PIN
+GPIO_UART_UTXD0_PIN
+GPIO_UART_UCTS0_PIN
+GPIO_UART_URTS0_PIN
+GPIO_UART_URXD1_PIN
+GPIO_UART_UTXD1_PIN
+GPIO_UART_UCTS1_PIN
+GPIO_UART_URTS1_PIN
+GPIO_UART_URXD2_PIN
+GPIO_UART_UTXD2_PIN
+GPIO_UART_UCTS2_PIN
+GPIO_UART_URTS2_PIN
+GPIO_UART_URXD3_PIN
+GPIO_UART_UTXD3_PIN
+GPIO_UART_UCTS3_PIN
+GPIO_UART_URTS3_PIN
+GPIO_UART_URXD4_PIN
+GPIO_UART_UTXD4_PIN
+GPIO_UART_UCTS4_PIN
+GPIO_UART_URTS4_PIN
+GPIO_KPD_KCOL0_PIN
+GPIO_KPD_KCOL1_PIN
+GPIO_KPD_KCOL2_PIN
+GPIO_KPD_KCOL3_PIN
+GPIO_KPD_KCOL4_PIN
+GPIO_KPD_KCOL5_PIN
+GPIO_KPD_KCOL6_PIN
+GPIO_KPD_KCOL7_PIN
+GPIO_KPD_KROW0_PIN
+GPIO_KPD_KROW1_PIN
+GPIO_KPD_KROW2_PIN
+GPIO_KPD_KROW3_PIN
+GPIO_KPD_KROW4_PIN
+GPIO_KPD_KROW5_PIN
+GPIO_KPD_KROW6_PIN
+GPIO_KPD_KROW7_PIN
+GPIO_CTP_EINT_PIN
+GPIO_CTP_EN_PIN
+GPIO_CTP_RST_PIN
+GPIO_WIFI_RST_PIN
+GPIO_WIFI_CLK_PIN
+GPIO_WIFI_EINT_PIN
+GPIO_WIFI_PMU_EN_PIN
+GPIO_WIFI_LDO_EN_PIN
+GPIO_BQ_INT_PIN
+GPIO_WIMAX_INT_PIN
+GPIO_WIMAX_RST_PIN
+GPIO_CAMERA_CMRST_PIN
+GPIO_CAMERA_CMPDN_PIN
+GPIO_CAMERA_CMRST1_PIN
+GPIO_CAMERA_CMPDN1_PIN
+GPIO_CAMERA_FLASH_EN_PIN
+GPIO_CAMERA_FLASH_MODE_PIN
+GPIO_CAMERA_LDO_EN_PIN
+GPIO_CAMERA_AF_EN_PIN
+GPIO_CAMERA_RCN_PIN
+GPIO_CAMERA_RCP_PIN
+GPIO_CAMERA_RDN0_PIN
+GPIO_CAMERA_RDP0_PIN
+GPIO_CAMERA_RDN1_PIN
+GPIO_CAMERA_RDP1_PIN
+GPIO_CAMERA_RDN2_PIN
+GPIO_CAMERA_RDP2_PIN
+GPIO_CAMERA_RDN3_PIN
+GPIO_CAMERA_RDP3_PIN
+GPIO_CAMERA_RCN_A_PIN
+GPIO_CAMERA_RCP_A_PIN
+GPIO_CAMERA_RDN0_A_PIN
+GPIO_CAMERA_RDP0_A_PIN
+GPIO_CAMERA_RDN1_A_PIN
+GPIO_CAMERA_RDP1_A_PIN
+GPIO_CAMERA_RDN2_A_PIN
+GPIO_CAMERA_RDP2_A_PIN
+GPIO_CAMERA_RDN3_A_PIN
+GPIO_CAMERA_RDP3_A_PIN
+GPIO_CAMERA_RCN_B_PIN
+GPIO_CAMERA_RCP_B_PIN
+GPIO_CAMERA_RDN0_B_PIN
+GPIO_CAMERA_RDP0_B_PIN
+GPIO_CAMERA_RDN1_B_PIN
+GPIO_CAMERA_RDP1_B_PIN
+GPIO_PMIC_EINT_PIN
+GPIO_PCM_DAICLK_PIN
+GPIO_PCM_DAIPCMOUT_PIN
+GPIO_PCM_DAIPCMIN_PIN
+GPIO_PCM_DAISYNC_PIN
+GPIO_JBD_INPUT_UP_PIN
+GPIO_JBD_INPUT_LEFT_PIN
+GPIO_JBD_INPUT_RIGHT_PIN
+GPIO_JBD_INPUT_DOWN_PIN
+GPIO_JTAG_TMS_PIN
+GPIO_JTAG_TCK_PIN
+GPIO_JTAG_TDI_PIN
+GPIO_JTAG_TDO_PIN
+GPIO_JTAG_TRSTN_PIN
+GPIO_QWERTYSLIDE_EINT_PIN
+GPIO_CAPTOUCH_EINT_PIN
+GPIO_HALL_1_PIN
+GPIO_HALL_2_PIN
+GPIO_HALL_3_PIN
+GPIO_HALL_4_PIN
+GPIO_OFN_EINT_PIN
+GPIO_OFN_DWN_PIN
+GPIO_OFN_RST_PIN
+GPIO_MHALL_EINT_PIN
+GPIO_FM_RDS_PIN
+GPIO_FM_CLK_PIN
+GPIO_ALS_EINT_PIN
+GPIO_MATV_PWR_ENABLE
+GPIO_MATV_N_RST
+GPIO_I2S_DATA
+GPIO_SPEAKER_EN_PIN
+GPIO_RECEIVER_EN_PIN
+GPIO_SPEAKER_EARPIECE_SWITCH_PIN
+GPIO_SWCHARGER_EN_PIN
+GPIO_COMBO_PMU_EN_PIN
+GPIO_COMBO_PMUV28_EN_PIN
+GPIO_COMBO_RST_PIN
+GPIO_COMBO_RTCCLK_PIN
+GPIO_COMBO_BGF_EINT_PIN
+GPIO_COMBO_ALL_EINT_PIN
+GPIO_COMBO_6620_LDO_EN_PIN
+GPIO_COMBO_I2S_CK_PIN
+GPIO_COMBO_I2S_DAT_PIN
+GPIO_COMBO_I2S_WS_PIN
+GPIO_COMBO_UTXD_PIN
+GPIO_COMBO_URXD_PIN
+GPIO_I2S0_CK_PIN
+GPIO_I2S0_DAT_PIN
+GPIO_I2S0_MCLK_PIN
+GPIO_I2S0_WS_PIN
+GPIO_I2S1_CK_PIN
+GPIO_I2S1_DAT_PIN
+GPIO_I2S1_MCLK_PIN
+GPIO_I2S1_WS_PIN
+GPIO_GSE_1_EINT_PIN
+GPIO_GSE_2_EINT_PIN
+GPIO_MSE_EINT_PIN
+GPIO_GYRO_EINT_PIN
+GPIO_ACCDET_EINT_PIN
+GPIO_OTG_IDDIG_EINT_PIN
+GPIO_OTG_DRVVBUS_PIN
+GPIO_VBUS_DETECT_PIN
+GPIO_USB_DEFAULT_DEVICE_MODE
+GPIO_HEADSET_SW_EN_PIN
+GPIO_HEADSET_JPOLE_PIN
+GPIO_HEADSET_REMOTE_BUTTON_PIN
+GPIO_DISP_LRSTB_PIN
+GPIO_HDMI_I2S_OUT_CK_PIN
+GPIO_HDMI_I2S_OUT_WS_PIN
+GPIO_HDMI_I2S_OUT_DAT_PIN
+GPIO_HDMI_I2C_SCL
+GPIO_HDMI_I2C_SDA
+GPIO_HDMI_POWER_CONTROL
+GPIO_HDMI_9024_RESET
+GPIO_HDMI_EINT_PIN
+GPIO_HDMI_LCD_SW_EN
+GPIO_HDMI_PWR_1_2V_EN
+GPIO_HIFI_VCCA_EN_PIN
+GPIO_HIFI_AVCC_EN_PIN
+GPIO_HIFI_DVCC_EN_PIN
+GPIO_HW_VER_CHECK_PIN
+GPIO_MATV_I2S_CK_PIN
+GPIO_MATV_I2S_WS_PIN
+GPIO_MATV_I2S_DAT_PIN
+GPIO_2G_TX_FILTER_MODE_PIN
+GPIO_2G_RX_ACTIVE_PIN
+GPIO_4G_RX_ACTIVE_PIN
+GPIO_4G_TX_FILTER_MODE_PIN
+GPIO_52_RST
+GPIO_52_TO_2G
+GPIO_52_3G_USB_RESUME
+GPIO_52_KCOL0
+GPIO_52_REC_SW
+GPIO_52_WD
+GPIO_52_USB_SW2
+GPIO_52_TO_3G
+GPIO_52_PWR_KEY
+GPIO_52_USB_SW1
+GPIO_EXT_BUCK_EN_A_PIN
+GPIO_EXT_BUCK_EN_B_PIN
+GPIO_EXT_BUCK_IC_EN_PIN
+GPIO_EXT_BUCK_OC_EINT_PIN
+GPIO_EXT_MD_RST
+GPIO_EXT_MD_PWR_KEY
+GPIO_EXT_MD_DL_KEY
+GPIO_EXT_MD_WD
+GPIO_EXT_MD_EXP
+GPIO_EXT_MD_WK_AP
+GPIO_EXT_MD_META
+GPIO_EXT_AP_WK_MD
+GPIO_EXT_USB_SW1
+GPIO_EXT_USB_SW2
+GPIO_EXT_USB_RESUME
+GPIO_EXT_SSW_S1
+GPIO_EXT_SSW_S2
+GPIO_EXT_SSW_EN
+GPIO_EXT_MD_DUMP
+GPIO_EXT_SPKAMP_EN_PIN
+GPIO_6280_USB_SW1
+GPIO_6280_USB_SW2
+GPIO_6280_KCOL0
+GPIO_6280_USB_WAKEUP_EINT
+GPIO_6280_WD
+GPIO_6280_RST
+GPIO_VIA_MDM_RST
+GPIO_VIA_MDM_RST_IND
+GPIO_VIA_MDM_PWR_EN
+GPIO_VIA_MDM_PWR_ON
+GPIO_VIA_CP_BOOT_SEL
+GPIO_VIA_AP_WAKE_MDM
+GPIO_VIA_MDM_RDY
+GPIO_VIA_MDM_WAKE_AP
+GPIO_VIA_AP_RDY
+GPIO_VIA_SDIO_ACK
+GPIO_VIA_FLOW_CTRL
+GPIO_VIA_ETS_SEL
+GPIO_MSDC0_DAT0
+GPIO_MSDC0_DAT1
+GPIO_MSDC0_DAT2
+GPIO_MSDC0_DAT3
+GPIO_MSDC0_DAT4
+GPIO_MSDC0_DAT5
+GPIO_MSDC0_DAT6
+GPIO_MSDC0_DAT7
+GPIO_MSDC0_CMD
+GPIO_MSDC0_CLK
+GPIO_MSDC0_RSTB
+GPIO_MSDC0_DSL
+GPIO_MSDC1_DAT0
+GPIO_MSDC1_DAT1
+GPIO_MSDC1_DAT2
+GPIO_MSDC1_DAT3
+GPIO_MSDC1_CMD
+GPIO_MSDC1_CLK
+GPIO_MSDC1_INSI
+GPIO_MSDC1_SDWPI
+GPIO_MSDC2_DAT0
+GPIO_MSDC2_DAT1
+GPIO_MSDC2_DAT2
+GPIO_MSDC2_DAT3
+GPIO_MSDC2_CMD
+GPIO_MSDC2_CLK
+GPIO_MSDC2_INSI
+GPIO_MSDC2_SDWPI
+GPIO_MSDC3_DAT0
+GPIO_MSDC3_DAT1
+GPIO_MSDC3_DAT2
+GPIO_MSDC3_DAT3
+GPIO_MSDC3_CMD
+GPIO_MSDC3_CLK
+GPIO_MSDC4_DAT0
+GPIO_MSDC4_DAT1
+GPIO_MSDC4_DAT2
+GPIO_MSDC4_DAT3
+GPIO_MSDC4_DAT4
+GPIO_MSDC4_DAT5
+GPIO_MSDC4_DAT6
+GPIO_MSDC4_DAT7
+GPIO_MSDC4_CMD
+GPIO_MSDC4_CLK
+GPIO_MSDC4_RSTB
+GPIO_SIM1_HOT_PLUG
+GPIO_SIM2_HOT_PLUG
+GPIO_FSA8049_PIN
+GPIO_ANT_SW_PIN
+GPIO_EINT_CHG_STAT_PIN
+GPIO_MHL_EINT_PIN
+GPIO_MHL_I2S_OUT_CK_PIN
+GPIO_MHL_I2S_OUT_WS_PIN
+GPIO_MHL_I2S_OUT_DAT_PIN
+GPIO_MHL_I2C_SCL
+GPIO_MHL_I2C_SDA
+GPIO_MHL_RST_B_PIN
+GPIO_MHL_POWER_CTRL_PIN
+GPIO_EXT_DISP_DPI0_PIN
+GPIO_TD_HIF_DCX_PIN
+GPIO_TD_HIF_WR_PIN
+GPIO_TD_HIF_RD_PIN
+GPIO_CAMERA_2_CMPDN_PIN
+GPIO_CAMERA_2_CMRST_PIN
+GPIO_CAMERA_2_CMMCLK_PIN
+GPIO_CAMERA_2_CMRST_PIN
+GPIO_CAMERA_2_CMPDN_PIN
+GPIO_CHR_PSEL_PIN
+GPIO_CHR_CE_PIN
+GPIO_CHR_SPM_PIN
+GPIO_CAMERA_FLASH_EXT1_PIN
+GPIO_CAMERA_FLASH_EXT2_PIN
+GPIO_GPS_EN_MT3332
+GPIO_GPS_FRAM_SYNC_MT3332
+GPIO_GPS_TXIND_MT3332
+GPIO_GPS_LNA_MT3332
+GPIO_EXTMD_PCM_CLK_PIN
+GPIO_EXTMD_PCM_PCMOUT_PIN
+GPIO_EXTMD_PCM_PCMIN_PIN
+GPIO_EXTMD_PCM_SYNC_PIN
+GPIO_MRG_I2S_PCM_CLK_PIN
+GPIO_MRG_I2S_PCM_SYNC_PIN
+GPIO_MRG_I2S_PCM_RX_PIN
+GPIO_MRG_I2S_PCM_TX_PIN
+GPIO_DAIBT_PCM_CLK_PIN
+GPIO_DAIBT_PCM_WS_PIN
+GPIO_DAIBT_PCM_DI_PIN
+GPIO_DAIBT_PCM_DO_PIN
+GPIO_DAC_I2S_CLK_PIN
+GPIO_DAC_I2S_WS_PIN
+GPIO_DAC_I2S_DAT_OUT_PIN
+GPIO_DAC_I2S_MCLK_PIN
+GPIO_ADC_I2S_CLK_PIN
+GPIO_ADC_I2S_WS_PIN
+GPIO_ADC_I2S_DAT_IN_PIN
+GPIO_ADC_I2S_MCLK_PIN
+GPIO_I2S_CLK_PIN
+GPIO_I2S_WS_PIN
+GPIO_I2S_DAT_OUT_PIN
+GPIO_I2S_DAT_IN_PIN
+GPIO_AUD_CLK_MOSI_PIN
+GPIO_AUD_DAT_MOSI_PIN
+GPIO_AUD_DAT_MISO_PIN
+GPIO_AUD_EXTHP_EN_PIN
+GPIO_AUD_EXTHP_GAIN_PIN
+GPIO_AUD_EXTDAC_PWREN_PIN
+GPIO_AUD_EXTDAC_RST_PIN
+GPIO_AUD_EXTPLL_S0_PIN
+GPIO_AUD_EXTPLL_S1_PIN
+GPIO_AUD_EXTHPBUF_SDB_PIN
+GPIO_AUD_EXTHPBUF_HI_Z_PIN
+GPIO_AUD_EXTHPBUF_GAIN_PIN
+GPIO_SIM_SWITCH_CLK_PIN
+GPIO_SIM_SWITCH_DAT_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_1ST_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_2ND_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_3RD_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_4TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_5TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_6TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_7TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_8TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_9TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_ATH_PIN
+GPIO_SIM1_SCLK
+GPIO_SIM1_SRST
+GPIO_SIM1_SIO
+GPIO_SIM2_SCLK
+GPIO_SIM2_SRST
+GPIO_SIM2_SIO
+GPIO_SWITCH1_1V8_PIN
+GPIO_USB_MHL_SW_SEL1
+GPIO_USB_MHL_SW_SEL2
+GPIO_LCM_LED_EN
+GPIO_LCM_MIPI2LVDS_EN
+GPIO_LCM_MIPI2LVDS_PWR_EN
+GPIO_LCM_LVDS_PWR_EN
+GPIO_LCM_LVDS_EN
+GPIO_LCM_PWR
+GPIO_LCM_PWR_EN
+GPIO_LCM_PWR2_EN
+GPIO_LCM_RST
+GPIO_LCM_STB
+GPIO_LCM_BL_EN
+GPIO_LCM_LVL_SHIFT_EN
+GPIO_LCM_BRIDGE_EN
+GPIO_SSW_EN_PIN
+GPIO_SSW_CH_SWAP_PIN
+GPIO_LCD_BIAS_ENP_PIN
+GPIO_LCD_BIAS_ENN_PIN
+GPIO_LCD_DRV_EN_PIN
+GPIO_LCDBL_EN_PIN
+GPIO_LCD_ENN
+GPIO_LCD_ENP
+GPIO_CMCSK
+GPIO_CMDAT0
+GPIO_CMDAT1
+GPIO_CMDAT2
+GPIO_CMDAT3
+GPIO_CMDAT4
+GPIO_CMDAT5
+GPIO_CMDAT6
+GPIO_CMDAT7
+GPIO_CMDAT8
+GPIO_CMDAT9
+GPIO_CMHSYNC
+GPIO_CMMCLK
+GPIO_CMPCLK
+GPIO_CMVSYNC
+GPIO_COMPASS_RST_PIN
+GPIO_EXT_BUCK_EN_PIN
+GPIO_EXT_BUCK_VSEL_PIN
+GPIO_LTE_SDIO_EINT_PIN
+GPIO_LTE_WDT_EINT_PIN
+GPIO_LTE_POWER_PIN
+GPIO_LTE_RESET_PIN
+GPIO_LTE_WK_MD_PIN
+GPIO_SWITCH1_1V8_PIN
+GPIO_CAMERA_MAIN_DVDD_ENADBLE_PIN
+GPIO_HIFI_LDO1V8_EN_PIN
+GPIO_SMARTPA_RST_PIN
+GPIO_EARPHONE_DETECT_PIN
+GPIO_LCD_ENP_PIN
+GPIO_HIFI_LDO3V3_EN_PIN
+GPIO_CAMERA_MCLK_EN_PIN
+GPIO_LCD_ENN_PIN
+GPIO_NXPSPA_I2S_DATAOUT_PIN
+GPIO_NXPSPA_I2S_DATAIN_PIN
+GPIO_NXPSPA_I2S_LRCK_PIN
+GPIO_NXPSPA_I2S_BCK_PIN
+GPIO_STROBE_LED_TPS61311_STRB0
+GPIO_STROBE_LED_TPS61311_STRB1
+GPIO_STROBE_LED_TPS61311_TXMASK
+GPIO_STROBE_LED_TPS61311_NRESET
+GPIO_EDP_EINT_PIN
+GPIO_EDP_ENPSR_PIN
+GPIO_EDP_SYSRSTN_PIN
+GPIO_EDP_STANDBY_PIN
+GPIO_EXT_BUCK_OC_EINT_PIN
+GPIO_VOW_CLK_MISO_PIN
+GPIO_G2_TXEN_PIN
+GPIO_G2_TXD3_PIN
+GPIO_G2_TXD2_PIN
+GPIO_G2_TXD1_PIN
+GPIO_G2_TXD0_PIN
+GPIO_G2_TXC_PIN
+GPIO_G2_RXC_PIN
+GPIO_G2_RXD0_PIN
+GPIO_G2_RXD1_PIN
+GPIO_G2_RXD2_PIN
+GPIO_G2_RXD3_PIN
+GPIO_ESW_INT_PIN
+GPIO_G2_RXDV_PIN
+GPIO_MDC_PIN
+GPIO_MDIO_PIN
+GPIO_ESW_RST_PIN
+GPIO_IRRX_PIN
+GPIO_HDMI_RX_SDA_PIN
+GPIO_HDMI_RX_SCL_PIN
+GPIO_MAIN_CAM_ID_PIN
+GPIO_SUB_CAM_ID_PIN
+GPIO_LCD_MAKER_ID
+GPIO_AUDIO_SEL
+GPIO_DSV_EN
+GPIO_TOUCH_MAKER_ID
+GPIO_BAT_ID
+GPIO_BATT_ID_PULLUP
+GPIO_SENSOR0_I2C_SDA
+GPIO_SENSOR0_I2C_SCL
+GPIO_COMMON_I2C_SCL
+GPIO_COMMON_I2C_SDA
+GPIO_LCD_BL_EN
+GPIO_DSV_AVEE_EN
+GPIO_DSV_AVDD_EN
+GPIO_NFC_MODE
+GPIO_HP_AMP_EN
+GPIO_SPK_AMP_EN
+GPIO_SMARTPA_I2S_WS_PIN
+GPIO_SMARTPA_I2S_DOUT_PIN
+GPIO_SMARTPA_I2S_DIN_PIN
+GPIO_SMARTPA_I2S_BCK_PIN
+GPIO_SMARTPA_RST_PIN
+GPIO_SMARTPA_EINT_PIN
+GPIO_SMARTPA_LDO_EN_PIN
+GPIO_EXT_SPKAMP2_EN_PIN
+GPIO_RCV_SPK_SWITCH_PIN
+GPIO_FLASH_LED_EN
+GPIO_TORCH_EN
+GPIO_LTE_VSRAM_EXT_POWER_EN_PIN
+GPIO_CAMERA_KEY1_PIN
+GPIO_CAMERA_KEY2_PIN
+GPIO_CODEC_SPI_CLK_PIN
+GPIO_CODEC_SPI_MISO_PIN
+GPIO_CODEC_SPI_MOSI_PIN
+GPIO_CODEC_SPI_CS_PIN
+GPIO_DTV_SPI_SCK_PIN
+GPIO_DTV_SPI_MISO_PIN
+GPIO_DTV_SPI_MOSI_PIN
+GPIO_DTV_SPI_CS_PIN
+GPIO_LCM_RST2_PIN
+GPIO_IRTX_OUT_PIN
+GPIO_PWRAP_SPI0_MI_PIN
+GPIO_PWRAP_SPI0_MO_PIN
+GPIO_PWRAP_SPI0_CK_PIN
+GPIO_PWRAP_SPI0_CSN_PIN
+GPIO_CMCSD0_PIN
+GPIO_CMCSD1_PIN
+GPIO_CMCSD2_PIN
+GPIO_CMCSD3_PIN
+GPIO_SENSORHUB_HOST_RESET
+GPIO_SENSORHUB_HOST_BOOT_ROM
+GPIO_SENSORHUB_WAKE_UP
+GPIO_SENSORHUB_EINT_PIN
+GPIO_HAPTIC_DRV_EN_PIN
+GPIO_HAPTIC_PWM_EN_PIN
+GPIO_LCD_IO_0_PIN
+GPIO_LCD_IO_1_PIN
+GPIO_LCD_IO_2_PIN
+GPIO_LCD_IO_3_PIN
+GPIO_LCD_IO_4_PIN
+GPIO_LCD_IO_5_PIN
+GPIO_LCD_IO_6_PIN
+GPIO_LCD_IO_7_PIN
+GPIO_LCD_IO_8_PIN
+GPIO_LCD_IO_9_PIN
+GPIO_LCD_IO_10_PIN
+GPIO_LCD_IO_11_PIN
+GPIO_LCD_IO_12_PIN
+GPIO_LCD_IO_13_PIN
+GPIO_LCD_IO_14_PIN
+GPIO_LCD_IO_15_PIN
+GPIO_LCD_IO_16_PIN
+GPIO_LCD_IO_17_PIN
+GPIO_LCD_IO_18_PIN
+GPIO_LCD_IO_19_PIN
+GPIO_LCD_IO_20_PIN
+GPIO_LCD_IO_21_PIN
+GPIO_LCD_IO_22_PIN
+GPIO_LCD_IO_23_PIN
+GPIO_PWM_BL_PIN
+GPIO_LCD_TE_PIN
+GPIO_LCD_PA_PIN
+GPIO_LCD_WRB_PIN
+GPIO_LCD_RDB_PIN
+GPIO_LCD_CEB_PIN
+GPIO_DPI_CK_PIN
+GPIO_DPI_DE_PIN
+GPIO_DPI_VSYNC_PIN
+GPIO_DPI_HSYNC_PIN
+GPIO_DSI_TE_PIN
+GPIO_DSI_CKP_PIN
+GPIO_DSI_CKN_PIN
+GPIO_DSI_D0P_PIN
+GPIO_DSI_D0N_PIN
+GPIO_DSI_D1P_PIN
+GPIO_DSI_D1N_PIN
+GPIO_DSI_D2P_PIN
+GPIO_DSI_D2N_PIN
+GPIO_DISP_LSDI_PIN
+GPIO_HEART_RATE_RESET_PIN
+GPIO_MT8193_BUS_SWITCH_PIN
+GPIO_HDMI_IN_SWITCH_PORT_PIN
+GPIO_CAMERA_VCAMA_ENABLE_PIN
+GPIO_USB_REDRI_SW_C1_PIN
+GPIO_USB_REDRI_SW_C2_PIN
+GPIO_USB_TYPEC_EINT_PIN
+GPIO_USB_TYPEC_SW_EN_PIN
+GPIO_USB_TYPEC_SW_SEL_PIN
+GPIO_CAMERA_MIPI_SWITCH_EN_PIN
+GPIO_CAMERA_MIPI_SWITCH_SEL_PIN
+GPIO_U3_REDRIVER_C2_PIN
+GPIO_U3_REDRIVER_C1_PIN
+GPIO_FUSB340_USBTYPEC_SEL_PIN
+GPIO_FUSB340_USBTYPEC_NOE_PIN
+GPIO_SIL7033_RST_PIN
+GPIO_HP_DEPOP_SWITCH_PIN
+GPIO_CMMCLK1_PIN
+GPIO_EINT_CHG_STAT_PIN
+GPIO_FINGERPRINT_RST_PIN
+GPIO_ANT_SEL0_PIN
+GPIO_ANT_SEL1_PIN
+GPIO_ANT_SEL2_PIN
+GPIO_ANT_SEL3_PIN
+GPIO_ANT_SEL4_PIN
+GPIO_ANT_SEL5_PIN
+GPIO_ANT_SEL6_PIN
+GPIO_ANT_SEL7_PIN
+GPIO_FP_EINT_PIN
+GPIO_SRCLKENA_PIN
+GPIO_FUSB300_EINT_DET_IN_PIN
+GPIO_SIL7033_EINT_INT_PIN
+GPIO_VIB_EN_PIN
+GPIO_VIB_PWM_PIN
+GPIO_VMBUCK_I2C_SDA
+GPIO_VMBUCK_I2C_SCL
+GPIO_Smart_PA_EINT_PIN
+GPIO_Smart_PA_RESET_N_PIN
+GPIO_SMARTPA_LRCK_PIN
+GPIO_EINT_SMARTPA_PIN
+GPIO_VCAM_EN_PIN
+GPIO_CAMERA_VCAMD_EN_PIN
+GPIO_EINT_WPC_PIN
+GPIO_BPI_ANT3_PIN
+GPIO_BPI_ANT2_PIN
+GPIO_BPI_ANT1_PIN
+GPIO_BPI_ANT0_PIN
+GPIO_MT6306_I2C_SCL_PIN
+GPIO_MT6306_I2C_SDA_PIN
+GPIO_NFC_SRCLKENAI_PIN
+GPIO_IR_LDO_EN_PIN
+GPIO_RFIC0_BSI_EN_PIN
+GPIO_CAMERA_CMMCLK0_PIN
+GPIO_DEPOP_SWITCH_PIN
+GPIO_FLASH_STROBE_PIN
+GPIO_SIM_SD_INT
+GPIO_U3_PD_PWR_EN_PIN
+GPIO_RT9465_PWR_EN_PIN
+GPIO_RT9465_EINT_PIN
+GPIO_MT6336_EINT_PIN
+GPIO_EINT_RAMDUMP_PIN
+GPIO_SIM3_HOT_PLUG
+
+[GPIO_MODE_EINT_WHITE_LIST]
+DSI_TE
+
+[GPIO_MODE]
+GPIO = _M_GPIO
+CLK = _M_CLK
+EINT = _M_EINT
+MD_EINT = _M_MDEINT
+IRQ = _M_IRQ
+KROW = _M_KROW
+KCOL = _M_KCOL
+PWM = _M_PWM
+
+[GPIO_FREQ]
+GPIO_BT_CLK_PIN = CLK_SRC_F32K
+GPIO_GPS_CLK_PIN = CLK_SRC_F32K
+GPIO_WIFI_CLK_PIN = CLK_SRC_F32K
+GPIO_FM_CLK_PIN = CLK_SRC_F32K
+GPIO_COMBO_RTCCLK_PIN = CLK_SRC_F32K
+
+[GPIO_VARIABLES_MAPPING]
+GPIO_FDD_BAND_SUPPORT_DETECT_1ST_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_2ND_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_3RD_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_4TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_5TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_6TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_7TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_8TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_9TH_PIN
+GPIO_FDD_BAND_SUPPORT_DETECT_ATH_PIN
+GPIO_SIM_SWITCH_DAT_PIN
+GPIO_SIM_SWITCH_CLK_PIN
+GPIO_SIM1_HOT_PLUG
+GPIO_SIM2_HOT_PLUG
+GPIO_CMDAT1
+GPIO_SIM1_SCLK
+GPIO_SIM1_SRST
+GPIO_SIM1_SIO
+GPIO_SIM2_SCLK
+GPIO_SIM2_SRST
+GPIO_SIM2_SIO
+GPIO_AST_CS_PIN
+GPIO_AST_CS_PIN_NCE
+GPIO_AST_RST_PIN
+GPIO_AST_CLK32K_PIN
+GPIO_AST_CLK32K_PIN_CLK
+GPIO_AST_WAKEUP_PIN
+GPIO_AST_WAKEUP_INTR_PIN
+GPIO_AST_INTR_PIN
+GPIO_AST_AFC_SWITCH_PIN
+GPIO_RF_CONTROL1
+GPIO_SIM3_HOT_PLUG
+
+[SLAVE_DEVICE]
+CAMERA_MAIN
+CAMERA_MAIN_AF
+CAMERA_MAIN_TWO
+CAMERA_MAIN_HW
+CAMERA_SUB
+CAMERA_SUB_AF
+CAMERA_MAIN_TWO_AF
+VPROC_BUCK
+VGPU_BUCK
+EXT_BOOST
+EXT_BUCK
+EXT_BUCK2
+EXT_BUCK3
+EXT_BUCK_LP4
+EXT_BUCK_LP4X
+EXT_BUCK_SRAM
+EXT_VBAT_BOOST
+CHARGEPUMP
+SW_CHARGER
+SLAVE_CHARGER
+SWITHING_CHARGER
+SWITCHING_CHARGER_TI
+SWITCHING_CHARGER_RT
+CAP_TOUCH
+MSENSOR
+MHL
+GSENSOR
+PRESSURE
+ALSPS
+GYRO
+TEMPER
+STROBE_MAIN
+STROBE_MAIN_2
+STROBE_SUB
+STROBE_SUB_2
+NFC
+EXT_SPEAKER_AMP
+EXT_DISP
+I2C_LCD_BIAS
+BUCK_BOOST
+SPEAKER_AMP
+USB_TYPE_C
+BAROMETER
+HUMIDITY
+
+[Key_definition]
+HOME = 102
+BACK = 158
+CALL = 231
+ENDCALL = 107
+VOLUMEDOWN = 114
+VOLUMEUP = 115
+MUTE = 113
+MENU = 139
+UP = 103
+DOWN = 108
+LEFT = 105
+RIGHT = 106
+OK = 352
+FOCUS = 211
+CAMERA = 212
+POWER = 116
+AT = 228
+POUND = 523
+STAR = 227
+DEL = 111
+TAB = 15
+ENTER = 28
+LEFTSHIFT = 42
+COMMA = 51
+DOT = 52
+SLASH = 53
+LEFTALT = 56
+RIGHTALT = 100
+SPACE = 57
+SEARCH = 217
+SYM = 127
+0 = 11
+1 = 2
+2 = 3
+3 = 4
+4 = 5
+5 = 6
+6 = 7
+7 = 8
+8 = 9
+9 = 10
+A = 30
+B = 48
+C = 46
+D = 32
+E = 18
+F = 33
+G = 34
+H = 35
+I = 23
+J = 36
+K = 37
+L = 38
+M = 50
+N = 49
+O = 24
+P = 25
+Q = 16
+R = 19
+S = 31
+T = 20
+U = 22
+V = 47
+W = 17
+X = 45
+Y = 21
+Z = 44
+
+[Power_Key_definition]
+POWER
+ENDCALL
+
+[APPLICATION]
+CAP_TOUCH_VDD
+CAP_TOUCH_VIO
+MAIN_CAMERA_POWER_A
+MAIN_CAMERA_POWER_D
+MAIN_CAMERA_POWER_IO
+MAIN_CAMERA_POWER_AF
+MAIN_CAMERA_2_POWER_A
+MAIN_CAMERA_2_POWER_AF
+MAIN_CAMERA_2_POWER_D
+MAIN_CAMERA_2_POWER_IO
+MHL_POWER_LDO1
+MHL_POWER_LDO2
+SUB_CAMERA_POWER_A
+SUB_CAMERA_POWER_IO
+SUB_CAMERA_POWER_D
+SUB_CAMERA_POWER_AF
+ACCELEROMETER_SENSOR_VDD
+ACCELEROMETER_SENSOR_VIO
+AMBIENT_LIGHT_SENSOR_VDD
+AMBIENT_LIGHT_SENSOR_VIO
+PROXIMITY_SENSOR_VDD
+PROXIMITY_SENSOR_VIO
+MAGNETOMETER_SENSOR_VDD
+MAGNETOMETER_SENSOR_VIO
+GYROSCOPE_VDD
+GYROSCOPE_VIO
+BAROMETER_VDD
+BAROMETER_VIO
+MEMORY_CARD_VDD
+
+
diff --git a/tools/dct/data/ClkData.py b/tools/dct/data/ClkData.py
new file mode 100755
index 00000000000..e33ede82200
--- /dev/null
+++ b/tools/dct/data/ClkData.py
@@ -0,0 +1,35 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+class ClkData:
+    _varList = ['DISABLE', 'SW_CONTROL', 'HW_CONTROL']
+    _count = 0
+
+    def __init__(self):
+        self.__varName = ''
+        self.__current = ''
+        self.__curList = []
+
+    def set_defVarName(self, idx):
+        self.__varName = self._varList[idx]
+
+    def set_varName(self, name):
+        self.__varName = name
+
+    def set_defCurrent(self, idx):
+        self.__current = self.__curList[idx]
+
+    def set_current(self, current):
+        self.__current = current
+
+    def get_varName(self):
+        return self.__varName
+
+    def get_current(self):
+        return self.__current
+
+    def set_curList(self, cur_list):
+        self.__curList = cur_list
+
+    def get_curList(self):
+        return self.__curList
diff --git a/tools/dct/data/EintData.py b/tools/dct/data/EintData.py
new file mode 100755
index 00000000000..8459876e16b
--- /dev/null
+++ b/tools/dct/data/EintData.py
@@ -0,0 +1,91 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+
+class EintData:
+    _count = 0
+    _debounce_enable_list = ['CUST_EINT_DEBOUNCE_DISABLE', 'CUST_EINT_DEBOUNCE_ENABLE']
+    _map_table = {}
+    _mode_map = {}
+    _int_eint = {}
+    _builtin_map = {}
+    _builtin_eint_count = 0
+    def __init__(self):
+        self.__varName = ''
+        self.__debounce_time = ''
+        self.__polarity = ''
+        self.__sensitive_level = ''
+        self.__debounce_enable = ''
+
+    def set_varName(self, varName):
+        self.__varName = varName
+
+    def get_varName(self):
+        return self.__varName
+
+    def set_debounceTime(self, time):
+        self.__debounce_time = time
+
+    def get_debounceTime(self):
+        return self.__debounce_time
+
+    def set_polarity(self, polarity):
+        self.__polarity = polarity
+
+    def get_polarity(self):
+        return self.__polarity
+
+    def set_sensitiveLevel(self, level):
+        self.__sensitive_level = level
+
+    def get_sensitiveLevel(self):
+        return self.__sensitive_level
+
+    def set_debounceEnable(self, enable):
+        self.__debounce_enable = enable
+
+    def get_debounceEnable(self):
+        return self.__debounce_enable
+
+    @staticmethod
+    def set_mapTable(map):
+        EintData._map_table = map
+
+    @staticmethod
+    def get_mapTable():
+        return EintData._map_table
+
+    @staticmethod
+    def get_modeName(gpio_num, mode_idx):
+        key = 'gpio%s' %(gpio_num)
+
+        if key in EintData._mode_map.keys():
+            list =  EintData._mode_map[key]
+            if mode_idx < len(list) and mode_idx >= 0:
+                return list[mode_idx]
+
+        return None
+
+    @staticmethod
+    def set_modeMap(map):
+        for (key, value) in map.items():
+            list = []
+            for item in value:
+                list.append(item[6:len(item)-1])
+            map[key] = list
+
+        EintData._mode_map = map
+
+    @staticmethod
+    def get_modeMap():
+        return EintData._mode_map
+
+    @staticmethod
+    def get_gpioNum(num):
+        if len(EintData._map_table):
+            for (key,value) in EintData._map_table.items():
+                if num == value:
+                    return key
+
+        return -1
+
diff --git a/tools/dct/data/GpioData.py b/tools/dct/data/GpioData.py
new file mode 100755
index 00000000000..94ac4e6f182
--- /dev/null
+++ b/tools/dct/data/GpioData.py
@@ -0,0 +1,119 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+class GpioData:
+    _count = 0
+    _modNum = 8
+    _specMap = {}
+    _freqMap = {}
+    _mapList = []
+    _modeMap = {}
+    _smtMap = {}
+
+    def __init__(self):
+        self.__defMode = 0
+        self.__eintMode = False
+        self.__modeVec = ['0', '0', '0', '0', '0', '0', '0', '0']
+        self.__inPullEn = True
+        self.__inPullSelHigh = False
+        self.__defDirInt = 0
+        self.__defDir = 'IN'
+        self.__inEn = True
+        self.__outEn = False
+        self.__outHigh = False
+        self.__varNames = []
+        self.__smtNum = -1
+        self.__smtEn = False
+        self.__iesEn = True
+
+
+    def get_defMode(self):
+        return self.__defMode
+
+    def set_defMode(self, mode):
+        self.__defMode = mode
+
+    def get_eintMode(self):
+        return self.__eintMode
+
+    def set_eintMode(self, flag):
+        self.__eintMode = flag
+
+    def get_modeVec(self):
+        return self.__modeVec
+
+    def set_modeVec(self, vec):
+        self.__modeVec = vec
+
+    def get_inPullEn(self):
+        return self.__inPullEn
+
+    def set_inpullEn(self, flag):
+        self.__inPullEn = flag
+
+    def get_inPullSelHigh(self):
+        return self.__inPullSelHigh
+
+    def set_inpullSelHigh(self, flag):
+        self.__inPullSelHigh = flag
+
+    def get_defDir(self):
+        return self.__defDir
+
+    def set_defDir(self, dir):
+        self.__defDir = dir
+
+    def get_inEn(self):
+        return self.__inEn
+
+    def set_inEn(self, flag):
+        self.__inEn = flag
+
+    def get_outEn(self):
+        return self.__outEn
+
+    def set_outEn(self, flag):
+        self.__outEn = flag
+
+    def get_outHigh(self):
+        return self.__outHigh
+
+    def set_outHigh(self, outHigh):
+        self.__outHigh = outHigh
+
+    def get_varNames(self):
+        return self.__varNames
+
+    def set_varNames(self, names):
+        self.__varNames = names
+
+    def set_smtEn(self, flag):
+        self.__smtEn = flag
+
+    def get_smtEn(self):
+        return self.__smtEn
+
+    def get_iesEn(self):
+        return self.__iesEn
+
+    def set_iesEn(self, flag):
+        self.__iesEn = flag
+
+    def set_smtNum(self, num):
+        self.__smtNum = num
+
+    def get_smtNum(self):
+        return self.__smtNum
+
+    def ge_defDirInt(self):
+        if self.__defDir == 'IN':
+            return 0
+        else:
+            return 1
+
+    @staticmethod
+    def get_modeName(key, idx):
+        if key in GpioData._modeMap.keys():
+            value = GpioData._modeMap[key]
+            return value[idx]
+
diff --git a/tools/dct/data/I2cData.py b/tools/dct/data/I2cData.py
new file mode 100755
index 00000000000..322eea63a32
--- /dev/null
+++ b/tools/dct/data/I2cData.py
@@ -0,0 +1,51 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+class BusData:
+    def __init__(self):
+        self.__speed = ''
+        self.__enable = False
+
+    def set_speed(self, speed):
+        self.__speed = speed
+
+    def set_enable(self, flag):
+        self.__enable = flag
+
+    def get_speed(self):
+        return self.__speed
+
+    def get_enable(self):
+        return self.__enable
+
+class I2cData:
+    _i2c_count = 0
+    _channel_count = 0
+    _busData = {}
+
+    def __init__(self):
+        self.__varname = ''
+        self.__channel = ''
+        self.__address = ''
+
+    def set_varName(self, name):
+        self.__varname = name
+
+    def set_channel(self, channel):
+        self.__channel = channel
+
+    def set_address(self, addr):
+        self.__address = addr
+
+    def get_varName(self):
+        return self.__varname
+
+    def get_channel(self):
+        return self.__channel
+
+    def get_address(self):
+        return self.__address
+
+
+
+
diff --git a/tools/dct/data/KpdData.py b/tools/dct/data/KpdData.py
new file mode 100755
index 00000000000..4d18f7dee1f
--- /dev/null
+++ b/tools/dct/data/KpdData.py
@@ -0,0 +1,148 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+class KpdData:
+    _row = -1
+    _col = -1
+    _row_ext = -1
+    _col_ext = -1
+    _gpioNum = -1
+    _util = ''
+    _homeKey = ''
+    _keyType = ''
+    _pressTime = -1
+    _dinHigh = False
+    _matrix = []
+    _matrix_ext = []
+    _useEint = False
+    _downloadKeys = []
+    _keyValueMap = {}
+    _usedKeys = []
+    _modeKeys = {'META':None, 'RECOVERY':None, 'FACTORY':None}
+
+    def __init__(self):
+        self.__varNames = []
+
+    @staticmethod
+    def set_row(row):
+        KpdData._row = row
+
+    @staticmethod
+    def get_row():
+        return KpdData._row
+
+    @staticmethod
+    def set_col(col):
+        KpdData._col = col
+
+    @staticmethod
+    def get_col():
+        return KpdData._col
+
+    @staticmethod
+    def set_row_ext(row):
+        KpdData._row_ext = row
+
+    @staticmethod
+    def get_row_ext():
+        return KpdData._row_ext
+
+    @staticmethod
+    def set_col_ext(col):
+        KpdData._col_ext = col
+
+    @staticmethod
+    def get_col_ext():
+        return KpdData._col_ext
+
+    @staticmethod
+    def set_matrix(matrix):
+        KpdData._matrix = matrix
+
+    @staticmethod
+    def set_matrix_ext(matrix):
+        KpdData._matrix_ext = matrix
+
+    @staticmethod
+    def get_matrix_ext():
+        return KpdData._matrix_ext
+
+    @staticmethod
+    def get_matrix():
+        return KpdData._matrix
+
+    @staticmethod
+    def set_downloadKeys(keys):
+        KpdData._downloadKeys = keys
+
+    @staticmethod
+    def get_downloadKeys():
+        return KpdData._downloadKeys
+
+    @staticmethod
+    def get_modeKeys():
+        return KpdData._modeKeys
+
+    @staticmethod
+    def set_gpioNum(num):
+        KpdData._gpioNum = num
+
+    @staticmethod
+    def get_gpioNum():
+        return KpdData._gpioNum
+
+    @staticmethod
+    def set_utility(util):
+        KpdData._util = util
+
+    @staticmethod
+    def get_utility():
+        return KpdData._util
+
+    @staticmethod
+    def set_homeKey(home):
+        KpdData._homeKey = home
+
+    @staticmethod
+    def get_homeKey():
+        return KpdData._homeKey
+
+    @staticmethod
+    def set_useEint(flag):
+        KpdData._useEint = flag
+
+    @staticmethod
+    def getUseEint():
+        return KpdData._useEint
+
+    @staticmethod
+    def set_gpioDinHigh(flag):
+        KpdData._dinHigh = flag
+
+    @staticmethod
+    def get_gpioDinHigh():
+        return KpdData._dinHigh
+
+    @staticmethod
+    def set_pressTime(time):
+        KpdData._pressTime = time
+
+    @staticmethod
+    def get_pressTime():
+        return KpdData._pressTime
+
+    @staticmethod
+    def set_keyType(keyType):
+        KpdData._keyType = keyType
+
+    @staticmethod
+    def get_keyType():
+        return KpdData._keyType
+
+    @staticmethod
+    def get_keyVal(key):
+        if key in KpdData._keyValueMap.keys():
+            return KpdData._keyValueMap[key]
+
+        return 0
+
diff --git a/tools/dct/data/Md1EintData.py b/tools/dct/data/Md1EintData.py
new file mode 100755
index 00000000000..654009bae33
--- /dev/null
+++ b/tools/dct/data/Md1EintData.py
@@ -0,0 +1,50 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from data.EintData import EintData
+
+class Md1EintData(EintData):
+    def __init__(self):
+        EintData.__init__(self)
+        self.__dedicatedEn = False
+        self.__srcPin = ''
+        self.__socetType = ''
+
+    def set_dedicatedEn(self, value):
+        if value == 'Disable':
+            self.__dedicatedEn = False
+        else:
+            self.__dedicatedEn = True
+
+    def get_dedicatedEn(self):
+        return self.__dedicatedEn
+
+    def set_srcPin(self, pin):
+        self.__srcPin = pin
+
+    def get_srcPin(self):
+        return self.__srcPin
+
+    def set_socketType(self, type):
+        self.__socetType = type
+
+    def get_socketType(self):
+        return self.__socetType
+
+    def set_sensitiveLevel(self, level):
+        EintData.set_sensitiveLevel(self, level)
+
+    def get_sensitiveLevel(self):
+        return EintData.get_sensitiveLevel(self)
+
+    def set_debounceEnable(self, enable):
+        EintData.set_debounceEnable(self, enable)
+
+    def get_debounceEnable(self):
+        return EintData.get_debounceEnable(self)
+
+    def set_polarity(self, polarity):
+        EintData.set_polarity(self, polarity)
+
+    def get_polarity(self):
+        return EintData.get_polarity(self)
\ No newline at end of file
diff --git a/tools/dct/data/PmicData.py b/tools/dct/data/PmicData.py
new file mode 100755
index 00000000000..c1978aa3801
--- /dev/null
+++ b/tools/dct/data/PmicData.py
@@ -0,0 +1,27 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+class PmicData:
+    _var_list = []
+    def __init__(self):
+        self.__ldoName = ''
+        self.__defEn = -1
+        self.__nameList = []
+
+    def set_ldoName(self, name):
+        self.__ldoName = name
+
+    def get_ldoName(self):
+        return self.__ldoName
+
+    def set_defEnable(self, number):
+        self.__defEn = number
+
+    def get_defEnable(self):
+        return self.__defEn
+
+    def set_nameList(self, name_list):
+        self.__nameList = name_list
+
+    def get_nameList(self):
+        return self.__nameList
\ No newline at end of file
diff --git a/tools/dct/data/PowerData.py b/tools/dct/data/PowerData.py
new file mode 100755
index 00000000000..5c64b49e3ae
--- /dev/null
+++ b/tools/dct/data/PowerData.py
@@ -0,0 +1,16 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+class PowerData:
+    def __init__(self):
+        self.__varName = ''
+
+    def set_varName(self, name):
+        self.__varName = name
+
+    def get_varName(self):
+        return self.__varName
+
+
+
+
diff --git a/tools/dct/data/__init__.py b/tools/dct/data/__init__.py
new file mode 100755
index 00000000000..e69de29bb2d
diff --git a/tools/dct/obj/AdcObj.py b/tools/dct/obj/AdcObj.py
new file mode 100755
index 00000000000..c94592c01fc
--- /dev/null
+++ b/tools/dct/obj/AdcObj.py
@@ -0,0 +1,84 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+import os
+import re
+import string
+import xml.dom.minidom
+
+from obj.ModuleObj import ModuleObj
+from utility.util import log
+from utility.util import LogLevel
+from utility.util import sorted_key
+
+
+class AdcObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self, 'cust_adc.h', 'cust_adc.dtsi')
+
+    def get_cfgInfo(self):
+        pass
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def read(self, node):
+        nodes = node.childNodes
+        try:
+            for node in nodes:
+                if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                    if node.nodeName == 'count':
+                        count = node.childNodes[0].nodeValue
+                        continue
+                    subNode = node.getElementsByTagName('varName')
+                    if len(subNode):
+                        ModuleObj.set_data(self, node.nodeName, subNode[0].childNodes[0].nodeValue)
+        except:
+            msg = 'read adc content fail!'
+            log(LogLevel.error, msg)
+            return False
+
+        return True
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def fill_hFile(self):
+        gen_str = ''
+        sorted_list = sorted(ModuleObj.get_data(self).keys())
+
+        for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''#define AUXADC_%s_CHANNEL\t\t\t%s\n''' %(value.upper(), key[len(key) - 1])
+
+        return gen_str
+
+    def fill_dtsiFile(self):
+        gen_str = '''&auxadc {\n'''
+        gen_str += '''\tadc_channel@ {\n'''
+        gen_str += '''\t\tcompatible = "mediatek,adc_channel";\n'''
+
+        # sort by the key, or the sequence is dissorted
+        #sorted_list = sorted(ModuleObj.get_data(self).keys())
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+
+            if value == "TEMPERATURE":
+                gen_str += '''\t\tmediatek,%s0 = <%d>;\n''' %(value.lower(), string.atoi(key[len(key) -1]))
+            else:
+                gen_str += '''\t\tmediatek,%s = <%d>;\n''' %(value.lower(), string.atoi(key[len(key) -1]))
+
+        gen_str += '''\t\tstatus = \"okay\";\n'''
+        gen_str += '''\t};\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+
+
+
+
+
+
+
diff --git a/tools/dct/obj/ChipObj.py b/tools/dct/obj/ChipObj.py
new file mode 100755
index 00000000000..37e7db31757
--- /dev/null
+++ b/tools/dct/obj/ChipObj.py
@@ -0,0 +1,249 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import os, sys
+import xml.dom.minidom
+
+from .GpioObj import GpioObj
+from .EintObj import EintObj
+from .AdcObj import AdcObj
+from .ClkObj import ClkObj
+from .ClkObj import ClkObj_Everest
+from .ClkObj import ClkObj_Olympus
+from .ClkObj import ClkObj_Rushmore
+from .I2cObj import I2cObj
+from .PmicObj import PmicObj
+from .Md1EintObj import Md1EintObj
+from .PowerObj import PowerObj
+from .KpdObj import KpdObj
+from .ModuleObj import ModuleObj
+
+from utility.util import log
+from utility.util import LogLevel
+
+para_map = {'adc':['adc_h', 'adc_dtsi'],\
+            'clk':['clk_buf_h', 'clk_buf_dtsi'],\
+            'eint':['eint_h', 'eint_dtsi'],\
+            'gpio':['gpio_usage_h', 'gpio_boot_h', 'gpio_dtsi', 'scp_gpio_usage_h', 'pinfunc_h', \
+                    'pinctrl_h', 'gpio_usage_mapping_dtsi', 'gpio_usage_mapping_dtsi'],\
+            'i2c':['i2c_h', 'i2c_dtsi'],\
+            'md1_eint':['md1_eint_h', 'md1_eint_dtsi'],\
+            'kpd':['kpd_h', 'kpd_dtsi'],\
+            'pmic':['pmic_drv_h', 'pmic_drv_c', 'pmic_dtsi'],\
+            'power':['power_h']}
+
+class ChipObj:
+    def __init__(self, path, dest):
+        self.__path = path
+        ModuleObj.set_genPath(dest)
+        self.__objs = {}
+
+        self.init_objs()
+
+    def init_objs(self):
+        self.__objs['adc'] = AdcObj()
+        self.__objs['clk'] = ClkObj()
+        self.__objs["gpio"] = GpioObj()
+        # eint obj need gpio data
+        self.__objs["eint"] = EintObj(self.__objs['gpio'])
+        self.__objs["i2c"] = I2cObj()
+        self.__objs["md1_eint"] = Md1EintObj()
+
+        self.__objs["pmic"] = PmicObj()
+        self.__objs["power"] = PowerObj()
+        self.__objs["kpd"] = KpdObj()
+
+    def replace_obj(self, tag, obj):
+        if not tag in self.__objs.keys():
+            return False
+
+        self.__objs[tag] = obj
+
+    def append_obj(self, tag, obj):
+        if tag in self.__objs.keys():
+            return False
+
+        self.__objs[tag] = obj
+
+    @staticmethod
+    def get_chipId(path):
+        if not os.path.exists(path):
+            msg = '%s is not a available path!' %(path)
+            log(LogLevel.error, msg)
+            return False
+        data = xml.dom.minidom.parse(path)
+        root = data.documentElement
+        # get 'general' node
+        node = root.getElementsByTagName('general')
+        return node[0].getAttribute('chip')
+
+    def parse(self):
+        if not os.path.exists(self.__path):
+            msg = '%s is not a available path!' %(self.__path)
+            log(LogLevel.error, msg)
+            return False
+
+        data = xml.dom.minidom.parse(self.__path)
+
+        root = data.documentElement
+        # get 'general' node
+        node = root.getElementsByTagName('general')
+        # get chip name and project name
+        ModuleObj.set_chipId(node[0].getAttribute('chip'))
+
+        msg = 'Chip ID : %s' %(node[0].getAttribute('chip'))
+        log(LogLevel.info, msg)
+        msg = 'Project Info: %s' %(node[0].getElementsByTagName('proj')[0].childNodes[0].nodeValue)
+        log(LogLevel.info, msg)
+
+        # initialize the objects mapping table
+        self.init_objs()
+        # get module nodes from DWS file
+        nodes = node[0].getElementsByTagName('module')
+
+        for node in nodes:
+            tag = node.getAttribute('name')
+            obj = self.create_obj(tag)
+            if obj == None:
+                msg = 'can not find %s node in DWS!' %(tag)
+                log(LogLevel.error, msg)
+                return False
+            obj.parse(node)
+
+        return True
+
+    def generate(self, paras):
+        if len(paras) == 0:
+            for obj in self.__objs.values():
+                obj.gen_files()
+
+            self.gen_custDtsi()
+        else:
+            self.gen_spec(paras)
+
+        return True
+
+    def create_obj(self, tag):
+        obj = None
+        if tag in self.__objs.keys():
+            obj = self.__objs[tag]
+
+        return obj
+
+
+    def gen_spec(self, paras):
+        if cmp(paras[0], 'cust_dtsi') == 0:
+            self.gen_custDtsi()
+            return True
+
+        for para in paras:
+            idx = 0
+            name = ''
+            if para.strip() != '':
+                for value in para_map.values():
+                    if para in value:
+                        name = para_map.keys()[idx]
+                        break
+                    idx += 1
+
+            if name != '':
+                log(LogLevel.info, 'Start to generate %s file...' %(para))
+                obj = self.__objs[name]
+                obj.gen_spec(para)
+                log(LogLevel.info, 'Generate %s file successfully!' %(para))
+            else:
+                log(LogLevel.error, '%s can not be recognized!' %(para))
+                sys.exit(-1)
+
+        return True
+
+    def gen_custDtsi(self):
+        log(LogLevel.info, 'Start to generate cust_dtsi file...')
+        fp = open(os.path.join(ModuleObj.get_genPath(), 'cust.dtsi'), 'w')
+        gen_str = ModuleObj.writeComment()
+
+        sorted_list = sorted(self.__objs.keys())
+        for tag in sorted_list:
+            if cmp(tag, 'gpio') == 0:
+                gpioObj = self.create_obj(tag)
+                gen_str += ModuleObj.writeHeader(gpioObj.get_dtsiFileName())
+                gen_str += gpioObj.fill_mapping_dtsiFile()
+            else:
+                obj = self.create_obj(tag)
+                gen_str += ModuleObj.writeHeader(obj.get_dtsiFileName())
+                gen_str += obj.fill_dtsiFile()
+
+            gen_str += '''\n\n'''
+
+        fp.write(gen_str)
+        fp.close()
+        log(LogLevel.info, 'Generate cust_dtsi file successfully!')
+
+
+class Everest(ChipObj):
+    def __init__(self, dws_path, gen_path):
+        ChipObj.__init__(self, dws_path, gen_path)
+        self.init_objs()
+
+    def init_objs(self):
+        ChipObj.init_objs(self)
+        ChipObj.replace_obj(self, 'clk', ClkObj_Everest())
+
+    def parse(self):
+        return ChipObj.parse(self)
+
+    def generate(self, paras):
+        return ChipObj.generate(self, paras)
+
+
+class Olympus(ChipObj):
+    def __init__(self, dws_path, gen_path):
+        ChipObj.__init__(self, dws_path, gen_path)
+
+    def init_objs(self):
+        ChipObj.init_objs(self)
+        ChipObj.replace_obj(self, 'clk', ClkObj_Olympus())
+
+    def parse(self):
+        return ChipObj.parse(self)
+
+
+    def generate(self, paras):
+        return ChipObj.generate(self, paras)
+
+
+class KiboPlus(ChipObj):
+    def __init__(self, dws_path, gen_path):
+        ChipObj.__init__(self, dws_path, gen_path)
+
+    def init_objs(self):
+        ChipObj.init_objs(self)
+        ChipObj.replace_obj(self, 'clk', ClkObj_Olympus())
+
+    def parse(self):
+        return ChipObj.parse(self)
+
+
+    def generate(self, paras):
+        return ChipObj.generate(self, paras)
+
+
+class Rushmore(ChipObj):
+    def __init__(self, dws_path, gen_path):
+        ChipObj.__init__(self, dws_path, gen_path)
+
+    def init_objs(self):
+        ChipObj.init_objs(self)
+        ChipObj.replace_obj(self, 'clk', ClkObj_Rushmore())
+
+    def parse(self):
+        return ChipObj.parse(self)
+
+
+    def generate(self, paras):
+        return ChipObj.generate(self, paras)
+
+
+
+
diff --git a/tools/dct/obj/ClkObj.py b/tools/dct/obj/ClkObj.py
new file mode 100755
index 00000000000..1192c6210bb
--- /dev/null
+++ b/tools/dct/obj/ClkObj.py
@@ -0,0 +1,437 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import os
+import re
+import string
+import configparser
+
+import xml.dom.minidom
+
+from .ModuleObj import ModuleObj
+from data.ClkData import ClkData
+from utility.util import log
+from utility.util import LogLevel
+from utility.util import sorted_key
+
+DEFAULT_AUTOK = 'AutoK'
+class ClkObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self, 'cust_clk_buf.h', 'cust_clk_buf.dtsi')
+        #self.__prefix_cfg = 'driving_current_pmic_clk_buf'
+        self.__suffix = '_BUF'
+        self.__count = -1
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if node.nodeName == 'count':
+                    continue
+
+                varNode = node.getElementsByTagName('varName')
+                curNode = node.getElementsByTagName('current')
+
+                key = re.findall(r'\D+', node.nodeName)[0].upper() + self.__suffix + '%s' %(re.findall(r'\d+', node.nodeName)[0])
+
+                data = ModuleObj.get_data(self)[key]
+
+                if len(varNode):
+                    data.set_varName(varNode[0].childNodes[0].nodeValue)
+
+                if len(curNode):
+                    data.set_current(curNode[0].childNodes[0].nodeValue)
+
+                ModuleObj.set_data(self, key, data)
+
+        return True
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_figPath())
+
+        count = string.atoi(cp.get('CLK_BUF', 'CLK_BUF_COUNT'))
+        self.__count = count
+
+        ops = cp.options('CLK_BUF')
+        for op in ops:
+            if op == 'clk_buf_count':
+                self.__count = string.atoi(cp.get('CLK_BUF', op))
+                ClkData._count = string.atoi(cp.get('CLK_BUF', op))
+                continue
+
+            value = cp.get('CLK_BUF', op)
+            var_list = value.split(':')
+
+            data = ClkData()
+            data.set_curList(var_list[2:])
+            data.set_defVarName(string.atoi(var_list[0]))
+            data.set_defCurrent(string.atoi(var_list[1]))
+
+            key = op[16:].upper()
+            ModuleObj.set_data(self, key, data)
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def fill_hFile(self):
+        gen_str = '''typedef enum {\n'''
+        gen_str += '''\tCLOCK_BUFFER_DISABLE,\n'''
+        gen_str += '''\tCLOCK_BUFFER_SW_CONTROL,\n'''
+        gen_str += '''\tCLOCK_BUFFER_HW_CONTROL\n'''
+        gen_str += '''} MTK_CLK_BUF_STATUS;\n'''
+        gen_str += '''\n'''
+
+        gen_str += '''typedef enum {\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_AUTO_K = -1,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_0,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_1,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_2,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_3\n'''
+        gen_str += '''} MTK_CLK_BUF_DRIVING_CURR;\n'''
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''#define %s_STATUS_PMIC\t\tCLOCK_BUFFER_%s\n''' %(key[5:], value.get_varName().upper())
+
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            idx = value.get_curList().index(value.get_current())
+            if cmp(value.get_curList()[0], DEFAULT_AUTOK) == 0:
+                idx -= 1
+
+            if idx >= 0:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_%d\n''' %(key, idx)
+            else:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_AUTO_K\n''' %(key)
+
+        gen_str += '''\n'''
+
+        return gen_str
+
+    def fill_dtsiFile(self):
+        gen_str = '''&pmic_clock_buffer_ctrl {\n'''
+        gen_str += '''\tmediatek,clkbuf-quantity = <%d>;\n''' %(self.__count)
+        gen_str += '''\tmediatek,clkbuf-config = <'''
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys())
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            if key.find('PMIC') == -1:
+                continue
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''%d ''' %(ClkData._varList.index(value.get_varName()))
+
+        gen_str = gen_str.rstrip()
+        gen_str += '''>;\n'''
+
+        gen_str += '''\tmediatek,clkbuf-driving-current = <'''
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys())
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            if key.find('PMIC') == -1:
+                continue
+            value = ModuleObj.get_data(self)[key]
+            idx = value.get_curList().index(value.get_current())
+            if cmp(value.get_curList()[0], DEFAULT_AUTOK) == 0:
+                idx -= 1
+            if idx < 0:
+                gen_str += '''(%d) ''' %(-1)
+            else:
+                gen_str += '''%d ''' %(idx)
+
+        gen_str = gen_str.rstrip()
+        gen_str += '''>;\n'''
+
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+
+class ClkObj_Everest(ClkObj):
+    def __init__(self):
+        ClkObj.__init__(self)
+        self.__rf = 'RF'
+        self.__pmic = 'PMIC'
+
+    def parse(self, node):
+        ClkObj.parse(self, node)
+
+    def gen_files(self):
+        ClkObj.gen_files(self)
+
+    def fill_hFile(self):
+        gen_str = '''typedef enum {\n'''
+        gen_str += '''\tCLOCK_BUFFER_DISABLE,\n'''
+        gen_str += '''\tCLOCK_BUFFER_SW_CONTROL,\n'''
+        gen_str += '''\tCLOCK_BUFFER_HW_CONTROL\n'''
+        gen_str += '''} MTK_CLK_BUF_STATUS;\n'''
+        gen_str += '''\n'''
+
+        gen_str += '''typedef enum {\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_0_4MA,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_0_9MA,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_1_4MA,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_1_9MA\n'''
+        gen_str += '''} MTK_CLK_BUF_DRIVING_CURR;\n'''
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find(self.__pmic) != -1:
+                gen_str += '''#define %s_STATUS_PMIC\t\t\t\tCLOCK_BUFFER_%s\n''' %(key[5:], value.get_varName())
+
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find(self.__pmic) != -1:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_%sMA\n''' %(key, value.get_current().replace('.', '_'))
+
+        gen_str += '''\n'''
+
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find(self.__rf) != -1:
+                gen_str += '''#define %s_STATUS\t\tCLOCK_BUFFER_%s\n''' %(key[3:], value.get_varName())
+
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find(self.__rf) != -1:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_%sMA\n''' %(key, value.get_current().replace('.', '_'))
+
+        gen_str += '''\n'''
+
+
+
+        return gen_str
+
+    def fill_dtsiFile(self):
+        gen_str = ClkObj.fill_dtsiFile(self)
+
+        gen_str += '''\n'''
+
+        gen_str += '''&rf_clock_buffer_ctrl {\n'''
+        gen_str += '''\tmediatek,clkbuf-quantity = <%d>;\n''' %(ClkData._count)
+        gen_str += '''\tmediatek,clkbuf-config = <'''
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys())
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+
+            if key.find(self.__rf) != -1:
+                gen_str += '''%d ''' %(ClkData._varList.index(value.get_varName()))
+        gen_str.rstrip()
+        gen_str += '''>;\n'''
+
+        gen_str += '''\tmediatek,clkbuf-driving-current = <'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find(self.__rf) != -1:
+                idx = value.get_curList().index(value.get_current())
+                if cmp(value.get_curList()[0], DEFAULT_AUTOK) == 0:
+                    idx -= 1
+                gen_str += '''%d ''' %(idx)
+
+        gen_str.rstrip()
+        gen_str += '''>;\n'''
+
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+class ClkObj_Olympus(ClkObj_Everest):
+
+    def __init__(self):
+        ClkObj_Everest.__init__(self)
+
+    def get_cfgInfo(self):
+        ClkObj_Everest.get_cfgInfo(self)
+
+    def parse(self, node):
+        ClkObj_Everest.parse(self, node)
+
+    def gen_files(self):
+        ClkObj_Everest.gen_files(self)
+
+    def fill_hFile(self):
+        gen_str = '''typedef enum {\n'''
+        gen_str += '''\tCLOCK_BUFFER_DISABLE,\n'''
+        gen_str += '''\tCLOCK_BUFFER_SW_CONTROL,\n'''
+        gen_str += '''\tCLOCK_BUFFER_HW_CONTROL\n'''
+        gen_str += '''} MTK_CLK_BUF_STATUS;\n'''
+        gen_str += '''\n'''
+
+        gen_str += '''typedef enum {\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_AUTO_K = -1,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_0,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_1,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_2,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_3\n'''
+        gen_str += '''} MTK_CLK_BUF_DRIVING_CURR;\n'''
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find('PMIC') != -1:
+                gen_str += '''#define %s_STATUS_PMIC\t\tCLOCK_BUFFER_%s\n''' %(key[5:], value.get_varName())
+
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find('RF') != -1:
+                gen_str += '''#define %s_STATUS\t\t\t\tCLOCK_BUFFER_%s\n''' %(key[3:], value.get_varName())
+
+        gen_str += '''\n'''
+
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            if key.find('PMIC') != -1:
+                continue
+            value = ModuleObj.get_data(self)[key]
+            idx = value.get_curList().index(value.get_current())
+            if cmp(value.get_curList()[0], DEFAULT_AUTOK) == 0:
+                idx -= 1
+
+            if idx >= 0:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_%d\n''' %(key, idx)
+            else:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_AUTO_K\n''' %(key)
+
+        gen_str += '''\n'''
+
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            if key.find('RF') != -1:
+                continue
+            value = ModuleObj.get_data(self)[key]
+            idx = value.get_curList().index(value.get_current())
+            if cmp(value.get_curList()[0], DEFAULT_AUTOK) == 0:
+                idx -= 1
+
+            if idx >= 0:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_%d\n''' %(key, idx)
+            else:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_AUTO_K\n''' %(key)
+
+        gen_str += '''\n'''
+
+        return gen_str
+
+class ClkObj_Rushmore(ClkObj):
+
+    def __init__(self):
+        ClkObj.__init__(self)
+        self.__suffix = '_BUF'
+
+    def parse(self, node):
+        ClkObj.parse(self, node)
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_figPath())
+
+        count = string.atoi(cp.get('CLK_BUF', 'CLK_BUF_COUNT'))
+        self.__count = count
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if node.nodeName == 'count':
+                    continue
+
+                varNode = node.getElementsByTagName('varName')
+                curNode = node.getElementsByTagName('current')
+
+                key = re.findall(r'\D+', node.nodeName)[0].upper() + self.__suffix + '%s' %(re.findall(r'\d+', node.nodeName)[0])
+                data = ClkData()
+                if len(varNode):
+                    data.set_varName(varNode[0].childNodes[0].nodeValue)
+
+                #if len(curNode):
+                    #data.set_current(curNode[0].childNodes[0].nodeValue)
+
+                ModuleObj.set_data(self, key, data)
+
+        return True
+
+    def fill_hFile(self):
+        gen_str = '''typedef enum {\n'''
+        gen_str += '''\tCLOCK_BUFFER_DISABLE,\n'''
+        gen_str += '''\tCLOCK_BUFFER_SW_CONTROL,\n'''
+        gen_str += '''\tCLOCK_BUFFER_HW_CONTROL\n'''
+        gen_str += '''} MTK_CLK_BUF_STATUS;\n'''
+        gen_str += '''\n'''
+
+        gen_str += '''typedef enum {\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_AUTO_K = -1,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_0,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_1,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_2,\n'''
+        gen_str += '''\tCLK_BUF_DRIVING_CURR_3\n'''
+        gen_str += '''} MTK_CLK_BUF_DRIVING_CURR;\n'''
+        gen_str += '''\n'''
+
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if key.find('RF') != -1:
+                gen_str += '''#define %s_STATUS\t\t\t\tCLOCK_BUFFER_%s\n''' %(key[3:], value.get_varName())
+
+        gen_str += '''\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            if key.find('RF') != -1:
+                continue
+            value = ModuleObj.get_data(self)[key]
+            idx = value.get_curList().index(value.get_current())
+            if cmp(value.get_curList()[0], DEFAULT_AUTOK) == 0:
+                idx -= 1
+
+            if idx >= 0:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_%d\n''' %(key, idx)
+            else:
+                gen_str += '''#define %s_DRIVING_CURR\t\tCLK_BUF_DRIVING_CURR_AUTO_K\n''' %(key)
+
+        gen_str += '''\n'''
+
+        return gen_str
+
+    def fill_dtsiFile(self):
+        gen_str = '''&rf_clock_buffer_ctrl {\n'''
+        gen_str += '''\tmediatek,clkbuf-quantity = <%d>;\n''' %(self.__count)
+        gen_str += '''\tmediatek,clkbuf-config = <'''
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys())
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            if key.find('RF') == -1:
+                continue
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''%d ''' %(ClkData._varList.index(value.get_varName()))
+
+        gen_str = gen_str.rstrip()
+        gen_str += '''>;\n'''
+
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+
+
diff --git a/tools/dct/obj/EintObj.py b/tools/dct/obj/EintObj.py
new file mode 100755
index 00000000000..c977b7a5c96
--- /dev/null
+++ b/tools/dct/obj/EintObj.py
@@ -0,0 +1,292 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+import re
+import os
+import string
+
+import configparser
+import xml.dom.minidom
+
+from data.EintData import EintData
+from data.GpioData import GpioData
+from utility.util import log
+from utility.util import LogLevel
+from utility.util import compare
+
+from obj.ModuleObj import ModuleObj
+from obj.GpioObj import GpioObj
+
+class EintObj(ModuleObj):
+    def __init__(self, gpio_obj):
+        ModuleObj.__init__(self, 'cust_eint.h', 'cust_eint.dtsi')
+        self.__gpio_obj = gpio_obj
+        self.__count = 0
+        self.__map_count = 0
+
+    def read(self, node):
+        nodes = node.childNodes
+
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if cmp(node.nodeName, 'count') == 0:
+                    self.__count = node.childNodes[0].nodeValue
+                    continue
+
+                varNode = node.getElementsByTagName('varName')
+                detNode = node.getElementsByTagName('debounce_time')
+                polNode = node.getElementsByTagName('polarity')
+                senNode = node.getElementsByTagName('sensitive_level')
+                deeNode = node.getElementsByTagName('debounce_en')
+
+                data = EintData()
+                if len(varNode):
+                    data.set_varName(varNode[0].childNodes[0].nodeValue)
+
+                if len(detNode):
+                    data.set_debounceTime(detNode[0].childNodes[0].nodeValue)
+
+                if len(polNode):
+                    data.set_polarity(polNode[0].childNodes[0].nodeValue)
+
+                if len(senNode):
+                    data.set_sensitiveLevel(senNode[0].childNodes[0].nodeValue)
+
+                if len(deeNode):
+                    data.set_debounceEnable(deeNode[0].childNodes[0].nodeValue)
+
+                ModuleObj.set_data(self, node.nodeName, data)
+
+        return True
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def gen_spec(self, para):
+        ModuleObj.gen_spec(self, para)
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_figPath())
+
+        ops = cp.options('GPIO')
+        map = {}
+        mode_map = {}
+        for op in ops:
+            value = cp.get('GPIO', op)
+            list = re.split(r' +|\t+', value)
+
+            map[string.atoi(re.findall(r'\d+', op)[0])] = string.atoi(list[len(list)-2])
+            mode_map[op] = list[0:len(list)-2]
+
+        EintData.set_mapTable(map)
+        EintData.set_modeMap(mode_map)
+
+        if cp.has_option('EINT', 'EINT_MAP_COUNT'):
+            self.__map_count = string.atoi(cp.get('EINT', 'EINT_MAP_COUNT'))
+
+        if cp.has_option('EINT', 'INTERNAL_EINT'):
+            info = cp.get('EINT', 'INTERNAL_EINT')
+            str_list = info.split(':')
+            for item in str_list:
+                sub_list = item.split('/')
+                EintData._int_eint[sub_list[0]] = sub_list[1]
+
+        if cp.has_option('EINT', 'BUILTIN_EINT'):
+            info = cp.get('EINT', 'BUILTIN_EINT')
+            str_list = info.split(':')
+            for builtin_item in str_list:
+                builtin_list = builtin_item.split('/')
+                #EintData._builtin_map[builtin_list[0]] = builtin_list[1]
+
+                temp = 'BUILTIN_%s' %(builtin_list[0])
+                if cp.has_option('EINT', temp):
+                    info = cp.get('EINT', temp)
+                    str_list = info.split(':')
+                    temp_map = {}
+                    for item in str_list:
+                        sub_list = item.split('/')
+                        temp_map[sub_list[0]] = sub_list[1] + ':' + builtin_list[1]
+
+                    EintData._builtin_map[builtin_list[0]] = temp_map
+                    EintData._builtin_eint_count += len(temp_map)
+
+
+    #def compare(self, value):
+        #return string.atoi(value[4:])
+
+    def fill_hFile(self):
+        gen_str = ''
+        gen_str += '''#ifdef __cplusplus\n'''
+        gen_str += '''extern \"C\" {\n'''
+        gen_str += '''#endif\n'''
+
+        gen_str += '''#define CUST_EINTF_TRIGGER_RISING\t\t\t1\n'''
+        gen_str += '''#define CUST_EINTF_TRIGGER_FALLING\t\t\t2\n'''
+        gen_str += '''#define CUST_EINTF_TRIGGER_HIGH\t\t\t4\n'''
+        gen_str += '''#define CUST_EINTF_TRIGGER_LOW\t\t\t8\n'''
+
+        gen_str += '''#define CUST_EINT_DEBOUNCE_DISABLE\t\t\t0\n'''
+        gen_str += '''#define CUST_EINT_DEBOUNCE_ENABLE\t\t\t1\n'''
+
+        gen_str += '''\n\n'''
+
+        sorted_list = sorted(ModuleObj.get_data(self).keys(), key=compare)
+
+        for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''#define CUST_EINT_%s_NUM\t\t\t%s\n''' %(value.get_varName().upper(), key[4:])
+            gen_str += '''#define CUST_EINT_%s_DEBOUNCE_CN\t\t%s\n''' %(value.get_varName().upper(), value.get_debounceTime())
+
+            temp = ''
+            polarity = value.get_polarity()
+            sensitive = value.get_sensitiveLevel()
+
+            if cmp(polarity, 'High') == 0 and cmp(sensitive, 'Edge') == 0:
+                temp = 'CUST_EINTF_TRIGGER_RISING'
+            elif cmp(polarity, 'Low') == 0 and cmp(sensitive, 'Edge') == 0:
+                temp = 'CUST_EINTF_TRIGGER_FALLING'
+            elif cmp(polarity, 'High') == 0 and cmp(sensitive, 'Level') == 0:
+                temp = 'CUST_EINTF_TRIGGER_HIGH'
+            elif cmp(polarity, 'Low') == 0 and cmp(sensitive, 'Level') == 0:
+                temp = 'CUST_EINTF_TRIGGER_LOW'
+
+            gen_str += '''#define CUST_EINT_%s_TYPE\t\t\t%s\n''' %(value.get_varName().upper(), temp)
+
+            temp = ''
+            if cmp(value.get_debounceEnable(), 'Disable') == 0:
+                temp = 'CUST_EINT_DEBOUNCE_DISABLE'
+            elif cmp(value.get_debounceEnable(), 'Enable') == 0:
+                temp = 'CUST_EINT_DEBOUNCE_ENABLE'
+            gen_str += '''#define CUST_EINT_%s_DEBOUNCE_EN\t\t%s\n\n''' %(value.get_varName().upper(), temp)
+
+
+        gen_str += '''#ifdef __cplusplus\n'''
+        gen_str += '''}\n'''
+        gen_str += '''#endif\n'''
+
+        return gen_str
+
+    def fill_mappingTable(self):
+        gen_str = '''&eintc {\n'''
+        count = 0
+
+        if self.__map_count == 0:
+            for i in range(0, string.atoi(self.__count)):
+                if EintData.get_gpioNum(i) >= 0:
+                    count += 1
+            count += len(EintData._int_eint)
+        else:
+            count = self.__map_count
+
+        gen_str += '''\tmediatek,mapping_table_entry = <%d>;\n''' %(count)
+        gen_str += '''\t\t\t/* <gpio_pin, eint_pin> */\n'''
+        gen_str += '''\tmediatek,mapping_table = '''
+
+        sorted_list = sorted(EintData.get_mapTable().keys())
+        for key in sorted_list:
+            value = EintData.get_mapTable()[key]
+            if value != -1:
+                gen_str += '''<%d %d>,\n\t\t\t\t\t''' %(key, value)
+
+        for (key, value) in EintData._int_eint.items():
+            gen_str += '''<%s %s>,\n\t\t\t\t\t''' %(value, key)
+
+        gen_str = gen_str[0:len(gen_str)-7]
+        gen_str += ''';\n'''
+        gen_str += '''\tmediatek,builtin_entry = <%d>;\n''' %(EintData._builtin_eint_count)
+        if len(EintData._builtin_map) == 0:
+            gen_str += '''};\n\n'''
+            return gen_str
+
+        gen_str += '''\t\t\t\t\t/* gpio, built-in func mode, built-in eint */\n'''
+        gen_str += '''\tmediatek,builtin_mapping = '''
+        for (key, value) in EintData._builtin_map.items():
+            for (sub_key, sub_value) in value.items():
+                gen_str += '''<%s %s %s>, /* %s */\n\t\t\t\t\t''' %(sub_key, sub_value[0:1], key, sub_value)
+
+        gen_str = gen_str[0:gen_str.rfind(',')]
+        gen_str += ';'
+        gen_str += '''};\n\n'''
+
+        return gen_str
+
+    def get_gpioNum(self, eint_num):
+        for (key, value) in EintData.get_mapTable().items():
+            if cmp(eint_num, value) == 0:
+                return key
+
+        return -1
+
+    def refGpio(self, eint_num, flag):
+        gpio_vec= []
+
+        gpio_num = EintData.get_gpioNum(string.atoi(eint_num))
+        if gpio_num >= 0:
+            gpio_vec.append(gpio_num)
+            if flag:
+                item_data = self.__gpio_obj.get_gpioData(gpio_num)
+                mode_idx = item_data.get_defMode()
+                mode_name = EintData.get_modeName(gpio_num, mode_idx)
+                if re.match(r'GPIO[\d]+', mode_name) or re.match(r'EINT[\d]+', mode_name):
+                    return gpio_vec
+
+        for key in EintData._builtin_map.keys():
+            if string.atoi(eint_num) == string.atoi(key):
+                temp_map = EintData._builtin_map[key]
+                for key in temp_map.keys():
+                    gpio_vec.append(key)
+
+                if flag:
+                    for item in temp_map.keys():
+                        item_data = self.__gpio_obj.get_gpioData(string.atoi(item))
+
+                        if item_data.get_defMode() == string.atoi(temp_map[item].split(':')[0]):
+                            gpio_vec = []
+                            gpio_vec.append(item)
+                            return gpio_vec
+
+                break
+
+        return gpio_vec
+
+    def fill_dtsiFile(self):
+        gen_str = '''#include <dt-bindings/interrupt-controller/irq.h>\n'''
+        gen_str += '''#include <dt-bindings/interrupt-controller/arm-gic.h>\n'''
+        gen_str += '''\n'''
+
+        gen_str += self.fill_mappingTable()
+
+        sorted_list = sorted(ModuleObj.get_data(self).keys(), key=compare)
+
+        for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''&%s {\n''' %(value.get_varName().lower())
+            gen_str += '''\tinterrupt-parent = <&eintc>;\n'''
+
+            temp = ''
+            polarity = value.get_polarity()
+            sensitive = value.get_sensitiveLevel()
+
+            if cmp(polarity, 'High') == 0 and cmp(sensitive, 'Edge') == 0:
+                temp = 'IRQ_TYPE_EDGE_RISING'
+            elif cmp(polarity, 'Low') == 0 and cmp(sensitive, 'Edge') == 0:
+                temp = 'IRQ_TYPE_EDGE_FALLING'
+            elif cmp(polarity, 'High') == 0 and cmp(sensitive, 'Level') == 0:
+                temp = 'IRQ_TYPE_LEVEL_HIGH'
+            elif cmp(polarity, 'Low') == 0 and cmp(sensitive, 'Level') == 0:
+                temp = 'IRQ_TYPE_LEVEL_LOW'
+
+            gen_str += '''\tinterrupts = <%s %s>;\n''' %(self.refGpio(key[4:], True)[0], temp)
+            gen_str += '''\tdebounce = <%s %d>;\n''' %(self.refGpio(key[4:], True)[0], string.atoi(value.get_debounceTime()) * 1000)
+            gen_str += '''\tstatus = \"okay\";\n'''
+            gen_str += '''};\n'''
+            gen_str += '''\n'''
+
+        return gen_str
+
+
diff --git a/tools/dct/obj/GpioObj.py b/tools/dct/obj/GpioObj.py
new file mode 100755
index 00000000000..fa37e00168c
--- /dev/null
+++ b/tools/dct/obj/GpioObj.py
@@ -0,0 +1,570 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import re
+import os
+import sys
+import string
+import configparser
+import xml.dom.minidom
+
+
+from data.GpioData import GpioData
+from data.EintData import EintData
+from .ModuleObj import ModuleObj
+from . import ChipObj
+from utility.util import compare
+from utility.util import sorted_key
+
+class GpioObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self,'cust_gpio_boot.h', 'cust_gpio.dtsi')
+        self.__fileName = 'cust_gpio_usage.h'
+        self.__filePinfunc = '%s-pinfunc.h' %(ModuleObj.get_chipId().lower())
+        self.__filePinCtrl = 'pinctrl-mtk-%s.h' %(ModuleObj.get_chipId().lower())
+        self.__fileScp = 'cust_scp_gpio_usage.h'
+        self.__fileMap = 'cust_gpio_usage_mapping.dtsi'
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_cmpPath())
+
+        # get GPIO_FREQ section
+        keys= cp.options('GPIO_FREQ')
+        for key in keys:
+            value = cp.get('GPIO_FREQ', key)
+            GpioData._freqMap[key] = value
+
+        # get GPIO_MODE section
+        keys = cp.options('GPIO_MODE')
+        for key in keys:
+            value = cp.get('GPIO_MODE', key)
+            GpioData._specMap[key] = value
+
+        GpioData._mapList = cp.options('GPIO_VARIABLES_MAPPING')
+
+        cp.read(ModuleObj.get_figPath())
+        ops = cp.options('GPIO')
+        for op in ops:
+            value = cp.get('GPIO', op)
+            list = re.split(r' +|\t+', value)
+            tmp_list = list[0:len(list)-2]
+            temp = []
+            for item in tmp_list:
+                str = item[6:len(item)-1]
+                temp.append(str)
+            GpioData._modeMap[op] = temp
+
+            data = GpioData()
+            data.set_smtNum(string.atoi(list[len(list)-1]))
+            ModuleObj.set_data(self, op.lower(), data)
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if cmp(node.nodeName, 'count') == 0:
+                    GpioData._count = string.atoi(node.childNodes[0].nodeValue)
+                    continue
+
+                eintNode = node.getElementsByTagName('eint_mode')
+                defmNode = node.getElementsByTagName('def_mode')
+                modsNode = node.getElementsByTagName('mode_arr')
+                inpeNode = node.getElementsByTagName('inpull_en')
+                inpsNode = node.getElementsByTagName('inpull_selhigh')
+                defdNode = node.getElementsByTagName('def_dir')
+                diriNode = node.getElementsByTagName('in')
+                diroNode = node.getElementsByTagName('out')
+                outhNode = node.getElementsByTagName('out_high')
+                var0Node = node.getElementsByTagName('varName0')
+                var1Node = node.getElementsByTagName('varName1')
+                var2Node = node.getElementsByTagName('varName2')
+                smtNode = node.getElementsByTagName('smt')
+                iesNode = node.getElementsByTagName('ies')
+
+                num = string.atoi(node.nodeName[4:])
+                if num >= len(ModuleObj.get_data(self)):
+                    break
+                data = ModuleObj.get_data(self)[node.nodeName]
+
+                if len(eintNode):
+                    flag = False
+                    if cmp(eintNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_eintMode(flag)
+
+                if len(defmNode):
+                    data.set_defMode(string.atoi(defmNode[0].childNodes[0].nodeValue))
+
+                if len(modsNode):
+                    str = modsNode[0].childNodes[0].nodeValue
+                    temp_list = []
+                    for i in range(0, len(str)):
+                        temp_list.append(str[i])
+                    data.set_modeVec(temp_list)
+
+                if len(inpeNode):
+                    flag = False
+                    if cmp(inpeNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_inpullEn(flag)
+
+                if len(inpsNode):
+                    flag = False
+                    if cmp(inpsNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_inpullSelHigh(flag)
+
+                if len(defdNode):
+                    data.set_defDir(defdNode[0].childNodes[0].nodeValue)
+
+                if len(diriNode):
+                    flag = False
+                    if cmp(diriNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_inEn(flag)
+
+                if len(diroNode):
+                    flag = False
+                    if cmp(diroNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_outEn(flag)
+
+                if len(outhNode):
+                    flag = False
+                    if cmp(outhNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_outHigh(flag)
+
+                temp_list= []
+
+                if len(var0Node) != 0 and len(var0Node[0].childNodes) != 0:
+                    temp_list.append(var0Node[0].childNodes[0].nodeValue)
+                if len(var1Node) != 0 and len(var1Node[0].childNodes) != 0:
+                    temp_list.append(var1Node[0].childNodes[0].nodeValue)
+                if len(var2Node) != 0 and len(var2Node[0].childNodes) != 0:
+                    temp_list.append(var2Node[0].childNodes[0].nodeValue)
+                data.set_varNames(temp_list)
+
+                if len(smtNode):
+                    flag = False
+                    if cmp(smtNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_smtEn(flag)
+
+                if len(iesNode):
+                    flag = False
+                    if cmp(iesNode[0].childNodes[0].nodeValue, 'true') == 0:
+                        flag = True
+                    data.set_iesEn(flag)
+
+                ModuleObj.set_data(self, node.nodeName, data)
+
+        return True
+
+    def get_gpioData(self, idx):
+        if idx >= GpioData._count or idx < 0:
+            return None
+
+        key = 'gpio%s' %(idx)
+        return ModuleObj.get_data(self)[key]
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def isMuxMode(self, key, index, modIdx):
+        mode_name = GpioData.get_modeName(key, index)
+        modIdx.append(index)
+
+        if mode_name.find('//') != -1:
+            return True
+        return False
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+        self.gen_cFile()
+        self.gen_specFiles()
+
+    def gen_spec(self, para):
+        if para == 'gpio_usage_h':
+            self.gen_cFile()
+        elif para == 'gpio_boot_h':
+            self.gen_hFile()
+        elif para == 'gpio_dtsi':
+            self.gen_dtsiFile()
+        elif para == 'scp_gpio_usage_h':
+            self.gen_scpUsage()
+        elif para == 'pinctrl_h':
+            self.gen_pinCtrl()
+        elif para == 'pinfunc_h':
+            self.gen_pinFunc()
+        elif para == 'gpio_usage_mapping_dtsi':
+            self.gen_mapDtsi()
+
+
+    def gen_cFile(self):
+        gen_str = ''
+        fp = open(os.path.join(ModuleObj.get_genPath(), self.__fileName), 'w')
+        gen_str += ModuleObj.writeComment()
+        gen_str += ModuleObj.writeHeader(self.__fileName)
+        gen_str += self.fill_cFile()
+        gen_str += ModuleObj.writeTail(self.__fileName)
+        fp.write(gen_str)
+        fp.close()
+
+    def gen_specFiles(self):
+        self.gen_pinFunc()
+        self.gen_pinCtrl()
+        self.gen_scpUsage()
+        self.gen_mapDtsi()
+
+    def gen_pinFunc(self):
+        gen_str = ''
+        fp = open(os.path.join(ModuleObj.get_genPath(), self.__filePinfunc), 'w')
+        gen_str += ModuleObj.writeComment()
+        gen_str += ModuleObj.writeHeader(self.__filePinfunc)
+        gen_str += self.fill_pinfunc_hFile()
+        gen_str += ModuleObj.writeTail(self.__filePinfunc)
+        fp.write(gen_str)
+        fp.close()
+
+    def gen_pinCtrl(self):
+        gen_str = ''
+        fp = open(os.path.join(ModuleObj.get_genPath(), self.__filePinCtrl), 'w')
+        gen_str += ModuleObj.writeComment()
+        gen_str += ModuleObj.writeHeader(self.__filePinCtrl)
+        gen_str += self.fill_pinctrl_hFile()
+        gen_str += ModuleObj.writeTail(self.__filePinCtrl)
+        fp.write(gen_str)
+        fp.close()
+
+    def gen_scpUsage(self):
+        gen_str = ''
+        fp = open(os.path.join(ModuleObj.get_genPath(), self.__fileScp), 'w')
+        gen_str += ModuleObj.writeComment()
+        gen_str += ModuleObj.writeHeader(self.__fileScp)
+        gen_str += self.fill_cFile()
+        gen_str += ModuleObj.writeTail(self.__fileScp)
+        fp.write(gen_str)
+        fp.close()
+
+    def gen_mapDtsi(self):
+        gen_str = ''
+        fp = open(os.path.join(ModuleObj.get_genPath(), self.__fileMap), 'w')
+        gen_str += ModuleObj.writeComment()
+        gen_str += self.fill_mapping_dtsiFile()
+        fp.write(gen_str)
+        fp.close()
+
+    def fill_hFile(self):
+        gen_str = '''//Configuration for GPIO SMT(Schmidt Trigger) Group output start\n'''
+        temp_list = []
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+        #for value in ModuleObj.get_data(self).values():
+            value = ModuleObj.get_data(self)[key]
+            num = value.get_smtNum()
+            if num in temp_list or num < 0:
+                continue
+            else:
+                temp_list.append(num)
+                if value.get_smtEn():
+                    gen_str += '''#define GPIO_SMT_GROUP_%d\t\t1\n''' %(num)
+                else:
+                    gen_str += '''#define GPIO_SMT_GROUP_%d\t\t0\n''' %(num)
+
+        gen_str += '''\n\n'''
+
+        sorted_list = sorted(ModuleObj.get_data(self).keys(), key = compare)
+
+        for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            if self.is_i2cPadPin(value.get_modeName(key, value.get_defMode())):
+                value.set_inpullEn(False)
+                value.set_outHigh(False)
+                value.set_inpullSelHigh(False)
+
+            gen_str += '''//Configuration for %s\n''' %(key.upper())
+
+            mode_name = GpioData.get_modeName(key, value.get_defMode())
+            val = ''
+            if mode_name != '':
+                flag = False
+                #val = ''
+                if mode_name.find('//') != -1:
+                    flag = True
+
+                value.get_modeVec()[value.get_defMode()]
+                if flag:
+                    if value.get_modeVec()[value.get_defMode()] == '1':
+                        val = str(value.get_defMode())
+                    elif value.get_modeVec()[value.get_defMode()] == '2':
+                        val = str(value.get_defMode() + GpioData._modNum)
+                else:
+                    val = str(value.get_defMode())
+
+            if len(val) < 2:
+                val = '0' + val
+
+            pull_en = ''
+            if value.get_inPullEn():
+                pull_en = 'ENABLE'
+            else:
+                pull_en = 'DISABLE'
+
+            pull_sel = ''
+            if value.get_inPullSelHigh():
+                pull_sel = 'UP'
+            else:
+                pull_sel = 'DOWN'
+
+            out_high = ''
+            if value.get_outHigh():
+                out_high = 'ONE'
+            else:
+                out_high = 'ZERO'
+
+            smt_en = ''
+            if value.get_smtEn():
+                smt_en = 'ENABLE'
+            else:
+                smt_en= 'DISABLE'
+
+            ies_en = ''
+            if value.get_iesEn():
+                ies_en = 'ENABLE'
+            else:
+                ies_en = 'DISABLE'
+
+            gen_str += '''#define %s_MODE\t\t\tGPIO_MODE_%s\n''' %(key.upper(), val)
+            gen_str += '''#define %s_DIR\t\t\tGPIO_DIR_%s\n''' %(key.upper(), value.get_defDir())
+            gen_str += '''#define %s_PULLEN\t\tGPIO_PULL_%s\n''' %(key.upper(), pull_en)
+            gen_str += '''#define %s_PULL\t\t\tGPIO_PULL_%s\n''' %(key.upper(), pull_sel)
+            gen_str += '''#define %s_DATAOUT\t\tGPIO_OUT_%s\n''' %(key.upper(), out_high)
+            gen_str += '''#define %s_SMT\t\t\tGPIO_SMT_%s\n''' %(key.upper(), smt_en)
+            gen_str += '''#define %s_IES\t\t\tGPIO_IES_%s\n\n''' %(key.upper(), ies_en)
+
+        return gen_str
+
+
+    def is_i2cPadPin(self, name):
+        if re.match(r'^SCL\d+$', name) or re.match(r'^SDA\d+$', name):
+            return True
+
+        return False
+
+    def fill_cFile(self):
+        gen_str = ''
+        #sorted_list = sorted(ModuleObj.get_data(self).keys(), key = compare)
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+        #for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            for varName in value.get_varNames():
+                gen_str += '''#define %s\t\t\t(%s | 0x80000000)\n''' %(varName.upper(), key.upper())
+
+                if value.get_eintMode():
+                    gen_str += '''#define %s_M_EINT\t\tGPIO_MODE_00\n''' %(varName)
+
+                temp_list = []
+                for item in GpioData._specMap.keys():
+                    regExp = '[_A-Z0-9:]*%s[_A-Z0-9:]*' %(item.upper())
+                    pat = re.compile(regExp)
+                    for i in range(0, GpioData._modNum):
+                        list = value.get_modeVec()
+                        mode_name = GpioData.get_modeName(key, i)
+
+                        if list[i] == '1':
+                            if mode_name.find('//') != -1:
+                                mode_name = mode_name.split('//')[0]
+                        elif list[i] == '2':
+                            if mode_name.find('//') != -1:
+                                mode_name = mode_name.split('//')[1]
+
+                        if pat.match(mode_name):
+                            if cmp(item, 'eint') == 0 and ((value.get_eintMode() or mode_name.find('MD_EINT') != -1)):
+                                continue
+
+                            gen_str += '''#define %s%s\t\tGPIO_MODE_0%d\n''' %(varName.upper(), GpioData._specMap[item].upper(), i)
+                            temp_list.append(i)
+                            break
+
+                if not value.get_eintMode():
+                    list = value.get_modeVec()
+                    for i in range(0,GpioData._modNum):
+                        mode_name = GpioData.get_modeName(key, i)
+
+                        if list[i] == '0':
+                            continue
+                        elif list[i] == '1':
+                            if mode_name.find('//') != -1:
+                                mode_name = mode_name.split('//')[0]
+                        elif list[i] == '2':
+                            if mode_name.find('//') != -1:
+                                mode_name = mode_name.split('//')[1]
+
+
+                        if not i in temp_list:
+                            gen_str += '''#define %s_M_%s\t\tGPIO_MODE_0%d\n''' %(varName, re.sub(r'\d{0,3}$', '', mode_name), i)
+
+                regExp = r'CLKM\d'
+                pat = re.compile(regExp)
+                for i in range(0, GpioData._modNum):
+                    mode = GpioData.get_modeName(key, i)
+                    if pat.match(mode):
+                        gen_str += '''#define %s_CLK\t\tCLK_OUT%s\n''' %(varName, mode[4:])
+                        temp = ''
+                        if varName in GpioData._freqMap.keys():
+                            temp = GpioData._freqMap[varName]
+                        else:
+                            temp = 'GPIO_CLKSRC_NONE'
+                        gen_str += '''#define %s_FREQ\t\t%s\n''' %(varName, temp)
+
+                gen_str += '''\n'''
+
+        return gen_str
+
+
+    def fill_dtsiFile(self):
+        gen_str = '''&pio {\n\n'''
+        gen_str += '''\tgpio_pins_default: gpiodef{\n\t};\n\n'''
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys(), key = compare)
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+        #for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''\t%s: gpio@%s {\n''' %(key.lower(), key[4:])
+            gen_str += '''\t\tpins_cmd_dat {\n'''
+            mode = value.get_defMode()
+            mode_name = GpioData.get_modeName(key, mode)
+            mode_val = value.get_modeVec()[mode]
+            if mode_val == '1':
+                if mode_name.find('//') != -1:
+                    mode_name = mode_name.split('//')[0]
+            elif mode_val == '2':
+                if mode_name.find('//') != -1:
+                    mode_name = mode_name.split('//')[1]
+
+            gen_str += '''\t\t\tpins = <PINMUX_GPIO%s__FUNC_%s>;\n''' %(key[4:], mode_name)
+            gen_str += '''\t\t\tslew-rate = <%d>;\n''' %(value.ge_defDirInt())
+
+            temp = ''
+            if not value.get_inPullEn():
+                temp = 'bias-disable;'
+            gen_str += '''\t\t\t%s\n''' %(temp)
+            if value.get_inPullSelHigh():
+                temp = '11'
+            else:
+                temp = '00'
+            gen_str += '''\t\t\tbias-pull-down = <%s>;\n''' %(temp)
+            if value.get_outHigh():
+                temp = 'high'
+            else:
+                temp = 'low'
+            gen_str += '''\t\t\toutput-%s;\n''' %(temp)
+            gen_str += '''\t\t\tinput-schmitt-enable = <%d>;\n''' %(value.get_smtEn())
+            gen_str += '''\t\t};\n'''
+            gen_str += '''\t};\n'''
+
+        gen_str += '''};\n\n'''
+
+        gen_str += '''&gpio {\n'''
+        lineLen = 0
+        gen_str += '''\tpinctrl-names = "default",'''
+        lineLen += 30
+        for i in range(0, GpioData._count-1):
+            gen_str += '''"gpio%d",''' %(i)
+            if i < 10:
+                lineLen += 8
+            elif i < 100:
+                lineLen += 9
+            elif i >= 100:
+                lineLen += 10
+
+            if lineLen > 100:
+                gen_str += '''\n'''
+                lineLen = 0
+
+
+        gen_str += '''"gpio%d";\n''' %(GpioData._count-1)
+        gen_str += '''\tpinctrl-0 = <&gpio_pins_default>;\n'''
+
+        for i in range(1, GpioData._count):
+            gen_str += '''\tpinctrl-%d = <&gpio%d>;\n''' %(i, i-1)
+
+        gen_str += '''\n'''
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+    def fill_pinfunc_hFile(self):
+        gen_str = '''#include \"mt65xx.h\"\n\n'''
+        #sorted_list = sorted(ModuleObj.get_data(self).keys(), key = compare)
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+        #for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            for i in range(0, GpioData._modNum):
+                mode_name = GpioData.get_modeName(key, i)
+
+                if mode_name != '':
+                    lst = []
+                    if mode_name.find('//') != -1:
+                        lst = mode_name.split('//')
+                    else:
+                        lst.append(mode_name)
+
+                    for j in range(0, len(lst)):
+                        gen_str += '''#define PINMUX_GPIO%s__FUNC_%s (MTK_PIN_NO(%s) | %d)\n''' %(key[4:], lst[j], key[4:], (i + j*8))
+
+            gen_str += '''\n'''
+        gen_str += '''\n'''
+
+        return gen_str
+
+    def fill_pinctrl_hFile(self):
+        gen_str = '''#include <linux/pinctrl/pinctrl.h>\n'''
+        gen_str += '''#include <pinctrl-mtk-common.h>\n\n'''
+        gen_str += '''static const struct mtk_desc_pin mtk_pins_%s[] = {\n''' %(ModuleObj.get_chipId().lower())
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys(), key = compare)
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+        #for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''\tMTK_PIN(\n'''
+            gen_str += '''\t\tPINCTRL_PIN(%s, \"%s\"),\n''' %(key[4:], key.upper())
+            gen_str += '''\t\tNULL, \"%s\",\n''' %(ModuleObj.get_chipId().lower())
+            gen_str += '''\t\tMTK_EINT_FUNCTION(NO_EINT_SUPPORT, NO_EINT_SUPPORT)'''
+            for i in range(0, GpioData._modNum):
+                mode_name = GpioData.get_modeName(key, i)
+
+                if mode_name != '':
+                    lst = []
+                    if mode_name.find('//') != -1:
+                        lst = mode_name.split('//')
+                    else:
+                        lst.append(mode_name)
+                    for j in range(0, len(lst)):
+                        gen_str += ''',\n\t\tMTK_FUNCTION(%d, "%s")''' %(i + j * 8, lst[j])
+            gen_str += '''\n\t),\n'''
+
+        gen_str += '''};\n'''
+
+        return gen_str
+
+    def fill_mapping_dtsiFile(self):
+        gen_str = '''&gpio_usage_mapping {\n'''
+
+        #sorted_list = sorted(ModuleObj.get_data(self).keys(), key = compare)
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+        #for key in sorted_list:
+            value = ModuleObj.get_data(self)[key]
+            for varName in value.get_varNames():
+                if varName != '' and varName.lower() in GpioData._mapList:
+                    gen_str += '''\t%s = <%s>;\n''' %(varName, key[4:])
+
+        gen_str += '''};\n'''
+        return gen_str
+
+
diff --git a/tools/dct/obj/I2cObj.py b/tools/dct/obj/I2cObj.py
new file mode 100755
index 00000000000..5e0f9aa9908
--- /dev/null
+++ b/tools/dct/obj/I2cObj.py
@@ -0,0 +1,130 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import re
+import string
+import xml.dom.minidom
+import configparser
+
+from .ModuleObj import ModuleObj
+#from utility import util
+from utility.util import sorted_key
+from data.I2cData import I2cData
+from data.I2cData import BusData
+from . import ChipObj
+
+class I2cObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self, 'cust_i2c.h', 'cust_i2c.dtsi')
+        self.__busList = []
+        self.__bBusEnable = True
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_figPath())
+
+        I2cData._i2c_count = string.atoi(cp.get('I2C', 'I2C_COUNT'))
+        I2cData._channel_count = string.atoi(cp.get('I2C', 'CHANNEL_COUNT'))
+
+        if cp.has_option('Chip Type', 'I2C_BUS'):
+            flag = cp.get('Chip Type', 'I2C_BUS')
+            if flag == '0':
+                self.__bBusEnable = False
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.minidom.Node.ELEMENT_NODE:
+                if cmp(node.nodeName, 'count') == 0:
+                    self.__count = node.childNodes[0].nodeValue
+                    continue
+                if node.nodeName.find('bus') != -1:
+                    speedNode = node.getElementsByTagName('speed_kbps')
+                    enableNode = node.getElementsByTagName('pullPushEn')
+
+                    data = BusData()
+                    if len(speedNode):
+                        data.set_speed(speedNode[0].childNodes[0].nodeValue)
+                    if len(enableNode):
+                        data.set_enable(enableNode[0].childNodes[0].nodeValue)
+
+                    self.__busList.append(data)
+                elif node.nodeName.find('device') != -1:
+                    nameNode = node.getElementsByTagName('varName')
+                    channelNode = node.getElementsByTagName('channel')
+                    addrNode = node.getElementsByTagName('address')
+
+                    data = I2cData()
+                    if len(nameNode):
+                        data.set_varName(nameNode[0].childNodes[0].nodeValue)
+                    if len(channelNode):
+                        data.set_channel(channelNode[0].childNodes[0].nodeValue)
+                    if len(addrNode):
+                        data.set_address(addrNode[0].childNodes[0].nodeValue)
+
+                    ModuleObj.set_data(self, node.nodeName, data)
+
+        return True
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def gen_spec(self, para):
+        ModuleObj.gen_spec(self, para)
+
+    def fill_hFile(self):
+        gen_str = ''
+        for i in range(0, I2cData._channel_count):
+            gen_str += '''#define I2C_CHANNEL_%d\t\t\t%d\n''' %(i, i)
+
+        gen_str += '''\n'''
+
+        #sorted_lst = sorted(ModuleObj.get_data(self).keys(), key=compare)
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            temp = ''
+            if value.get_address().strip() == '':
+                temp = 'TRUE'
+            else:
+                temp = 'FALSE'
+            gen_str += '''#define I2C_%s_AUTO_DETECT\t\t\t%s\n''' %(value.get_varName(), temp)
+            gen_str += '''#define I2C_%s_CHANNEL\t\t\t%s\n''' %(value.get_varName(), value.get_channel())
+            gen_str += '''#define I2C_%s_SLAVE_7_BIT_ADDR\t\t%s\n''' %(value.get_varName(), value.get_address().upper())
+            gen_str += '''\n'''
+
+        return gen_str
+
+    def fill_dtsiFile(self):
+        gen_str = ''
+        for i in range(0, I2cData._channel_count):
+            gen_str += '''&i2c%d {\n''' %(i)
+            gen_str += '''\t#address-cells = <1>;\n'''
+            gen_str += '''\t#size-cells = <0>;\n'''
+            if self.__bBusEnable:
+                gen_str += '''\tclock-frequency = <%d>;\n''' %(string.atoi(self.__busList[i].get_speed()) * 1000)
+                temp_str = ''
+
+                if cmp(self.__busList[i].get_enable(), 'false') == 0:
+                    temp_str = 'use-open-drain'
+                elif cmp(self.__busList[i].get_enable(), 'true') == 0:
+                    temp_str = 'use-push-pull'
+                gen_str += '''\tmediatek,%s;\n''' %(temp_str)
+
+            for key in sorted_key(ModuleObj.get_data(self).keys()):
+                value = ModuleObj.get_data(self)[key]
+                channel = 'I2C_CHANNEL_%d' %(i)
+                if cmp(value.get_channel(), channel) == 0 and cmp(value.get_varName(), 'NC') != 0 and value.get_address().strip() != '':
+                    gen_str += '''\t%s@%s {\n''' %(value.get_varName().lower(), value.get_address()[2:].lower())
+                    gen_str += '''\t\tcompatible = \"mediatek,%s\";\n''' %(value.get_varName().lower())
+                    gen_str += '''\t\treg = <%s>;\n''' %(value.get_address().lower())
+                    gen_str += '''\t\tstatus = \"okay\";\n'''
+                    gen_str += '''\t};\n\n'''
+
+            gen_str += '''};\n\n'''
+
+        return gen_str
\ No newline at end of file
diff --git a/tools/dct/obj/KpdObj.py b/tools/dct/obj/KpdObj.py
new file mode 100755
index 00000000000..06adf15bc96
--- /dev/null
+++ b/tools/dct/obj/KpdObj.py
@@ -0,0 +1,292 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import re
+import string
+import configparser
+import xml.dom.minidom
+
+from .ModuleObj import ModuleObj
+from utility.util import LogLevel
+from utility.util import log
+from data.KpdData import KpdData
+
+class KpdObj(ModuleObj):
+
+    def __init__(self):
+        ModuleObj.__init__(self, 'cust_kpd.h', 'cust_kpd.dtsi')
+
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_cmpPath())
+
+        ops = cp.options('Key_definition')
+        for op in ops:
+            KpdData._keyValueMap[op.upper()] = string.atoi(cp.get('Key_definition', op))
+
+        KpdData._keyValueMap['NC'] = 0
+
+        cp.read(ModuleObj.get_figPath())
+        if cp.has_option('KEYPAD_EXTEND_TYPE', 'KEY_ROW'):
+            KpdData.set_row_ext(string.atoi(cp.get('KEYPAD_EXTEND_TYPE', 'KEY_ROW')))
+        if cp.has_option('KEYPAD_EXTEND_TYPE', 'KEY_COLUMN'):
+            KpdData.set_col_ext(string.atoi(cp.get('KEYPAD_EXTEND_TYPE', 'KEY_COLUMN')))
+
+        return True
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if node.nodeName == 'row':
+                    row = string.atoi(node.childNodes[0].nodeValue)
+                    KpdData.set_row(row)
+
+                if node.nodeName == 'column':
+                    col = string.atoi(node.childNodes[0].nodeValue)
+                    KpdData.set_col(col)
+
+                if node.nodeName == 'keyMatrix':
+                    content = node.childNodes[0].nodeValue
+                    content = content.replace('\t', '')
+                    rows = content.split('''\n''')
+                    matrix = []
+                    for row in rows:
+                        for item in row.split(' '):
+                            matrix.append(item)
+                    KpdData.set_matrix(matrix)
+                    for item in matrix:
+                        if cmp(item, 'NC') != 0:
+                            KpdData._usedKeys.append(item)
+                    KpdData._usedKeys.append('POWER')
+
+                if node.nodeName == "keyMatrix_ext":
+                    content = node.childNodes[0].nodeValue
+                    content = content.replace('\t', '')
+                    rows = content.split('''\n''')
+                    matrix = []
+                    for row in rows:
+                        for item in row.split(' '):
+                            matrix.append(item)
+                    KpdData.set_matrix_ext(matrix)
+
+                if node.nodeName == 'downloadKey':
+                    keys = node.childNodes[0].nodeValue
+                    KpdData.set_downloadKeys(keys.split(' '))
+
+                if node.nodeName == 'modeKey':
+                    value = node.childNodes[0].nodeValue
+                    keys = value.split(' ')
+                    KpdData._modeKeys['META'] = keys[0]
+                    KpdData._modeKeys['RECOVERY'] = keys[1]
+                    KpdData._modeKeys['FACTORY'] = keys[2]
+
+                if node.nodeName == 'pwrKeyEint_gpioNum':
+                    num = string.atoi(node.childNodes[0].nodeValue)
+                    KpdData.set_gpioNum(num)
+
+                if node.nodeName == 'pwrKeyUtility':
+                    util = node.childNodes[0].nodeValue
+                    KpdData.set_utility(util)
+
+                if node.nodeName == 'home_key':
+                    if len(node.childNodes) != 0:
+                        home = node.childNodes[0].nodeValue
+                    else:
+                        home = ''
+                    KpdData.set_homeKey(home)
+
+                if node.nodeName == 'bPwrKeyUseEint':
+                    flag = False
+                    if node.childNodes[0].nodeValue == 'false':
+                        flag = False
+                    else:
+                        flag = True
+
+                    KpdData.set_useEint(flag)
+
+                if node.nodeName == 'bPwrKeyGpioDinHigh':
+                    flag = False
+                    if node.childNodes[0].nodeValue == 'false':
+                        KpdData.set_gpioDinHigh(flag)
+
+                if node.nodeName == 'pressPeriod':
+                    time = string.atoi(node.childNodes[0].nodeValue)
+                    KpdData.set_pressTime(time)
+
+                if node.nodeName == 'keyType':
+                    keyType = node.childNodes[0].nodeValue
+                    KpdData.set_keyType(keyType)
+
+        return True
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def gen_spec(self, para):
+        ModuleObj.gen_spec(self, para)
+
+
+    def fill_hFile(self):
+        gen_str = '''#include <linux/input.h>\n'''
+        gen_str += '''#include <cust_eint.h>\n'''
+        gen_str += '''\n'''
+        gen_str += '''#define KPD_YES\t\t1\n'''
+        gen_str += '''#define KPD_NO\t\t0\n'''
+        gen_str += '''\n'''
+        gen_str += '''/* available keys (Linux keycodes) */\n'''
+        gen_str += '''#define KEY_CALL\t\tKEY_SEND\n'''
+        gen_str += '''#define KEY_ENDCALL\tKEY_END\n'''
+        gen_str += '''#undef KEY_OK\n'''
+        gen_str += '''#define KEY_OK\t\tKEY_REPLY    /* DPAD_CENTER */\n'''
+        gen_str += '''#define KEY_FOCUS\tKEY_HP\n'''
+        gen_str += '''#define KEY_AT\t\tKEY_EMAIL\n'''
+        gen_str += '''#define KEY_POUND\t228\t//KEY_KBDILLUMTOGGLE\n'''
+        gen_str += '''#define KEY_STAR\t227\t//KEY_SWITCHVIDEOMODE\n'''
+        gen_str += '''#define KEY_DEL\t\tKEY_BACKSPACE\n'''
+        gen_str += '''#define KEY_SYM\t\tKEY_COMPOSE\n'''
+        gen_str += '''\n'''
+        gen_str += '''#define KPD_KEY_DEBOUNCE\t%d\n''' %(KpdData.get_pressTime())
+        gen_str += '''#define KPD_PWRKEY_MAP\tKEY_%s\n''' %(KpdData.get_utility())
+        # do not gen this macro if the home key is null
+        if KpdData.get_homeKey() != '':
+            gen_str += '''#define KPD_PMIC_RSTKEY_MAP\tKEY_%s\n''' %(KpdData.get_homeKey())
+        if cmp(KpdData.get_keyType(), 'EXTEND_TYPE') != 0:
+            gen_str += '''#define MTK_PMIC_PWR_KEY\t%d\n''' %(KpdData.get_col() - 1)
+            if KpdData.get_homeKey() != '':
+                gen_str += '''#define MTK_PMIC_RST_KEY\t\t%d\n''' %(2*KpdData.get_col() - 1)
+            gen_str += '''\n'''
+            gen_str += '''#define KPD_USE_EXTEND_TYPE\tKPD_NO\n'''
+        else:
+            gen_str += '''#define MTK_PMIC_PWR_KEY\t%d\n''' %(KpdData.get_col_ext() - 1)
+            if KpdData.get_keyType() != '':
+                gen_str += '''#define MTK_PMIC_RST_KEY\t\t%d\n''' %(2*KpdData.get_col_ext() - 1)
+            gen_str += '''\n'''
+            gen_str += '''#define KPD_USE_EXTEND_TYPE\tKPD_YES\n'''
+        gen_str += '''\n'''
+        gen_str += '''/* HW keycode [0 ~ 71] -> Linux keycode */\n'''
+        gen_str += '''#define KPD_INIT_KEYMAP()\t\\\n'''
+        gen_str += '''{\t\\\n'''
+
+
+        if KpdData.get_keyType() == 'NORMAL_TYPE':
+            for key in KpdData.get_matrix():
+                if cmp(key, 'NC') != 0:
+                    gen_str += '''\t[%d] = KEY_%s,\t\\\n''' %(KpdData.get_matrix().index(key), key)
+        else:
+            for key in KpdData.get_matrix_ext():
+                if cmp(key, 'NC') != 0:
+                    gen_str += '''\t[%d] = KEY_%s,\t\\\n''' %(KpdData.get_matrix_ext().index(key), key)
+
+        gen_str += '''}\n'''
+        gen_str += '''\n'''
+
+        gen_str += '''/***********************************************************/\n'''
+        gen_str += '''/****************Preload Customation************************/\n'''
+        gen_str += '''/***********************************************************/\n'''
+        gen_str += '''#define KPD_PWRKEY_EINT_GPIO\tGPIO%d\n''' %(KpdData.get_gpioNum())
+        gen_str += '''#define KPD_PWRKEY_GPIO_DIN\t%d\n''' %(int(KpdData.get_gpioDinHigh()))
+        gen_str += '''\n'''
+
+        for key in KpdData.get_downloadKeys():
+            if cmp(key, 'NC') != 0:
+                dlIdx = KpdData.get_downloadKeys().index(key)
+                mtxIdx = self.get_matrixIdx(key)
+                gen_str += '''#define KPD_DL_KEY%d\t%d\t/* KEY_%s */\n''' %(dlIdx+1, mtxIdx, key)
+        gen_str += '''\n'''
+
+        gen_str += '''/***********************************************************/\n'''
+        gen_str += '''/****************Uboot Customation**************************/\n'''
+        gen_str += '''/***********************************************************/\n'''
+
+        for (key, value) in KpdData.get_modeKeys().items():
+            if cmp(value, 'NC') != 0:
+                idx = self.get_matrixIdx(value)
+                #idx = KpdData.get_matrix().index(value)
+                gen_str += '''#define MT65XX_%s_KEY\t%d\t/* KEY_%s */\n''' %(key, idx, value)
+
+        gen_str += '''\n'''
+
+        return gen_str
+
+    def get_matrixIdx(self, value):
+        if KpdData.get_keyType() == 'NORMAL_TYPE':
+            if cmp(value, 'POWER') == 0:
+                return KpdData.get_col() - 1
+            elif cmp(value, KpdData.get_homeKey()) == 0:
+                return 2 * KpdData.get_col() - 1
+            else:
+                return KpdData.get_matrix().index(value)
+        elif KpdData.get_keyType() == 'EXTEND_TYPE':
+            if cmp(value, 'POWER') == 0:
+                return KpdData.get_col_ext() - 1
+            elif cmp(value, KpdData.get_homeKey()) == 0:
+                return 2 * KpdData.get_col_ext() - 1
+            else:
+                return KpdData.get_matrix_ext().index(value)
+
+    def fill_dtsiFile(self):
+        gen_str = '''&keypad {\n'''
+        gen_str += '''\tmediatek,kpd-key-debounce = <%d>;\n''' %(KpdData.get_pressTime())
+        gen_str += '''\tmediatek,kpd-sw-pwrkey = <%d>;\n''' %(KpdData._keyValueMap[KpdData.get_utility()])
+        if KpdData.get_keyType() == 'NORMAL_TYPE':
+            gen_str += '''\tmediatek,kpd-hw-pwrkey = <%d>;\n''' %(KpdData.get_col()-1)
+        else:
+            gen_str += '''\tmediatek,kpd-hw-pwrkey = <%d>;\n''' %(KpdData.get_col_ext()-1)
+
+        #gen_str += '''\tmediatek,kpd-sw-rstkey  = <%d>;\n''' %(KpdData._keyValueMap[KpdData.get_homeKey()])
+        if KpdData.get_homeKey() != '':
+            gen_str += '''\tmediatek,kpd-sw-rstkey  = <%d>;\n''' %(KpdData.get_keyVal(KpdData.get_homeKey()))
+        if KpdData.get_keyType() == 'NORMAL_TYPE':
+            if KpdData.get_homeKey() != '':
+                gen_str += '''\tmediatek,kpd-hw-rstkey = <%d>;\n''' %(2*KpdData.get_col() - 1)
+            gen_str += '''\tmediatek,kpd-use-extend-type = <0>;\n'''
+        else:
+            if KpdData.get_homeKey() != '':
+                gen_str += '''\tmediatek,kpd-hw-rstkey = <%d>;\n''' %(2*KpdData.get_col_ext() - 1)
+            gen_str += '''\tmediatek,kpd-use-extend-type = <1>;\n'''
+
+        #gen_str += '''\tmediatek,kpd-use-extend-type = <0>;\n'''
+        gen_str += '''\t/*HW Keycode [0~%d] -> Linux Keycode*/\n''' %(KpdData.get_row() * KpdData.get_col() - 1)
+        gen_str += '''\tmediatek,kpd-hw-map-num = <%d>;\n''' %(KpdData.get_row() * KpdData.get_col())
+        gen_str += '''\tmediatek,kpd-hw-init-map = <'''
+
+        if KpdData.get_keyType() == 'NORMAL_TYPE':
+            for key in KpdData.get_matrix():
+                idx = KpdData._keyValueMap[key]
+                gen_str += '''%d ''' %(idx)
+        else:
+            for key in KpdData.get_matrix_ext():
+                idx = KpdData._keyValueMap[key]
+                gen_str += '''%d ''' %(idx)
+
+        gen_str.rstrip()
+        gen_str += '''>;\n'''
+        gen_str += '''\tmediatek,kpd-pwrkey-eint-gpio = <%d>;\n''' %(KpdData.get_gpioNum())
+        gen_str += '''\tmediatek,kpd-pwkey-gpio-din  = <%d>;\n''' %(int(KpdData.get_gpioDinHigh()))
+        for key in KpdData.get_downloadKeys():
+            if cmp(key, 'NC') == 0:
+                continue
+            gen_str += '''\tmediatek,kpd-hw-dl-key%d = <%s>;\n''' %(KpdData.get_downloadKeys().index(key), self.get_matrixIdx(key))
+
+        for (key, value) in KpdData.get_modeKeys().items():
+            if cmp(value, 'NC') == 0:
+                continue
+            gen_str += '''\tmediatek,kpd-hw-%s-key = <%d>;\n''' %(key.lower(), self.get_matrixIdx(value))
+
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+
+
+
+
+
diff --git a/tools/dct/obj/Md1EintObj.py b/tools/dct/obj/Md1EintObj.py
new file mode 100755
index 00000000000..e4660fc94b3
--- /dev/null
+++ b/tools/dct/obj/Md1EintObj.py
@@ -0,0 +1,174 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import configparser
+import string
+import xml.dom.minidom
+
+from utility import util
+from utility.util import sorted_key
+from .ModuleObj import ModuleObj
+from data.Md1EintData import Md1EintData
+from utility.util import LogLevel
+
+class Md1EintObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self, 'cust_eint_md1.h', 'cust_md1_eint.dtsi')
+        self.__srcPin = {}
+        self.__bSrcPinEnable = True
+
+    def get_cfgInfo(self):
+        # ConfigParser accept ":" and "=", so SRC_PIN will be treated specially
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_figPath())
+
+        if cp.has_option('Chip Type', 'MD1_EINT_SRC_PIN'):
+            flag = cp.get('Chip Type', 'MD1_EINT_SRC_PIN')
+            if flag == '0':
+                self.__bSrcPinEnable = False
+
+        if(self.__bSrcPinEnable):
+            for option in cp.options('SRC_PIN'):
+                value = cp.get('SRC_PIN', option)
+                value = value[1:]
+                temp = value.split('=')
+                self.__srcPin[temp[0]] = temp[1]
+        else:
+            self.__srcPin[''] = '-1'
+
+    def read(self, node):
+        nodes = node.childNodes
+        try:
+            for node in nodes:
+                if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                    if cmp(node.nodeName, 'count') == 0:
+                        self.__count = node.childNodes[0].nodeValue
+                        continue
+
+                    varNode = node.getElementsByTagName('varName')
+                    detNode = node.getElementsByTagName('debounce_time')
+                    polNode = node.getElementsByTagName('polarity')
+                    senNode = node.getElementsByTagName('sensitive_level')
+                    deeNode = node.getElementsByTagName('debounce_en')
+                    dedNode = node.getElementsByTagName('dedicated_en')
+                    srcNode = node.getElementsByTagName('srcPin')
+                    sktNode = node.getElementsByTagName('socketType')
+
+                    data = Md1EintData()
+                    if len(varNode):
+                        data.set_varName(varNode[0].childNodes[0].nodeValue)
+                    if len(detNode):
+                        data.set_debounceTime(detNode[0].childNodes[0].nodeValue)
+                    if len(polNode):
+                        data.set_polarity(polNode[0].childNodes[0].nodeValue)
+                    if len(senNode):
+                        data.set_sensitiveLevel(senNode[0].childNodes[0].nodeValue)
+                    if len(deeNode):
+                        data.set_debounceEnable(deeNode[0].childNodes[0].nodeValue)
+                    if len(dedNode):
+                        data.set_dedicatedEn(dedNode[0].childNodes[0].nodeValue)
+                    if len(srcNode) and len(srcNode[0].childNodes):
+                        data.set_srcPin(srcNode[0].childNodes[0].nodeValue)
+                    if len(sktNode) and len(sktNode[0].childNodes):
+                        data.set_socketType(sktNode[0].childNodes[0].nodeValue)
+
+                    ModuleObj.set_data(self, node.nodeName, data)
+        except:
+            msg = 'read md1_eint content fail!'
+            util.log(LogLevel.error, msg)
+            return False
+
+        return True
+
+    def parse(self, node):
+        self.get_cfgInfo()
+        self.read(node)
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def fill_hFile(self):
+        gen_str = ''
+        gen_str += '''#define CUST_EINT_MD_LEVEL_SENSITIVE\t\t0\n'''
+        gen_str += '''#define CUST_EINT_MD_EDGE_SENSITIVE\t\t1\n'''
+
+        gen_str += '''\n'''
+
+        if self.__bSrcPinEnable:
+            for (key, value) in self.__srcPin.items():
+                gen_str += '''#define %s\t\t%s\n''' %(key, value)
+            gen_str += '''\n'''
+
+        gen_str += '''#define CUST_EINT_POLARITY_LOW\t\t0\n'''
+        gen_str += '''#define CUST_EINT_POLARITY_HIGH\t\t1\n'''
+        gen_str += '''\n'''
+
+        gen_str += '''#define CUST_EINT_LEVEL_SENSITIVE\t\t0\n'''
+        gen_str += '''#define CUST_EINT_EDGE_SENSITIVE\t\t1\n'''
+        gen_str += '''\n'''
+
+        count = 0
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if cmp(value.get_varName(), 'NC') == 0:
+                continue
+            num = key[4:]
+            count += 1
+            gen_str += '''#define CUST_EINT_MD1_%s_NAME\t\t\t"%s"\n''' %(num, value.get_varName())
+            gen_str += '''#define CUST_EINT_MD1_%s_NUM\t\t\t%s\n''' %(num, num)
+            gen_str += '''#define CUST_EINT_MD1_%s_DEBOUNCE_CN\t\t%s\n''' %(num, value.get_debounceTime())
+            gen_str += '''#define CUST_EINT_MD1_%s_POLARITY\t\tCUST_EINT_POLARITY_%s\n''' %(num, value.get_polarity().upper())
+            gen_str += '''#define CUST_EINT_MD1_%s_SENSITIVE\t\tCUST_EINT_MD_%s_SENSITIVE\n''' %(num, value.get_sensitiveLevel().upper())
+            gen_str += '''#define CUST_EINT_MD1_%s_DEBOUNCE_EN\t\tCUST_EINT_DEBOUNCE_%s\n''' %(num, value.get_debounceEnable().upper())
+            gen_str += '''#define CUST_EINT_MD1_%s_DEDICATED_EN\t\t%s\n''' %(num, int(value.get_dedicatedEn()))
+            if self.__bSrcPinEnable:
+                gen_str += '''#define CUST_EINT_MD1_%s_SRCPIN\t\t\t%s\n''' %(num, value.get_srcPin())
+            gen_str += '''\n'''
+
+        gen_str += '''#define CUST_EINT_MD1_CNT\t\t\t%d\n''' %(count)
+
+        return gen_str
+
+
+    def fill_dtsiFile(self):
+        gen_str = ''
+        gen_str += '''&eintc {\n'''
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if cmp(value.get_varName(), 'NC') == 0:
+                continue
+            num = key[4:]
+            gen_str += '''\t%s@%s {\n''' %(value.get_varName(), num)
+            gen_str += '''\t\tcompatible = \"mediatek,%s-eint\";\n''' %(value.get_varName())
+
+            type = 1
+            polarity = value.get_polarity()
+            sensitive = value.get_sensitiveLevel()
+
+            if cmp(polarity, 'High') == 0 and cmp(sensitive, 'Edge') == 0:
+                type = 1
+            elif cmp(polarity, 'Low') == 0 and cmp(sensitive, 'Edge') == 0:
+                type = 2
+            elif cmp(polarity, 'High') == 0 and cmp(sensitive, 'Level') == 0:
+                type = 4
+            elif cmp(polarity, 'Low') == 0 and cmp(sensitive, 'Level') == 0:
+                type = 8
+
+            gen_str += '''\t\tinterrupts = <%s %d>;\n''' %(num, type)
+            gen_str += '''\t\tdebounce = <%s %d>;\n''' %(num, (string.atoi(value.get_debounceTime()))*1000)
+            gen_str += '''\t\tdedicated = <%s %d>;\n''' %(num, int(value.get_dedicatedEn()))
+            if self.__bSrcPinEnable:
+                gen_str += '''\t\tsrc_pin = <%s %s>;\n''' %(num, self.__srcPin[value.get_srcPin()])
+            else:
+                gen_str += '''\t\tsrc_pin = <%s %s>;\n''' %(num, -1)
+            gen_str += '''\t\tsockettype = <%s %s>;\n''' %(num, value.get_socketType())
+            gen_str += '''\t\tstatus = \"okay\";\n'''
+            gen_str += '''\t};\n'''
+
+            gen_str += '''\n'''
+
+        gen_str += '''};\n'''
+
+        return gen_str
+
diff --git a/tools/dct/obj/ModuleObj.py b/tools/dct/obj/ModuleObj.py
new file mode 100755
index 00000000000..cc09f6cb8be
--- /dev/null
+++ b/tools/dct/obj/ModuleObj.py
@@ -0,0 +1,147 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+import os, sys
+import time
+import re
+import string
+
+from utility import version
+from utility.util import log
+from utility.util import LogLevel
+
+class ModuleObj:
+    _chip_id = ''
+    _gen_path = ''
+
+    def __init__(self, name1, name2):
+        self.__hName = name1
+        self.__dtsiName = name2
+        self.__data = {}
+
+    def get_hFileName(self):
+        return self.__hName
+
+    def get_dtsiFileName(self):
+        return self.__dtsiName
+
+    def get_cfgInfo(self, section):
+        pass
+
+    def set_data(self, key, value):
+        self.__data[key] = value
+
+    def get_data(self):
+        return self.__data
+
+    def gen_files(self):
+        self.gen_hFile()
+        self.gen_dtsiFile()
+
+
+    def gen_hFile(self):
+        fp = open(os.path.join(ModuleObj.get_genPath(), ModuleObj.get_hFileName(self)), 'w')
+        gen_str = ''
+        gen_str += ModuleObj.writeComment()
+        gen_str += ModuleObj.writeHeader(ModuleObj.get_hFileName(self))
+        gen_str += self.fill_hFile()
+        gen_str += ModuleObj.writeTail(ModuleObj.get_hFileName(self))
+        fp.write(gen_str)
+        fp.close()
+
+
+    def gen_dtsiFile(self):
+        fp = open(os.path.join(ModuleObj.get_genPath(), ModuleObj.get_dtsiFileName(self)), 'w')
+        gen_str = ''
+        gen_str = ModuleObj.writeComment()
+        gen_str += ModuleObj.writeHeader(ModuleObj.get_dtsiFileName(self))
+        gen_str += self.fill_dtsiFile()
+        fp.write(gen_str)
+        fp.close()
+
+    def gen_spec(self, para):
+        if re.match(r'.*_h$', para):
+            self.gen_hFile()
+        elif re.match(r'.*_dtsi', para):
+            self.gen_dtsiFile()
+        elif re.match(r'.*_c', para):
+            self.gen_cFile()
+
+    @staticmethod
+    def get_figPath():
+        figPath = os.path.join(sys.path[0], 'config', ModuleObj.get_chipId() + '.fig')
+        if not os.path.exists(figPath) or not os.path.isfile(figPath):
+            log(LogLevel.error, 'Can not find %s.fig file!' %(ModuleObj.get_chipId()))
+            sys.exit(-1)
+
+        return figPath
+
+    @staticmethod
+    def get_cmpPath():
+        cmpPath = os.path.join(sys.path[0], 'config', 'YuSu.cmp')
+
+        if not os.path.exists(cmpPath) or not os.path.isfile(cmpPath):
+            log(LogLevel.error, 'Can not find YuSu.cmp file!')
+            sys.exit(-1)
+
+        return cmpPath
+
+    @staticmethod
+    def get_chipId():
+        return ModuleObj._chip_id
+
+    @staticmethod
+    def set_chipId(id):
+        ModuleObj._chip_id = id
+
+    @staticmethod
+    def set_genPath(path):
+        ModuleObj._gen_path = path
+
+    @staticmethod
+    def get_genPath():
+        return ModuleObj._gen_path
+
+    @staticmethod
+    def writeComment():
+        stamp = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
+        ver_info = version.VER_MAIN + '.' + version.VER_SUB + '.' + version.BUILD_SN
+
+        gen_str = '''/*\n * Generated by MTK SP DrvGen Version: '''
+        gen_str += ver_info
+        gen_str += ''' for '''
+        gen_str += ModuleObj.get_chipId()
+        gen_str += '''.\n'''
+        gen_str += ''' * '''
+        gen_str += stamp
+        gen_str += '''\n * Do Not Modify The File.\n'''
+        gen_str += ''' * Copyright Mediatek Inc. (c) 2016.\n*/\n\n'''
+
+        return gen_str
+
+    @staticmethod
+    def writeHeader(name):
+        str = ''
+        if re.match(r'.*\.h$', name):
+            name = string.replace(name, '.', '_')
+            name = string.replace(name, '-', '_')
+            str += '''#ifndef __%s\n''' %(name.upper())
+            str += '''#define __%s\n''' %(name.upper())
+            str += '''\n'''
+        elif re.match(r'.*\.dtsi$', name):
+            str += '''/*************************\n'''
+            str += ''' * %s File\n''' %(name.replace('cust_', '').replace('.', ' ').upper())
+            str += '''*************************/\n\n'''
+
+        return str
+
+    @staticmethod
+    def writeTail(name):
+        if re.match(r'.*\.h$', name):
+            gen_str = '''\n\n#endif /* %s */\n''' %('__' + string.replace(name, '.', '_').upper())
+            return gen_str
+
+
+
+
+
diff --git a/tools/dct/obj/PmicObj.py b/tools/dct/obj/PmicObj.py
new file mode 100755
index 00000000000..4b5a96630c5
--- /dev/null
+++ b/tools/dct/obj/PmicObj.py
@@ -0,0 +1,207 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import sys, os
+import re
+import configparser
+import xml.dom.minidom
+
+from .ModuleObj import ModuleObj
+from data.PmicData import PmicData
+
+from utility.util import log
+from utility.util import LogLevel
+from utility.util import compare
+from utility.util import sorted_key
+
+
+class PmicObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self, 'pmic_drv.h', 'cust_pmic.dtsi')
+        self.__fileName = 'pmic_drv.c'
+        self.__chipName = ''
+        self.__defLdo = ''
+        self.__appCount = -1
+        self.__func = ''
+        self.__paraList = []
+        self.__headerList = []
+
+
+    def get_cfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_cmpPath())
+
+        PmicData._var_list = cp.options('APPLICATION')
+
+        if self.__chipName == '':
+            return
+        #parse the pmic config file
+        cmpPath = os.path.join(sys.path[0], 'config', self.__chipName + '.cmp')
+        if not os.path.exists(cmpPath) or not os.path.isfile(cmpPath):
+            log(LogLevel.error, 'Can not find %s pmic config file!' %(self.__chipName))
+            sys.exit(-1)
+        cp.read(cmpPath)
+        self.__defLdo = cp.get('PMIC_TABLE', 'LDO_APPNAME_DEFAULT')
+        self.__headerList = cp.get('PMIC_TABLE', 'INCLUDE_HEADER').split(':')
+        self.__func = cp.get('PMIC_TABLE', 'FUNCTION')
+
+        for i in range(1, cp.getint('PMIC_TABLE', 'NUM_LDO')+1):
+            key = 'LDO_NAME%d' %(i)
+            self.__paraList.append(cp.get(key, 'PARAMETER_NAME'))
+
+        #parse app count in fig file
+        cp.read(ModuleObj.get_chipId() + '.fig')
+
+        cp.read(ModuleObj.get_figPath())
+        self.__appCount = cp.getint('Chip Type', 'PMIC_APP_COUNT')
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if cmp(node.nodeName, 'chip') == 0:
+                    if len(node.childNodes) == 0:
+                       break
+                    self.__chipName = node.childNodes[0].nodeValue
+                    continue
+                if cmp(node.nodeName, 'count') == 0:
+                    continue
+                ldoNode = node.getElementsByTagName('ldoVar')
+                defNode = node.getElementsByTagName('defEn')
+
+                data = PmicData()
+                if len(ldoNode):
+                    data.set_ldoName(ldoNode[0].childNodes[0].nodeValue)
+
+                if len(defNode):
+                    number = -1
+                    if cmp(defNode[0].childNodes[0].nodeValue, 'SKIP') == 0:
+                        number = 0
+                    elif cmp(defNode[0].childNodes[0].nodeValue, 'OFF') == 0:
+                        number = 1
+                    else:
+                        number = 2
+                    data.set_defEnable(number)
+
+                name_list = []
+                for i in range(0, 6):
+                    key = 'varName%d' %(i)
+                    nameNode = node.getElementsByTagName(key)
+                    if len(nameNode):
+                        name_list.append(nameNode[0].childNodes[0].nodeValue)
+
+                data.set_nameList(name_list)
+
+                ModuleObj.set_data(self, node.nodeName, data)
+
+        return True
+
+    def parse(self, node):
+        self.read(node)
+        self.get_cfgInfo()
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+        self.gen_cFile()
+
+    def gen_cFile(self):
+        fp = open(os.path.join(ModuleObj.get_genPath(), self.__fileName), 'w')
+        gen_str = ''
+        gen_str += ModuleObj.writeComment()
+        gen_str += self.fill_cFile()
+        fp.write(gen_str)
+        fp.close()
+
+
+    def fill_hFile(self):
+        gen_str = ''
+        used = []
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            for name in value.get_nameList():
+                if name.strip() != '':
+                    used.append(name)
+                    gen_str += '''#define PMIC_APP_%s\t\t\t%s_POWER_LDO_%s\n''' %(name, self.__chipName[5:11], value.get_ldoName())
+
+
+        gen_str += '''\n'''
+
+        gen_str += '''/**********Output default name********************/\n'''
+
+        for varName in PmicData._var_list:
+            if not varName.upper() in used:
+                gen_str += '''#define PMIC_APP_%s\t\t\t%s\n''' %(varName.upper(), self.__defLdo)
+
+        return gen_str
+
+
+    def fill_dtsiFile(self):
+        gen_str = ''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            gen_str += '''&mt_pmic_%s_ldo_reg {\n''' %(value.get_ldoName().lower())
+            gen_str += '''\tregulator-name = \"%s\";\n''' %((value.get_ldoName().replace('_', '')).lower())
+            gen_str += '''\tregulator-default-on = <%d>; /* 0:skip, 1: off, 2:on */\n''' %(value.get_defEnable())
+            gen_str += '''\tstatus = \"okay\";\n'''
+            gen_str += '''};\n'''
+
+        gen_str += '''\n'''
+        gen_str += '''&kd_camera_hw1 {\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            for varName in value.get_nameList():
+            #for i in range(0, self.__appCount):
+                bExisted = False
+                postFix = ''
+                #varName = value.get_nameList()[i]
+                if varName.find('CAMERA') != -1:
+                    postFix = varName[varName.rfind('_')+1:]
+                    bExisted = True
+
+                if varName.find('MAIN_CAMERA') != -1:
+                    gen_str += '''\tvcam%s-supply = <&mt_pmic_%s_ldo_reg>;\n''' %(postFix.lower(), value.get_ldoName().lower())
+
+                if varName.find('SUB_CAMERA') != -1:
+                    gen_str += '''\tvcam%s_main2-supply = <&mt_pmic_%s_ldo_reg>;\n''' %(postFix.lower(), value.get_ldoName().lower())
+                    gen_str += '''\tvcam%s_sub-supply = <&mt_pmic_%s_ldo_reg>;\n''' %(postFix.lower(), value.get_ldoName().lower())
+
+            #if bExisted == True:
+                #gen_str += '''\n'''
+
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n\n'''
+        gen_str += '''&touch {\n'''
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            for name in value.get_nameList():
+                if name.find('TOUCH') != -1:
+                    gen_str += '''\tvtouch-supply = <&mt_pmic_%s_ldo_reg>;\n''' %(value.get_ldoName().lower())
+
+        gen_str += '''\tstatus = \"okay\";\n'''
+        gen_str += '''};\n'''
+
+        return gen_str
+
+    def fill_cFile(self):
+        gen_str = ''
+        for header in self.__headerList:
+            gen_str += '''#include <%s>\n''' %(header)
+
+        gen_str += '''\n'''
+        gen_str += '''void pmu_drv_tool_customization_init(void)\n'''
+        gen_str += '''{\n'''
+        idx = 0
+
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if value.get_defEnable() != 0:
+                gen_str += '''\t%s(%s,%d);\n''' %(self.__func, self.__paraList[idx], value.get_defEnable()-1)
+            idx += 1
+        gen_str += '''}\n'''
+
+        return gen_str
+
diff --git a/tools/dct/obj/PowerObj.py b/tools/dct/obj/PowerObj.py
new file mode 100755
index 00000000000..925075e9cc0
--- /dev/null
+++ b/tools/dct/obj/PowerObj.py
@@ -0,0 +1,76 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import absolute_import
+import sys,os
+import re
+import string
+import configparser
+import xml.dom.minidom
+
+from . import ChipObj
+from data.PowerData import PowerData
+from utility.util import log
+from utility.util import LogLevel
+from utility.util import sorted_key
+from .ModuleObj import ModuleObj
+
+class PowerObj(ModuleObj):
+    def __init__(self):
+        ModuleObj.__init__(self, 'cust_power.h', 'cust_power.dtsi')
+        self.__list = {}
+
+    def getCfgInfo(self):
+        cp = configparser.ConfigParser(allow_no_value=True)
+        cp.read(ModuleObj.get_figPath())
+
+        self.__list = cp.options('POWER')
+        self.__list = self.__list[1:]
+        self.__list = sorted(self.__list)
+
+    def read(self, node):
+        nodes = node.childNodes
+        for node in nodes:
+            if node.nodeType == xml.dom.Node.ELEMENT_NODE:
+                if node.nodeName == 'count':
+                    continue
+
+                varNode = node.getElementsByTagName('varName')
+
+                data = PowerData()
+                data.set_varName(varNode[0].childNodes[0].nodeValue)
+
+                ModuleObj.set_data(self, node.nodeName, data)
+
+        return True
+
+    def parse(self, node):
+        self.getCfgInfo()
+        self.read(node)
+
+    def gen_files(self):
+        ModuleObj.gen_files(self)
+
+    def gen_spec(self, para):
+        if re.match(r'.*_h$', para):
+            self.gen_hFile()
+
+    # power module has no DTSI file
+    def gen_dtsiFile(self):
+        pass
+
+    def fill_hFile(self):
+        gen_str = ''
+        for key in sorted_key(ModuleObj.get_data(self).keys()):
+            value = ModuleObj.get_data(self)[key]
+            if value.get_varName() == '':
+                continue
+            idx = string.atoi(key[5:])
+            name = self.__list[idx]
+            gen_str += '''#define GPIO_%s\t\tGPIO_%s\n''' %(name.upper(), value.get_varName())
+
+        return gen_str
+
+    def fill_dtsiFile(self):
+        return ''
+
diff --git a/tools/dct/obj/__init__.py b/tools/dct/obj/__init__.py
new file mode 100755
index 00000000000..e69de29bb2d
diff --git a/tools/dct/utility/__init__.py b/tools/dct/utility/__init__.py
new file mode 100755
index 00000000000..e69de29bb2d
diff --git a/tools/dct/utility/util.py b/tools/dct/utility/util.py
new file mode 100755
index 00000000000..388336f2d1f
--- /dev/null
+++ b/tools/dct/utility/util.py
@@ -0,0 +1,37 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+from __future__ import print_function
+import re
+import string
+
+
+LEVEL_INFO = '[DCT_INFO]: '
+LEVEL_WARN = '[DCT_WARNING]: '
+LEVEL_ERROR = '[DCT_ERROR]: '
+
+class LogLevel:
+    info = 1
+    warn = 2
+    error = 3
+
+def log(level, msg):
+    if level == LogLevel.info:
+        print(LEVEL_INFO + msg)
+    elif level == LogLevel.warn:
+        print(LEVEL_WARN + msg)
+    elif level == LogLevel.error:
+        print(LEVEL_ERROR + msg)
+
+def compare(value):
+    lst = re.findall(r'\d+', value)
+    if len(lst) != 0:
+        return string.atoi(lst[0])
+
+    # if can not find numbers
+    return value
+
+def sorted_key(lst):
+    return sorted(lst, key=compare)
+
+
diff --git a/tools/dct/utility/version.py b/tools/dct/utility/version.py
new file mode 100755
index 00000000000..976e5dd9654
--- /dev/null
+++ b/tools/dct/utility/version.py
@@ -0,0 +1,6 @@
+#! /usr/bin/python3
+# -*- coding: utf-8 -*-
+
+VER_MAIN = '3'
+VER_SUB = '4'
+BUILD_SN = '160808'