100 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#include "os_types.h"
 | 
						|
#include "dbg_io.h"
 | 
						|
#include "iot_diag.h"
 | 
						|
#include "iot_io.h"
 | 
						|
#include "rtc_hw.h"
 | 
						|
#include "gp_timer.h"
 | 
						|
#include "iot_clock.h"
 | 
						|
 | 
						|
#include "pmm_hw.h"
 | 
						|
 | 
						|
#define PMM_EN       1
 | 
						|
 | 
						|
int IRAM_ATTR main(void)
 | 
						|
{
 | 
						|
    gp_timer_init();
 | 
						|
    gp_timer_set(0, 1*10000000, 1);
 | 
						|
    gp_timer_start(0);
 | 
						|
    dbg_uart_init();
 | 
						|
 | 
						|
    rtc_tmr_int_en(0, 0);
 | 
						|
    rtc_tmr_int_en(1, 0);
 | 
						|
    rtc_tmr_int_en(2, 0);
 | 
						|
    rtc_tmr_int_en(3, 0);
 | 
						|
#if PMM_EN
 | 
						|
    rtc_tmr_int_en(4, 0);
 | 
						|
    rtc_tmr_int_en(5, 0);
 | 
						|
#endif
 | 
						|
    rtc_tmr_cnt_clr(0);
 | 
						|
    rtc_tmr_cnt_clr(1);
 | 
						|
    rtc_tmr_cnt_clr(2);
 | 
						|
    rtc_tmr_cnt_clr(3);
 | 
						|
#if PMM_EN
 | 
						|
    rtc_tmr_cnt_clr(4);
 | 
						|
    rtc_tmr_cnt_clr(5);
 | 
						|
 | 
						|
    pmm_lp_ctrl_en(LP_DIG_RTC_WAKEUP, 1);
 | 
						|
#endif
 | 
						|
    iot_printf("--------TEST-----------\r\n");
 | 
						|
 | 
						|
    rtc_tmr_set_value(0, 0xfffff);
 | 
						|
    rtc_tmr_mode_set(0,1);
 | 
						|
    rtc_tmr_en(0, 1);
 | 
						|
    rtc_tmr_int_init(0);
 | 
						|
    rtc_tmr_int_en(0, 1);
 | 
						|
    iot_delay_us(1000000);
 | 
						|
 | 
						|
    rtc_tmr_set_value(1, 0xeffff);
 | 
						|
    rtc_tmr_mode_set(1,1);
 | 
						|
    rtc_tmr_en(1, 1);
 | 
						|
    rtc_tmr_int_init(1);
 | 
						|
    rtc_tmr_int_en(1, 1);
 | 
						|
    iot_delay_us(1000000);
 | 
						|
 | 
						|
    rtc_tmr_set_value(2, 0xdffff);
 | 
						|
    rtc_tmr_mode_set(2,1);
 | 
						|
    rtc_tmr_en(2, 1);
 | 
						|
    rtc_tmr_int_init(2);
 | 
						|
    rtc_tmr_int_en(2, 1);
 | 
						|
    iot_delay_us(1000000);
 | 
						|
 | 
						|
    rtc_tmr_set_value(3, 0xcffff);
 | 
						|
    rtc_tmr_mode_set(3,1);
 | 
						|
    rtc_tmr_en(3, 1);
 | 
						|
    rtc_tmr_int_init(3);
 | 
						|
    rtc_tmr_int_en(3, 1);
 | 
						|
    iot_delay_us(1000000);
 | 
						|
#if PMM_EN
 | 
						|
    rtc_tmr_set_value(4, 0xbffff);
 | 
						|
    rtc_tmr_mode_set(4,1);
 | 
						|
    rtc_tmr_en(4, 1);
 | 
						|
    rtc_tmr_int_init(4);
 | 
						|
    rtc_tmr_int_en(4, 1);
 | 
						|
    iot_delay_us(1000000);
 | 
						|
 | 
						|
    rtc_tmr_set_value(5, 0xaffff);
 | 
						|
    rtc_tmr_mode_set(5,1);
 | 
						|
    rtc_tmr_en(5, 1);
 | 
						|
    rtc_tmr_int_init(5);
 | 
						|
    rtc_tmr_int_en(5, 1);
 | 
						|
#endif
 | 
						|
 | 
						|
    while(1) {
 | 
						|
        iot_delay_us(10000000);
 | 
						|
#if PMM_EN
 | 
						|
        iot_printf("TMR:: 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x \r\n status:  0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x \n",rtc_tmr_get_curr_value(0),rtc_tmr_get_curr_value(1), \
 | 
						|
          rtc_tmr_get_curr_value(2),rtc_tmr_get_curr_value(3),rtc_tmr_get_curr_value(4),rtc_tmr_get_curr_value(5),rtc_tmr_get_int_status(0),rtc_tmr_get_int_status(1), \
 | 
						|
          rtc_tmr_get_int_status(2),rtc_tmr_get_int_status(3),rtc_tmr_get_int_status(4),rtc_tmr_get_int_status(5));
 | 
						|
#else
 | 
						|
        iot_printf("TMR:: 0x%x, 0x%x, 0x%x, 0x%x \r\n status:  0x%x, 0x%x, 0x%x, 0x%x \n",rtc_tmr_get_curr_value(0),rtc_tmr_get_curr_value(1), \
 | 
						|
          rtc_tmr_get_curr_value(2),rtc_tmr_get_curr_value(3),rtc_tmr_get_int_status(0),rtc_tmr_get_int_status(1), \
 | 
						|
          rtc_tmr_get_int_status(2),rtc_tmr_get_int_status(3));
 | 
						|
 | 
						|
#endif
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 |