270 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			270 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/****************************************************************************
 | 
						|
 | 
						|
Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED.
 | 
						|
 | 
						|
This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT
 | 
						|
be copied by any method or incorporated into another program without
 | 
						|
the express written consent of Aerospace C.Power. This Information or any portion
 | 
						|
thereof remains the property of Aerospace C.Power. The Information contained herein
 | 
						|
is believed to be accurate and Aerospace C.Power assumes no responsibility or
 | 
						|
liability for its use in any way and conveys no license or title under
 | 
						|
any patent or copyright and makes no representation or warranty that this
 | 
						|
Information is free from patent or copyright infringement.
 | 
						|
 | 
						|
****************************************************************************/
 | 
						|
/* os shim includes */
 | 
						|
#include "os_types.h"
 | 
						|
#include "os_task.h"
 | 
						|
#include "os_utils.h"
 | 
						|
 | 
						|
/* common includes */
 | 
						|
#include "iot_io.h"
 | 
						|
#include "iot_bitops.h"
 | 
						|
#include "iot_pkt.h"
 | 
						|
#include "iot_ipc.h"
 | 
						|
#include "iot_dbglog_api.h"
 | 
						|
#include "iot_config.h"
 | 
						|
 | 
						|
/* driver includes */
 | 
						|
#include "iot_clock.h"
 | 
						|
#include "iot_uart.h"
 | 
						|
#include "iot_uart_h.h"
 | 
						|
#include "iot_dma.h"
 | 
						|
#include "cpu.h"
 | 
						|
#include "uart.h"
 | 
						|
#include "apb_hw.h"
 | 
						|
#include "apb.h"
 | 
						|
#include "iot_adc_api.h"
 | 
						|
#include "iot_gpio_api.h"
 | 
						|
 | 
						|
/* debug includes*/
 | 
						|
#include "dbg_io.h"
 | 
						|
#include "rtc.h"
 | 
						|
#include "ahb.h"
 | 
						|
#include "gpio.h"
 | 
						|
#include "gpio_mtx_hw.h"
 | 
						|
#include "gpio_mtx.h"
 | 
						|
#include "smc_rf.h"
 | 
						|
#include "smc.h"
 | 
						|
#include "sfc.h"
 | 
						|
#include "flash.h"
 | 
						|
#include "clk.h"
 | 
						|
 | 
						|
#include "hw_reg_api.h"
 | 
						|
#include "apb_hw.h"
 | 
						|
#include "apb.h"
 | 
						|
#include "sar_adc_reg.h"
 | 
						|
#include "bond_reg.h"
 | 
						|
#include "cpu.h"
 | 
						|
#include "ana_dig_wrap_rf.h"
 | 
						|
#include "mac_reset.h"
 | 
						|
 | 
						|
extern int platform_init();
 | 
						|
static os_task_h test_init_handle;
 | 
						|
uint32_t clk_debug_output_set(uint32_t type, uint32_t div, uint32_t gpio);
 | 
						|
 | 
						|
static const iot_pkt_config_t test_pkt_config =
 | 
						|
{
 | 
						|
    {
 | 
						|
        {
 | 
						|
            256,
 | 
						|
            25,
 | 
						|
            PKT_OWNER_ALL,
 | 
						|
        },
 | 
						|
        {
 | 
						|
            600,
 | 
						|
            25,
 | 
						|
            PKT_OWNER_ALL,
 | 
						|
            },
 | 
						|
        {
 | 
						|
            1100,
 | 
						|
            10,
 | 
						|
            PKT_OWNER_ALL,
 | 
						|
        },
 | 
						|
        {
 | 
						|
            2200,
 | 
						|
            3,
 | 
						|
            PKT_OWNER_ALL,
 | 
						|
        },
 | 
						|
        {
 | 
						|
            0,
 | 
						|
            0,
 | 
						|
            PKT_OWNER_NONE,
 | 
						|
        },
 | 
						|
        {
 | 
						|
            0,
 | 
						|
            0,
 | 
						|
            PKT_OWNER_NONE,
 | 
						|
        },
 | 
						|
        {
 | 
						|
            0,
 | 
						|
            0,
 | 
						|
            PKT_OWNER_NONE,
 | 
						|
        },
 | 
						|
        {
 | 
						|
            0,
 | 
						|
            0,
 | 
						|
            PKT_OWNER_NONE,
 | 
						|
        },
 | 
						|
    }
 | 
						|
};
 | 
						|
 | 
						|
