mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
sbc: Make use of parameters selected in alsa plugin and fix auto selection.
This commit is contained in:
parent
5be53d24ab
commit
ccf5d9ea7e
2 changed files with 6 additions and 15 deletions
|
@ -31,10 +31,10 @@
|
||||||
#include "gstsbcenc.h"
|
#include "gstsbcenc.h"
|
||||||
#include "gstsbcutil.h"
|
#include "gstsbcutil.h"
|
||||||
|
|
||||||
#define SBC_ENC_DEFAULT_MODE BT_A2DP_CHANNEL_MODE_AUTO
|
#define SBC_ENC_DEFAULT_MODE BT_A2DP_CHANNEL_MODE_JOINT_STEREO
|
||||||
#define SBC_ENC_DEFAULT_BLOCKS 0
|
#define SBC_ENC_DEFAULT_BLOCKS 0
|
||||||
#define SBC_ENC_DEFAULT_SUB_BANDS 0
|
#define SBC_ENC_DEFAULT_SUB_BANDS 0
|
||||||
#define SBC_ENC_DEFAULT_ALLOCATION BT_A2DP_ALLOCATION_AUTO
|
#define SBC_ENC_DEFAULT_ALLOCATION BT_A2DP_ALLOCATION_LOUDNESS
|
||||||
#define SBC_ENC_DEFAULT_RATE 0
|
#define SBC_ENC_DEFAULT_RATE 0
|
||||||
#define SBC_ENC_DEFAULT_CHANNELS 0
|
#define SBC_ENC_DEFAULT_CHANNELS 0
|
||||||
|
|
||||||
|
@ -75,7 +75,6 @@ gst_sbc_allocation_get_type (void)
|
||||||
{
|
{
|
||||||
static GType sbc_allocation_type = 0;
|
static GType sbc_allocation_type = 0;
|
||||||
static GEnumValue sbc_allocations[] = {
|
static GEnumValue sbc_allocations[] = {
|
||||||
{BT_A2DP_ALLOCATION_AUTO, "Auto", "auto"},
|
|
||||||
{BT_A2DP_ALLOCATION_LOUDNESS, "Loudness", "loudness"},
|
{BT_A2DP_ALLOCATION_LOUDNESS, "Loudness", "loudness"},
|
||||||
{BT_A2DP_ALLOCATION_SNR, "SNR", "snr"},
|
{BT_A2DP_ALLOCATION_SNR, "SNR", "snr"},
|
||||||
{-1, NULL, NULL}
|
{-1, NULL, NULL}
|
||||||
|
@ -202,7 +201,7 @@ sbc_enc_generate_srcpad_caps (GstSbcEnc * enc)
|
||||||
gst_sbc_util_set_structure_int_param (structure, "bitpool",
|
gst_sbc_util_set_structure_int_param (structure, "bitpool",
|
||||||
enc->bitpool, value);
|
enc->bitpool, value);
|
||||||
|
|
||||||
if (enc->mode != BT_A2DP_CHANNEL_MODE_AUTO) {
|
if (enc->mode != SBC_ENC_DEFAULT_MODE) {
|
||||||
enum_class = g_type_class_ref (GST_TYPE_SBC_MODE);
|
enum_class = g_type_class_ref (GST_TYPE_SBC_MODE);
|
||||||
enum_value = g_enum_get_value (enum_class, enc->mode);
|
enum_value = g_enum_get_value (enum_class, enc->mode);
|
||||||
gst_sbc_util_set_structure_string_param (structure, "mode",
|
gst_sbc_util_set_structure_string_param (structure, "mode",
|
||||||
|
@ -210,7 +209,7 @@ sbc_enc_generate_srcpad_caps (GstSbcEnc * enc)
|
||||||
g_type_class_unref (enum_class);
|
g_type_class_unref (enum_class);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (enc->allocation != BT_A2DP_ALLOCATION_AUTO) {
|
if (enc->allocation != SBC_ENC_DEFAULT_ALLOCATION) {
|
||||||
enum_class = g_type_class_ref (GST_TYPE_SBC_ALLOCATION);
|
enum_class = g_type_class_ref (GST_TYPE_SBC_ALLOCATION);
|
||||||
enum_value = g_enum_get_value (enum_class, enc->allocation);
|
enum_value = g_enum_get_value (enum_class, enc->allocation);
|
||||||
gst_sbc_util_set_structure_string_param (structure, "allocation",
|
gst_sbc_util_set_structure_string_param (structure, "allocation",
|
||||||
|
@ -347,10 +346,10 @@ gst_sbc_enc_fill_sbc_params (GstSbcEnc * enc, GstCaps * caps)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
mode = gst_sbc_get_mode_int_from_sbc_t (&enc->sbc);
|
mode = gst_sbc_get_mode_int_from_sbc_t (&enc->sbc);
|
||||||
if (enc->mode != BT_A2DP_CHANNEL_MODE_AUTO && mode != enc->mode)
|
if (enc->mode != SBC_ENC_DEFAULT_MODE && mode != enc->mode)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
if (enc->allocation != BT_A2DP_ALLOCATION_AUTO &&
|
if (enc->allocation != SBC_ENC_DEFAULT_ALLOCATION &&
|
||||||
enc->sbc.allocation != enc->allocation)
|
enc->sbc.allocation != enc->allocation)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
|
|
|
@ -139,8 +139,6 @@ gst_sbc_get_allocation_mode_int (const gchar * allocation)
|
||||||
return BT_A2DP_ALLOCATION_LOUDNESS;
|
return BT_A2DP_ALLOCATION_LOUDNESS;
|
||||||
else if (g_ascii_strcasecmp (allocation, "snr") == 0)
|
else if (g_ascii_strcasecmp (allocation, "snr") == 0)
|
||||||
return BT_A2DP_ALLOCATION_SNR;
|
return BT_A2DP_ALLOCATION_SNR;
|
||||||
else if (g_ascii_strcasecmp (allocation, "auto") == 0)
|
|
||||||
return BT_A2DP_ALLOCATION_AUTO;
|
|
||||||
else
|
else
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -156,8 +154,6 @@ gst_sbc_get_mode_int (const gchar * mode)
|
||||||
return BT_A2DP_CHANNEL_MODE_DUAL_CHANNEL;
|
return BT_A2DP_CHANNEL_MODE_DUAL_CHANNEL;
|
||||||
else if (g_ascii_strcasecmp (mode, "mono") == 0)
|
else if (g_ascii_strcasecmp (mode, "mono") == 0)
|
||||||
return BT_A2DP_CHANNEL_MODE_MONO;
|
return BT_A2DP_CHANNEL_MODE_MONO;
|
||||||
else if (g_ascii_strcasecmp (mode, "auto") == 0)
|
|
||||||
return BT_A2DP_CHANNEL_MODE_AUTO;
|
|
||||||
else
|
else
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -202,8 +198,6 @@ gst_sbc_get_mode_string (gint joint)
|
||||||
return "stereo";
|
return "stereo";
|
||||||
case BT_A2DP_CHANNEL_MODE_JOINT_STEREO:
|
case BT_A2DP_CHANNEL_MODE_JOINT_STEREO:
|
||||||
return "joint";
|
return "joint";
|
||||||
case BT_A2DP_CHANNEL_MODE_AUTO:
|
|
||||||
return NULL; /* TODO what should be selected here? */
|
|
||||||
default:
|
default:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -217,8 +211,6 @@ gst_sbc_get_allocation_string (gint alloc)
|
||||||
return "loudness";
|
return "loudness";
|
||||||
case BT_A2DP_ALLOCATION_SNR:
|
case BT_A2DP_ALLOCATION_SNR:
|
||||||
return "snr";
|
return "snr";
|
||||||
case BT_A2DP_ALLOCATION_AUTO:
|
|
||||||
return "loudness"; /* TODO what should be selected here? */
|
|
||||||
default:
|
default:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue