blob: 6ae8b72896fe82ce2df93f8474f8aa9cb4d59b99 [file] [log] [blame]
Phil Burk204a1632017-01-03 17:23:43 -08001/*
2 * Copyright (C) 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 OBOE_AUDIO_ENDPOINT_H
18#define OBOE_AUDIO_ENDPOINT_H
19
20#include <oboe/OboeAudio.h>
21
22#include "OboeServiceMessage.h"
23#include "AudioEndpointParcelable.h"
24#include "fifo/FifoBuffer.h"
25
26namespace oboe {
27
28#define ENDPOINT_DATA_QUEUE_SIZE_MIN 64
29
30/**
31 * A sink for audio.
32 * Used by the client code.
33 */
34class AudioEndpoint {
35
36public:
37 AudioEndpoint();
38 virtual ~AudioEndpoint();
39
40 /**
41 * Configure based on the EndPointDescriptor_t.
42 */
43 oboe_result_t configure(const EndpointDescriptor *pEndpointDescriptor);
44
45 /**
46 * Read from a command passed up from the Server.
47 * @return 1 if command received, 0 for no command, or negative error.
48 */
49 oboe_result_t readUpCommand(OboeServiceMessage *commandPtr);
50
51 /**
52 * Non-blocking write.
53 * @return framesWritten or a negative error code.
54 */
55 oboe_result_t writeDataNow(const void *buffer, int32_t numFrames);
56
57 /**
58 * Set the read index in the downData queue.
59 * This is needed if the reader is not updating the index itself.
60 */
61 void setDownDataReadCounter(fifo_counter_t framesRead);
62 fifo_counter_t getDownDataReadCounter();
63
64 void setDownDataWriteCounter(fifo_counter_t framesWritten);
65 fifo_counter_t getDownDataWriteCounter();
66
67 /**
68 * The result is not valid until after configure() is called.
69 *
70 * @return true if the output buffer read position is not updated, eg. DMA
71 */
72 bool isOutputFreeRunning() const { return mOutputFreeRunning; }
73
74 int32_t setBufferSizeInFrames(oboe_size_frames_t requestedFrames,
75 oboe_size_frames_t *actualFrames);
76 oboe_size_frames_t getBufferSizeInFrames() const;
77
78 oboe_size_frames_t getBufferCapacityInFrames() const;
79
80 oboe_size_frames_t getFullFramesAvailable();
81
82private:
83 FifoBuffer * mUpCommandQueue;
84 FifoBuffer * mDownDataQueue;
85 bool mOutputFreeRunning;
86 fifo_counter_t mDataReadCounter; // only used if free-running
87 fifo_counter_t mDataWriteCounter; // only used if free-running
88};
89
90} // namespace oboe
91
92#endif //OBOE_AUDIO_ENDPOINT_H