xref: /aosp_15_r20/frameworks/av/services/oboeservice/TimestampScheduler.h (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2016 The Android Open Source Project
3*ec779b8eSAndroid Build Coastguard Worker  *
4*ec779b8eSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*ec779b8eSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*ec779b8eSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*ec779b8eSAndroid Build Coastguard Worker  *
8*ec779b8eSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*ec779b8eSAndroid Build Coastguard Worker  *
10*ec779b8eSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*ec779b8eSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*ec779b8eSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*ec779b8eSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*ec779b8eSAndroid Build Coastguard Worker  * limitations under the License.
15*ec779b8eSAndroid Build Coastguard Worker  */
16*ec779b8eSAndroid Build Coastguard Worker 
17*ec779b8eSAndroid Build Coastguard Worker #ifndef AAUDIO_TIMESTAMP_SCHEDULER_H
18*ec779b8eSAndroid Build Coastguard Worker #define AAUDIO_TIMESTAMP_SCHEDULER_H
19*ec779b8eSAndroid Build Coastguard Worker 
20*ec779b8eSAndroid Build Coastguard Worker #include <aaudio/AAudio.h>
21*ec779b8eSAndroid Build Coastguard Worker #include <utility/AudioClock.h>
22*ec779b8eSAndroid Build Coastguard Worker 
23*ec779b8eSAndroid Build Coastguard Worker namespace aaudio {
24*ec779b8eSAndroid Build Coastguard Worker 
25*ec779b8eSAndroid Build Coastguard Worker /**
26*ec779b8eSAndroid Build Coastguard Worker  * Schedule wakeup time for monitoring the position
27*ec779b8eSAndroid Build Coastguard Worker  * of an MMAP/NOIRQ buffer.
28*ec779b8eSAndroid Build Coastguard Worker  *
29*ec779b8eSAndroid Build Coastguard Worker  * Note that this object is not thread safe. Only call it from a single thread.
30*ec779b8eSAndroid Build Coastguard Worker  */
31*ec779b8eSAndroid Build Coastguard Worker class TimestampScheduler
32*ec779b8eSAndroid Build Coastguard Worker {
33*ec779b8eSAndroid Build Coastguard Worker public:
34*ec779b8eSAndroid Build Coastguard Worker     TimestampScheduler() = default;
35*ec779b8eSAndroid Build Coastguard Worker     virtual ~TimestampScheduler() = default;
36*ec779b8eSAndroid Build Coastguard Worker 
37*ec779b8eSAndroid Build Coastguard Worker     /**
38*ec779b8eSAndroid Build Coastguard Worker      * Start the schedule at the given time.
39*ec779b8eSAndroid Build Coastguard Worker      */
40*ec779b8eSAndroid Build Coastguard Worker     void start(int64_t startTime);
41*ec779b8eSAndroid Build Coastguard Worker 
42*ec779b8eSAndroid Build Coastguard Worker     /**
43*ec779b8eSAndroid Build Coastguard Worker      * Calculate the next time that the read position should be measured.
44*ec779b8eSAndroid Build Coastguard Worker      */
45*ec779b8eSAndroid Build Coastguard Worker     int64_t nextAbsoluteTime();
46*ec779b8eSAndroid Build Coastguard Worker 
setBurstPeriod(int64_t burstPeriod)47*ec779b8eSAndroid Build Coastguard Worker     void setBurstPeriod(int64_t burstPeriod) {
48*ec779b8eSAndroid Build Coastguard Worker         mBurstPeriod = burstPeriod;
49*ec779b8eSAndroid Build Coastguard Worker     }
50*ec779b8eSAndroid Build Coastguard Worker 
setBurstPeriod(int32_t framesPerBurst,int32_t sampleRate)51*ec779b8eSAndroid Build Coastguard Worker     void setBurstPeriod(int32_t framesPerBurst,
52*ec779b8eSAndroid Build Coastguard Worker                         int32_t sampleRate) {
53*ec779b8eSAndroid Build Coastguard Worker         mBurstPeriod = AAUDIO_NANOS_PER_SECOND * framesPerBurst / sampleRate;
54*ec779b8eSAndroid Build Coastguard Worker     }
55*ec779b8eSAndroid Build Coastguard Worker 
getBurstPeriod()56*ec779b8eSAndroid Build Coastguard Worker     int64_t getBurstPeriod() {
57*ec779b8eSAndroid Build Coastguard Worker         return mBurstPeriod;
58*ec779b8eSAndroid Build Coastguard Worker     }
59*ec779b8eSAndroid Build Coastguard Worker 
60*ec779b8eSAndroid Build Coastguard Worker private:
61*ec779b8eSAndroid Build Coastguard Worker     // Start with an arbitrary default so we do not divide by zero.
62*ec779b8eSAndroid Build Coastguard Worker     int64_t mBurstPeriod = AAUDIO_NANOS_PER_MILLISECOND;
63*ec779b8eSAndroid Build Coastguard Worker     int64_t mStartTime = 0;
64*ec779b8eSAndroid Build Coastguard Worker     int64_t mLastTime = 0;
65*ec779b8eSAndroid Build Coastguard Worker };
66*ec779b8eSAndroid Build Coastguard Worker 
67*ec779b8eSAndroid Build Coastguard Worker } /* namespace aaudio */
68*ec779b8eSAndroid Build Coastguard Worker 
69*ec779b8eSAndroid Build Coastguard Worker #endif /* AAUDIO_TIMESTAMP_SCHEDULER_H */
70