OSDN Git Service

730e5a91db0a2e7911d472326e78bcc6701666da
[android-x86/hardware-libhardware_legacy.git] / include / hardware_legacy / AudioHardwareInterface.h
1 /*
2  * Copyright (C) 2007 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 ANDROID_AUDIO_HARDWARE_INTERFACE_H
18 #define ANDROID_AUDIO_HARDWARE_INTERFACE_H
19
20 #include <stdint.h>
21 #include <sys/types.h>
22
23 #include <utils/Errors.h>
24 #include <utils/Vector.h>
25 #include <utils/String16.h>
26
27 #include <media/IAudioFlinger.h>
28 #include "media/AudioSystem.h"
29
30
31 namespace android {
32
33 // ----------------------------------------------------------------------------
34
35 /**
36  * AudioStreamOut is the abstraction interface for the audio output hardware.
37  *
38  * It provides information about various properties of the audio output hardware driver.
39  */
40 class AudioStreamOut {
41 public:
42     virtual             ~AudioStreamOut() = 0;
43
44     /** return audio sampling rate in hz - eg. 44100 */
45     virtual uint32_t    sampleRate() const = 0;
46
47     /** returns size of output buffer - eg. 4800 */
48     virtual size_t      bufferSize() const = 0;
49
50     /**
51      * return number of output audio channels.
52      * Acceptable values are 1 (mono) or 2 (stereo)
53      */
54     virtual int         channelCount() const = 0;
55
56     /**
57      * return audio format in 8bit or 16bit PCM format -
58      * eg. AudioSystem:PCM_16_BIT
59      */
60     virtual int         format() const = 0;
61
62     /**
63      * return the frame size (number of bytes per sample).
64      */
65     uint32_t    frameSize() const { return channelCount()*((format()==AudioSystem::PCM_16_BIT)?sizeof(int16_t):sizeof(int8_t)); }
66
67     /**
68      * return the audio hardware driver latency in milli seconds.
69      */
70     virtual uint32_t    latency() const = 0;
71
72     /**
73      * Use this method in situations where audio mixing is done in the
74      * hardware. This method serves as a direct interface with hardware,
75      * allowing you to directly set the volume as apposed to via the framework.
76      * This method might produce multiple PCM outputs or hardware accelerated
77      * codecs, such as MP3 or AAC.
78      */
79     virtual status_t    setVolume(float volume) = 0;
80
81     /** write audio buffer to driver. Returns number of bytes written */
82     virtual ssize_t     write(const void* buffer, size_t bytes) = 0;
83
84     /**
85      * Put the audio hardware output into standby mode. Returns
86      * status based on include/utils/Errors.h
87      */
88     virtual status_t    standby() = 0;
89
90     /** dump the state of the audio output device */
91     virtual status_t dump(int fd, const Vector<String16>& args) = 0;
92 };
93
94 /**
95  * AudioStreamIn is the abstraction interface for the audio input hardware.
96  *
97  * It defines the various properties of the audio hardware input driver.
98  */
99 class AudioStreamIn {
100 public:
101     virtual             ~AudioStreamIn() = 0;
102
103     /** return the input buffer size allowed by audio driver */
104     virtual size_t      bufferSize() const = 0;
105
106     /** return the number of audio input channels */
107     virtual int         channelCount() const = 0;
108
109     /**
110      * return audio format in 8bit or 16bit PCM format -
111      * eg. AudioSystem:PCM_16_BIT
112      */
113     virtual int         format() const = 0;
114
115     /**
116      * return the frame size (number of bytes per sample).
117      */
118     uint32_t    frameSize() const { return channelCount()*((format()==AudioSystem::PCM_16_BIT)?sizeof(int16_t):sizeof(int8_t)); }
119
120     /** set the input gain for the audio driver. This method is for
121      *  for future use */
122     virtual status_t    setGain(float gain) = 0;
123
124     /** read audio buffer in from audio driver */
125     virtual ssize_t     read(void* buffer, ssize_t bytes) = 0;
126
127     /** dump the state of the audio input device */
128     virtual status_t dump(int fd, const Vector<String16>& args) = 0;
129
130     /**
131      * Put the audio hardware input into standby mode. Returns
132      * status based on include/utils/Errors.h
133      */
134     virtual status_t    standby() = 0;
135
136 };
137
138 /**
139  * AudioHardwareInterface.h defines the interface to the audio hardware abstraction layer.
140  *
141  * The interface supports setting and getting parameters, selecting audio routing
142  * paths, and defining input and output streams.
143  *
144  * AudioFlinger initializes the audio hardware and immediately opens an output stream.
145  * You can set Audio routing to output to handset, speaker, Bluetooth, or a headset.
146  *
147  * The audio input stream is initialized when AudioFlinger is called to carry out
148  * a record operation.
149  */
150 class AudioHardwareInterface
151 {
152 public:
153     /**
154      * check to see if the audio hardware interface has been initialized.
155      * return status based on values defined in include/utils/Errors.h
156      */
157     virtual status_t    initCheck() = 0;
158
159     /** set the audio volume of a voice call. Range is between 0.0 and 1.0 */
160     virtual status_t    setVoiceVolume(float volume) = 0;
161
162     /**
163      * set the audio volume for all audio activities other than voice call.
164      * Range between 0.0 and 1.0. If any value other than NO_ERROR is returned,
165      * the software mixer will emulate this capability.
166      */
167     virtual status_t    setMasterVolume(float volume) = 0;
168
169     /**
170      * Audio routing methods. Routes defined in include/hardware_legacy/AudioSystem.h.
171      * Audio routes can be (ROUTE_EARPIECE | ROUTE_SPEAKER | ROUTE_BLUETOOTH
172      *                    | ROUTE_HEADSET)
173      *
174      * setRouting sets the routes for a mode. This is called at startup. It is
175      * also called when a new device is connected, such as a wired headset is
176      * plugged in or a Bluetooth headset is paired.
177      */
178     virtual status_t    setRouting(int mode, uint32_t routes) = 0;
179
180     virtual status_t    getRouting(int mode, uint32_t* routes) = 0;
181
182     /**
183      * setMode is called when the audio mode changes. NORMAL mode is for
184      * standard audio playback, RINGTONE when a ringtone is playing, and IN_CALL
185      * when a call is in progress.
186      */
187     virtual status_t    setMode(int mode) = 0;
188     virtual status_t    getMode(int* mode) = 0;
189
190     // mic mute
191     virtual status_t    setMicMute(bool state) = 0;
192     virtual status_t    getMicMute(bool* state) = 0;
193
194     // Temporary interface, do not use
195     // TODO: Replace with a more generic key:value get/set mechanism
196     virtual status_t    setParameter(const char* key, const char* value) = 0;
197
198     // Returns audio input buffer size according to parameters passed or 0 if one of the
199     // parameters is not supported
200     virtual size_t    getInputBufferSize(uint32_t sampleRate, int format, int channelCount) = 0;
201     
202     /** This method creates and opens the audio hardware output stream */
203     virtual AudioStreamOut* openOutputStream(
204                                 int format=0,
205                                 int channelCount=0,
206                                 uint32_t sampleRate=0,
207                                 status_t *status=0) = 0;
208
209     /** This method creates and opens the audio hardware input stream */
210     virtual AudioStreamIn* openInputStream(
211                                 int inputSource,
212                                 int format,
213                                 int channelCount,
214                                 uint32_t sampleRate,
215                                 status_t *status,
216                                 AudioSystem::audio_in_acoustics acoustics) = 0;
217
218     /**This method dumps the state of the audio hardware */
219     virtual status_t dumpState(int fd, const Vector<String16>& args) = 0;
220
221     static AudioHardwareInterface* create();
222
223 protected:
224     /**
225      * doRouting actually initiates the routing. A call to setRouting
226      * or setMode may result in a routing change. The generic logic calls
227      * doRouting when required. If the device has any special requirements these
228      * methods can be overriden.
229      */
230     virtual status_t    doRouting() = 0;
231
232     virtual status_t dump(int fd, const Vector<String16>& args) = 0;
233 };
234
235 // ----------------------------------------------------------------------------
236
237 extern "C" AudioHardwareInterface* createAudioHardware(void);
238
239 }; // namespace android
240
241 #endif // ANDROID_AUDIO_HARDWARE_INTERFACE_H