xref: /nrf52832-nimble/packages/NimBLE-latest/porting/nimble/src/os_cputime.c (revision 042d53a763ad75cb1465103098bb88c245d95138)
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