OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "components/arc/audio/arc_audio_bridge.h" | 5 #include "components/arc/audio/arc_audio_bridge.h" |
6 | 6 |
7 #include "ash/common/system/tray/system_tray_notifier.h" | 7 #include "ash/common/system/tray/system_tray_notifier.h" |
8 #include "ash/common/wm_shell.h" | 8 #include "ash/common/wm_shell.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "chromeos/audio/audio_device.h" | 10 #include "chromeos/audio/audio_device.h" |
11 | 11 |
12 namespace arc { | 12 namespace arc { |
13 | 13 |
| 14 namespace { |
| 15 |
| 16 // Note: unlike most of our mojom definitions, AudioInstance::Init's minimum |
| 17 // version is not zero. |
| 18 constexpr uint32_t kMinInstanceVersionForInit = 1; |
| 19 |
| 20 } // namespace |
| 21 |
14 ArcAudioBridge::ArcAudioBridge(ArcBridgeService* bridge_service) | 22 ArcAudioBridge::ArcAudioBridge(ArcBridgeService* bridge_service) |
15 : ArcService(bridge_service), binding_(this) { | 23 : ArcService(bridge_service), binding_(this) { |
16 arc_bridge_service()->audio()->AddObserver(this); | 24 arc_bridge_service()->audio()->AddObserver(this); |
17 if (chromeos::CrasAudioHandler::IsInitialized()) { | 25 if (chromeos::CrasAudioHandler::IsInitialized()) { |
18 cras_audio_handler_ = chromeos::CrasAudioHandler::Get(); | 26 cras_audio_handler_ = chromeos::CrasAudioHandler::Get(); |
19 cras_audio_handler_->AddAudioObserver(this); | 27 cras_audio_handler_->AddAudioObserver(this); |
20 } | 28 } |
21 } | 29 } |
22 | 30 |
23 ArcAudioBridge::~ArcAudioBridge() { | 31 ArcAudioBridge::~ArcAudioBridge() { |
24 if (cras_audio_handler_ && chromeos::CrasAudioHandler::IsInitialized()) { | 32 if (cras_audio_handler_ && chromeos::CrasAudioHandler::IsInitialized()) { |
25 cras_audio_handler_->RemoveAudioObserver(this); | 33 cras_audio_handler_->RemoveAudioObserver(this); |
26 } | 34 } |
27 arc_bridge_service()->audio()->RemoveObserver(this); | 35 arc_bridge_service()->audio()->RemoveObserver(this); |
28 } | 36 } |
29 | 37 |
30 void ArcAudioBridge::OnInstanceReady() { | 38 void ArcAudioBridge::OnInstanceReady() { |
31 mojom::AudioInstance* audio_instance = | 39 mojom::AudioInstance* audio_instance = |
32 arc_bridge_service()->audio()->instance(); | 40 arc_bridge_service()->audio()->GetInstanceForMethod( |
33 if (!audio_instance) { | 41 "Init", kMinInstanceVersionForInit); |
34 LOG(ERROR) << "OnAudioInstanceReady called, " | 42 CHECK(audio_instance); // the instance on ARC side is too old. |
35 << "but no audio instance found"; | |
36 return; | |
37 } | |
38 if (arc_bridge_service()->audio()->version() < 1) { | |
39 LOG(WARNING) << "Audio instance is too old and does not support Init()"; | |
40 return; | |
41 } | |
42 audio_instance->Init(binding_.CreateInterfacePtrAndBind()); | 43 audio_instance->Init(binding_.CreateInterfacePtrAndBind()); |
43 } | 44 } |
44 | 45 |
45 void ArcAudioBridge::ShowVolumeControls() { | 46 void ArcAudioBridge::ShowVolumeControls() { |
46 VLOG(2) << "ArcAudioBridge::ShowVolumeControls"; | 47 VLOG(2) << "ArcAudioBridge::ShowVolumeControls"; |
47 ash::WmShell::Get()->system_tray_notifier()->NotifyAudioOutputVolumeChanged( | 48 ash::WmShell::Get()->system_tray_notifier()->NotifyAudioOutputVolumeChanged( |
48 0, 0); | 49 0, 0); |
49 } | 50 } |
50 | 51 |
51 void ArcAudioBridge::OnAudioNodesChanged() { | 52 void ArcAudioBridge::OnAudioNodesChanged() { |
(...skipping 23 matching lines...) Expand all Loading... |
75 switch_state |= | 76 switch_state |= |
76 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_HEADPHONE_INSERT)); | 77 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_HEADPHONE_INSERT)); |
77 } | 78 } |
78 if (microphone_inserted) { | 79 if (microphone_inserted) { |
79 switch_state |= | 80 switch_state |= |
80 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_MICROPHONE_INSERT)); | 81 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_MICROPHONE_INSERT)); |
81 } | 82 } |
82 | 83 |
83 VLOG(1) << "Send switch state " << switch_state; | 84 VLOG(1) << "Send switch state " << switch_state; |
84 mojom::AudioInstance* audio_instance = | 85 mojom::AudioInstance* audio_instance = |
85 arc_bridge_service()->audio()->instance(); | 86 arc_bridge_service()->audio()->GetInstanceForMethod("NotifySwitchState"); |
86 if (audio_instance) | 87 if (audio_instance) |
87 audio_instance->NotifySwitchState(switch_state); | 88 audio_instance->NotifySwitchState(switch_state); |
88 } | 89 } |
89 | 90 |
90 } // namespace arc | 91 } // namespace arc |
OLD | NEW |