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_hd.h"
22
A2DP_IsCodecValidAptxHd(const uint8_t * p_codec_info)23 bool A2DP_IsCodecValidAptxHd(const uint8_t* p_codec_info) { return false; }
24
A2DP_VendorUsesRtpHeaderAptxHd(bool content_protection_enabled,const uint8_t * p_codec_info)25 bool A2DP_VendorUsesRtpHeaderAptxHd(bool content_protection_enabled,
26 const uint8_t* p_codec_info) {
27 return false;
28 }
29
A2DP_VendorCodecNameAptxHd(const uint8_t * p_codec_info)30 const char* A2DP_VendorCodecNameAptxHd(const uint8_t* p_codec_info) {
31 return "AptxHd";
32 }
33
A2DP_VendorCodecTypeEqualsAptxHd(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)34 bool A2DP_VendorCodecTypeEqualsAptxHd(const uint8_t* p_codec_info_a,
35 const uint8_t* p_codec_info_b) {
36 return false;
37 }
38
A2DP_VendorCodecEqualsAptxHd(const uint8_t * p_codec_info_a,const uint8_t * p_codec_info_b)39 bool A2DP_VendorCodecEqualsAptxHd(const uint8_t* p_codec_info_a, const uint8_t* p_codec_info_b) {
40 return false;
41 }
42
A2DP_VendorGetBitRateAptxHd(const uint8_t * p_codec_info)43 int A2DP_VendorGetBitRateAptxHd(const uint8_t* p_codec_info) { return -1; }
44
A2DP_VendorGetTrackSampleRateAptxHd(const uint8_t * p_codec_info)45 int A2DP_VendorGetTrackSampleRateAptxHd(const uint8_t* p_codec_info) { return -1; }
46
A2DP_VendorGetTrackBitsPerSampleAptxHd(const uint8_t * p_codec_info)47 int A2DP_VendorGetTrackBitsPerSampleAptxHd(const uint8_t* p_codec_info) { return -1; }
48
A2DP_VendorGetTrackChannelCountAptxHd(const uint8_t * p_codec_info)49 int A2DP_VendorGetTrackChannelCountAptxHd(const uint8_t* p_codec_info) { return -1; }
50
A2DP_VendorGetSinkTrackChannelTypeAptxHd(const uint8_t * p_codec_info)51 int A2DP_VendorGetSinkTrackChannelTypeAptxHd(const uint8_t* p_codec_info) { return -1; }
52
A2DP_VendorGetChannelModeCodeAptxHd(const uint8_t * p_codec_info)53 int A2DP_VendorGetChannelModeCodeAptxHd(const uint8_t* p_codec_info) { return -1; }
54
A2DP_VendorGetFrameSizeAptxHd(const uint8_t * p_codec_info)55 int A2DP_VendorGetFrameSizeAptxHd(const uint8_t* p_codec_info) { return -1; }
56
A2DP_VendorGetPacketTimestampAptxHd(const uint8_t * p_codec_info,const uint8_t * p_data,uint32_t * p_timestamp)57 bool A2DP_VendorGetPacketTimestampAptxHd(const uint8_t* p_codec_info, const uint8_t* p_data,
58 uint32_t* p_timestamp) {
59 return false;
60 }
61
A2DP_VendorBuildCodecHeaderAptxHd(const uint8_t * p_codec_info,BT_HDR * p_buf,uint16_t frames_per_packet)62 bool A2DP_VendorBuildCodecHeaderAptxHd(const uint8_t* p_codec_info, BT_HDR* p_buf,
63 uint16_t frames_per_packet) {
64 return false;
65 }
66
A2DP_VendorCodecInfoStringAptxHd(const uint8_t * p_codec_info)67 std::string A2DP_VendorCodecInfoStringAptxHd(const uint8_t* p_codec_info) {
68 return "Unsupported codec: AptxHd";
69 }
70
A2DP_VendorGetEncoderInterfaceAptxHd(const uint8_t * p_codec_info)71 const tA2DP_ENCODER_INTERFACE* A2DP_VendorGetEncoderInterfaceAptxHd(const uint8_t* p_codec_info) {
72 return nullptr;
73 }
74
A2DP_VendorGetDecoderInterfaceAptxHd(const uint8_t * p_codec_info)75 const tA2DP_DECODER_INTERFACE* A2DP_VendorGetDecoderInterfaceAptxHd(const uint8_t* p_codec_info) {
76 return nullptr;
77 }
78
A2DP_VendorAdjustCodecAptxHd(uint8_t * p_codec_info)79 bool A2DP_VendorAdjustCodecAptxHd(uint8_t* p_codec_info) { return false; }
80
A2DP_VendorSourceCodecIndexAptxHd(const uint8_t * p_codec_info)81 btav_a2dp_codec_index_t A2DP_VendorSourceCodecIndexAptxHd(const uint8_t* p_codec_info) {
82 return BTAV_A2DP_CODEC_INDEX_MAX;
83 }
84
A2DP_VendorSinkCodecIndexAptxHd(const uint8_t * p_codec_info)85 btav_a2dp_codec_index_t A2DP_VendorSinkCodecIndexAptxHd(const uint8_t* p_codec_info) {
86 return BTAV_A2DP_CODEC_INDEX_MAX;
87 }
88
A2DP_VendorCodecIndexStrAptxHd(void)89 const char* A2DP_VendorCodecIndexStrAptxHd(void) { return "AptxHd"; }
90
A2DP_VendorInitCodecConfigAptxHd(AvdtpSepConfig * p_cfg)91 bool A2DP_VendorInitCodecConfigAptxHd(AvdtpSepConfig* p_cfg) { return false; }
92
A2dpCodecConfigAptxHd(btav_a2dp_codec_priority_t codec_priority)93 A2dpCodecConfigAptxHd::A2dpCodecConfigAptxHd(btav_a2dp_codec_priority_t codec_priority)
94 : A2dpCodecConfig(BTAV_A2DP_CODEC_INDEX_SOURCE_APTX_HD, bluetooth::a2dp::CodecId::APTX_HD,
95 A2DP_VendorCodecIndexStrAptxHd(), codec_priority) {}
96
~A2dpCodecConfigAptxHd()97 A2dpCodecConfigAptxHd::~A2dpCodecConfigAptxHd() {}
98
init()99 bool A2dpCodecConfigAptxHd::init() { return false; }
100
useRtpHeaderMarkerBit() const101 bool A2dpCodecConfigAptxHd::useRtpHeaderMarkerBit() const { return false; }
102
debug_codec_dump(int fd)103 void A2dpCodecConfigAptxHd::debug_codec_dump(int fd) {}
104
setCodecConfig(const uint8_t * p_peer_codec_info,bool is_capability,uint8_t * p_result_codec_config)105 tA2DP_STATUS A2dpCodecConfigAptxHd::setCodecConfig(const uint8_t* p_peer_codec_info,
106 bool is_capability,
107 uint8_t* p_result_codec_config) {
108 return AVDTP_UNSUPPORTED_CONFIGURATION;
109 }
110
setPeerCodecCapabilities(const uint8_t * p_peer_codec_capabilities)111 bool A2dpCodecConfigAptxHd::setPeerCodecCapabilities(const uint8_t* p_peer_codec_capabilities) {
112 return false;
113 }
114