mirror of
https://git.kernel.org/pub/scm/bluetooth/bluez.git
synced 2024-11-29 15:14:31 +08:00
35906565c9
The header files with constants and structures for audio specific interaction with Pulseaudio are suppose to be under LGPL license. For some odd reason a2dp-codecs.h ended up being under GPL license which is against the intention of this being shared and re-used by non-GPL programs. Fix this now to avoid any future confusion.
362 lines
9.3 KiB
C
362 lines
9.3 KiB
C
/*
|
|
*
|
|
* BlueZ - Bluetooth protocol stack for Linux
|
|
*
|
|
* Copyright (C) 2004-2010 Marcel Holtmann <marcel@holtmann.org>
|
|
*
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*
|
|
*/
|
|
|
|
/*
|
|
Message sequence chart of streaming sequence for A2DP transport
|
|
|
|
Audio daemon User
|
|
on snd_pcm_open
|
|
<--BT_GET_CAPABILITIES_REQ
|
|
|
|
BT_GET_CAPABILITIES_RSP-->
|
|
|
|
on snd_pcm_hw_params
|
|
<--BT_SETCONFIGURATION_REQ
|
|
|
|
BT_SET_CONFIGURATION_RSP-->
|
|
|
|
on snd_pcm_prepare
|
|
<--BT_START_STREAM_REQ
|
|
|
|
<Moves to streaming state>
|
|
BT_START_STREAM_RSP-->
|
|
|
|
BT_NEW_STREAM_IND -->
|
|
|
|
< streams data >
|
|
..........
|
|
|
|
on snd_pcm_drop/snd_pcm_drain
|
|
|
|
<--BT_STOP_STREAM_REQ
|
|
|
|
<Moves to open state>
|
|
BT_STOP_STREAM_RSP-->
|
|
|
|
on IPC close or appl crash
|
|
<Moves to idle>
|
|
|
|
*/
|
|
|
|
#ifndef BT_AUDIOCLIENT_H
|
|
#define BT_AUDIOCLIENT_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdint.h>
|
|
#include <stdio.h>
|
|
#include <unistd.h>
|
|
#include <sys/socket.h>
|
|
#include <sys/un.h>
|
|
#include <errno.h>
|
|
|
|
#define BT_SUGGESTED_BUFFER_SIZE 512
|
|
#define BT_IPC_SOCKET_NAME "\0/org/bluez/audio"
|
|
|
|
/* Generic message header definition, except for RESPONSE messages */
|
|
typedef struct {
|
|
uint8_t type;
|
|
uint8_t name;
|
|
uint16_t length;
|
|
} __attribute__ ((packed)) bt_audio_msg_header_t;
|
|
|
|
typedef struct {
|
|
bt_audio_msg_header_t h;
|
|
uint8_t posix_errno;
|
|
} __attribute__ ((packed)) bt_audio_error_t;
|
|
|
|
/* Message types */
|
|
#define BT_REQUEST 0
|
|
#define BT_RESPONSE 1
|
|
#define BT_INDICATION 2
|
|
#define BT_ERROR 3
|
|
|
|
/* Messages names */
|
|
#define BT_GET_CAPABILITIES 0
|
|
#define BT_OPEN 1
|
|
#define BT_SET_CONFIGURATION 2
|
|
#define BT_NEW_STREAM 3
|
|
#define BT_START_STREAM 4
|
|
#define BT_STOP_STREAM 5
|
|
#define BT_CLOSE 6
|
|
#define BT_CONTROL 7
|
|
#define BT_DELAY_REPORT 8
|
|
|
|
#define BT_CAPABILITIES_TRANSPORT_A2DP 0
|
|
#define BT_CAPABILITIES_TRANSPORT_SCO 1
|
|
#define BT_CAPABILITIES_TRANSPORT_ANY 2
|
|
|
|
#define BT_CAPABILITIES_ACCESS_MODE_READ 1
|
|
#define BT_CAPABILITIES_ACCESS_MODE_WRITE 2
|
|
#define BT_CAPABILITIES_ACCESS_MODE_READWRITE 3
|
|
|
|
#define BT_FLAG_AUTOCONNECT 1
|
|
|
|
struct bt_get_capabilities_req {
|
|
bt_audio_msg_header_t h;
|
|
char source[18]; /* Address of the local Device */
|
|
char destination[18];/* Address of the remote Device */
|
|
char object[128]; /* DBus object path */
|
|
uint8_t transport; /* Requested transport */
|
|
uint8_t flags; /* Requested flags */
|
|
uint8_t seid; /* Requested capability configuration */
|
|
} __attribute__ ((packed));
|
|
|
|
/**
|
|
* SBC Codec parameters as per A2DP profile 1.0 § 4.3
|
|
*/
|
|
|
|
/* A2DP seid are 6 bytes long so HSP/HFP are assigned to 7-8 bits */
|
|
#define BT_A2DP_SEID_RANGE (1 << 6) - 1
|
|
|
|
#define BT_A2DP_SBC_SOURCE 0x00
|
|
#define BT_A2DP_SBC_SINK 0x01
|
|
#define BT_A2DP_MPEG12_SOURCE 0x02
|
|
#define BT_A2DP_MPEG12_SINK 0x03
|
|
#define BT_A2DP_MPEG24_SOURCE 0x04
|
|
#define BT_A2DP_MPEG24_SINK 0x05
|
|
#define BT_A2DP_ATRAC_SOURCE 0x06
|
|
#define BT_A2DP_ATRAC_SINK 0x07
|
|
#define BT_A2DP_UNKNOWN_SOURCE 0x08
|
|
#define BT_A2DP_UNKNOWN_SINK 0x09
|
|
|
|
#define BT_SBC_SAMPLING_FREQ_16000 (1 << 3)
|
|
#define BT_SBC_SAMPLING_FREQ_32000 (1 << 2)
|
|
#define BT_SBC_SAMPLING_FREQ_44100 (1 << 1)
|
|
#define BT_SBC_SAMPLING_FREQ_48000 1
|
|
|
|
#define BT_A2DP_CHANNEL_MODE_MONO (1 << 3)
|
|
#define BT_A2DP_CHANNEL_MODE_DUAL_CHANNEL (1 << 2)
|
|
#define BT_A2DP_CHANNEL_MODE_STEREO (1 << 1)
|
|
#define BT_A2DP_CHANNEL_MODE_JOINT_STEREO 1
|
|
|
|
#define BT_A2DP_BLOCK_LENGTH_4 (1 << 3)
|
|
#define BT_A2DP_BLOCK_LENGTH_8 (1 << 2)
|
|
#define BT_A2DP_BLOCK_LENGTH_12 (1 << 1)
|
|
#define BT_A2DP_BLOCK_LENGTH_16 1
|
|
|
|
#define BT_A2DP_SUBBANDS_4 (1 << 1)
|
|
#define BT_A2DP_SUBBANDS_8 1
|
|
|
|
#define BT_A2DP_ALLOCATION_SNR (1 << 1)
|
|
#define BT_A2DP_ALLOCATION_LOUDNESS 1
|
|
|
|
#define BT_MPEG_SAMPLING_FREQ_16000 (1 << 5)
|
|
#define BT_MPEG_SAMPLING_FREQ_22050 (1 << 4)
|
|
#define BT_MPEG_SAMPLING_FREQ_24000 (1 << 3)
|
|
#define BT_MPEG_SAMPLING_FREQ_32000 (1 << 2)
|
|
#define BT_MPEG_SAMPLING_FREQ_44100 (1 << 1)
|
|
#define BT_MPEG_SAMPLING_FREQ_48000 1
|
|
|
|
#define BT_MPEG_LAYER_1 (1 << 2)
|
|
#define BT_MPEG_LAYER_2 (1 << 1)
|
|
#define BT_MPEG_LAYER_3 1
|
|
|
|
#define BT_HFP_CODEC_PCM 0x00
|
|
|
|
#define BT_PCM_FLAG_NREC 0x01
|
|
#define BT_PCM_FLAG_PCM_ROUTING 0x02
|
|
|
|
#define BT_WRITE_LOCK (1 << 1)
|
|
#define BT_READ_LOCK 1
|
|
|
|
typedef struct {
|
|
uint8_t seid;
|
|
uint8_t transport;
|
|
uint8_t type;
|
|
uint8_t length;
|
|
uint8_t configured;
|
|
uint8_t lock;
|
|
uint8_t data[0];
|
|
} __attribute__ ((packed)) codec_capabilities_t;
|
|
|
|
typedef struct {
|
|
codec_capabilities_t capability;
|
|
uint8_t channel_mode;
|
|
uint8_t frequency;
|
|
uint8_t allocation_method;
|
|
uint8_t subbands;
|
|
uint8_t block_length;
|
|
uint8_t min_bitpool;
|
|
uint8_t max_bitpool;
|
|
} __attribute__ ((packed)) sbc_capabilities_t;
|
|
|
|
typedef struct {
|
|
codec_capabilities_t capability;
|
|
uint8_t channel_mode;
|
|
uint8_t crc;
|
|
uint8_t layer;
|
|
uint8_t frequency;
|
|
uint8_t mpf;
|
|
uint16_t bitrate;
|
|
} __attribute__ ((packed)) mpeg_capabilities_t;
|
|
|
|
typedef struct {
|
|
codec_capabilities_t capability;
|
|
uint8_t flags;
|
|
uint16_t sampling_rate;
|
|
} __attribute__ ((packed)) pcm_capabilities_t;
|
|
|
|
struct bt_get_capabilities_rsp {
|
|
bt_audio_msg_header_t h;
|
|
char source[18]; /* Address of the local Device */
|
|
char destination[18];/* Address of the remote Device */
|
|
char object[128]; /* DBus object path */
|
|
uint8_t data[0]; /* First codec_capabilities_t */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_open_req {
|
|
bt_audio_msg_header_t h;
|
|
char source[18]; /* Address of the local Device */
|
|
char destination[18];/* Address of the remote Device */
|
|
char object[128]; /* DBus object path */
|
|
uint8_t seid; /* Requested capability configuration to lock */
|
|
uint8_t lock; /* Requested lock */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_open_rsp {
|
|
bt_audio_msg_header_t h;
|
|
char source[18]; /* Address of the local Device */
|
|
char destination[18];/* Address of the remote Device */
|
|
char object[128]; /* DBus object path */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_set_configuration_req {
|
|
bt_audio_msg_header_t h;
|
|
codec_capabilities_t codec; /* Requested codec */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_set_configuration_rsp {
|
|
bt_audio_msg_header_t h;
|
|
uint16_t link_mtu; /* Max length that transport supports */
|
|
} __attribute__ ((packed));
|
|
|
|
#define BT_STREAM_ACCESS_READ 0
|
|
#define BT_STREAM_ACCESS_WRITE 1
|
|
#define BT_STREAM_ACCESS_READWRITE 2
|
|
struct bt_start_stream_req {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_start_stream_rsp {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
/* This message is followed by one byte of data containing the stream data fd
|
|
as ancillary data */
|
|
struct bt_new_stream_ind {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_stop_stream_req {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_stop_stream_rsp {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_close_req {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_close_rsp {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_suspend_stream_ind {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_resume_stream_ind {
|
|
bt_audio_msg_header_t h;
|
|
} __attribute__ ((packed));
|
|
|
|
#define BT_CONTROL_KEY_POWER 0x40
|
|
#define BT_CONTROL_KEY_VOL_UP 0x41
|
|
#define BT_CONTROL_KEY_VOL_DOWN 0x42
|
|
#define BT_CONTROL_KEY_MUTE 0x43
|
|
#define BT_CONTROL_KEY_PLAY 0x44
|
|
#define BT_CONTROL_KEY_STOP 0x45
|
|
#define BT_CONTROL_KEY_PAUSE 0x46
|
|
#define BT_CONTROL_KEY_RECORD 0x47
|
|
#define BT_CONTROL_KEY_REWIND 0x48
|
|
#define BT_CONTROL_KEY_FAST_FORWARD 0x49
|
|
#define BT_CONTROL_KEY_EJECT 0x4A
|
|
#define BT_CONTROL_KEY_FORWARD 0x4B
|
|
#define BT_CONTROL_KEY_BACKWARD 0x4C
|
|
|
|
struct bt_control_req {
|
|
bt_audio_msg_header_t h;
|
|
uint8_t mode; /* Control Mode */
|
|
uint8_t key; /* Control Key */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_control_rsp {
|
|
bt_audio_msg_header_t h;
|
|
uint8_t mode; /* Control Mode */
|
|
uint8_t key; /* Control Key */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_control_ind {
|
|
bt_audio_msg_header_t h;
|
|
uint8_t mode; /* Control Mode */
|
|
uint8_t key; /* Control Key */
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_delay_report_req {
|
|
bt_audio_msg_header_t h;
|
|
uint16_t delay;
|
|
} __attribute__ ((packed));
|
|
|
|
struct bt_delay_report_ind {
|
|
bt_audio_msg_header_t h;
|
|
uint16_t delay;
|
|
} __attribute__ ((packed));
|
|
|
|
/* Function declaration */
|
|
|
|
/* Opens a connection to the audio service: return a socket descriptor */
|
|
int bt_audio_service_open(void);
|
|
|
|
/* Closes a connection to the audio service */
|
|
int bt_audio_service_close(int sk);
|
|
|
|
/* Receives stream data file descriptor : must be called after a
|
|
BT_STREAMFD_IND message is returned */
|
|
int bt_audio_service_get_data_fd(int sk);
|
|
|
|
/* Human readable message type string */
|
|
const char *bt_audio_strtype(uint8_t type);
|
|
|
|
/* Human readable message name string */
|
|
const char *bt_audio_strname(uint8_t name);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* BT_AUDIOCLIENT_H */
|