ALSA: preliminary support for Toshiba SB-0500
The Toshiba Multimedia Center SB-0500 is a rebranded version of the Creative Technology SB Live! 24-bit External: it shares the same chipset and only has minor cosmetic differences. Remote controller works with alsa_usb module, basic audio is there and mixer controls are mostly untested. Signed-off-by: Andrea Borgia <andrea@borgia.bo.it> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
913ae5a24e
commit
3195954da9
2 changed files with 15 additions and 5 deletions
|
@ -66,6 +66,7 @@ static const struct rc_config {
|
||||||
{ USB_ID(0x041e, 0x3000), 0, 1, 2, 1, 18, 0x0013 }, /* Extigy */
|
{ USB_ID(0x041e, 0x3000), 0, 1, 2, 1, 18, 0x0013 }, /* Extigy */
|
||||||
{ USB_ID(0x041e, 0x3020), 2, 1, 6, 6, 18, 0x0013 }, /* Audigy 2 NX */
|
{ USB_ID(0x041e, 0x3020), 2, 1, 6, 6, 18, 0x0013 }, /* Audigy 2 NX */
|
||||||
{ USB_ID(0x041e, 0x3040), 2, 2, 6, 6, 2, 0x6e91 }, /* Live! 24-bit */
|
{ USB_ID(0x041e, 0x3040), 2, 2, 6, 6, 2, 0x6e91 }, /* Live! 24-bit */
|
||||||
|
{ USB_ID(0x041e, 0x3048), 2, 2, 6, 6, 2, 0x6e91 }, /* Toshiba SB0500 */
|
||||||
};
|
};
|
||||||
|
|
||||||
struct usb_mixer_interface {
|
struct usb_mixer_interface {
|
||||||
|
@ -1706,7 +1707,8 @@ static void snd_usb_mixer_memory_change(struct usb_mixer_interface *mixer,
|
||||||
break;
|
break;
|
||||||
/* live24ext: 4 = line-in jack */
|
/* live24ext: 4 = line-in jack */
|
||||||
case 3: /* hp-out jack (may actuate Mute) */
|
case 3: /* hp-out jack (may actuate Mute) */
|
||||||
if (mixer->chip->usb_id == USB_ID(0x041e, 0x3040))
|
if (mixer->chip->usb_id == USB_ID(0x041e, 0x3040) ||
|
||||||
|
mixer->chip->usb_id == USB_ID(0x041e, 0x3048))
|
||||||
snd_usb_mixer_notify_id(mixer, mixer->rc_cfg->mute_mixer_id);
|
snd_usb_mixer_notify_id(mixer, mixer->rc_cfg->mute_mixer_id);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -1956,8 +1958,9 @@ static int snd_audigy2nx_controls_create(struct usb_mixer_interface *mixer)
|
||||||
int i, err;
|
int i, err;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(snd_audigy2nx_controls); ++i) {
|
for (i = 0; i < ARRAY_SIZE(snd_audigy2nx_controls); ++i) {
|
||||||
if (i > 1 && /* Live24ext has 2 LEDs only */
|
if (i > 1 && /* Live24ext has 2 LEDs only */
|
||||||
mixer->chip->usb_id == USB_ID(0x041e, 0x3040))
|
(mixer->chip->usb_id == USB_ID(0x041e, 0x3040) ||
|
||||||
|
mixer->chip->usb_id == USB_ID(0x041e, 0x3048)))
|
||||||
break;
|
break;
|
||||||
err = snd_ctl_add(mixer->chip->card,
|
err = snd_ctl_add(mixer->chip->card,
|
||||||
snd_ctl_new1(&snd_audigy2nx_controls[i], mixer));
|
snd_ctl_new1(&snd_audigy2nx_controls[i], mixer));
|
||||||
|
@ -1994,7 +1997,8 @@ static void snd_audigy2nx_proc_read(struct snd_info_entry *entry,
|
||||||
snd_iprintf(buffer, "%s jacks\n\n", mixer->chip->card->shortname);
|
snd_iprintf(buffer, "%s jacks\n\n", mixer->chip->card->shortname);
|
||||||
if (mixer->chip->usb_id == USB_ID(0x041e, 0x3020))
|
if (mixer->chip->usb_id == USB_ID(0x041e, 0x3020))
|
||||||
jacks = jacks_audigy2nx;
|
jacks = jacks_audigy2nx;
|
||||||
else if (mixer->chip->usb_id == USB_ID(0x041e, 0x3040))
|
else if (mixer->chip->usb_id == USB_ID(0x041e, 0x3040) ||
|
||||||
|
mixer->chip->usb_id == USB_ID(0x041e, 0x3048))
|
||||||
jacks = jacks_live24ext;
|
jacks = jacks_live24ext;
|
||||||
else
|
else
|
||||||
return;
|
return;
|
||||||
|
@ -2044,7 +2048,8 @@ int snd_usb_create_mixer(struct snd_usb_audio *chip, int ctrlif,
|
||||||
goto _error;
|
goto _error;
|
||||||
|
|
||||||
if (mixer->chip->usb_id == USB_ID(0x041e, 0x3020) ||
|
if (mixer->chip->usb_id == USB_ID(0x041e, 0x3020) ||
|
||||||
mixer->chip->usb_id == USB_ID(0x041e, 0x3040)) {
|
mixer->chip->usb_id == USB_ID(0x041e, 0x3040) ||
|
||||||
|
mixer->chip->usb_id == USB_ID(0x041e, 0x3048)) {
|
||||||
struct snd_info_entry *entry;
|
struct snd_info_entry *entry;
|
||||||
|
|
||||||
if ((err = snd_audigy2nx_controls_create(mixer)) < 0)
|
if ((err = snd_audigy2nx_controls_create(mixer)) < 0)
|
||||||
|
|
|
@ -284,6 +284,11 @@ static struct usbmix_ctl_map usbmix_ctl_maps[] = {
|
||||||
.id = USB_ID(0x041e, 0x3040),
|
.id = USB_ID(0x041e, 0x3040),
|
||||||
.map = live24ext_map,
|
.map = live24ext_map,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.id = USB_ID(0x041e, 0x3048),
|
||||||
|
.map = audigy2nx_map,
|
||||||
|
.selector_map = audigy2nx_selectors,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
/* Hercules DJ Console (Windows Edition) */
|
/* Hercules DJ Console (Windows Edition) */
|
||||||
.id = USB_ID(0x06f8, 0xb000),
|
.id = USB_ID(0x06f8, 0xb000),
|
||||||
|
|
Loading…
Reference in a new issue