#include "bflb_uart.h" #include "bflb_gpio.h" #include "bflb_clock.h" #include "bflb_rtc.h" #include "bflb_flash.h" #ifdef CONFIG_TLSF #include "bflb_tlsf.h" #else #include "bflb_mmheap.h" #endif #include "board.h" #include "bl616_tzc_sec.h" #include "bl616_psram.h" #include "bl616_glb.h" #include "bl616_sflash.h" #define WB_4MB_PSRAM (1) #ifdef CONFIG_BSP_SDH_SDCARD #include "sdh_sdcard.h" #endif extern uint32_t __HeapBase; extern uint32_t __HeapLimit; #ifndef CONFIG_TLSF struct heap_info mmheap_root; static struct heap_region system_mmheap[] = { { NULL, 0 }, { NULL, 0 }, /* Terminates the array. */ }; #endif static struct bflb_device_s *uart0; #if (defined(CONFIG_LUA) || defined(CONFIG_BFLOG) || defined(CONFIG_FATFS)) static struct bflb_device_s *rtc; #endif static void system_clock_init(void) { /* wifipll/audiopll */ GLB_Power_On_XTAL_And_PLL_CLK(GLB_XTAL_40M, GLB_PLL_WIFIPLL | GLB_PLL_AUPLL); GLB_Set_MCU_System_CLK(GLB_MCU_SYS_CLK_TOP_WIFIPLL_320M); CPU_Set_MTimer_CLK(ENABLE, BL_MTIMER_SOURCE_CLOCK_MCU_CLK, Clock_System_Clock_Get(BL_SYSTEM_CLOCK_MCU_CLK) / 1000000 - 1); } 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_ENABLE(); PERIPHERAL_CLOCK_I2C0_ENABLE(); PERIPHERAL_CLOCK_PWM0_ENABLE(); PERIPHERAL_CLOCK_TIMER0_1_WDG_ENABLE(); PERIPHERAL_CLOCK_IR_ENABLE(); PERIPHERAL_CLOCK_I2S_ENABLE(); PERIPHERAL_CLOCK_USB_ENABLE(); PERIPHERAL_CLOCK_CAN_ENABLE(); GLB_Set_UART_CLK(ENABLE, HBN_UART_CLK_XCLK, 0); GLB_Set_SPI_CLK(ENABLE, GLB_SPI_CLK_MCU_MUXPLL_160M, 0); GLB_Set_I2C_CLK(ENABLE, GLB_I2C_CLK_XCLK, 0); GLB_Set_ADC_CLK(ENABLE, GLB_ADC_CLK_XCLK, 1); GLB_Set_DIG_CLK_Sel(GLB_DIG_CLK_XCLK); GLB_Set_DIG_512K_CLK(ENABLE, ENABLE, 0x4E); GLB_Set_PWM1_IO_Sel(GLB_PWM1_IO_DIFF_END); GLB_Set_IR_CLK(ENABLE, GLB_IR_CLK_SRC_XCLK, 19); GLB_Set_CAM_CLK(ENABLE, GLB_CAM_CLK_WIFIPLL_96M, 3); GLB_Set_PKA_CLK_Sel(GLB_PKA_CLK_MCU_MUXPLL_160M); #ifdef CONFIG_BSP_SDH_SDCARD PERIPHERAL_CLOCK_SDH_ENABLE(); GLB_AHB_MCU_Software_Reset(GLB_AHB_MCU_SW_EXT_SDH); #endif GLB_Set_USB_CLK_From_WIFIPLL(1); GLB_Swap_MCU_SPI_0_MOSI_With_MISO(0); } static void bflb_init_psram_gpio(void) { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); for (uint8_t i = 0; i < 12; i++) { bflb_gpio_init(gpio, (41 + i), GPIO_INPUT | GPIO_FLOAT | GPIO_SMT_EN | GPIO_DRV_0); } } static void psram_winbond_default_init(void) { PSRAM_Ctrl_Cfg_Type default_psram_ctrl_cfg = { .vendor = PSRAM_CTRL_VENDOR_WINBOND, .ioMode = PSRAM_CTRL_X8_MODE, .size = PSRAM_SIZE_4MB, .dqs_delay = 0xfff0, }; PSRAM_Winbond_Cfg_Type default_winbond_cfg = { .rst = DISABLE, .clockType = PSRAM_CLOCK_DIFF, .inputPowerDownMode = DISABLE, .hybridSleepMode = DISABLE, .linear_dis = ENABLE, .PASR = PSRAM_PARTIAL_REFRESH_FULL, .disDeepPowerDownMode = ENABLE, .fixedLatency = DISABLE, .brustLen = PSRAM_WINBOND_BURST_LENGTH_32_BYTES, .brustType = PSRAM_WRAPPED_BURST, .latency = PSRAM_WINBOND_6_CLOCKS_LATENCY, .driveStrength = PSRAM_WINBOND_DRIVE_STRENGTH_35_OHMS_FOR_4M_115_OHMS_FOR_8M, }; PSram_Ctrl_Init(PSRAM0_ID, &default_psram_ctrl_cfg); // PSram_Ctrl_Winbond_Reset(PSRAM0_ID); PSram_Ctrl_Winbond_Write_Reg(PSRAM0_ID, PSRAM_WINBOND_REG_CR0, &default_winbond_cfg); } uint32_t board_psram_x8_init(void) { uint16_t reg_read = 0; GLB_Set_PSRAMB_CLK_Sel(ENABLE, GLB_PSRAMB_EMI_WIFIPLL_320M, 0); bflb_init_psram_gpio(); /* psram init*/ psram_winbond_default_init(); /* check psram work or not */ PSram_Ctrl_Winbond_Read_Reg(PSRAM0_ID, PSRAM_WINBOND_REG_ID0, ®_read); return reg_read; } 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"); } void bl_show_flashinfo(void) { SPI_Flash_Cfg_Type flashCfg; uint8_t *pFlashCfg = NULL; uint32_t flashCfgLen = 0; uint32_t flashJedecId = 0; flashJedecId = bflb_flash_get_jedec_id(); bflb_flash_get_cfg(&pFlashCfg, &flashCfgLen); arch_memcpy((void *)&flashCfg, pFlashCfg, flashCfgLen); printf("=========== flash cfg ==============\r\n"); printf("jedec id 0x%06X\r\n", flashJedecId); printf("mid 0x%02X\r\n", flashCfg.mid); printf("iomode 0x%02X\r\n", flashCfg.ioMode); printf("clk delay 0x%02X\r\n", flashCfg.clkDelay); printf("clk invert 0x%02X\r\n", flashCfg.clkInvert); printf("read reg cmd0 0x%02X\r\n", flashCfg.readRegCmd[0]); printf("read reg cmd1 0x%02X\r\n", flashCfg.readRegCmd[1]); printf("write reg cmd0 0x%02X\r\n", flashCfg.writeRegCmd[0]); printf("write reg cmd1 0x%02X\r\n", flashCfg.writeRegCmd[1]); printf("qe write len 0x%02X\r\n", flashCfg.qeWriteRegLen); printf("cread support 0x%02X\r\n", flashCfg.cReadSupport); printf("cread code 0x%02X\r\n", flashCfg.cReadMode); printf("burst wrap cmd 0x%02X\r\n", flashCfg.burstWrapCmd); printf("=====================================\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_21, GPIO_UART_FUNC_UART0_TX); bflb_gpio_uart_init(gpio, GPIO_PIN_22, 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) { uintptr_t flag; flag = bflb_irq_save(); bflb_flash_init(); system_clock_init(); peripheral_clock_init(); bflb_irq_initialize(); bflb_irq_restore(flag); #ifdef CONFIG_TLSF bflb_mmheap_init((void *)&__HeapBase, ((size_t)&__HeapLimit - (size_t)&__HeapBase)); #else 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) { bflb_mmheap_init(&mmheap_root, system_mmheap); } #endif console_init(); bl_show_log(); bl_show_flashinfo(); printf("dynamic memory init success,heap size = %d Kbyte \r\n", ((size_t)&__HeapLimit - (size_t)&__HeapBase) / 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)); printf("cgen1:%08x\r\n", getreg32(BFLB_GLB_CGEN1_BASE)); #if (defined(CONFIG_LUA) || defined(CONFIG_BFLOG) || defined(CONFIG_FATFS)) rtc = bflb_device_get_by_name("rtc"); #endif #ifdef CONFIG_PSRAM board_psram_x8_init(); Tzc_Sec_PSRAMB_Access_Release(); #endif } void board_uartx_gpio_init() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); bflb_gpio_uart_init(gpio, GPIO_PIN_23, GPIO_UART_FUNC_UART1_TX); bflb_gpio_uart_init(gpio, GPIO_PIN_24, GPIO_UART_FUNC_UART1_RX); bflb_gpio_uart_init(gpio, GPIO_PIN_25, GPIO_UART_FUNC_UART1_CTS); bflb_gpio_uart_init(gpio, GPIO_PIN_26, GPIO_UART_FUNC_UART1_RTS); } void board_i2c0_gpio_init() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); /* I2C0_SDA */ bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* I2C0_SCL */ 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() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); /* spi cs */ bflb_gpio_init(gpio, GPIO_PIN_12, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* spi clk */ bflb_gpio_init(gpio, GPIO_PIN_13, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* spi miso */ bflb_gpio_init(gpio, GPIO_PIN_18, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* spi mosi */ bflb_gpio_init(gpio, GPIO_PIN_19, GPIO_FUNC_SPI0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); } void board_pwm_gpio_init() { 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() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); /* ADC_CH0 */ bflb_gpio_init(gpio, GPIO_PIN_20, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); /* ADC_CH8 */ bflb_gpio_init(gpio, GPIO_PIN_1, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); /* ADC_CH9 */ bflb_gpio_init(gpio, GPIO_PIN_0, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); /* ADC_CH10 */ bflb_gpio_init(gpio, GPIO_PIN_27, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); /* ADC_CH11 */ bflb_gpio_init(gpio, GPIO_PIN_28, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); } void board_dac_gpio_init() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); /* DAC_CHA */ bflb_gpio_init(gpio, GPIO_PIN_3, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); /* DAC_CHB */ bflb_gpio_init(gpio, GPIO_PIN_2, GPIO_ANALOG | GPIO_SMT_EN | GPIO_DRV_0); } void board_emac_gpio_init() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); 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); bflb_gpio_init(gpio, GPIO_PIN_34, GPIO_FUNC_EMAC | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); #if defined(BL616) GLB_Config_AUDIO_PLL_To_400M(); // GLB_PER_Clock_UnGate(GLB_AHB_CLOCK_IP_EMAC); #endif } void board_sdh_gpio_init() { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); bflb_gpio_init(gpio, GPIO_PIN_10, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2); bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2); bflb_gpio_init(gpio, GPIO_PIN_12, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2); bflb_gpio_init(gpio, GPIO_PIN_13, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2); bflb_gpio_init(gpio, GPIO_PIN_14, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2); bflb_gpio_init(gpio, GPIO_PIN_15, GPIO_FUNC_SDH | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_2); } void board_ir_gpio_init(void) { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); bflb_gpio_init(gpio, GPIO_PIN_10, GPIO_INPUT | GPIO_SMT_EN | GPIO_DRV_0); GLB_IR_RX_GPIO_Sel(GLB_GPIO_PIN_10); } void board_dvp_gpio_init(void) { struct bflb_device_s *gpio; gpio = bflb_device_get_by_name("gpio"); #if 0 /* DVP0 GPIO init */ /* I2C GPIO */ bflb_gpio_init(gpio, GPIO_PIN_0, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_1, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* Power down GPIO */ bflb_gpio_init(gpio, GPIO_PIN_2, GPIO_OUTPUT | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_reset(gpio, GPIO_PIN_2); /* Reset GPIO */ bflb_gpio_init(gpio, GPIO_PIN_3, GPIO_OUTPUT | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_set(gpio, GPIO_PIN_3); /* MCLK GPIO */ bflb_gpio_init(gpio, GPIO_PIN_23, GPIO_FUNC_CLKOUT | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* DVP0 GPIO */ bflb_gpio_init(gpio, GPIO_PIN_24, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_25, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_26, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_27, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_28, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_29, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_30, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_31, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_32, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_33, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_34, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); #else /* DVP1 GPIO init */ /* I2C GPIO */ bflb_gpio_init(gpio, GPIO_PIN_28, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_27, GPIO_FUNC_I2C0 | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* Power down GPIO */ bflb_gpio_init(gpio, GPIO_PIN_29, GPIO_OUTPUT | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_reset(gpio, GPIO_PIN_29); /* Reset GPIO */ bflb_gpio_init(gpio, GPIO_PIN_30, GPIO_OUTPUT | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_set(gpio, GPIO_PIN_30); /* MCLK GPIO */ bflb_gpio_init(gpio, GPIO_PIN_20, GPIO_FUNC_CLKOUT | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); /* DVP1 GPIO */ bflb_gpio_init(gpio, GPIO_PIN_0, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_1, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_3, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_10, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_11, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_12, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_13, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_14, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_15, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_16, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); bflb_gpio_init(gpio, GPIO_PIN_17, GPIO_FUNC_CAM | GPIO_ALTERNATE | GPIO_PULLUP | GPIO_SMT_EN | GPIO_DRV_1); #endif } void board_iso11898_gpio_init() { // struct bflb_device_s *gpio; // gpio = bflb_device_get_by_name("gpio"); } #ifdef CONFIG_BFLOG __attribute__((weak)) uint64_t bflog_clock(void) { return bflb_mtimer_get_time_us(); } __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 __attribute__((weak)) clock_t luaport_clock(void) { return (clock_t)bflb_mtimer_get_time_us(); } __attribute__((weak)) 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 #ifdef CONFIG_FATFS #include "bflb_timestamp.h" __attribute__((weak)) uint32_t get_fattime(void) { bflb_timestamp_t tm; bflb_timestamp_utc2time(BFLB_RTC_TIME2SEC(bflb_rtc_get_time(rtc)), &tm); return ((uint32_t)(tm.year - 1980) << 25) /* Year 2015 */ | ((uint32_t)tm.mon << 21) /* Month 1 */ | ((uint32_t)tm.mday << 16) /* Mday 1 */ | ((uint32_t)tm.hour << 11) /* Hour 0 */ | ((uint32_t)tm.min << 5) /* Min 0 */ | ((uint32_t)tm.sec >> 1); /* Sec 0 */ } #endif