1 /*
2 * Copyright 2023 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 // Stubbed non-standard codec.
18
19 #include "a2dp_vendor.h"
20 #include "a2dp_vendor_opus.h"
21
A2DP_IsCodecValidOpus(const uint8_t * p_codec_info)22 bool A2DP_IsCodecValidOpus(const uint8_t* p_codec_info) { return false; }
23
A2DP_IsVendorSinkCodecSupportedOpus(const uint8_t * p_codec_info)24 tA2DP_STATUS A2DP_IsVendorSinkCodecSupportedOpus(const uint8_t* p_codec_info) {
25 return A2DP_NOT_SUPPORTED_CODEC_TYPE;
26 }
27
A2DP_VendorUsesRtpHeaderOpus(bool content_protection_enabled,const uint8_t * p_codec_info)28 bool A2DP_VendorUsesRtpHeaderOpus(bool content_protection_enabled,
29 const uint8_t* p_codec_info) {
30 return false;
31 }
32
A2DP_VendorCodecNameOpus(const uint8_t * p_codec_info)33 const char* A2DP_VendorCodecNameOpus(const uint8_t* p_codec_info) {
34 return "Opus";
35 }
36
A2DP_VendorCodecTypeEqualsOpus(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)37 bool A2DP_VendorCodecTypeEqualsOpus(const uint8_t* p_codec_info_a,
38 const uint8_t* p_codec_info_b) {
39 return false;
40 }
41
A2DP_VendorCodecEqualsOpus(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)42 bool A2DP_VendorCodecEqualsOpus(const uint8_t* p_codec_info_a,
43 const uint8_t* p_codec_info_b) {
44 return false;
45 }
46
A2DP_VendorGetBitRateOpus(const uint8_t * p_codec_info)47 int A2DP_VendorGetBitRateOpus(const uint8_t* p_codec_info) { return -1; }
48
A2DP_VendorGetTrackSampleRateOpus(const uint8_t * p_codec_info)49 int A2DP_VendorGetTrackSampleRateOpus(const uint8_t* p_codec_info) { return -1; }
50
A2DP_VendorGetTrackBitsPerSampleOpus(const uint8_t * p_codec_info)51 int A2DP_VendorGetTrackBitsPerSampleOpus(const uint8_t* p_codec_info) { return -1; }
52
A2DP_VendorGetTrackChannelCountOpus(const uint8_t * p_codec_info)53 int A2DP_VendorGetTrackChannelCountOpus(const uint8_t* p_codec_info) { return -1; }
54
A2DP_VendorGetSinkTrackChannelTypeOpus(const uint8_t * p_codec_info)55 int A2DP_VendorGetSinkTrackChannelTypeOpus(const uint8_t* p_codec_info) { return -1; }
56
A2DP_VendorGetChannelModeCodeOpus(const uint8_t * p_codec_info)57 int A2DP_VendorGetChannelModeCodeOpus(const uint8_t* p_codec_info) { return -1; }
58
A2DP_VendorGetFrameSizeOpus(const uint8_t * p_codec_info)59 int A2DP_VendorGetFrameSizeOpus(const uint8_t* p_codec_info) { return -1; }
60
A2DP_VendorGetPacketTimestampOpus(const uint8_t * p_codec_info,const uint8_t * p_data,uint32_t * p_timestamp)61 bool A2DP_VendorGetPacketTimestampOpus(const uint8_t* p_codec_info, const uint8_t* p_data,
62 uint32_t* p_timestamp) {
63 return false;
64 }
65
A2DP_VendorBuildCodecHeaderOpus(const uint8_t * p_codec_info,BT_HDR * p_buf,uint16_t frames_per_packet)66 bool A2DP_VendorBuildCodecHeaderOpus(const uint8_t* p_codec_info, BT_HDR* p_buf,
67 uint16_t frames_per_packet) {
68 return false;
69 }
70
A2DP_VendorCodecInfoStringOpus(const uint8_t * p_codec_info)71 std::string A2DP_VendorCodecInfoStringOpus(const uint8_t* p_codec_info) {
72 return "Unsupported codec: Opus";
73 }
74
A2DP_VendorGetEncoderInterfaceOpus(const uint8_t * p_codec_info)75 const tA2DP_ENCODER_INTERFACE* A2DP_VendorGetEncoderInterfaceOpus(const uint8_t* p_codec_info) {
76 return nullptr;
77 }
78
A2DP_VendorGetDecoderInterfaceOpus(const uint8_t * p_codec_info)79 const tA2DP_DECODER_INTERFACE* A2DP_VendorGetDecoderInterfaceOpus(const uint8_t* p_codec_info) {
80 return nullptr;
81 }
82
A2DP_VendorAdjustCodecOpus(uint8_t * p_codec_info)83 bool A2DP_VendorAdjustCodecOpus(uint8_t* p_codec_info) { return false; }
84
A2DP_VendorSourceCodecIndexOpus(const uint8_t * p_codec_info)85 btav_a2dp_codec_index_t A2DP_VendorSourceCodecIndexOpus(const uint8_t* p_codec_info) {
86 return BTAV_A2DP_CODEC_INDEX_MAX;
87 }
88
A2DP_VendorSinkCodecIndexOpus(const uint8_t * p_codec_info)89 btav_a2dp_codec_index_t A2DP_VendorSinkCodecIndexOpus(const uint8_t* p_codec_info) {
90 return BTAV_A2DP_CODEC_INDEX_MAX;
91 }
92
A2DP_VendorCodecIndexStrOpus(void)93 const char* A2DP_VendorCodecIndexStrOpus(void) { return "Opus"; }
94
A2DP_VendorCodecIndexStrOpusSink(void)95 const char* A2DP_VendorCodecIndexStrOpusSink(void) { return "Opus SINK"; }
96
A2DP_VendorInitCodecConfigOpus(AvdtpSepConfig * p_cfg)97 bool A2DP_VendorInitCodecConfigOpus(AvdtpSepConfig* p_cfg) { return false; }
98
A2DP_VendorInitCodecConfigOpusSink(AvdtpSepConfig * p_cfg)99 bool A2DP_VendorInitCodecConfigOpusSink(AvdtpSepConfig* p_cfg) { return false; }
100
A2dpCodecConfigOpusSource(btav_a2dp_codec_priority_t codec_priority)101 A2dpCodecConfigOpusSource::A2dpCodecConfigOpusSource(btav_a2dp_codec_priority_t codec_priority)
102 : A2dpCodecConfigOpusBase(BTAV_A2DP_CODEC_INDEX_SOURCE_OPUS, A2DP_VendorCodecIndexStrOpus(),
103 codec_priority, true) {}
104
~A2dpCodecConfigOpusSource()105 A2dpCodecConfigOpusSource::~A2dpCodecConfigOpusSource() {}
106
init()107 bool A2dpCodecConfigOpusSource::init() { return false; }
108
useRtpHeaderMarkerBit() const109 bool A2dpCodecConfigOpusSource::useRtpHeaderMarkerBit() const { return false; }
110
debug_codec_dump(int fd)111 void A2dpCodecConfigOpusSource::debug_codec_dump(int fd) {}
112
setCodecConfig(const uint8_t * p_peer_codec_info,bool is_capability,uint8_t * p_result_codec_config)113 tA2DP_STATUS A2dpCodecConfigOpusBase::setCodecConfig(const uint8_t* p_peer_codec_info,
114 bool is_capability,
115 uint8_t* p_result_codec_config) {
116 return AVDTP_UNSUPPORTED_CONFIGURATION;
117 }
118
setPeerCodecCapabilities(const uint8_t * p_peer_codec_capabilities)119 bool A2dpCodecConfigOpusBase::setPeerCodecCapabilities(const uint8_t* p_peer_codec_capabilities) {
120 return false;
121 }
122
A2dpCodecConfigOpusSink(btav_a2dp_codec_priority_t codec_priority)123 A2dpCodecConfigOpusSink::A2dpCodecConfigOpusSink(btav_a2dp_codec_priority_t codec_priority)
124 : A2dpCodecConfigOpusBase(BTAV_A2DP_CODEC_INDEX_SINK_OPUS, A2DP_VendorCodecIndexStrOpusSink(),
125 codec_priority, false) {}
126
~A2dpCodecConfigOpusSink()127 A2dpCodecConfigOpusSink::~A2dpCodecConfigOpusSink() {}
128
init()129 bool A2dpCodecConfigOpusSink::init() { return false; }
130
useRtpHeaderMarkerBit() const131 bool A2dpCodecConfigOpusSink::useRtpHeaderMarkerBit() const { return false; }
132
updateEncoderUserConfig(const tA2DP_ENCODER_INIT_PEER_PARAMS * p_peer_params,bool * p_restart_input,bool * p_restart_output,bool * p_config_updated)133 bool A2dpCodecConfigOpusSink::updateEncoderUserConfig(
134 const tA2DP_ENCODER_INIT_PEER_PARAMS* p_peer_params, bool* p_restart_input,
135 bool* p_restart_output, bool* p_config_updated) {
136 return false;
137 }
138