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 <cstdint>
20 
21 #include "a2dp_vendor_aptx.h"
22 
A2DP_IsCodecValidAptx(const uint8_t * p_codec_info)23 bool A2DP_IsCodecValidAptx(const uint8_t* p_codec_info) { return false; }
24 
A2DP_VendorUsesRtpHeaderAptx(bool content_protection_enabled,const uint8_t * p_codec_info)25 bool A2DP_VendorUsesRtpHeaderAptx(bool content_protection_enabled, const uint8_t* p_codec_info) {
26   return false;
27 }
28 
A2DP_VendorCodecNameAptx(const uint8_t * p_codec_info)29 const char* A2DP_VendorCodecNameAptx(const uint8_t* p_codec_info) { return "Aptx"; }
30 
A2DP_VendorCodecTypeEqualsAptx(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)31 bool A2DP_VendorCodecTypeEqualsAptx(const uint8_t* p_codec_info_a, const uint8_t* p_codec_info_b) {
32   return false;
33 }
34 
A2DP_VendorCodecEqualsAptx(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)35 bool A2DP_VendorCodecEqualsAptx(const uint8_t* p_codec_info_a, const uint8_t* p_codec_info_b) {
36   return false;
37 }
38 
A2DP_VendorGetBitRateAptx(const uint8_t * p_codec_info)39 int A2DP_VendorGetBitRateAptx(const uint8_t* p_codec_info) { return -1; }
40 
A2DP_VendorGetTrackSampleRateAptx(const uint8_t * p_codec_info)41 int A2DP_VendorGetTrackSampleRateAptx(const uint8_t* p_codec_info) { return -1; }
42 
A2DP_VendorGetTrackBitsPerSampleAptx(const uint8_t * p_codec_info)43 int A2DP_VendorGetTrackBitsPerSampleAptx(const uint8_t* p_codec_info) { return -1; }
44 
A2DP_VendorGetTrackChannelCountAptx(const uint8_t * p_codec_info)45 int A2DP_VendorGetTrackChannelCountAptx(const uint8_t* p_codec_info) { return -1; }
46 
A2DP_VendorGetSinkTrackChannelTypeAptx(const uint8_t * p_codec_info)47 int A2DP_VendorGetSinkTrackChannelTypeAptx(const uint8_t* p_codec_info) { return -1; }
48 
A2DP_VendorGetChannelModeCodeAptx(const uint8_t * p_codec_info)49 int A2DP_VendorGetChannelModeCodeAptx(const uint8_t* p_codec_info) { return -1; }
50 
A2DP_VendorGetFrameSizeAptx(const uint8_t * p_codec_info)51 int A2DP_VendorGetFrameSizeAptx(const uint8_t* p_codec_info) { return -1; }
52 
A2DP_VendorGetPacketTimestampAptx(const uint8_t * p_codec_info,const uint8_t * p_data,uint32_t * p_timestamp)53 bool A2DP_VendorGetPacketTimestampAptx(const uint8_t* p_codec_info, const uint8_t* p_data,
54                                        uint32_t* p_timestamp) {
55   return false;
56 }
57 
A2DP_VendorBuildCodecHeaderAptx(const uint8_t * p_codec_info,BT_HDR * p_buf,uint16_t frames_per_packet)58 bool A2DP_VendorBuildCodecHeaderAptx(const uint8_t* p_codec_info, BT_HDR* p_buf,
59                                      uint16_t frames_per_packet) {
60   return false;
61 }
62 
A2DP_VendorCodecInfoStringAptx(const uint8_t * p_codec_info)63 std::string A2DP_VendorCodecInfoStringAptx(const uint8_t* p_codec_info) {
64   return "Unsupported codec: Aptx";
65 }
66 
A2DP_VendorGetEncoderInterfaceAptx(const uint8_t * p_codec_info)67 const tA2DP_ENCODER_INTERFACE* A2DP_VendorGetEncoderInterfaceAptx(const uint8_t* p_codec_info) {
68   return nullptr;
69 }
70 
A2DP_VendorGetDecoderInterfaceAptx(const uint8_t * p_codec_info)71 const tA2DP_DECODER_INTERFACE* A2DP_VendorGetDecoderInterfaceAptx(const uint8_t* p_codec_info) {
72   return nullptr;
73 }
74 
A2DP_VendorAdjustCodecAptx(uint8_t * p_codec_info)75 bool A2DP_VendorAdjustCodecAptx(uint8_t* p_codec_info) { return false; }
76 
A2DP_VendorSourceCodecIndexAptx(const uint8_t * p_codec_info)77 btav_a2dp_codec_index_t A2DP_VendorSourceCodecIndexAptx(const uint8_t* p_codec_info) {
78   return BTAV_A2DP_CODEC_INDEX_MAX;
79 }
80 
A2DP_VendorSinkCodecIndexAptx(const uint8_t * p_codec_info)81 btav_a2dp_codec_index_t A2DP_VendorSinkCodecIndexAptx(const uint8_t* p_codec_info) {
82   return BTAV_A2DP_CODEC_INDEX_MAX;
83 }
84 
A2DP_VendorCodecIndexStrAptx(void)85 const char* A2DP_VendorCodecIndexStrAptx(void) { return "Aptx"; }
86 
A2DP_VendorInitCodecConfigAptx(AvdtpSepConfig * p_cfg)87 bool A2DP_VendorInitCodecConfigAptx(AvdtpSepConfig* p_cfg) { return false; }
88 
A2dpCodecConfigAptx(btav_a2dp_codec_priority_t codec_priority)89 A2dpCodecConfigAptx::A2dpCodecConfigAptx(btav_a2dp_codec_priority_t codec_priority)
90     : A2dpCodecConfig(BTAV_A2DP_CODEC_INDEX_SOURCE_APTX, bluetooth::a2dp::CodecId::APTX,
91                       A2DP_VendorCodecIndexStrAptx(), codec_priority) {}
92 
~A2dpCodecConfigAptx()93 A2dpCodecConfigAptx::~A2dpCodecConfigAptx() {}
94 
init()95 bool A2dpCodecConfigAptx::init() { return false; }
96 
useRtpHeaderMarkerBit() const97 bool A2dpCodecConfigAptx::useRtpHeaderMarkerBit() const { return false; }
98 
debug_codec_dump(int fd)99 void A2dpCodecConfigAptx::debug_codec_dump(int fd) {}
100 
setCodecConfig(const uint8_t * p_peer_codec_info,bool is_capability,uint8_t * p_result_codec_config)101 tA2DP_STATUS A2dpCodecConfigAptx::setCodecConfig(const uint8_t* p_peer_codec_info,
102                                                  bool is_capability,
103                                                  uint8_t* p_result_codec_config) {
104   return AVDTP_UNSUPPORTED_CONFIGURATION;
105 }
106 
setPeerCodecCapabilities(const uint8_t * p_peer_codec_capabilities)107 bool A2dpCodecConfigAptx::setPeerCodecCapabilities(const uint8_t* p_peer_codec_capabilities) {
108   return false;
109 }
110