static void iot_sub_system_init()
 | 
						|
{
 | 
						|
    /* init common modules */
 | 
						|
    iot_bitops_init();
 | 
						|
 | 
						|
    /* init os related modules and utilities */
 | 
						|
    os_utils_init();
 | 
						|
 | 
						|
    /* init pkt module */
 | 
						|
    iot_pkt_init(&test_pkt_config);
 | 
						|
 | 
						|
    /* init ipc module */
 | 
						|
    iot_ipc_init();
 | 
						|
}
 | 
						|
 | 
						|
static void iot_task_1(void *arg)
 | 
						|
{
 | 
						|
    uint8_t test_case = 2;
 | 
						|
    uint8_t test_pin = 33;
 | 
						|
    /* tpye : 1-XTAL, 2-APB, 3-MPLL, 4-WPHY_FCLK, 5-PLC_ADC, 6-PLC_DAC,
 | 
						|
       7-TPID, 8-METER, 9-AHB, 10-PLC_50, 11-PLC_75, 12-PLC_150.
 | 
						|
    */
 | 
						|
    uint8_t test_clk_type = 9;
 | 
						|
 | 
						|
    iot_sub_system_init();
 | 
						|
    if (0) {
 | 
						|
        iot_gpio_open_as_output(test_pin);
 | 
						|
        while (1) {
 | 
						|
            os_delay(1000);
 | 
						|
            iot_gpio_value_set(test_pin, 1);
 | 
						|
            os_delay(1000);
 | 
						|
            iot_gpio_value_set(test_pin, 0);
 | 
						|
        }
 | 
						|
    }
 | 
						|
    iot_printf("clock tree test\n");
 | 
						|
 | 
						|
    apb_enable(APB_GMTX);
 | 
						|
    gpio_pin_select(test_pin, 0);
 | 
						|
 | 
						|
    //CLK_FRQ_75M CLK_FRQ_150M
 | 
						|
    //clk_core_freq_set(CLK_FRQ_25M);
 | 
						|
 | 
						|
    /*
 | 
						|
    CLK_FRQ_GP_IDX_XTAL         = 0,
 | 
						|
    CLK_FRQ_GP_IDX_LOW_POWER    = 1,
 | 
						|
    CLK_FRQ_GP_IDX_SLOW         = 2,
 | 
						|
    CLK_FRQ_GP_IDX_MEDIUM_SPEED = 3,
 | 
						|
    CLK_FRQ_GP_IDX_FAST         = 4,
 | 
						|
    CLK_FRQ_GP_IDX_PERFORMANCE  = 5,
 | 
						|
    CLK_FRQ_GP_IDX_MAX
 | 
						|
    */
 | 
						|
    clk_system_clock_tree_config(CLK_FRQ_GP_IDX_FAST);
 | 
						|
 | 
						|
    if (8 == test_clk_type) {
 | 
						|
        //HW module read/write macro
 | 
						|
        int data = DTOP_ANA_INF_READ_REG(CFG_ANA_DIG_REG_CFG23_ADDR);
 | 
						|
        REG_FIELD_SET(D_METER_ADC_EN, data, 1);
 | 
						|
        DTOP_ANA_INF_WRITE_REG(CFG_ANA_DIG_REG_CFG23_ADDR, data);
 | 
						|
    } else if (7 == test_clk_type) {
 | 
						|
        //HW module read/write macro
 | 
						|
        int data = DTOP_ANA_INF_READ_REG(CFG_ANA_DIG_REG_CFG24_ADDR);
 | 
						|
        REG_FIELD_SET(D_TPID_ADC_EN, data, 1);
 | 
						|
        DTOP_ANA_INF_WRITE_REG(CFG_ANA_DIG_REG_CFG24_ADDR, data);
 | 
						|
    } else if (5 == test_clk_type || 6 == test_clk_type) {
 | 
						|
        ahb_phy_mac_enable();
 | 
						|
        mac_sw_trig_need_en(false);
 | 
						|
    }
 | 
						|
 | 
						|
    switch (test_case) {
 | 
						|
        case 0:
 | 
						|
            //sfc_clk_div_set(0);
 | 
						|
            hal_qspi_cfg_sfc_clk_out(true);
 | 
						|
            gpio_mtx_sig_out(GPIO_MTX_SFC_SPI_CLK_OUT_MON, test_pin);
 | 
						|
            break;
 | 
						|
        case 1:
 | 
						|
            //hal_smc_clk_div_set(0);
 | 
						|
            hal_smc_clk_out(true);
 | 
						|
            gpio_mtx_sig_out(GPIO_MTX_SMC_SPI_CLK_OUT_MON, test_pin);
 | 
						|
            break;
 | 
						|
        case 2:
 | 
						|
            // div : 0x1 - DIV2, 0x3 - DIV4, 0x7 - DIV8, 0xF - DIV16.
 | 
						|
            clk_debug_output_set(test_clk_type, 1, test_pin);
 | 
						|
            break;
 | 
						|
        case 3:
 | 
						|
            break;
 | 
						|
        default:break;
 | 
						|
    }
 | 
						|
 | 
						|
    for (;;) {
 | 
						|
        os_delay(1000);
 | 
						|
        iot_printf(".");
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
static int32_t iot_task_init()
 | 
						|
{
 | 
						|
    /* start plc lib task */
 | 
						|
    test_init_handle = os_create_task(iot_task_1, NULL, 9);
 | 
						|
 | 
						|
    /* create the tasks */
 | 
						|
    if (test_init_handle != NULL) {
 | 
						|
        iot_printf("task create successfully...\n");
 | 
						|
    }
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
static void cache_init()
 | 
						|
{
 | 
						|
    cache_enable(AHB_CACHE_D0);
 | 
						|
    cache_set_buffer_mode(AHB_CACHE_D0, 1);
 | 
						|
    cache_enable(AHB_CACHE_D1);
 | 
						|
    cache_set_buffer_mode(AHB_CACHE_D1, 1);
 | 
						|
}
 | 
						|
 | 
						|
static int32_t iot_platform_init()
 | 
						|
{
 | 
						|
    cache_init();
 | 
						|
    /* platform intialization */
 | 
						|
    platform_init();
 | 
						|
 | 
						|
    /* resource initializations */
 | 
						|
    system_clock_init();
 | 
						|
 | 
						|
    system_uart_init();
 | 
						|
 | 
						|
    dbg_uart_init();
 | 
						|
 | 
						|
    dbg_uart_stage1_init();
 | 
						|
 | 
						|
    iot_printf("iot platform init successfully...\n");
 | 
						|
 | 
						|
    /* rtc init, idle used rtc lock */
 | 
						|
    iot_rtc_init();
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
static int32_t iot_task_start()
 | 
						|
{
 | 
						|
    //start the tasks;
 | 
						|
    os_start_kernel();
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
int main(void)
 | 
						|
{
 | 
						|
    //platform intialization;
 | 
						|
    iot_platform_init();
 | 
						|
 | 
						|
    //create all the tasks;
 | 
						|
    iot_task_init();
 | 
						|
 | 
						|
    iot_task_start();
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 |