1*042d53a7SEvalZero /*
2*042d53a7SEvalZero * Licensed to the Apache Software Foundation (ASF) under one
3*042d53a7SEvalZero * or more contributor license agreements. See the NOTICE file
4*042d53a7SEvalZero * distributed with this work for additional information
5*042d53a7SEvalZero * regarding copyright ownership. The ASF licenses this file
6*042d53a7SEvalZero * to you under the Apache License, Version 2.0 (the
7*042d53a7SEvalZero * "License"); you may not use this file except in compliance
8*042d53a7SEvalZero * with the License. You may obtain a copy of the License at
9*042d53a7SEvalZero *
10*042d53a7SEvalZero * http://www.apache.org/licenses/LICENSE-2.0
11*042d53a7SEvalZero *
12*042d53a7SEvalZero * Unless required by applicable law or agreed to in writing,
13*042d53a7SEvalZero * software distributed under the License is distributed on an
14*042d53a7SEvalZero * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15*042d53a7SEvalZero * KIND, either express or implied. See the License for the
16*042d53a7SEvalZero * specific language governing permissions and limitations
17*042d53a7SEvalZero * under the License.
18*042d53a7SEvalZero */
19*042d53a7SEvalZero
20*042d53a7SEvalZero #include <string.h>
21*042d53a7SEvalZero #include <stdint.h>
22*042d53a7SEvalZero #include <assert.h>
23*042d53a7SEvalZero #include "syscfg/syscfg.h"
24*042d53a7SEvalZero #include "os/os_cputime.h"
25*042d53a7SEvalZero #include "hal/hal_timer.h"
26*042d53a7SEvalZero
27*042d53a7SEvalZero #if defined(OS_CPUTIME_FREQ_HIGH)
28*042d53a7SEvalZero struct os_cputime_data g_os_cputime;
29*042d53a7SEvalZero #endif
30*042d53a7SEvalZero
31*042d53a7SEvalZero int
os_cputime_init(uint32_t clock_freq)32*042d53a7SEvalZero os_cputime_init(uint32_t clock_freq)
33*042d53a7SEvalZero {
34*042d53a7SEvalZero int rc;
35*042d53a7SEvalZero
36*042d53a7SEvalZero /* Set the ticks per microsecond. */
37*042d53a7SEvalZero #if defined(OS_CPUTIME_FREQ_HIGH)
38*042d53a7SEvalZero g_os_cputime.ticks_per_usec = clock_freq / 1000000U;
39*042d53a7SEvalZero #endif
40*042d53a7SEvalZero rc = hal_timer_config(MYNEWT_VAL(OS_CPUTIME_TIMER_NUM), clock_freq);
41*042d53a7SEvalZero return rc;
42*042d53a7SEvalZero }
43*042d53a7SEvalZero
44*042d53a7SEvalZero /**
45*042d53a7SEvalZero * Wait until the number of ticks has elapsed. This is a blocking delay.
46*042d53a7SEvalZero *
47*042d53a7SEvalZero * @param ticks The number of ticks to wait.
48*042d53a7SEvalZero */
49*042d53a7SEvalZero void
os_cputime_delay_ticks(uint32_t ticks)50*042d53a7SEvalZero os_cputime_delay_ticks(uint32_t ticks)
51*042d53a7SEvalZero {
52*042d53a7SEvalZero uint32_t until;
53*042d53a7SEvalZero
54*042d53a7SEvalZero until = os_cputime_get32() + ticks;
55*042d53a7SEvalZero while ((int32_t)(os_cputime_get32() - until) < 0) {
56*042d53a7SEvalZero /* Loop here till finished */
57*042d53a7SEvalZero }
58*042d53a7SEvalZero }
59*042d53a7SEvalZero
60*042d53a7SEvalZero #if !defined(OS_CPUTIME_FREQ_PWR2)
61*042d53a7SEvalZero void
os_cputime_delay_nsecs(uint32_t nsecs)62*042d53a7SEvalZero os_cputime_delay_nsecs(uint32_t nsecs)
63*042d53a7SEvalZero {
64*042d53a7SEvalZero uint32_t ticks;
65*042d53a7SEvalZero
66*042d53a7SEvalZero ticks = os_cputime_nsecs_to_ticks(nsecs);
67*042d53a7SEvalZero os_cputime_delay_ticks(ticks);
68*042d53a7SEvalZero }
69*042d53a7SEvalZero #endif
70*042d53a7SEvalZero
71*042d53a7SEvalZero void
os_cputime_delay_usecs(uint32_t usecs)72*042d53a7SEvalZero os_cputime_delay_usecs(uint32_t usecs)
73*042d53a7SEvalZero {
74*042d53a7SEvalZero uint32_t ticks;
75*042d53a7SEvalZero
76*042d53a7SEvalZero ticks = os_cputime_usecs_to_ticks(usecs);
77*042d53a7SEvalZero os_cputime_delay_ticks(ticks);
78*042d53a7SEvalZero }
79*042d53a7SEvalZero
80*042d53a7SEvalZero void
os_cputime_timer_init(struct hal_timer * timer,hal_timer_cb fp,void * arg)81*042d53a7SEvalZero os_cputime_timer_init(struct hal_timer *timer, hal_timer_cb fp, void *arg)
82*042d53a7SEvalZero {
83*042d53a7SEvalZero assert(timer != NULL);
84*042d53a7SEvalZero assert(fp != NULL);
85*042d53a7SEvalZero
86*042d53a7SEvalZero hal_timer_set_cb(MYNEWT_VAL(OS_CPUTIME_TIMER_NUM), timer, fp, arg);
87*042d53a7SEvalZero }
88*042d53a7SEvalZero
89*042d53a7SEvalZero int
os_cputime_timer_start(struct hal_timer * timer,uint32_t cputime)90*042d53a7SEvalZero os_cputime_timer_start(struct hal_timer *timer, uint32_t cputime)
91*042d53a7SEvalZero {
92*042d53a7SEvalZero int rc;
93*042d53a7SEvalZero
94*042d53a7SEvalZero rc = hal_timer_start_at(timer, cputime);
95*042d53a7SEvalZero return rc;
96*042d53a7SEvalZero }
97*042d53a7SEvalZero
98*042d53a7SEvalZero int
os_cputime_timer_relative(struct hal_timer * timer,uint32_t usecs)99*042d53a7SEvalZero os_cputime_timer_relative(struct hal_timer *timer, uint32_t usecs)
100*042d53a7SEvalZero {
101*042d53a7SEvalZero int rc;
102*042d53a7SEvalZero uint32_t cputime;
103*042d53a7SEvalZero
104*042d53a7SEvalZero assert(timer != NULL);
105*042d53a7SEvalZero
106*042d53a7SEvalZero cputime = os_cputime_get32() + os_cputime_usecs_to_ticks(usecs);
107*042d53a7SEvalZero rc = hal_timer_start_at(timer, cputime);
108*042d53a7SEvalZero
109*042d53a7SEvalZero return rc;
110*042d53a7SEvalZero }
111*042d53a7SEvalZero
112*042d53a7SEvalZero void
os_cputime_timer_stop(struct hal_timer * timer)113*042d53a7SEvalZero os_cputime_timer_stop(struct hal_timer *timer)
114*042d53a7SEvalZero {
115*042d53a7SEvalZero hal_timer_stop(timer);
116*042d53a7SEvalZero }
117*042d53a7SEvalZero
118*042d53a7SEvalZero uint32_t
os_cputime_get32(void)119*042d53a7SEvalZero os_cputime_get32(void)
120*042d53a7SEvalZero {
121*042d53a7SEvalZero uint32_t cpu_time;
122*042d53a7SEvalZero
123*042d53a7SEvalZero cpu_time = hal_timer_read(MYNEWT_VAL(OS_CPUTIME_TIMER_NUM));
124*042d53a7SEvalZero return cpu_time;
125*042d53a7SEvalZero }
126*042d53a7SEvalZero
127