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_ldac.h"
20 
A2DP_IsCodecValidLdac(const uint8_t * p_codec_info)21 bool A2DP_IsCodecValidLdac(const uint8_t* p_codec_info) { return false; }
22 
A2DP_IsVendorSinkCodecSupportedLdac(const uint8_t * p_codec_info)23 tA2DP_STATUS A2DP_IsVendorSinkCodecSupportedLdac(const uint8_t* p_codec_info) {
24   return A2DP_NOT_SUPPORTED_CODEC_TYPE;
25 }
26 
A2DP_VendorUsesRtpHeaderLdac(bool content_protection_enabled,const uint8_t * p_codec_info)27 bool A2DP_VendorUsesRtpHeaderLdac(bool content_protection_enabled,
28                                   const uint8_t* p_codec_info) {
29   return false;
30 }
31 
A2DP_VendorCodecNameLdac(const uint8_t * p_codec_info)32 const char* A2DP_VendorCodecNameLdac(const uint8_t* p_codec_info) {
33   return "Ldac";
34 }
35 
A2DP_VendorCodecTypeEqualsLdac(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)36 bool A2DP_VendorCodecTypeEqualsLdac(const uint8_t* p_codec_info_a,
37                                     const uint8_t* p_codec_info_b) {
38   return false;
39 }
40 
A2DP_VendorCodecEqualsLdac(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)41 bool A2DP_VendorCodecEqualsLdac(const uint8_t* p_codec_info_a,
42                                 const uint8_t* p_codec_info_b) {
43   return false;
44 }
45 
A2DP_VendorGetBitRateLdac(const uint8_t * p_codec_info)46 int A2DP_VendorGetBitRateLdac(const uint8_t* p_codec_info) { return -1; }
47 
A2DP_VendorGetTrackSampleRateLdac(const uint8_t * p_codec_info)48 int A2DP_VendorGetTrackSampleRateLdac(const uint8_t* p_codec_info) { return -1; }
49 
A2DP_VendorGetTrackBitsPerSampleLdac(const uint8_t * p_codec_info)50 int A2DP_VendorGetTrackBitsPerSampleLdac(const uint8_t* p_codec_info) { return -1; }
51 
A2DP_VendorGetTrackChannelCountLdac(const uint8_t * p_codec_info)52 int A2DP_VendorGetTrackChannelCountLdac(const uint8_t* p_codec_info) { return -1; }
53 
A2DP_VendorGetSinkTrackChannelTypeLdac(const uint8_t * p_codec_info)54 int A2DP_VendorGetSinkTrackChannelTypeLdac(const uint8_t* p_codec_info) { return -1; }
55 
A2DP_VendorGetChannelModeCodeLdac(const uint8_t * p_codec_info)56 int A2DP_VendorGetChannelModeCodeLdac(const uint8_t* p_codec_info) { return -1; }
57 
A2DP_VendorGetFrameSizeLdac(const uint8_t * p_codec_info)58 int A2DP_VendorGetFrameSizeLdac(const uint8_t* p_codec_info) { return -1; }
59 
A2DP_VendorGetPacketTimestampLdac(const uint8_t * p_codec_info,const uint8_t * p_data,uint32_t * p_timestamp)60 bool A2DP_VendorGetPacketTimestampLdac(const uint8_t* p_codec_info, const uint8_t* p_data,
61                                        uint32_t* p_timestamp) {
62   return false;
63 }
64 
A2DP_VendorBuildCodecHeaderLdac(const uint8_t * p_codec_info,BT_HDR * p_buf,uint16_t frames_per_packet)65 bool A2DP_VendorBuildCodecHeaderLdac(const uint8_t* p_codec_info, BT_HDR* p_buf,
66                                      uint16_t frames_per_packet) {
67   return false;
68 }
69 
A2DP_VendorCodecInfoStringLdac(const uint8_t * p_codec_info)70 std::string A2DP_VendorCodecInfoStringLdac(const uint8_t* p_codec_info) {
71   return "Unsupported codec: Ldac";
72 }
73 
A2DP_VendorGetEncoderInterfaceLdac(const uint8_t * p_codec_info)74 const tA2DP_ENCODER_INTERFACE* A2DP_VendorGetEncoderInterfaceLdac(const uint8_t* p_codec_info) {
75   return nullptr;
76 }
77 
A2DP_VendorGetDecoderInterfaceLdac(const uint8_t * p_codec_info)78 const tA2DP_DECODER_INTERFACE* A2DP_VendorGetDecoderInterfaceLdac(const uint8_t* p_codec_info) {
79   return nullptr;
80 }
81 
A2DP_VendorAdjustCodecLdac(uint8_t * p_codec_info)82 bool A2DP_VendorAdjustCodecLdac(uint8_t* p_codec_info) { return false; }
83 
A2DP_VendorSourceCodecIndexLdac(const uint8_t * p_codec_info)84 btav_a2dp_codec_index_t A2DP_VendorSourceCodecIndexLdac(const uint8_t* p_codec_info) {
85   return BTAV_A2DP_CODEC_INDEX_MAX;
86 }
87 
A2DP_VendorSinkCodecIndexLdac(const uint8_t * p_codec_info)88 btav_a2dp_codec_index_t A2DP_VendorSinkCodecIndexLdac(const uint8_t* p_codec_info) {
89   return BTAV_A2DP_CODEC_INDEX_MAX;
90 }
91 
A2DP_VendorCodecIndexStrLdac(void)92 const char* A2DP_VendorCodecIndexStrLdac(void) { return "Ldac"; }
93 
A2DP_VendorCodecIndexStrLdacSink(void)94 const char* A2DP_VendorCodecIndexStrLdacSink(void) { return "Ldac SINK"; }
95 
A2DP_VendorInitCodecConfigLdac(AvdtpSepConfig * p_cfg)96 bool A2DP_VendorInitCodecConfigLdac(AvdtpSepConfig* p_cfg) { return false; }
97 
A2DP_VendorInitCodecConfigLdacSink(AvdtpSepConfig * p_cfg)98 bool A2DP_VendorInitCodecConfigLdacSink(AvdtpSepConfig* p_cfg) { return false; }
99 
A2dpCodecConfigLdacSource(btav_a2dp_codec_priority_t codec_priority)100 A2dpCodecConfigLdacSource::A2dpCodecConfigLdacSource(btav_a2dp_codec_priority_t codec_priority)
101     : A2dpCodecConfigLdacBase(BTAV_A2DP_CODEC_INDEX_SOURCE_LDAC, A2DP_VendorCodecIndexStrLdac(),
102                               codec_priority, true) {}
103 
~A2dpCodecConfigLdacSource()104 A2dpCodecConfigLdacSource::~A2dpCodecConfigLdacSource() {}
105 
init()106 bool A2dpCodecConfigLdacSource::init() { return false; }
107 
useRtpHeaderMarkerBit() const108 bool A2dpCodecConfigLdacSource::useRtpHeaderMarkerBit() const { return false; }
109 
debug_codec_dump(int fd)110 void A2dpCodecConfigLdacSource::debug_codec_dump(int fd) {}
111 
setCodecConfig(const uint8_t * p_peer_codec_info,bool is_capability,uint8_t * p_result_codec_config)112 tA2DP_STATUS A2dpCodecConfigLdacBase::setCodecConfig(const uint8_t* p_peer_codec_info,
113                                                      bool is_capability,
114                                                      uint8_t* p_result_codec_config) {
115   return AVDTP_UNSUPPORTED_CONFIGURATION;
116 }
117 
setPeerCodecCapabilities(const uint8_t * p_peer_codec_capabilities)118 bool A2dpCodecConfigLdacBase::setPeerCodecCapabilities(const uint8_t* p_peer_codec_capabilities) {
119   return false;
120 }
121 
A2dpCodecConfigLdacSink(btav_a2dp_codec_priority_t codec_priority)122 A2dpCodecConfigLdacSink::A2dpCodecConfigLdacSink(btav_a2dp_codec_priority_t codec_priority)
123     : A2dpCodecConfigLdacBase(BTAV_A2DP_CODEC_INDEX_SINK_LDAC, A2DP_VendorCodecIndexStrLdacSink(),
124                               codec_priority, false) {}
125 
~A2dpCodecConfigLdacSink()126 A2dpCodecConfigLdacSink::~A2dpCodecConfigLdacSink() {}
127 
init()128 bool A2dpCodecConfigLdacSink::init() { return false; }
129 
useRtpHeaderMarkerBit() const130 bool A2dpCodecConfigLdacSink::useRtpHeaderMarkerBit() const { return false; }
131