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_IsVendorSourceCodecValidLdac(const uint8_t * p_codec_info)21 bool A2DP_IsVendorSourceCodecValidLdac(const uint8_t* p_codec_info) {
22 return false;
23 }
24
A2DP_IsVendorSinkCodecValidLdac(const uint8_t * p_codec_info)25 bool A2DP_IsVendorSinkCodecValidLdac(const uint8_t* p_codec_info) {
26 return false;
27 }
28
A2DP_IsVendorPeerSourceCodecValidLdac(const uint8_t * p_codec_info)29 bool A2DP_IsVendorPeerSourceCodecValidLdac(const uint8_t* p_codec_info) {
30 return false;
31 }
32
A2DP_IsVendorPeerSinkCodecValidLdac(const uint8_t * p_codec_info)33 bool A2DP_IsVendorPeerSinkCodecValidLdac(const uint8_t* p_codec_info) {
34 return false;
35 }
36
A2DP_IsVendorSinkCodecSupportedLdac(const uint8_t * p_codec_info)37 bool A2DP_IsVendorSinkCodecSupportedLdac(const uint8_t* p_codec_info) {
38 return false;
39 }
A2DP_IsPeerSourceCodecSupportedLdac(const uint8_t * p_codec_info)40 bool A2DP_IsPeerSourceCodecSupportedLdac(const uint8_t* p_codec_info) {
41 return false;
42 }
43
A2DP_VendorUsesRtpHeaderLdac(bool content_protection_enabled,const uint8_t * p_codec_info)44 bool A2DP_VendorUsesRtpHeaderLdac(bool content_protection_enabled,
45 const uint8_t* p_codec_info) {
46 return false;
47 }
48
A2DP_VendorCodecNameLdac(const uint8_t * p_codec_info)49 const char* A2DP_VendorCodecNameLdac(const uint8_t* p_codec_info) {
50 return "Ldac";
51 }
52
A2DP_VendorCodecTypeEqualsLdac(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)53 bool A2DP_VendorCodecTypeEqualsLdac(const uint8_t* p_codec_info_a,
54 const uint8_t* p_codec_info_b) {
55 return false;
56 }
57
A2DP_VendorCodecEqualsLdac(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)58 bool A2DP_VendorCodecEqualsLdac(const uint8_t* p_codec_info_a,
59 const uint8_t* p_codec_info_b) {
60 return false;
61 }
62
A2DP_VendorGetBitRateLdac(const uint8_t * p_codec_info)63 int A2DP_VendorGetBitRateLdac(const uint8_t* p_codec_info) { return -1; }
64
A2DP_VendorGetTrackSampleRateLdac(const uint8_t * p_codec_info)65 int A2DP_VendorGetTrackSampleRateLdac(const uint8_t* p_codec_info) {
66 return -1;
67 }
68
A2DP_VendorGetTrackBitsPerSampleLdac(const uint8_t * p_codec_info)69 int A2DP_VendorGetTrackBitsPerSampleLdac(const uint8_t* p_codec_info) {
70 return -1;
71 }
72
A2DP_VendorGetTrackChannelCountLdac(const uint8_t * p_codec_info)73 int A2DP_VendorGetTrackChannelCountLdac(const uint8_t* p_codec_info) {
74 return -1;
75 }
76
A2DP_VendorGetSinkTrackChannelTypeLdac(const uint8_t * p_codec_info)77 int A2DP_VendorGetSinkTrackChannelTypeLdac(const uint8_t* p_codec_info) {
78 return -1;
79 }
80
A2DP_VendorGetChannelModeCodeLdac(const uint8_t * p_codec_info)81 int A2DP_VendorGetChannelModeCodeLdac(const uint8_t* p_codec_info) {
82 return -1;
83 }
84
A2DP_VendorGetFrameSizeLdac(const uint8_t * p_codec_info)85 int A2DP_VendorGetFrameSizeLdac(const uint8_t* p_codec_info) { return -1; }
86
A2DP_VendorGetPacketTimestampLdac(const uint8_t * p_codec_info,const uint8_t * p_data,uint32_t * p_timestamp)87 bool A2DP_VendorGetPacketTimestampLdac(const uint8_t* p_codec_info,
88 const uint8_t* p_data,
89 uint32_t* p_timestamp) {
90 return false;
91 }
92
A2DP_VendorBuildCodecHeaderLdac(const uint8_t * p_codec_info,BT_HDR * p_buf,uint16_t frames_per_packet)93 bool A2DP_VendorBuildCodecHeaderLdac(const uint8_t* p_codec_info, BT_HDR* p_buf,
94 uint16_t frames_per_packet) {
95 return false;
96 }
97
A2DP_VendorCodecInfoStringLdac(const uint8_t * p_codec_info)98 std::string A2DP_VendorCodecInfoStringLdac(const uint8_t* p_codec_info) {
99 return "Unsupported codec: Ldac";
100 }
101
A2DP_VendorGetEncoderInterfaceLdac(const uint8_t * p_codec_info)102 const tA2DP_ENCODER_INTERFACE* A2DP_VendorGetEncoderInterfaceLdac(
103 const uint8_t* p_codec_info) {
104 return nullptr;
105 }
106
A2DP_VendorGetDecoderInterfaceLdac(const uint8_t * p_codec_info)107 const tA2DP_DECODER_INTERFACE* A2DP_VendorGetDecoderInterfaceLdac(
108 const uint8_t* p_codec_info) {
109 return nullptr;
110 }
111
A2DP_VendorAdjustCodecLdac(uint8_t * p_codec_info)112 bool A2DP_VendorAdjustCodecLdac(uint8_t* p_codec_info) { return false; }
113
A2DP_VendorSourceCodecIndexLdac(const uint8_t * p_codec_info)114 btav_a2dp_codec_index_t A2DP_VendorSourceCodecIndexLdac(
115 const uint8_t* p_codec_info) {
116 return BTAV_A2DP_CODEC_INDEX_MAX;
117 }
118
A2DP_VendorSinkCodecIndexLdac(const uint8_t * p_codec_info)119 btav_a2dp_codec_index_t A2DP_VendorSinkCodecIndexLdac(
120 const uint8_t* p_codec_info) {
121 return BTAV_A2DP_CODEC_INDEX_MAX;
122 }
123
A2DP_VendorCodecIndexStrLdac(void)124 const char* A2DP_VendorCodecIndexStrLdac(void) { return "Ldac"; }
125
A2DP_VendorCodecIndexStrLdacSink(void)126 const char* A2DP_VendorCodecIndexStrLdacSink(void) { return "Ldac SINK"; }
127
A2DP_VendorInitCodecConfigLdac(AvdtpSepConfig * p_cfg)128 bool A2DP_VendorInitCodecConfigLdac(AvdtpSepConfig* p_cfg) { return false; }
129
A2DP_VendorInitCodecConfigLdacSink(AvdtpSepConfig * p_cfg)130 bool A2DP_VendorInitCodecConfigLdacSink(AvdtpSepConfig* p_cfg) { return false; }
131
A2dpCodecConfigLdacSource(btav_a2dp_codec_priority_t codec_priority)132 A2dpCodecConfigLdacSource::A2dpCodecConfigLdacSource(
133 btav_a2dp_codec_priority_t codec_priority)
134 : A2dpCodecConfigLdacBase(BTAV_A2DP_CODEC_INDEX_SOURCE_LDAC,
135 A2DP_VendorCodecIndexStrLdac(), codec_priority,
136 true) {}
137
~A2dpCodecConfigLdacSource()138 A2dpCodecConfigLdacSource::~A2dpCodecConfigLdacSource() {}
139
init()140 bool A2dpCodecConfigLdacSource::init() { return false; }
141
useRtpHeaderMarkerBit() const142 bool A2dpCodecConfigLdacSource::useRtpHeaderMarkerBit() const { return false; }
143
debug_codec_dump(int fd)144 void A2dpCodecConfigLdacSource::debug_codec_dump(int fd) {}
145
setCodecConfig(const uint8_t * p_peer_codec_info,bool is_capability,uint8_t * p_result_codec_config)146 bool A2dpCodecConfigLdacBase::setCodecConfig(const uint8_t* p_peer_codec_info,
147 bool is_capability,
148 uint8_t* p_result_codec_config) {
149 return false;
150 }
151
setPeerCodecCapabilities(const uint8_t * p_peer_codec_capabilities)152 bool A2dpCodecConfigLdacBase::setPeerCodecCapabilities(
153 const uint8_t* p_peer_codec_capabilities) {
154 return false;
155 }
156
A2dpCodecConfigLdacSink(btav_a2dp_codec_priority_t codec_priority)157 A2dpCodecConfigLdacSink::A2dpCodecConfigLdacSink(
158 btav_a2dp_codec_priority_t codec_priority)
159 : A2dpCodecConfigLdacBase(BTAV_A2DP_CODEC_INDEX_SINK_LDAC,
160 A2DP_VendorCodecIndexStrLdacSink(),
161 codec_priority, false) {}
162
~A2dpCodecConfigLdacSink()163 A2dpCodecConfigLdacSink::~A2dpCodecConfigLdacSink() {}
164
init()165 bool A2dpCodecConfigLdacSink::init() { return false; }
166
useRtpHeaderMarkerBit() const167 bool A2dpCodecConfigLdacSink::useRtpHeaderMarkerBit() const { return false; }
168