blob: 905a4cd1a0ba52feb72dcb676f63ca530bbb04eb [file] [log] [blame]
Vlad Popab042ee62022-10-20 18:05:00 +02001/*
2**
3** Copyright 2022, The Android Open Source Project
4**
5** Licensed under the Apache License, Version 2.0 (the "License");
6** you may not use this file except in compliance with the License.
7** You may obtain a copy of the License at
8**
9** http://www.apache.org/licenses/LICENSE-2.0
10**
11** Unless required by applicable law or agreed to in writing, software
12** distributed under the License is distributed on an "AS IS" BASIS,
13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14** See the License for the specific language governing permissions and
15** limitations under the License.
16*/
17
18#ifndef INCLUDING_FROM_AUDIOFLINGER_H
19 #error This header file should only be included from AudioFlinger.h
20#endif
21
22#include <unordered_map>
23#include <mutex>
24
25constexpr static int kMaxTimestampDeltaInSec = 120;
26
27/**
28 * Class for listening to new patches and starting the MEL computation. MelReporter is
29 * concealed within AudioFlinger, their lifetimes are the same.
30 */
31class MelReporter : public PatchCommandThread::PatchCommandListener {
32public:
33 explicit MelReporter(AudioFlinger& audioFlinger)
34 : mAudioFlinger(audioFlinger),
35 mMelAggregator(kMaxTimestampDeltaInSec) {}
36
37 void onFirstRef() override {
38 mAudioFlinger.mPatchCommandThread->addListener(this);
39 }
40
41 /** Returns true if we should compute MEL for the given device. */
42 static bool shouldComputeMelForDeviceType(audio_devices_t device);
43
44 // For now only support internal MelReporting
45 [[nodiscard]] bool isHalReportingEnabled() const { return false; }
46
47 std::string dump();
48
49 // PatchCommandListener methods
50 void onCreateAudioPatch(audio_patch_handle_t handle,
51 const PatchPanel::Patch& patch) override;
52 void onReleaseAudioPatch(audio_patch_handle_t handle) override;
53
54private:
55 AudioFlinger& mAudioFlinger; // does not own the object
56
57 audio_utils::MelAggregator mMelAggregator;
58
59 struct ActiveMelPatch {
60 audio_io_handle_t streamHandle{AUDIO_IO_HANDLE_NONE};
61 std::vector<audio_port_handle_t> deviceHandles;
62 };
63
64 /**
65 * Lock for protecting the active mel patches. Do not mix with the AudioFlinger lock.
66 * Locking order AudioFlinger::mLock -> PatchCommandThread::mLock -> MelReporter::mLock.
67 */
68 std::mutex mLock;
69 std::unordered_map<audio_patch_handle_t, ActiveMelPatch>
70 mActiveMelPatches GUARDED_BY(AudioFlinger::MelReporter::mLock);
71};