diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2018-05-23 14:17:25 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2018-06-15 13:02:44 +0200 |
commit | 65f868cac6f7fd5c3ad02046574c19f8f4673255 (patch) | |
tree | 15103fb87ed2e7161c17006e2c077f35e3506a95 /bsps/arm/shared/clock/clock-generic-timer.c | |
parent | Add RTEMS_SYSINIT_CPU_COUNTER (diff) | |
download | rtems-65f868cac6f7fd5c3ad02046574c19f8f4673255.tar.bz2 |
Add _CPU_Counter_frequency()
Add rtems_counter_frequency() API function. Use it to initialize the
counter value converter via the new system initialization step
(RTEMS_SYSINIT_CPU_COUNTER). This decouples the counter implementation
and the counter converter. It avoids an unnecessary pull in of the
64-bit integer division from libgcc.
Update #3456.
Diffstat (limited to 'bsps/arm/shared/clock/clock-generic-timer.c')
-rw-r--r-- | bsps/arm/shared/clock/clock-generic-timer.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/bsps/arm/shared/clock/clock-generic-timer.c b/bsps/arm/shared/clock/clock-generic-timer.c index 8a992d44f4..2cb85003e1 100644 --- a/bsps/arm/shared/clock/clock-generic-timer.c +++ b/bsps/arm/shared/clock/clock-generic-timer.c @@ -166,6 +166,11 @@ static void arm_gt_clock_initialize(void) rtems_timecounter_install(tc); } +uint32_t _CPU_Counter_frequency(void) +{ + return arm_gt_clock_instance.interval; +} + CPU_Counter_ticks _CPU_Counter_read(void) { return (uint32_t) arm_gt_clock_get_count(); @@ -179,14 +184,12 @@ static void arm_gt_clock_early_init(void) &arm_gt_clock_instance.interval, &arm_gt_clock_instance.irq ); - - rtems_counter_initialize_converter(arm_gt_clock_instance.interval); } RTEMS_SYSINIT_ITEM( arm_gt_clock_early_init, - RTEMS_SYSINIT_BSP_START, - RTEMS_SYSINIT_ORDER_LAST + RTEMS_SYSINIT_CPU_COUNTER, + RTEMS_SYSINIT_ORDER_FIRST ); #define Clock_driver_support_at_tick() \ |