blob: ca98b28ab36ffc4abaed3b08e0b33e3e3a7ef5cf [file] [log] [blame]
Glenn Kasten01066232012-02-27 11:50:44 -08001/*
2 * Copyright (C) 2012 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#define LOG_TAG "AudioStreamInSource"
18//#define LOG_NDEBUG 0
19
20#include <cutils/compiler.h>
21#include <utils/Log.h>
Mikhail Naganova0c91332016-09-19 10:01:12 -070022#include <media/audiohal/StreamHalInterface.h>
Glenn Kasten2dd4bdd2012-08-29 11:10:32 -070023#include <media/nbaio/AudioStreamInSource.h>
Glenn Kasten01066232012-02-27 11:50:44 -080024
25namespace android {
26
Mikhail Naganova0c91332016-09-19 10:01:12 -070027AudioStreamInSource::AudioStreamInSource(sp<StreamInHalInterface> stream) :
Glenn Kasten01066232012-02-27 11:50:44 -080028 NBAIO_Source(),
29 mStream(stream),
30 mStreamBufferSizeBytes(0),
31 mFramesOverrun(0),
32 mOverruns(0)
33{
Mikhail Naganova0c91332016-09-19 10:01:12 -070034 ALOG_ASSERT(stream != 0);
Glenn Kasten01066232012-02-27 11:50:44 -080035}
36
37AudioStreamInSource::~AudioStreamInSource()
38{
Mikhail Naganova0c91332016-09-19 10:01:12 -070039 mStream.clear();
Glenn Kasten01066232012-02-27 11:50:44 -080040}
41
42ssize_t AudioStreamInSource::negotiate(const NBAIO_Format offers[], size_t numOffers,
43 NBAIO_Format counterOffers[], size_t& numCounterOffers)
44{
Glenn Kasten6e0d67d2014-01-31 09:41:08 -080045 if (!Format_isValid(mFormat)) {
Mikhail Naganova0c91332016-09-19 10:01:12 -070046 status_t result;
47 result = mStream->getBufferSize(&mStreamBufferSizeBytes);
48 if (result != OK) return result;
Mikhail Naganov560637e2021-03-31 22:40:13 +000049 audio_config_base_t config = AUDIO_CONFIG_BASE_INITIALIZER;
50 result = mStream->getAudioProperties(&config);
Mikhail Naganova0c91332016-09-19 10:01:12 -070051 if (result != OK) return result;
Mikhail Naganov560637e2021-03-31 22:40:13 +000052 mFormat = Format_from_SR_C(config.sample_rate,
53 audio_channel_count_from_in_mask(config.channel_mask), config.format);
Glenn Kasten43d9b872014-03-06 09:03:34 -080054 mFrameSize = Format_frameSize(mFormat);
Glenn Kasten01066232012-02-27 11:50:44 -080055 }
56 return NBAIO_Source::negotiate(offers, numOffers, counterOffers, numCounterOffers);
57}
58
Andy Hung818e7a32016-02-16 18:08:07 -080059int64_t AudioStreamInSource::framesOverrun()
Glenn Kasten01066232012-02-27 11:50:44 -080060{
Mikhail Naganova0c91332016-09-19 10:01:12 -070061 uint32_t framesOverrun;
62 status_t result = mStream->getInputFramesLost(&framesOverrun);
63 if (result == OK && framesOverrun > 0) {
Glenn Kasten01066232012-02-27 11:50:44 -080064 mFramesOverrun += framesOverrun;
65 // FIXME only increment for contiguous ranges
66 ++mOverruns;
Mikhail Naganova0c91332016-09-19 10:01:12 -070067 } else if (result != OK) {
68 ALOGE("Error when retrieving lost frames count from HAL: %d", result);
Glenn Kasten01066232012-02-27 11:50:44 -080069 }
70 return mFramesOverrun;
71}
72
Glenn Kastend79072e2016-01-06 08:41:20 -080073ssize_t AudioStreamInSource::read(void *buffer, size_t count)
Glenn Kasten01066232012-02-27 11:50:44 -080074{
Glenn Kasten6e0d67d2014-01-31 09:41:08 -080075 if (CC_UNLIKELY(!Format_isValid(mFormat))) {
Glenn Kasten01066232012-02-27 11:50:44 -080076 return NEGOTIATE;
77 }
Mikhail Naganova0c91332016-09-19 10:01:12 -070078 size_t bytesRead;
79 status_t result = mStream->read(buffer, count * mFrameSize, &bytesRead);
80 if (result == OK && bytesRead > 0) {
Glenn Kasten4d693d62014-03-06 07:53:11 -080081 size_t framesRead = bytesRead / mFrameSize;
Glenn Kasten01066232012-02-27 11:50:44 -080082 mFramesRead += framesRead;
83 return framesRead;
84 } else {
Mikhail Naganova0c91332016-09-19 10:01:12 -070085 ALOGE_IF(result != OK, "Error while reading data from HAL: %d", result);
Glenn Kasten01066232012-02-27 11:50:44 -080086 return bytesRead;
87 }
88}
89
90} // namespace android