205 lines
5.5 KiB
C++
205 lines
5.5 KiB
C++
/* //device/servers/AudioFlinger/AudioHardwareStub.cpp
|
|
**
|
|
** Copyright 2007, The Android Open Source Project
|
|
**
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
** you may not use this file except in compliance with the License.
|
|
** You may obtain a copy of the License at
|
|
**
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
**
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
** See the License for the specific language governing permissions and
|
|
** limitations under the License.
|
|
*/
|
|
|
|
#include <stdint.h>
|
|
#include <sys/types.h>
|
|
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
#include <utils/String8.h>
|
|
|
|
#include "AudioHardwareStub.h"
|
|
#include <media/AudioRecord.h>
|
|
|
|
namespace android {
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
AudioHardwareStub::AudioHardwareStub() : mMicMute(false)
|
|
{
|
|
}
|
|
|
|
AudioHardwareStub::~AudioHardwareStub()
|
|
{
|
|
}
|
|
|
|
status_t AudioHardwareStub::initCheck()
|
|
{
|
|
return NO_ERROR;
|
|
}
|
|
|
|
AudioStreamOut* AudioHardwareStub::openOutputStream(
|
|
uint32_t devices, int *format, uint32_t *channels, uint32_t *sampleRate, status_t *status)
|
|
{
|
|
AudioStreamOutStub* out = new AudioStreamOutStub();
|
|
status_t lStatus = out->set(format, channels, sampleRate);
|
|
if (status) {
|
|
*status = lStatus;
|
|
}
|
|
if (lStatus == NO_ERROR)
|
|
return out;
|
|
delete out;
|
|
return 0;
|
|
}
|
|
|
|
void AudioHardwareStub::closeOutputStream(AudioStreamOut* out)
|
|
{
|
|
delete out;
|
|
}
|
|
|
|
AudioStreamIn* AudioHardwareStub::openInputStream(
|
|
uint32_t devices, int *format, uint32_t *channels, uint32_t *sampleRate,
|
|
status_t *status, AudioSystem::audio_in_acoustics acoustics)
|
|
{
|
|
// check for valid input source
|
|
if (!AudioSystem::isInputDevice((AudioSystem::audio_devices)devices)) {
|
|
return 0;
|
|
}
|
|
|
|
AudioStreamInStub* in = new AudioStreamInStub();
|
|
status_t lStatus = in->set(format, channels, sampleRate, acoustics);
|
|
if (status) {
|
|
*status = lStatus;
|
|
}
|
|
if (lStatus == NO_ERROR)
|
|
return in;
|
|
delete in;
|
|
return 0;
|
|
}
|
|
|
|
void AudioHardwareStub::closeInputStream(AudioStreamIn* in)
|
|
{
|
|
delete in;
|
|
}
|
|
|
|
status_t AudioHardwareStub::setVoiceVolume(float volume)
|
|
{
|
|
return NO_ERROR;
|
|
}
|
|
|
|
status_t AudioHardwareStub::setMasterVolume(float volume)
|
|
{
|
|
return NO_ERROR;
|
|
}
|
|
|
|
status_t AudioHardwareStub::dumpInternals(int fd, const Vector<String16>& args)
|
|
{
|
|
const size_t SIZE = 256;
|
|
char buffer[SIZE];
|
|
String8 result;
|
|
result.append("AudioHardwareStub::dumpInternals\n");
|
|
snprintf(buffer, SIZE, "\tmMicMute: %s\n", mMicMute? "true": "false");
|
|
result.append(buffer);
|
|
::write(fd, result.string(), result.size());
|
|
return NO_ERROR;
|
|
}
|
|
|
|
status_t AudioHardwareStub::dump(int fd, const Vector<String16>& args)
|
|
{
|
|
dumpInternals(fd, args);
|
|
return NO_ERROR;
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
status_t AudioStreamOutStub::set(int *pFormat, uint32_t *pChannels, uint32_t *pRate)
|
|
{
|
|
if (pFormat) *pFormat = format();
|
|
if (pChannels) *pChannels = channels();
|
|
if (pRate) *pRate = sampleRate();
|
|
|
|
return NO_ERROR;
|
|
}
|
|
|
|
ssize_t AudioStreamOutStub::write(const void* buffer, size_t bytes)
|
|
{
|
|
// fake timing for audio output
|
|
usleep(bytes * 1000000 / sizeof(int16_t) / AudioSystem::popCount(channels()) / sampleRate());
|
|
return bytes;
|
|
}
|
|
|
|
status_t AudioStreamOutStub::standby()
|
|
{
|
|
return NO_ERROR;
|
|
}
|
|
|
|
status_t AudioStreamOutStub::dump(int fd, const Vector<String16>& args)
|
|
{
|
|
const size_t SIZE = 256;
|
|
char buffer[SIZE];
|
|
String8 result;
|
|
snprintf(buffer, SIZE, "AudioStreamOutStub::dump\n");
|
|
snprintf(buffer, SIZE, "\tsample rate: %d\n", sampleRate());
|
|
snprintf(buffer, SIZE, "\tbuffer size: %d\n", bufferSize());
|
|
snprintf(buffer, SIZE, "\tchannels: %d\n", channels());
|
|
snprintf(buffer, SIZE, "\tformat: %d\n", format());
|
|
result.append(buffer);
|
|
::write(fd, result.string(), result.size());
|
|
return NO_ERROR;
|
|
}
|
|
|
|
String8 AudioStreamOutStub::getParameters(const String8& keys)
|
|
{
|
|
AudioParameter param = AudioParameter(keys);
|
|
return param.toString();
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
status_t AudioStreamInStub::set(int *pFormat, uint32_t *pChannels, uint32_t *pRate,
|
|
AudioSystem::audio_in_acoustics acoustics)
|
|
{
|
|
return NO_ERROR;
|
|
}
|
|
|
|
ssize_t AudioStreamInStub::read(void* buffer, ssize_t bytes)
|
|
{
|
|
// fake timing for audio input
|
|
usleep(bytes * 1000000 / sizeof(int16_t) / AudioSystem::popCount(channels()) / sampleRate());
|
|
memset(buffer, 0, bytes);
|
|
return bytes;
|
|
}
|
|
|
|
status_t AudioStreamInStub::dump(int fd, const Vector<String16>& args)
|
|
{
|
|
const size_t SIZE = 256;
|
|
char buffer[SIZE];
|
|
String8 result;
|
|
snprintf(buffer, SIZE, "AudioStreamInStub::dump\n");
|
|
result.append(buffer);
|
|
snprintf(buffer, SIZE, "\tsample rate: %d\n", sampleRate());
|
|
result.append(buffer);
|
|
snprintf(buffer, SIZE, "\tbuffer size: %d\n", bufferSize());
|
|
result.append(buffer);
|
|
snprintf(buffer, SIZE, "\tchannels: %d\n", channels());
|
|
result.append(buffer);
|
|
snprintf(buffer, SIZE, "\tformat: %d\n", format());
|
|
result.append(buffer);
|
|
::write(fd, result.string(), result.size());
|
|
return NO_ERROR;
|
|
}
|
|
|
|
String8 AudioStreamInStub::getParameters(const String8& keys)
|
|
{
|
|
AudioParameter param = AudioParameter(keys);
|
|
return param.toString();
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
}; // namespace android
|