sbc: Make use of parameters selected in alsa plugin and fix auto selection.

This commit is contained in:
Luiz Augusto von Dentz 2008-02-14 21:22:38 +00:00 committed by Tim-Philipp Müller
parent 5be53d24ab
commit ccf5d9ea7e
2 changed files with 6 additions and 15 deletions

View file

@ -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;

View file

@ -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;
} }