Angel Pons | bbc99cf | 2020-04-04 18:51:23 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 2 | |
Kyösti Mälkki | 13f6650 | 2019-03-03 08:01:05 +0200 | [diff] [blame] | 3 | #include <device/mmio.h> |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 4 | #include <delay.h> |
Julius Werner | 7a453eb | 2014-10-20 13:14:55 -0700 | [diff] [blame] | 5 | #include <soc/timer.h> |
Julius Werner | 8d978a8 | 2014-12-08 13:16:03 -0800 | [diff] [blame] | 6 | #include <stdint.h> |
Julius Werner | 7a453eb | 2014-10-20 13:14:55 -0700 | [diff] [blame] | 7 | #include <timer.h> |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 8 | |
Julius Werner | 8d978a8 | 2014-12-08 13:16:03 -0800 | [diff] [blame] | 9 | static uint64_t timer_raw_value(void) |
| 10 | { |
| 11 | uint64_t value0; |
| 12 | uint64_t value1; |
| 13 | |
| 14 | value0 = (uint64_t)read32(&timer7_ptr->timer_curr_value0); |
| 15 | value1 = (uint64_t)read32(&timer7_ptr->timer_curr_value1); |
| 16 | value0 = value0 | value1<<32; |
| 17 | return value0; |
| 18 | } |
| 19 | |
| 20 | void timer_monotonic_get(struct mono_time *mt) |
| 21 | { |
| 22 | mono_time_set_usecs(mt, timer_raw_value() / clocks_per_usec); |
| 23 | } |
| 24 | |
Julius Werner | 44cf870 | 2014-12-08 13:39:14 -0800 | [diff] [blame] | 25 | void init_timer(void) |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 26 | { |
Julius Werner | 2f37bd6 | 2015-02-19 14:51:15 -0800 | [diff] [blame] | 27 | write32(&timer7_ptr->timer_load_count0, TIMER_LOAD_VAL); |
| 28 | write32(&timer7_ptr->timer_load_count1, TIMER_LOAD_VAL); |
| 29 | write32(&timer7_ptr->timer_ctrl_reg, 1); |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 30 | } |