blob: 6a506b31d0558c9c1b4d9d653d511711180a92f3 [file] [log] [blame]
Phil Burke4d7bb42017-03-28 11:32:39 -07001/*
2 * Copyright 2016 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef LEGACY_AUDIO_STREAM_LEGACY_H
18#define LEGACY_AUDIO_STREAM_LEGACY_H
19
Phil Burk5204d312017-05-04 17:16:13 -070020#include <media/AudioTimestamp.h>
Eric Laurentfb00fc72017-05-25 18:17:12 -070021#include <media/AudioSystem.h>
Phil Burke4d7bb42017-03-28 11:32:39 -070022
23#include <aaudio/AAudio.h>
24
25#include "AudioStream.h"
26#include "AAudioLegacy.h"
Phil Burk2d5ba532017-09-06 14:36:11 -070027#include "utility/AAudioUtilities.h"
Phil Burke4d7bb42017-03-28 11:32:39 -070028#include "utility/FixedBlockAdapter.h"
29
30namespace aaudio {
31
32
33typedef void (*aaudio_legacy_callback_t)(int event, void* user, void *info);
34
35enum {
36 /**
37 * Request that the callback function should fill the data buffer of an output stream,
38 * or process the data of an input stream.
39 * The address parameter passed to the callback function will point to a data buffer.
40 * For an input stream, the data is read-only.
41 * The value1 parameter will be the number of frames.
42 * The value2 parameter is reserved and will be set to zero.
43 * The callback should return AAUDIO_CALLBACK_RESULT_CONTINUE or AAUDIO_CALLBACK_RESULT_STOP.
44 */
45 AAUDIO_CALLBACK_OPERATION_PROCESS_DATA,
46
47 /**
48 * Inform the callback function that the stream was disconnected.
49 * The address parameter passed to the callback function will be NULL.
50 * The value1 will be an error code or AAUDIO_OK.
51 * The value2 parameter is reserved and will be set to zero.
52 * The callback return value will be ignored.
53 */
54 AAUDIO_CALLBACK_OPERATION_DISCONNECTED,
55};
56typedef int32_t aaudio_callback_operation_t;
57
58
59class AudioStreamLegacy : public AudioStream, public FixedBlockProcessor {
60public:
61 AudioStreamLegacy();
62
63 virtual ~AudioStreamLegacy();
64
65 aaudio_legacy_callback_t getLegacyCallback();
66
Phil Burk7328a802017-08-30 09:29:48 -070067 int32_t callDataCallbackFrames(uint8_t *buffer, int32_t numFrames);
68
Phil Burke4d7bb42017-03-28 11:32:39 -070069 // This is public so it can be called from the C callback function.
70 // This is called from the AudioTrack/AudioRecord client.
71 virtual void processCallback(int event, void *info) = 0;
72
73 void processCallbackCommon(aaudio_callback_operation_t opcode, void *info);
74
75 // Implement FixedBlockProcessor
76 int32_t onProcessFixedBlock(uint8_t *buffer, int32_t numBytes) override;
77
Phil Burk4c5129b2017-04-28 15:17:32 -070078 virtual int64_t incrementClientFrameCounter(int32_t frames) = 0;
79
Phil Burkec89b2e2017-06-20 15:05:06 -070080
81 virtual int64_t getFramesWritten() override {
82 return mFramesWritten.get();
83 }
84
85 virtual int64_t getFramesRead() override {
86 return mFramesRead.get();
87 }
88
Phil Burke4d7bb42017-03-28 11:32:39 -070089protected:
Phil Burk5204d312017-05-04 17:16:13 -070090
Eric Laurentfb00fc72017-05-25 18:17:12 -070091 class StreamDeviceCallback : public android::AudioSystem::AudioDeviceCallback
92 {
93 public:
94
95 StreamDeviceCallback(AudioStreamLegacy *parent) : mParent(parent) {}
96 virtual ~StreamDeviceCallback() {}
97
98 virtual void onAudioDeviceUpdate(audio_io_handle_t audioIo __unused,
99 audio_port_handle_t deviceId) {
100 if (mParent != nullptr) {
101 mParent->onAudioDeviceUpdate(deviceId);
102 }
103 }
104
105 AudioStreamLegacy *mParent;
106 };
107
Phil Burk5204d312017-05-04 17:16:13 -0700108 aaudio_result_t getBestTimestamp(clockid_t clockId,
109 int64_t *framePosition,
110 int64_t *timeNanoseconds,
111 android::ExtendedTimestamp *extendedTimestamp);
112
Eric Laurentfb00fc72017-05-25 18:17:12 -0700113 void onAudioDeviceUpdate(audio_port_handle_t deviceId);
114
Phil Burk134f1972017-12-08 13:06:11 -0800115 /*
116 * Check to see whether a callback thread has requested a disconnected.
117 * @param errorCallbackEnabled set true to call errorCallback on disconnect
118 * @return AAUDIO_OK or AAUDIO_ERROR_DISCONNECTED
119 */
120 aaudio_result_t checkForDisconnectRequest(bool errorCallbackEnabled);
Phil Burk2d5ba532017-09-06 14:36:11 -0700121
Phil Burk134f1972017-12-08 13:06:11 -0800122 void forceDisconnect(bool errorCallbackEnabled = true);
Phil Burk2d5ba532017-09-06 14:36:11 -0700123
Eric Laurentfb00fc72017-05-25 18:17:12 -0700124 void onStart() { mCallbackEnabled.store(true); }
125 void onStop() { mCallbackEnabled.store(false); }
126
Phil Burkec89b2e2017-06-20 15:05:06 -0700127 int64_t incrementFramesWritten(int32_t frames) {
128 return mFramesWritten.increment(frames);
129 }
130
131 int64_t incrementFramesRead(int32_t frames) {
132 return mFramesRead.increment(frames);
133 }
134
135 MonotonicCounter mFramesWritten;
136 MonotonicCounter mFramesRead;
Phil Burk7328a802017-08-30 09:29:48 -0700137 MonotonicCounter mTimestampPosition;
Phil Burkec89b2e2017-06-20 15:05:06 -0700138
Phil Burke4d7bb42017-03-28 11:32:39 -0700139 FixedBlockAdapter *mBlockAdapter = nullptr;
140 aaudio_wrapping_frames_t mPositionWhenStarting = 0;
141 int32_t mCallbackBufferSize = 0;
Eric Laurentfb00fc72017-05-25 18:17:12 -0700142 const android::sp<StreamDeviceCallback> mDeviceCallback;
Phil Burk2d5ba532017-09-06 14:36:11 -0700143
144 AtomicRequestor mRequestDisconnect;
Phil Burke4d7bb42017-03-28 11:32:39 -0700145};
146
147} /* namespace aaudio */
148
149#endif //LEGACY_AUDIO_STREAM_LEGACY_H