blob: 79f498bfb65934296147e5fe55d4b6a3b12cb6ed [file] [log] [blame]
Phil Burkc0c70e32017-02-09 13:18:38 -08001/*
2 * Copyright (C) 2017 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 Burk5204d312017-05-04 17:16:13 -070017#ifndef ANDROID_AAUDIO_BINDING_AAUDIO_SERVICE_INTERFACE_H
18#define ANDROID_AAUDIO_BINDING_AAUDIO_SERVICE_INTERFACE_H
Phil Burkc0c70e32017-02-09 13:18:38 -080019
Phil Burk11e8d332017-05-24 09:59:02 -070020#include <utils/StrongPointer.h>
Eric Laurenta54f1282017-07-01 19:39:32 -070021#include <media/AudioClient.h>
Phil Burk11e8d332017-05-24 09:59:02 -070022
Ytai Ben-Tsvi0412f732020-08-17 14:43:36 -070023#include "aaudio/IAAudioClient.h"
Phil Burkc0c70e32017-02-09 13:18:38 -080024#include "binding/AAudioServiceDefinitions.h"
25#include "binding/AAudioStreamRequest.h"
26#include "binding/AAudioStreamConfiguration.h"
27#include "binding/AudioEndpointParcelable.h"
28
29/**
30 * This has the same methods as IAAudioService but without the Binder features.
31 *
32 * It allows us to abstract the Binder interface and use an AudioStreamInternal
33 * both in the client and in the service.
34 */
35namespace aaudio {
36
37class AAudioServiceInterface {
38public:
39
jiabind5bd06a2021-04-27 22:04:08 +000040 AAudioServiceInterface() = default;
Phil Burkc0c70e32017-02-09 13:18:38 -080041 virtual ~AAudioServiceInterface() = default;
42
Ytai Ben-Tsvi0412f732020-08-17 14:43:36 -070043 virtual void registerClient(const android::sp<IAAudioClient>& client) = 0;
Phil Burk11e8d332017-05-24 09:59:02 -070044
Phil Burkc0c70e32017-02-09 13:18:38 -080045 /**
46 * @param request info needed to create the stream
47 * @param configuration contains information about the created stream
jiabin5f787812023-03-02 20:42:43 +000048 * @return an object for aaudio handle information, which includes the connected
49 * aaudio service lifetime id to recognize the connected aaudio service
50 * and aaudio handle to recognize the stream. If an error occurs, the
51 * aaudio handle will be set as the negative error.
Phil Burkc0c70e32017-02-09 13:18:38 -080052 */
jiabin5f787812023-03-02 20:42:43 +000053 virtual AAudioHandleInfo openStream(const AAudioStreamRequest &request,
54 AAudioStreamConfiguration &configuration) = 0;
Phil Burkc0c70e32017-02-09 13:18:38 -080055
jiabin5f787812023-03-02 20:42:43 +000056 virtual aaudio_result_t closeStream(const AAudioHandleInfo& streamHandleInfo) = 0;
Phil Burkc0c70e32017-02-09 13:18:38 -080057
58 /* Get an immutable description of the in-memory queues
59 * used to communicate with the underlying HAL or Service.
60 */
jiabin5f787812023-03-02 20:42:43 +000061 virtual aaudio_result_t getStreamDescription(const AAudioHandleInfo& streamHandleInfo,
Phil Burkc0c70e32017-02-09 13:18:38 -080062 AudioEndpointParcelable &parcelable) = 0;
63
64 /**
65 * Start the flow of data.
66 */
jiabin5f787812023-03-02 20:42:43 +000067 virtual aaudio_result_t startStream(const AAudioHandleInfo& streamHandleInfo) = 0;
Phil Burkc0c70e32017-02-09 13:18:38 -080068
69 /**
70 * Stop the flow of data such that start() can resume without loss of data.
71 */
jiabin5f787812023-03-02 20:42:43 +000072 virtual aaudio_result_t pauseStream(const AAudioHandleInfo& streamHandleInfo) = 0;
Phil Burkc0c70e32017-02-09 13:18:38 -080073
74 /**
jiabin5f787812023-03-02 20:42:43 +000075 * Stop the flow of data after data currently in the buffer has played.
Phil Burk71f35bb2017-04-13 16:05:07 -070076 */
jiabin5f787812023-03-02 20:42:43 +000077 virtual aaudio_result_t stopStream(const AAudioHandleInfo& streamHandleInfo) = 0;
Phil Burk71f35bb2017-04-13 16:05:07 -070078
79 /**
Phil Burkc0c70e32017-02-09 13:18:38 -080080 * Discard any data held by the underlying HAL or Service.
81 */
jiabin5f787812023-03-02 20:42:43 +000082 virtual aaudio_result_t flushStream(const AAudioHandleInfo& streamHandleInfo) = 0;
Phil Burkc0c70e32017-02-09 13:18:38 -080083
84 /**
85 * Manage the specified thread as a low latency audio thread.
86 */
jiabin5f787812023-03-02 20:42:43 +000087 virtual aaudio_result_t registerAudioThread(const AAudioHandleInfo& streamHandleInfo,
Phil Burkc0c70e32017-02-09 13:18:38 -080088 pid_t clientThreadId,
89 int64_t periodNanoseconds) = 0;
90
jiabin5f787812023-03-02 20:42:43 +000091 virtual aaudio_result_t unregisterAudioThread(const AAudioHandleInfo& streamHandleInfo,
Phil Burkc0c70e32017-02-09 13:18:38 -080092 pid_t clientThreadId) = 0;
Eric Laurenta54f1282017-07-01 19:39:32 -070093
jiabin5f787812023-03-02 20:42:43 +000094 virtual aaudio_result_t startClient(const AAudioHandleInfo& streamHandleInfo,
jiabind1f1cb62020-03-24 11:57:57 -070095 const android::AudioClient& client,
96 const audio_attributes_t *attr,
97 audio_port_handle_t *clientHandle) = 0;
Eric Laurenta54f1282017-07-01 19:39:32 -070098
jiabin5f787812023-03-02 20:42:43 +000099 virtual aaudio_result_t stopClient(const AAudioHandleInfo& streamHandleInfo,
Eric Laurenta54f1282017-07-01 19:39:32 -0700100 audio_port_handle_t clientHandle) = 0;
jiabinf7f06152021-11-22 18:10:14 +0000101
102 /**
103 * Exit the standby mode.
104 *
105 * @param streamHandle the stream handle
106 * @param parcelable contains new data queue information
107 * @return the result of the execution
108 */
jiabin5f787812023-03-02 20:42:43 +0000109 virtual aaudio_result_t exitStandby(const AAudioHandleInfo& streamHandleInfo,
jiabinf7f06152021-11-22 18:10:14 +0000110 AudioEndpointParcelable &parcelable) = 0;
Phil Burkc0c70e32017-02-09 13:18:38 -0800111};
112
113} /* namespace aaudio */
114
Phil Burk5204d312017-05-04 17:16:13 -0700115#endif //ANDROID_AAUDIO_BINDING_AAUDIO_SERVICE_INTERFACE_H