diff options
-rw-r--r-- | bsps/riscv/riscv/clock/clockdrv.c | 12 | ||||
-rw-r--r-- | cpukit/score/cpu/riscv/Makefile.am | 1 | ||||
-rw-r--r-- | cpukit/score/cpu/riscv/include/rtems/score/cpu.h | 17 |
3 files changed, 18 insertions, 12 deletions
diff --git a/bsps/riscv/riscv/clock/clockdrv.c b/bsps/riscv/riscv/clock/clockdrv.c index 6a5d2dbfcd..d2d7a406a0 100644 --- a/bsps/riscv/riscv/clock/clockdrv.c +++ b/bsps/riscv/riscv/clock/clockdrv.c @@ -87,11 +87,6 @@ static uint32_t riscv_clock_get_timecount(struct timecounter *tc) return clint->mtime.val_32[0]; } -CPU_Counter_ticks _CPU_Counter_read(void) -{ - return riscv_clock_get_timecount(NULL); -} - static uint32_t riscv_clock_get_timebase_frequency(const void *fdt) { int node; @@ -131,12 +126,9 @@ static void riscv_clock_initialize(void) rtems_timecounter_install(&riscv_clock_tc); } -CPU_Counter_ticks _CPU_Counter_difference( - CPU_Counter_ticks second, - CPU_Counter_ticks first -) +uint32_t _CPU_Counter_frequency( void ) { - return second - first; + return riscv_clock_get_timebase_frequency(bsp_fdt_get()); } #define Clock_driver_support_at_tick() riscv_clock_at_tick() diff --git a/cpukit/score/cpu/riscv/Makefile.am b/cpukit/score/cpu/riscv/Makefile.am index e7714686f2..3630c038a7 100644 --- a/cpukit/score/cpu/riscv/Makefile.am +++ b/cpukit/score/cpu/riscv/Makefile.am @@ -2,7 +2,6 @@ include $(top_srcdir)/automake/compile.am noinst_LIBRARIES = libscorecpu.a libscorecpu_a_CPPFLAGS = $(AM_CPPFLAGS) libscorecpu_a_SOURCES = cpu.c -libscorecpu_a_SOURCES += ../no_cpu/cpucounterfrequency.c libscorecpu_a_SOURCES += riscv-exception-handler.S libscorecpu_a_SOURCES += riscv-exception-default.c libscorecpu_a_SOURCES += riscv-exception-frame-print.c diff --git a/cpukit/score/cpu/riscv/include/rtems/score/cpu.h b/cpukit/score/cpu/riscv/include/rtems/score/cpu.h index e79ce25510..f84395c638 100644 --- a/cpukit/score/cpu/riscv/include/rtems/score/cpu.h +++ b/cpukit/score/cpu/riscv/include/rtems/score/cpu.h @@ -370,7 +370,22 @@ typedef uint32_t CPU_Counter_ticks; uint32_t _CPU_Counter_frequency( void ); -CPU_Counter_ticks _CPU_Counter_read( void ); +static inline CPU_Counter_ticks _CPU_Counter_read( void ) +{ + unsigned long ticks; + + __asm__ volatile ( "rdtime %0" : "=&r" ( ticks ) ); + + return (uint32_t) ticks; +} + +static inline CPU_Counter_ticks _CPU_Counter_difference( + CPU_Counter_ticks second, + CPU_Counter_ticks first +) +{ + return second - first; +} #ifdef RTEMS_SMP |