blob: 9def180fcb9f32063c38b09e149a37c00298c3e6 [file] [log] [blame]
Chris Waddellca0dd182022-11-25 17:15:30 +00001#define LOG_TAG "UsecaseLookup"
2// #define LOG_NDEBUG 0
3
4#include "media/UsecaseLookup.h"
5
6#include <utils/Log.h>
7
8namespace android {
9namespace media {
10
11/**
12 * Add streamId and outputFlags to stream list.
13 */
14void UsecaseLookup::addStream(STREAMID streamId, bool outputFlagGame) {
15 ALOGV("%s streamId: %d outputFlagGame: %d", __func__, streamId, outputFlagGame);
16
17 mutex_lock lock(m_mutex);
18 m_streams[streamId] = outputFlagGame;
19}
20
21/**
22 * Remove streamId from stream list.
23 */
24void UsecaseLookup::removeStream(STREAMID streamId) {
25 ALOGV("%s streamId: %d ", __func__, streamId);
26
27 mutex_lock lock(m_mutex);
28 m_streams.erase(streamId);
29
30 // Shouldn't happen but it might.
31 for (auto it = m_tracks.begin(); it != m_tracks.end();) {
32 if (it->second == streamId) {
33 it = m_tracks.erase(it);
34 } else {
35 it++;
36 }
37 }
38}
39
40/**
41 * Add streamId and portId to track list.
42 */
43void UsecaseLookup::addTrack(STREAMID streamId, PORTID portId) {
44 ALOGV("%s streamId: %d portId: %d", __func__, streamId, portId);
45
46 mutex_lock lock(m_mutex);
47
48 if (m_tracks.find(portId) == m_tracks.end()) {
49 m_tracks[portId] = streamId;
50 }
51}
52
53/**
54 * Remove streamId and portId from track list.
55 */
56void UsecaseLookup::removeTrack(STREAMID streamId, PORTID portId) {
57 ALOGV("%s streamId: %d portId: %d", __func__, streamId, portId);
58
59 mutex_lock lock(m_mutex);
60 auto it = m_tracks.find(portId);
61
62 if (it != m_tracks.end() && it->second == streamId) {
63 m_tracks.erase(portId);
64 }
65}
66
67/**
68 * Check if stream list contains streamId with Game outputFlag.
69 */
70bool UsecaseLookup::isGameStream(STREAMID streamId) {
71 ALOGV("%s streamId: %d ", __func__, streamId);
72 mutex_lock lock(m_mutex);
73 auto it = m_streams.find(streamId);
74
75 return (it != m_streams.end()) ? it->second : false;
76}
77
78} // namespace media
79} // namespace android