74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.4 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.
 | 
						|
 | 
						|
****************************************************************************/
 | 
						|
 | 
						|
#include "bb_cpu_timer.h"
 | 
						|
#include "hw_reg_api.h"
 | 
						|
#include "rfplc_reg_base.h"
 | 
						|
#include "rf_mac_reg.h"
 | 
						|
#include "mac_sys_reg.h"
 | 
						|
#include "mac_rf_isr.h"
 | 
						|
 | 
						|
extern rf_mac_isr_ctx_t g_rf_mac_isr_1;
 | 
						|
 | 
						|
uint32_t bb_cpu_timer_get_timeout_id()
 | 
						|
{
 | 
						|
    return RF_MAC_READ_REG(CFG_RF_MAC_COMMON_TIMER_REG_7_ADDR);
 | 
						|
}
 | 
						|
 | 
						|
void bb_cpu_timer_clr_timeout_id(uint32_t timer_sts)
 | 
						|
{
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_5_ADDR, timer_sts);
 | 
						|
}
 | 
						|
 | 
						|
void bb_cpu_timer_enable()
 | 
						|
{
 | 
						|
    g_rf_mac_isr_1.isr_timer_mask = RF_MAC_COMMON_TIMER_CLR_CPU1_MASK;
 | 
						|
    /* enable all timer */
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_1_ADDR,
 | 
						|
        g_rf_mac_isr_1.isr_timer_mask);
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_9_ADDR,
 | 
						|
        g_rf_mac_isr_1.isr_timer_mask);
 | 
						|
}
 | 
						|
 | 
						|
void bb_cpu_timer_disable()
 | 
						|
{
 | 
						|
    g_rf_mac_isr_1.isr_timer_mask = 0;
 | 
						|
    /* disable all common timer */
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_1_ADDR, 0);
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_9_ADDR, 0);
 | 
						|
    /* clear all status */
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_5_ADDR,
 | 
						|
        RF_MAC_COMMON_TIMER_CLR_CPU1_MASK);
 | 
						|
}
 | 
						|
 | 
						|
void bb_cpu_timer_start(uint32_t timer_id)
 | 
						|
{
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_3_ADDR, (1 << timer_id));
 | 
						|
}
 | 
						|
 | 
						|
void bb_cpu_timer_stop(uint32_t timer_id)
 | 
						|
{
 | 
						|
    RF_MAC_WRITE_REG(CFG_RF_MAC_COMMON_TIMER_REG_5_ADDR, (1 << timer_id));
 | 
						|
}
 | 
						|
 | 
						|
void bb_cpu_timer_set(uint32_t timer_id, uint32_t time_us)
 | 
						|
{
 | 
						|
    IOT_ASSERT(timer_id < BB_CPU_TIMER_MAX_ID &&
 | 
						|
        time_us < BB_CPU_TIMER_MAX_TIME_US);
 | 
						|
    uint32_t addr_base = CFG_RF_MAC_COMMON_TIMER_REG_42_ADDR;
 | 
						|
    RF_MAC_WRITE_REG(addr_base + (timer_id * 4), (time_us * 25));
 | 
						|
}
 | 
						|
 |