blob: e78651363733926d2dcaf4ac7ba9816e3746c208 [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
Phil Burk5ed503c2017-02-01 09:38:15 -080017#ifndef AAUDIO_AUDIO_ENDPOINT_H
18#define AAUDIO_AUDIO_ENDPOINT_H
Phil Burk204a1632017-01-03 17:23:43 -080019
Phil Burk5ed503c2017-02-01 09:38:15 -080020#include <aaudio/AAudio.h>
Phil Burk204a1632017-01-03 17:23:43 -080021
Phil Burk5ed503c2017-02-01 09:38:15 -080022#include "AAudioServiceMessage.h"
Phil Burk204a1632017-01-03 17:23:43 -080023#include "AudioEndpointParcelable.h"
24#include "fifo/FifoBuffer.h"
25
Phil Burk5ed503c2017-02-01 09:38:15 -080026namespace aaudio {
Phil Burk204a1632017-01-03 17:23:43 -080027
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 */
Phil Burk5ed503c2017-02-01 09:38:15 -080043 aaudio_result_t configure(const EndpointDescriptor *pEndpointDescriptor);
Phil Burk204a1632017-01-03 17:23:43 -080044
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 */
Phil Burk5ed503c2017-02-01 09:38:15 -080049 aaudio_result_t readUpCommand(AAudioServiceMessage *commandPtr);
Phil Burk204a1632017-01-03 17:23:43 -080050
51 /**
52 * Non-blocking write.
53 * @return framesWritten or a negative error code.
54 */
Phil Burk5ed503c2017-02-01 09:38:15 -080055 aaudio_result_t writeDataNow(const void *buffer, int32_t numFrames);
Phil Burk204a1632017-01-03 17:23:43 -080056
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
Phil Burk5ed503c2017-02-01 09:38:15 -080074 int32_t setBufferSizeInFrames(aaudio_size_frames_t requestedFrames,
75 aaudio_size_frames_t *actualFrames);
76 aaudio_size_frames_t getBufferSizeInFrames() const;
Phil Burk204a1632017-01-03 17:23:43 -080077
Phil Burk5ed503c2017-02-01 09:38:15 -080078 aaudio_size_frames_t getBufferCapacityInFrames() const;
Phil Burk204a1632017-01-03 17:23:43 -080079
Phil Burk5ed503c2017-02-01 09:38:15 -080080 aaudio_size_frames_t getFullFramesAvailable();
Phil Burk204a1632017-01-03 17:23:43 -080081
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
Phil Burk5ed503c2017-02-01 09:38:15 -080090} // namespace aaudio
Phil Burk204a1632017-01-03 17:23:43 -080091
Phil Burk5ed503c2017-02-01 09:38:15 -080092#endif //AAUDIO_AUDIO_ENDPOINT_H