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