395 lines
14 KiB
C
395 lines
14 KiB
C
#include "bflb_uart.h"
|
|
#include "bflb_irq.h"
|
|
#include "bflb_gpio.h"
|
|
#include "bflb_clock.h"
|
|
#include "bflb_rtc.h"
|
|
#include "mmheap.h"
|
|
#include "bl808_glb.h"
|
|
// #include "bl808_psram_uhs.h"
|
|
// #include "bl808_tzc_sec.h"
|
|
// #include "bl808_ef_cfg.h"
|
|
// #include "bl808_uhs_phy.h"
|
|
#include "board.h"
|
|
|
|
#ifdef CONFIG_BSP_SDH_SDCARD
|
|
#include "sdh_sdcard.h"
|
|
#endif
|
|
|
|
extern uint32_t __HeapBase;
|
|
extern uint32_t __HeapLimit;
|
|
|
|
struct heap_info mmheap_root;
|
|
|
|
static struct heap_region system_mmheap[] = {
|
|
{ NULL, 0 },
|
|
{ NULL, 0 }, /* Terminates the array. */
|
|
};
|
|
|
|
static struct bflb_device_s *uart0;
|
|
|
|
#if (defined(CONFIG_LUA) || defined(CONFIG_BFLOG))
|
|
static struct bflb_device_s *rtc;
|
|
#endif
|
|
|
|
static void system_clock_init(void)
|
|
{
|
|
GLB_Halt_CPU(GLB_CORE_ID_D0);
|
|
GLB_Halt_CPU(GLB_CORE_ID_LP);
|
|
/* wifipll/audiopll */
|
|
GLB_Power_On_XTAL_And_PLL_CLK(GLB_XTAL_40M, GLB_PLL_WIFIPLL |
|
|
GLB_PLL_CPUPLL |
|
|
GLB_PLL_UHSPLL |
|
|
GLB_PLL_MIPIPLL);
|
|
|
|
GLB_Set_MCU_System_CLK(GLB_MCU_SYS_CLK_WIFIPLL_320M);
|
|
GLB_Set_DSP_System_CLK(GLB_DSP_SYS_CLK_CPUPLL_400M);
|
|
|
|
CPU_Set_MTimer_CLK(ENABLE, CPU_Get_MTimer_Source_Clock() / 1000 / 1000 - 1);
|
|
GLB_Release_CPU(GLB_CORE_ID_D0);
|
|
GLB_Release_CPU(GLB_CORE_ID_LP);
|
|
}
|
|
|
|
static void peripheral_clock_init(void)
|
|
{
|
|
PERIPHERAL_CLOCK_ADC_DAC_ENABLE();
|
|
PERIPHERAL_CLOCK_SEC_ENABLE();
|
|
PERIPHERAL_CLOCK_DMA0_ENABLE();
|
|
PERIPHERAL_CLOCK_UART0_ENABLE();
|
|
PERIPHERAL_CLOCK_UART1_ENABLE();
|
|
PERIPHERAL_CLOCK_SPI0_1_ENABLE();
|
|
PERIPHERAL_CLOCK_I2C0_ENABLE();
|
|
PERIPHERAL_CLOCK_PWM0_ENABLE();
|
|
PERIPHERAL_CLOCK_TIMER0_1_WDG_ENABLE();
|
|
PERIPHERAL_CLOCK_IR_ENABLE();
|
|
PERIPHERAL_CLOCK_I2S_ENABLE();
|
|
|
|
GLB_Set_ADC_CLK(1, GLB_ADC_CLK_XCLK, 4);
|
|
GLB_Set_UART_CLK(ENABLE, HBN_UART_CLK_XCLK, 0);
|
|
GLB_Set_SPI_CLK(ENABLE, GLB_SPI_CLK_MCU_MUXPLL_160M, 0);
|
|
GLB_Set_IR_CLK(ENABLE, GLB_IR_CLK_SRC_XCLK, 19);
|
|
GLB_Set_ADC_CLK(1, GLB_ADC_CLK_XCLK, 0);
|
|
GLB_Set_DIG_CLK_Sel(GLB_DIG_CLK_XCLK);
|
|
GLB_Set_DIG_512K_CLK(1, ENABLE, 0x4E);
|
|
GLB_Set_PWM1_IO_Sel(GLB_PWM1_IO_DIFF_END);
|
|
|
|
#ifdef CONFIG_BSP_SDH_SDCARD
|
|
PERIPHERAL_CLOCK_SDH_ENABLE();
|
|
uint32_t tmp_val;
|
|
tmp_val = BL_RD_REG(PDS_BASE, PDS_CTL5);
|
|
uint32_t tmp_val2 = BL_GET_REG_BITS_VAL(tmp_val, PDS_CR_PDS_GPIO_KEEP_EN);
|
|
tmp_val2 &= ~(1 << 0);
|
|
tmp_val = BL_SET_REG_BITS_VAL(tmp_val, PDS_CR_PDS_GPIO_KEEP_EN, tmp_val2);
|
|
BL_WR_REG(PDS_BASE, PDS_CTL5, tmp_val);
|
|
|
|
GLB_Set_SDH_CLK(ENABLE, GLB_SDH_CLK_WIFIPLL_96M, 0);
|
|
GLB_AHB_MCU_Software_Reset(GLB_AHB_MCU_SW_EXT_SDH);
|
|
#endif
|
|
}
|
|
#ifdef CONFIG_PSRAM
|
|
#define WB_4MB_PSRAM (1)
|
|
#define UHS_32MB_PSRAM (2)
|
|
#define UHS_64MB_PSRAM (3)
|
|
#define WB_32MB_PSRAM (4)
|
|
#define NONE_UHS_PSRAM (-1)
|
|
|
|
int uhs_psram_init(void)
|
|
{
|
|
PSRAM_UHS_Cfg_Type psramDefaultCfg = {
|
|
2000,
|
|
PSRAM_MEM_SIZE_32MB,
|
|
PSRAM_PAGE_SIZE_2KB,
|
|
PSRAM_UHS_NORMAL_TEMP,
|
|
};
|
|
|
|
Efuse_Chip_Info_Type chip_info;
|
|
EF_Ctrl_Get_Chip_Info(&chip_info);
|
|
if (chip_info.psramInfo == UHS_32MB_PSRAM) {
|
|
psramDefaultCfg.psramMemSize = PSRAM_MEM_SIZE_32MB;
|
|
} else if (chip_info.psramInfo == UHS_64MB_PSRAM) {
|
|
psramDefaultCfg.psramMemSize = PSRAM_MEM_SIZE_64MB;
|
|
} else {
|
|
return -1;
|
|
}
|
|
|
|
Efuse_Psram_Trim_Type uhs_psram_trim;
|
|
EF_Ctrl_Read_Psram_Trim(&uhs_psram_trim);
|
|
|
|
//init uhs PLL; Must open uhs pll first, and then initialize uhs psram
|
|
GLB_Config_UHS_PLL(GLB_XTAL_40M, uhsPllCfg_2000M);
|
|
//init uhs psram ;
|
|
// Psram_UHS_x16_Init(Clock_Peripheral_Clock_Get(BL_PERIPHERAL_CLOCK_PSRAMA) / 1000000);
|
|
Psram_UHS_x16_Init_Override(&psramDefaultCfg);
|
|
Tzc_Sec_PSRAMA_Access_Release();
|
|
|
|
// example: 2000Mbps typical cal values
|
|
uhs_phy_cal_res->rl = 39;
|
|
uhs_phy_cal_res->rdqs = 3;
|
|
uhs_phy_cal_res->rdq = 0;
|
|
uhs_phy_cal_res->wl = 13;
|
|
uhs_phy_cal_res->wdqs = 4;
|
|
uhs_phy_cal_res->wdq = 5;
|
|
uhs_phy_cal_res->ck = 9;
|
|
/* TODO: use uhs psram trim update */
|
|
set_uhs_latency_r(uhs_phy_cal_res->rl);
|
|
cfg_dqs_rx(uhs_phy_cal_res->rdqs);
|
|
cfg_dq_rx(uhs_phy_cal_res->rdq);
|
|
set_uhs_latency_w(uhs_phy_cal_res->wl);
|
|
cfg_dq_drv(uhs_phy_cal_res->wdq);
|
|
cfg_ck_cen_drv(uhs_phy_cal_res->wdq + 4, uhs_phy_cal_res->wdq + 1);
|
|
cfg_dqs_drv(uhs_phy_cal_res->wdqs);
|
|
// set_odt_en();
|
|
mr_read_back();
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
void bl_show_log(void)
|
|
{
|
|
printf("\r\n");
|
|
printf(" ____ __ __ _ _ _ \r\n");
|
|
printf(" | _ \\ / _|/ _| | | | | | | \r\n");
|
|
printf(" | |_) | ___ _ _| |_| |_ __ _| | ___ | | __ _| |__ \r\n");
|
|
printf(" | _ < / _ \\| | | | _| _/ _` | |/ _ \\| |/ _` | '_ \\ \r\n");
|
|
printf(" | |_) | (_) | |_| | | | || (_| | | (_) | | (_| | |_) |\r\n");
|
|
printf(" |____/ \\___/ \\__,_|_| |_| \\__,_|_|\\___/|_|\\__,_|_.__/ \r\n");
|
|
printf("\r\n");
|
|
printf("Build:%s,%s\r\n", __TIME__, __DATE__);
|
|
printf("Copyright (c) 2022 Bouffalolab team\r\n");
|
|
}
|
|
|
|
extern void bflb_uart_set_console(struct bflb_device_s *dev);
|
|
|
|
static void console_init()
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_uart_init(gpio, GPIO_PIN_14, GPIO_UART_FUNC_UART0_TX);
|
|
bflb_gpio_uart_init(gpio, GPIO_PIN_15, GPIO_UART_FUNC_UART0_RX);
|
|
|
|
struct bflb_uart_config_s cfg;
|
|
cfg.baudrate = 2000000;
|
|
cfg.data_bits = UART_DATA_BITS_8;
|
|
cfg.stop_bits = UART_STOP_BITS_1;
|
|
cfg.parity = UART_PARITY_NONE;
|
|
cfg.flow_ctrl = 0;
|
|
cfg.tx_fifo_threshold = 7;
|
|
cfg.rx_fifo_threshold = 7;
|
|
|
|
uart0 = bflb_device_get_by_name("uart0");
|
|
|
|
bflb_uart_init(uart0, &cfg);
|
|
bflb_uart_set_console(uart0);
|
|
}
|
|
|
|
void board_init(void)
|
|
{
|
|
bflb_irq_initialize();
|
|
system_clock_init();
|
|
peripheral_clock_init();
|
|
|
|
system_mmheap[0].addr = (uint8_t *)&__HeapBase;
|
|
system_mmheap[0].mem_size = ((size_t)&__HeapLimit - (size_t)&__HeapBase);
|
|
|
|
if (system_mmheap[0].mem_size > 0) {
|
|
mmheap_init(&mmheap_root, system_mmheap);
|
|
}
|
|
|
|
console_init();
|
|
|
|
bl_show_log();
|
|
|
|
printf("dynamic memory init success,heap size = %d Kbyte \r\n", system_mmheap[0].mem_size / 1024);
|
|
|
|
printf("sig1:%08x\r\n", BL_RD_REG(GLB_BASE, GLB_UART_CFG1));
|
|
printf("sig2:%08x\r\n", BL_RD_REG(GLB_BASE, GLB_UART_CFG2));
|
|
|
|
#if (defined(CONFIG_LUA) || defined(CONFIG_BFLOG))
|
|
rtc = bflb_device_get_by_name("rtc");
|
|
bflb_rtc_set_time(rtc, BFLB_RTC_SEC2TIME(0));
|
|
#endif
|
|
#ifdef CONFIG_PSRAM
|
|
if (uhs_psram_init() < 0) {
|
|
while (1) {
|
|
}
|
|
}
|
|
#endif
|
|
}
|
|
|
|
void board_uart1_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
|
|
bflb_gpio_uart_init(gpio, GPIO_PIN_4, GPIO_UART_FUNC_UART1_TX);
|
|
bflb_gpio_uart_init(gpio, GPIO_PIN_5, GPIO_UART_FUNC_UART1_RX);
|
|
bflb_gpio_uart_init(gpio, GPIO_PIN_6, GPIO_UART_FUNC_UART1_CTS);
|
|
bflb_gpio_uart_init(gpio, GPIO_PIN_7, GPIO_UART_FUNC_UART1_RTS);
|
|
}
|
|
|
|
void board_i2c0_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_16, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
}
|
|
|
|
void board_spi0_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_init(gpio, GPIO_PIN_16, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_17, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_18, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_19, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
}
|
|
|
|
void board_pwm0_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_init(gpio, GPIO_PIN_24, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLDOWN | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_25, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_26, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLDOWN | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_27, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_28, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLDOWN | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_29, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_30, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLDOWN | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_31, GPIO_FUNC_PWM0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
}
|
|
|
|
void board_adc_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
/* ADC_CH0 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_17, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH1 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_5, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH2 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_4, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH3 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH4 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_6, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH5 */
|
|
//bflb_gpio_init(gpio, GPIO_PIN_40, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH6 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_12, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH7 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_13, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH8 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_16, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH9 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_18, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH10 */
|
|
bflb_gpio_init(gpio, GPIO_PIN_19, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* ADC_CH11,note the FLASH pin */
|
|
//bflb_gpio_init(gpio, GPIO_PIN_34, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
}
|
|
|
|
void board_dac_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
/* DAC_CHA */
|
|
bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
/* DAC_CHB */
|
|
bflb_gpio_init(gpio, GPIO_PIN_4, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
}
|
|
|
|
void board_ir_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0);
|
|
bflb_gpio_init(gpio, GPIO_PIN_17, GPIO_INPUT | GPIO_SMT_EN | GPIO_DRV_0);
|
|
GLB_IR_RX_GPIO_Sel(GLB_GPIO_PIN_17);
|
|
}
|
|
|
|
void board_emac_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_init(gpio, GPIO_PIN_24, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_25, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_26, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_27, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_28, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_29, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_30, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_31, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_32, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
bflb_gpio_init(gpio, GPIO_PIN_33, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1);
|
|
|
|
#if defined(BL808)
|
|
// GLB_PER_Clock_UnGate(1<<12);
|
|
#endif
|
|
}
|
|
|
|
#ifdef CONFIG_BSP_SDH_SDCARD
|
|
void board_sdh_gpio_init(void)
|
|
{
|
|
struct bflb_device_s *gpio;
|
|
|
|
gpio = bflb_device_get_by_name("gpio");
|
|
bflb_gpio_init(gpio, GPIO_PIN_0, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2);
|
|
bflb_gpio_init(gpio, GPIO_PIN_1, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2);
|
|
bflb_gpio_init(gpio, GPIO_PIN_2, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2);
|
|
bflb_gpio_init(gpio, GPIO_PIN_3, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2);
|
|
bflb_gpio_init(gpio, GPIO_PIN_4, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2);
|
|
bflb_gpio_init(gpio, GPIO_PIN_5, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2);
|
|
|
|
/* config sdh clock */
|
|
SDH_ClockSet(400000, 96000000, 48000000);
|
|
|
|
#ifdef CONFIG_BSP_FATFS_SDH_SDCARD
|
|
extern void fatfs_sdh_driver_register(void);
|
|
fatfs_sdh_driver_register();
|
|
#endif
|
|
}
|
|
|
|
#endif
|
|
|
|
#ifdef CONFIG_BFLOG
|
|
__attribute__((weak)) uint64_t bflog_clock(void)
|
|
{
|
|
return CPU_Get_MTimer_Counter();
|
|
}
|
|
|
|
__attribute__((weak)) uint32_t bflog_time(void)
|
|
{
|
|
return BFLB_RTC_TIME2SEC(bflb_rtc_get_time(rtc));
|
|
}
|
|
|
|
__attribute__((weak)) char *bflog_thread(void)
|
|
{
|
|
return "";
|
|
}
|
|
#endif
|
|
|
|
#ifdef CONFIG_LUA
|
|
clock_t luaport_clock(void)
|
|
{
|
|
return (clock_t)CPU_Get_MTimer_Counter();
|
|
}
|
|
|
|
time_t luaport_time(time_t *seconds)
|
|
{
|
|
time_t t = (time_t)BFLB_RTC_TIME2SEC(bflb_rtc_get_time(rtc));
|
|
if (seconds != NULL) {
|
|
*seconds = t;
|
|
}
|
|
|
|
return t;
|
|
}
|
|
#endif |