mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-27 01:27:40 +08:00
65ffe4e13e
The changes unify the tick.c implementations for all risc-v64 architectures, leveraging the CPUTIME feature. This refactoring was necessary to streamline the codebase, and ensure consistent timer handling across different platforms. Changes: - Updated `Kconfig` in `bsp/cvitek/cv18xx_risc-v` to fix formatting issues. - Updated .config for BSPs to update `CPUTIME_TIMER_FREQ` - Updated header of for API `riscv_cputime_init` - Initialized riscv timer on `rt_hw_tick_init` - Refactored `tick.c` and `tick.h` in `libcpu/risc-v/t-head/c906` and `libcpu/risc-v/virt64`: - Replaced direct use of `rdtime` with `clock_cpu_gettime`. - Removed redundant timer frequency definitions. - Added static assertions to check the value of `CPUTIME_TIMER_FREQ`. - Initialized `tick_cycles` based on `CPUTIME_TIMER_FREQ`. - Integrated `ktime` support for tick initialization. Signed-off-by: Shell <smokewood@qq.com> Reviewed-on: https://github.com/RT-Thread/rt-thread/pull/9164 Reviewed-by: Chen Wang <unicorn_wang@outlook.com>
535 lines
11 KiB
C
535 lines
11 KiB
C
#ifndef RT_CONFIG_H__
|
|
#define RT_CONFIG_H__
|
|
|
|
/* RT-Thread Kernel */
|
|
|
|
#define RT_NAME_MAX 20
|
|
#define RT_USING_SMART
|
|
#define RT_CPUS_NR 1
|
|
#define RT_ALIGN_SIZE 8
|
|
#define RT_THREAD_PRIORITY_32
|
|
#define RT_THREAD_PRIORITY_MAX 32
|
|
#define RT_TICK_PER_SECOND 100
|
|
#define RT_USING_HOOK
|
|
#define RT_HOOK_USING_FUNC_PTR
|
|
#define RT_USING_IDLE_HOOK
|
|
#define RT_IDLE_HOOK_LIST_SIZE 4
|
|
#define IDLE_THREAD_STACK_SIZE 16384
|
|
#define RT_USING_TIMER_SOFT
|
|
#define RT_TIMER_THREAD_PRIO 4
|
|
#define RT_TIMER_THREAD_STACK_SIZE 16384
|
|
#define RT_USING_CPU_USAGE_TRACER
|
|
|
|
/* kservice optimization */
|
|
|
|
/* end of kservice optimization */
|
|
|
|
/* klibc optimization */
|
|
|
|
#define RT_KLIBC_USING_PRINTF_LONGLONG
|
|
/* end of klibc optimization */
|
|
#define RT_USING_DEBUG
|
|
#define RT_DEBUGING_ASSERT
|
|
#define RT_DEBUGING_COLOR
|
|
#define RT_DEBUGING_CONTEXT
|
|
|
|
/* Inter-Thread communication */
|
|
|
|
#define RT_USING_SEMAPHORE
|
|
#define RT_USING_MUTEX
|
|
#define RT_USING_EVENT
|
|
#define RT_USING_MAILBOX
|
|
#define RT_USING_MESSAGEQUEUE
|
|
/* end of Inter-Thread communication */
|
|
|
|
/* Memory Management */
|
|
|
|
#define RT_PAGE_MAX_ORDER 11
|
|
#define RT_USING_MEMHEAP
|
|
#define RT_MEMHEAP_FAST_MODE
|
|
#define RT_USING_MEMHEAP_AS_HEAP
|
|
#define RT_USING_MEMHEAP_AUTO_BINDING
|
|
#define RT_USING_MEMTRACE
|
|
#define RT_USING_HEAP
|
|
/* end of Memory Management */
|
|
#define RT_USING_DEVICE
|
|
#define RT_USING_DEVICE_OPS
|
|
#define RT_USING_SCHED_THREAD_CTX
|
|
#define RT_USING_CONSOLE
|
|
#define RT_CONSOLEBUF_SIZE 256
|
|
#define RT_CONSOLE_DEVICE_NAME "uart0"
|
|
#define RT_VER_NUM 0x50200
|
|
#define RT_USING_STDC_ATOMIC
|
|
#define RT_BACKTRACE_LEVEL_MAX_NR 32
|
|
/* end of RT-Thread Kernel */
|
|
#define ARCH_CPU_64BIT
|
|
#define RT_USING_CACHE
|
|
#define ARCH_MM_MMU
|
|
#define KERNEL_VADDR_START 0x40000000
|
|
#define ARCH_RISCV
|
|
#define ARCH_RISCV64
|
|
#define ARCH_USING_RISCV_COMMON64
|
|
|
|
/* RT-Thread Components */
|
|
|
|
#define RT_USING_COMPONENTS_INIT
|
|
#define RT_USING_USER_MAIN
|
|
#define RT_MAIN_THREAD_STACK_SIZE 16384
|
|
#define RT_MAIN_THREAD_PRIORITY 10
|
|
#define RT_USING_MSH
|
|
#define RT_USING_FINSH
|
|
#define FINSH_USING_MSH
|
|
#define FINSH_THREAD_NAME "tshell"
|
|
#define FINSH_THREAD_PRIORITY 20
|
|
#define FINSH_THREAD_STACK_SIZE 8192
|
|
#define FINSH_USING_HISTORY
|
|
#define FINSH_HISTORY_LINES 5
|
|
#define FINSH_USING_SYMTAB
|
|
#define FINSH_CMD_SIZE 80
|
|
#define MSH_USING_BUILT_IN_COMMANDS
|
|
#define FINSH_USING_DESCRIPTION
|
|
#define FINSH_ARG_MAX 10
|
|
#define FINSH_USING_OPTION_COMPLETION
|
|
|
|
/* DFS: device virtual file system */
|
|
|
|
#define RT_USING_DFS
|
|
#define DFS_USING_POSIX
|
|
#define DFS_USING_WORKDIR
|
|
#define DFS_FD_MAX 32
|
|
#define RT_USING_DFS_V2
|
|
#define RT_USING_DFS_ELMFAT
|
|
|
|
/* elm-chan's FatFs, Generic FAT Filesystem Module */
|
|
|
|
#define RT_DFS_ELM_CODE_PAGE 936
|
|
#define RT_DFS_ELM_WORD_ACCESS
|
|
#define RT_DFS_ELM_USE_LFN_3
|
|
#define RT_DFS_ELM_USE_LFN 3
|
|
#define RT_DFS_ELM_LFN_UNICODE_0
|
|
#define RT_DFS_ELM_LFN_UNICODE 0
|
|
#define RT_DFS_ELM_MAX_LFN 255
|
|
#define RT_DFS_ELM_DRIVES 8
|
|
#define RT_DFS_ELM_MAX_SECTOR_SIZE 512
|
|
#define RT_DFS_ELM_REENTRANT
|
|
#define RT_DFS_ELM_MUTEX_TIMEOUT 3000
|
|
/* end of elm-chan's FatFs, Generic FAT Filesystem Module */
|
|
#define RT_USING_DFS_DEVFS
|
|
#define RT_USING_DFS_PTYFS
|
|
#define RT_USING_DFS_TMPFS
|
|
#define RT_USING_PAGECACHE
|
|
|
|
/* page cache config */
|
|
|
|
#define RT_PAGECACHE_COUNT 4096
|
|
#define RT_PAGECACHE_ASPACE_COUNT 1024
|
|
#define RT_PAGECACHE_PRELOAD 4
|
|
#define RT_PAGECACHE_HASH_NR 1024
|
|
#define RT_PAGECACHE_GC_WORK_LEVEL 90
|
|
#define RT_PAGECACHE_GC_STOP_LEVEL 70
|
|
/* end of page cache config */
|
|
/* end of DFS: device virtual file system */
|
|
#define RT_USING_FAL
|
|
#define FAL_DEBUG_CONFIG
|
|
#define FAL_DEBUG 1
|
|
#define FAL_PART_HAS_TABLE_CFG
|
|
|
|
/* Device Drivers */
|
|
|
|
#define RT_USING_DEV_BUS
|
|
#define RT_USING_DEVICE_IPC
|
|
#define RT_UNAMED_PIPE_NUMBER 64
|
|
#define RT_USING_SYSTEM_WORKQUEUE
|
|
#define RT_SYSTEM_WORKQUEUE_STACKSIZE 16384
|
|
#define RT_SYSTEM_WORKQUEUE_PRIORITY 23
|
|
#define RT_USING_SERIAL
|
|
#define RT_USING_SERIAL_V2
|
|
#define RT_USING_CPUTIME
|
|
#define RT_USING_CPUTIME_RISCV
|
|
#define CPUTIME_TIMER_FREQ 24000000
|
|
#define RT_USING_NULL
|
|
#define RT_USING_ZERO
|
|
#define RT_USING_RANDOM
|
|
#define RT_USING_RTC
|
|
#define RT_USING_WDT
|
|
#define RT_USING_PIN
|
|
#define RT_USING_KTIME
|
|
/* end of Device Drivers */
|
|
|
|
/* C/C++ and POSIX layer */
|
|
|
|
/* ISO-ANSI C layer */
|
|
|
|
/* Timezone and Daylight Saving Time */
|
|
|
|
#define RT_LIBC_USING_LIGHT_TZ_DST
|
|
#define RT_LIBC_TZ_DEFAULT_HOUR 8
|
|
#define RT_LIBC_TZ_DEFAULT_MIN 0
|
|
#define RT_LIBC_TZ_DEFAULT_SEC 0
|
|
/* end of Timezone and Daylight Saving Time */
|
|
/* end of ISO-ANSI C layer */
|
|
|
|
/* POSIX (Portable Operating System Interface) layer */
|
|
|
|
#define RT_USING_POSIX_FS
|
|
#define RT_USING_POSIX_DEVIO
|
|
#define RT_USING_POSIX_STDIO
|
|
#define RT_USING_POSIX_POLL
|
|
#define RT_USING_POSIX_SELECT
|
|
#define RT_USING_POSIX_TERMIOS
|
|
#define RT_USING_POSIX_DELAY
|
|
#define RT_USING_POSIX_CLOCK
|
|
#define RT_USING_POSIX_TIMER
|
|
|
|
/* Interprocess Communication (IPC) */
|
|
|
|
#define RT_USING_POSIX_PIPE
|
|
#define RT_USING_POSIX_PIPE_SIZE 512
|
|
|
|
/* Socket is in the 'Network' category */
|
|
|
|
/* end of Interprocess Communication (IPC) */
|
|
/* end of POSIX (Portable Operating System Interface) layer */
|
|
/* end of C/C++ and POSIX layer */
|
|
|
|
/* Network */
|
|
|
|
/* end of Network */
|
|
|
|
/* Memory protection */
|
|
|
|
/* end of Memory protection */
|
|
|
|
/* Utilities */
|
|
|
|
#define RT_USING_RESOURCE_ID
|
|
#define RT_USING_ADT
|
|
#define RT_USING_ADT_AVL
|
|
#define RT_USING_ADT_BITMAP
|
|
#define RT_USING_ADT_HASHMAP
|
|
#define RT_USING_ADT_REF
|
|
/* end of Utilities */
|
|
#define RT_USING_LWP
|
|
#define RT_LWP_MAX_NR 30
|
|
#define LWP_TASK_STACK_SIZE 16384
|
|
#define RT_CH_MSG_MAX_NR 1024
|
|
#define LWP_CONSOLE_INPUT_BUFFER_SIZE 1024
|
|
#define LWP_TID_MAX_NR 64
|
|
#define RT_LWP_SHM_MAX_NR 64
|
|
#define RT_USING_LDSO
|
|
#define LWP_USING_TERMINAL
|
|
#define LWP_PTY_MAX_PARIS_LIMIT 64
|
|
|
|
/* Memory management */
|
|
|
|
/* end of Memory management */
|
|
|
|
/* Using USB legacy version */
|
|
|
|
/* end of Using USB legacy version */
|
|
/* end of RT-Thread Components */
|
|
|
|
/* RT-Thread Utestcases */
|
|
|
|
/* end of RT-Thread Utestcases */
|
|
|
|
/* RT-Thread online packages */
|
|
|
|
/* IoT - internet of things */
|
|
|
|
|
|
/* Wi-Fi */
|
|
|
|
/* Marvell WiFi */
|
|
|
|
/* end of Marvell WiFi */
|
|
|
|
/* Wiced WiFi */
|
|
|
|
/* end of Wiced WiFi */
|
|
|
|
/* CYW43012 WiFi */
|
|
|
|
/* end of CYW43012 WiFi */
|
|
|
|
/* BL808 WiFi */
|
|
|
|
/* end of BL808 WiFi */
|
|
|
|
/* CYW43439 WiFi */
|
|
|
|
/* end of CYW43439 WiFi */
|
|
/* end of Wi-Fi */
|
|
|
|
/* IoT Cloud */
|
|
|
|
/* end of IoT Cloud */
|
|
/* end of IoT - internet of things */
|
|
|
|
/* security packages */
|
|
|
|
/* end of security packages */
|
|
|
|
/* language packages */
|
|
|
|
/* JSON: JavaScript Object Notation, a lightweight data-interchange format */
|
|
|
|
/* end of JSON: JavaScript Object Notation, a lightweight data-interchange format */
|
|
|
|
/* XML: Extensible Markup Language */
|
|
|
|
/* end of XML: Extensible Markup Language */
|
|
/* end of language packages */
|
|
|
|
/* multimedia packages */
|
|
|
|
/* LVGL: powerful and easy-to-use embedded GUI library */
|
|
|
|
/* end of LVGL: powerful and easy-to-use embedded GUI library */
|
|
|
|
/* u8g2: a monochrome graphic library */
|
|
|
|
/* end of u8g2: a monochrome graphic library */
|
|
/* end of multimedia packages */
|
|
|
|
/* tools packages */
|
|
|
|
/* end of tools packages */
|
|
|
|
/* system packages */
|
|
|
|
/* enhanced kernel services */
|
|
|
|
/* end of enhanced kernel services */
|
|
|
|
/* acceleration: Assembly language or algorithmic acceleration packages */
|
|
|
|
/* end of acceleration: Assembly language or algorithmic acceleration packages */
|
|
|
|
/* CMSIS: ARM Cortex-M Microcontroller Software Interface Standard */
|
|
|
|
/* end of CMSIS: ARM Cortex-M Microcontroller Software Interface Standard */
|
|
|
|
/* Micrium: Micrium software products porting for RT-Thread */
|
|
|
|
/* end of Micrium: Micrium software products porting for RT-Thread */
|
|
/* end of system packages */
|
|
|
|
/* peripheral libraries and drivers */
|
|
|
|
/* HAL & SDK Drivers */
|
|
|
|
/* STM32 HAL & SDK Drivers */
|
|
|
|
/* end of STM32 HAL & SDK Drivers */
|
|
|
|
/* Infineon HAL Packages */
|
|
|
|
/* end of Infineon HAL Packages */
|
|
|
|
/* Kendryte SDK */
|
|
|
|
/* end of Kendryte SDK */
|
|
/* end of HAL & SDK Drivers */
|
|
|
|
/* sensors drivers */
|
|
|
|
/* end of sensors drivers */
|
|
|
|
/* touch drivers */
|
|
|
|
/* end of touch drivers */
|
|
/* end of peripheral libraries and drivers */
|
|
|
|
/* AI packages */
|
|
|
|
/* end of AI packages */
|
|
|
|
/* Signal Processing and Control Algorithm Packages */
|
|
|
|
/* end of Signal Processing and Control Algorithm Packages */
|
|
|
|
/* miscellaneous packages */
|
|
|
|
/* project laboratory */
|
|
|
|
/* end of project laboratory */
|
|
|
|
/* samples: kernel and components samples */
|
|
|
|
/* end of samples: kernel and components samples */
|
|
|
|
/* entertainment: terminal games and other interesting software packages */
|
|
|
|
/* end of entertainment: terminal games and other interesting software packages */
|
|
/* end of miscellaneous packages */
|
|
|
|
/* Arduino libraries */
|
|
|
|
|
|
/* Projects and Demos */
|
|
|
|
/* end of Projects and Demos */
|
|
|
|
/* Sensors */
|
|
|
|
/* end of Sensors */
|
|
|
|
/* Display */
|
|
|
|
/* end of Display */
|
|
|
|
/* Timing */
|
|
|
|
/* end of Timing */
|
|
|
|
/* Data Processing */
|
|
|
|
/* end of Data Processing */
|
|
|
|
/* Data Storage */
|
|
|
|
/* Communication */
|
|
|
|
/* end of Communication */
|
|
|
|
/* Device Control */
|
|
|
|
/* end of Device Control */
|
|
|
|
/* Other */
|
|
|
|
/* end of Other */
|
|
|
|
/* Signal IO */
|
|
|
|
/* end of Signal IO */
|
|
|
|
/* Uncategorized */
|
|
|
|
/* end of Arduino libraries */
|
|
/* end of RT-Thread online packages */
|
|
|
|
/* Privated Packages of RealThread */
|
|
|
|
|
|
/* Network Utilities */
|
|
|
|
/* end of Network Utilities */
|
|
|
|
/* RT-Thread Smart */
|
|
|
|
/* end of RT-Thread Smart */
|
|
/* end of Privated Packages of RealThread */
|
|
#define BOARD_allwinnerd1s
|
|
#define __STACKSIZE__ 16384
|
|
|
|
/* General Drivers Configuration */
|
|
|
|
#define BSP_USING_M7
|
|
|
|
/* General Purpose UARTs */
|
|
|
|
#define BSP_USING_UART0
|
|
#define UART0_TX_USING_GPIOE2
|
|
#define UART0_RX_USING_GPIOE3
|
|
/* end of General Purpose UARTs */
|
|
#define BSP_USING_SDMMC
|
|
#define SD_CARD_CHECK
|
|
#define BSP_USING_FS
|
|
|
|
/* Board extended module Drivers */
|
|
|
|
/* end of Board extended module Drivers */
|
|
/* end of General Drivers Configuration */
|
|
#define RT_USING_SUNXI_HAL
|
|
|
|
/* UART Devices */
|
|
|
|
/* end of UART Devices */
|
|
|
|
/* CCMU Devices */
|
|
|
|
#define DRIVERS_CCMU
|
|
#define DRIVERS_SUNXI_CCU
|
|
/* end of CCMU Devices */
|
|
|
|
/* DMA Devices */
|
|
|
|
#define DRIVERS_DMA
|
|
/* end of DMA Devices */
|
|
|
|
/* GPIO Devices */
|
|
|
|
#define DRIVERS_GPIO
|
|
/* end of GPIO Devices */
|
|
|
|
/* Video support for sunxi */
|
|
|
|
#define DISP2_SUNXI
|
|
#define SUNXI_DISP2_FB_DISABLE_ROTATE
|
|
|
|
/* LCD panels select */
|
|
|
|
#define LCD_SUPPORT_HE0801A068
|
|
#define LCD_SUPPORT_WILLIAMLCD
|
|
#define LCD_SUPPORT_LQ101R1SX03
|
|
#define LCD_SUPPORT_INET_DSI_PANEL
|
|
/* end of LCD panels select */
|
|
|
|
/* Display engine feature select */
|
|
|
|
#define DISP2_SUNXI_SUPPORT_ENAHNCE
|
|
/* end of Display engine feature select */
|
|
|
|
/* Soc and board select */
|
|
|
|
/* Board Select */
|
|
|
|
/* end of Board Select */
|
|
|
|
/* Soc Select */
|
|
|
|
/* end of Soc Select */
|
|
/* end of Soc and board select */
|
|
/* end of Video support for sunxi */
|
|
|
|
/* SDMMC Devices */
|
|
|
|
#define DRIVERS_SDMMC
|
|
#define USE_SD
|
|
#define USE_SDIO
|
|
#define DETECT_CARD
|
|
#define SDC_DMA_USED
|
|
#define SDIO_IRQ_SUPPORT
|
|
#define SDC_DMA_BUF_SIZE 64
|
|
#define DRIVERS_SDC_CDPIN_PRESENT_VAL 0
|
|
/* end of SDMMC Devices */
|
|
|
|
/* SPI Devices */
|
|
|
|
#define DRIVERS_SPI
|
|
/* end of SPI Devices */
|
|
|
|
/* TWI Devices */
|
|
|
|
#define DRIVERS_TWI
|
|
/* end of TWI Devices */
|
|
|
|
/* G2D Devices */
|
|
|
|
#define DRIVERS_G2D
|
|
/* end of G2D Devices */
|
|
|
|
/* CE Devices */
|
|
|
|
#define DRIVERS_CE
|
|
/* end of CE Devices */
|
|
|
|
/* EFUSE Devices */
|
|
|
|
#define DRIVERS_EFUSE
|
|
/* end of EFUSE Devices */
|
|
|
|
#endif
|