2008-10-21 14:00:00 +00:00
|
|
|
/* //device/servers/AudioFlinger/AudioDumpInterface.cpp
|
|
|
|
**
|
|
|
|
** Copyright 2008, The Android Open Source Project
|
|
|
|
**
|
2008-12-18 02:05:43 +00:00
|
|
|
** 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
|
2008-10-21 14:00:00 +00:00
|
|
|
**
|
2008-12-18 02:05:43 +00:00
|
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
2008-10-21 14:00:00 +00:00
|
|
|
**
|
2008-12-18 02:05:43 +00:00
|
|
|
** 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
|
2008-10-21 14:00:00 +00:00
|
|
|
** limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define LOG_TAG "AudioFlingerDump"
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <utils/Log.h>
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include "AudioDumpInterface.h"
|
|
|
|
|
|
|
|
namespace android {
|
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
bool gFirst = true; // true if first write after a standby
|
|
|
|
|
2008-10-21 14:00:00 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
AudioDumpInterface::AudioDumpInterface(AudioHardwareInterface* hw)
|
|
|
|
{
|
|
|
|
if(hw == 0) {
|
|
|
|
LOGE("Dump construct hw = 0");
|
|
|
|
}
|
|
|
|
mFinalInterface = hw;
|
|
|
|
mStreamOut = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
AudioDumpInterface::~AudioDumpInterface()
|
|
|
|
{
|
|
|
|
if(mFinalInterface) delete mFinalInterface;
|
|
|
|
if(mStreamOut) delete mStreamOut;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-10-21 14:00:00 +00:00
|
|
|
status_t AudioDumpInterface::standby()
|
|
|
|
{
|
|
|
|
if(mStreamOut) mStreamOut->Close();
|
2008-12-18 02:05:43 +00:00
|
|
|
gFirst = true;
|
2008-10-21 14:00:00 +00:00
|
|
|
return mFinalInterface->standby();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
AudioStreamOut* AudioDumpInterface::openOutputStream(
|
2008-12-18 02:05:43 +00:00
|
|
|
int format, int channelCount, uint32_t sampleRate, status_t *status)
|
2008-10-21 14:00:00 +00:00
|
|
|
{
|
2008-12-18 02:05:43 +00:00
|
|
|
AudioStreamOut* outFinal = mFinalInterface->openOutputStream(format, channelCount, sampleRate, status);
|
2008-10-21 14:00:00 +00:00
|
|
|
|
|
|
|
if(outFinal) {
|
|
|
|
mStreamOut = new AudioStreamOutDump(outFinal);
|
|
|
|
return mStreamOut;
|
|
|
|
} else {
|
|
|
|
LOGE("Dump outFinal=0");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
AudioStreamOutDump::AudioStreamOutDump( AudioStreamOut* finalStream)
|
|
|
|
{
|
|
|
|
mFinalStream = finalStream;
|
|
|
|
mOutFile = 0;
|
|
|
|
}
|
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
AudioStreamOutDump::~AudioStreamOutDump()
|
|
|
|
{
|
|
|
|
Close();
|
|
|
|
delete mFinalStream;
|
|
|
|
}
|
|
|
|
|
2008-10-21 14:00:00 +00:00
|
|
|
ssize_t AudioStreamOutDump::write(const void* buffer, size_t bytes)
|
|
|
|
{
|
|
|
|
ssize_t ret;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
2008-10-21 14:00:00 +00:00
|
|
|
ret = mFinalStream->write(buffer, bytes);
|
2008-12-18 02:05:43 +00:00
|
|
|
if(!mOutFile && gFirst) {
|
|
|
|
gFirst = false;
|
|
|
|
// check if dump file exist
|
|
|
|
mOutFile = fopen(FLINGER_DUMP_NAME, "r");
|
|
|
|
if(mOutFile) {
|
|
|
|
fclose(mOutFile);
|
|
|
|
mOutFile = fopen(FLINGER_DUMP_NAME, "ab");
|
|
|
|
}
|
2008-10-21 14:00:00 +00:00
|
|
|
}
|
|
|
|
if (mOutFile) {
|
|
|
|
fwrite(buffer, bytes, 1, mOutFile);
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
void AudioStreamOutDump::Close(void)
|
|
|
|
{
|
|
|
|
if(mOutFile) {
|
|
|
|
fclose(mOutFile);
|
|
|
|
mOutFile = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}; // namespace android
|