Commit dbd82c05 authored by Geoffrey D. Bennett's avatar Geoffrey D. Bennett Committed by Takashi Iwai

ALSA: usb-audio: scarlett2: Rename buttons/interrupts/vol

To match the vendor's terminology, change #defines, identifiers, and
comments:
- mute/dim/hardware buttons are now called dim/mute
- mixer status/interrupt is now notify
- vol is now monitor
Signed-off-by: default avatarGeoffrey D. Bennett <g@b4.vu>
Link: https://lore.kernel.org/r/20210620164636.GA9199@m.b4.vuSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 03bdbcf0
...@@ -194,10 +194,10 @@ enum { ...@@ -194,10 +194,10 @@ enum {
SCARLETT2_PORT_DIRNS = 5, SCARLETT2_PORT_DIRNS = 5,
}; };
/* Hardware buttons on the 18i20 */ /* Dim/Mute buttons on the 18i20 */
#define SCARLETT2_BUTTON_MAX 2 #define SCARLETT2_DIM_MUTE_COUNT 2
static const char *const scarlett2_button_names[SCARLETT2_BUTTON_MAX] = { static const char *const scarlett2_dim_mute_names[SCARLETT2_DIM_MUTE_COUNT] = {
"Mute", "Dim" "Mute", "Dim"
}; };
...@@ -239,10 +239,10 @@ struct scarlett2_mixer_data { ...@@ -239,10 +239,10 @@ struct scarlett2_mixer_data {
u8 vol_sw_hw_switch[SCARLETT2_ANALOGUE_MAX]; u8 vol_sw_hw_switch[SCARLETT2_ANALOGUE_MAX];
u8 level_switch[SCARLETT2_LEVEL_SWITCH_MAX]; u8 level_switch[SCARLETT2_LEVEL_SWITCH_MAX];
u8 pad_switch[SCARLETT2_PAD_SWITCH_MAX]; u8 pad_switch[SCARLETT2_PAD_SWITCH_MAX];
u8 buttons[SCARLETT2_BUTTON_MAX]; u8 dim_mute[SCARLETT2_DIM_MUTE_COUNT];
struct snd_kcontrol *master_vol_ctl; struct snd_kcontrol *master_vol_ctl;
struct snd_kcontrol *vol_ctls[SCARLETT2_ANALOGUE_MAX]; struct snd_kcontrol *vol_ctls[SCARLETT2_ANALOGUE_MAX];
struct snd_kcontrol *button_ctls[SCARLETT2_BUTTON_MAX]; struct snd_kcontrol *dim_mute_ctls[SCARLETT2_DIM_MUTE_COUNT];
u8 mux[SCARLETT2_MUX_MAX]; u8 mux[SCARLETT2_MUX_MAX];
u8 mix[SCARLETT2_INPUT_MIX_MAX * SCARLETT2_OUTPUT_MIX_MAX]; u8 mix[SCARLETT2_INPUT_MIX_MAX * SCARLETT2_OUTPUT_MIX_MAX];
}; };
...@@ -450,9 +450,9 @@ static int scarlett2_get_port_start_num(const struct scarlett2_ports *ports, ...@@ -450,9 +450,9 @@ static int scarlett2_get_port_start_num(const struct scarlett2_ports *ports,
#define SCARLETT2_USB_INTERRUPT_MAX_DATA 64 #define SCARLETT2_USB_INTERRUPT_MAX_DATA 64
#define SCARLETT2_USB_INTERRUPT_INTERVAL 3 #define SCARLETT2_USB_INTERRUPT_INTERVAL 3
/* Interrupt flags for volume and mute/dim button changes */ /* Interrupt flags for dim/mute button and monitor changes */
#define SCARLETT2_USB_INTERRUPT_VOL_CHANGE 0x00400000 #define SCARLETT2_USB_NOTIFY_DIM_MUTE 0x00200000
#define SCARLETT2_USB_INTERRUPT_BUTTON_CHANGE 0x00200000 #define SCARLETT2_USB_NOTIFY_MONITOR 0x00400000
/* Commands for sending/receiving requests/responses */ /* Commands for sending/receiving requests/responses */
#define SCARLETT2_USB_VENDOR_SPECIFIC_CMD_REQ 2 #define SCARLETT2_USB_VENDOR_SPECIFIC_CMD_REQ 2
...@@ -475,8 +475,8 @@ static int scarlett2_get_port_start_num(const struct scarlett2_ports *ports, ...@@ -475,8 +475,8 @@ static int scarlett2_get_port_start_num(const struct scarlett2_ports *ports,
/* volume status is read together (matches scarlett2_config_items[]) */ /* volume status is read together (matches scarlett2_config_items[]) */
struct scarlett2_usb_volume_status { struct scarlett2_usb_volume_status {
/* mute & dim buttons */ /* dim/mute buttons */
u8 buttons[SCARLETT2_BUTTON_MAX]; u8 dim_mute[SCARLETT2_DIM_MUTE_COUNT];
u8 pad1; u8 pad1;
...@@ -499,7 +499,7 @@ struct scarlett2_usb_volume_status { ...@@ -499,7 +499,7 @@ struct scarlett2_usb_volume_status {
/* Configuration parameters that can be read and written */ /* Configuration parameters that can be read and written */
enum { enum {
SCARLETT2_CONFIG_BUTTONS = 0, SCARLETT2_CONFIG_DIM_MUTE = 0,
SCARLETT2_CONFIG_LINE_OUT_VOLUME = 1, SCARLETT2_CONFIG_LINE_OUT_VOLUME = 1,
SCARLETT2_CONFIG_SW_HW_SWITCH = 2, SCARLETT2_CONFIG_SW_HW_SWITCH = 2,
SCARLETT2_CONFIG_LEVEL_SWITCH = 3, SCARLETT2_CONFIG_LEVEL_SWITCH = 3,
...@@ -518,7 +518,7 @@ struct scarlett2_config { ...@@ -518,7 +518,7 @@ struct scarlett2_config {
static const struct scarlett2_config static const struct scarlett2_config
scarlett2_config_items[SCARLETT2_CONFIG_COUNT] = { scarlett2_config_items[SCARLETT2_CONFIG_COUNT] = {
/* Mute/Dim Buttons */ /* Dim/Mute Buttons */
{ {
.offset = 0x31, .offset = 0x31,
.size = 1, .size = 1,
...@@ -1127,8 +1127,8 @@ static int scarlett2_update_volumes(struct usb_mixer_interface *mixer) ...@@ -1127,8 +1127,8 @@ static int scarlett2_update_volumes(struct usb_mixer_interface *mixer)
} }
if (info->line_out_hw_vol) if (info->line_out_hw_vol)
for (i = 0; i < SCARLETT2_BUTTON_MAX; i++) for (i = 0; i < SCARLETT2_DIM_MUTE_COUNT; i++)
private->buttons[i] = !!volume_status.buttons[i]; private->dim_mute[i] = !!volume_status.dim_mute[i];
return 0; return 0;
} }
...@@ -1430,9 +1430,9 @@ static const struct snd_kcontrol_new scarlett2_pad_ctl = { ...@@ -1430,9 +1430,9 @@ static const struct snd_kcontrol_new scarlett2_pad_ctl = {
.put = scarlett2_pad_ctl_put, .put = scarlett2_pad_ctl_put,
}; };
/*** Mute/Dim Controls ***/ /*** Dim/Mute Controls ***/
static int scarlett2_button_ctl_get(struct snd_kcontrol *kctl, static int scarlett2_dim_mute_ctl_get(struct snd_kcontrol *kctl,
struct snd_ctl_elem_value *ucontrol) struct snd_ctl_elem_value *ucontrol)
{ {
struct usb_mixer_elem_info *elem = kctl->private_data; struct usb_mixer_elem_info *elem = kctl->private_data;
...@@ -1445,11 +1445,11 @@ static int scarlett2_button_ctl_get(struct snd_kcontrol *kctl, ...@@ -1445,11 +1445,11 @@ static int scarlett2_button_ctl_get(struct snd_kcontrol *kctl,
mutex_unlock(&private->data_mutex); mutex_unlock(&private->data_mutex);
} }
ucontrol->value.enumerated.item[0] = private->buttons[elem->control]; ucontrol->value.enumerated.item[0] = private->dim_mute[elem->control];
return 0; return 0;
} }
static int scarlett2_button_ctl_put(struct snd_kcontrol *kctl, static int scarlett2_dim_mute_ctl_put(struct snd_kcontrol *kctl,
struct snd_ctl_elem_value *ucontrol) struct snd_ctl_elem_value *ucontrol)
{ {
struct usb_mixer_elem_info *elem = kctl->private_data; struct usb_mixer_elem_info *elem = kctl->private_data;
...@@ -1461,16 +1461,16 @@ static int scarlett2_button_ctl_put(struct snd_kcontrol *kctl, ...@@ -1461,16 +1461,16 @@ static int scarlett2_button_ctl_put(struct snd_kcontrol *kctl,
mutex_lock(&private->data_mutex); mutex_lock(&private->data_mutex);
oval = private->buttons[index]; oval = private->dim_mute[index];
val = !!ucontrol->value.integer.value[0]; val = !!ucontrol->value.integer.value[0];
if (oval == val) if (oval == val)
goto unlock; goto unlock;
private->buttons[index] = val; private->dim_mute[index] = val;
/* Send switch change to the device */ /* Send switch change to the device */
err = scarlett2_usb_set_config(mixer, SCARLETT2_CONFIG_BUTTONS, err = scarlett2_usb_set_config(mixer, SCARLETT2_CONFIG_DIM_MUTE,
index, val); index, val);
unlock: unlock:
...@@ -1478,12 +1478,12 @@ static int scarlett2_button_ctl_put(struct snd_kcontrol *kctl, ...@@ -1478,12 +1478,12 @@ static int scarlett2_button_ctl_put(struct snd_kcontrol *kctl,
return err; return err;
} }
static const struct snd_kcontrol_new scarlett2_button_ctl = { static const struct snd_kcontrol_new scarlett2_dim_mute_ctl = {
.iface = SNDRV_CTL_ELEM_IFACE_MIXER, .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
.name = "", .name = "",
.info = snd_ctl_boolean_mono_info, .info = snd_ctl_boolean_mono_info,
.get = scarlett2_button_ctl_get, .get = scarlett2_dim_mute_ctl_get,
.put = scarlett2_button_ctl_put .put = scarlett2_dim_mute_ctl_put
}; };
/*** Create the analogue output controls ***/ /*** Create the analogue output controls ***/
...@@ -1544,13 +1544,13 @@ static int scarlett2_add_line_out_ctls(struct usb_mixer_interface *mixer) ...@@ -1544,13 +1544,13 @@ static int scarlett2_add_line_out_ctls(struct usb_mixer_interface *mixer)
} }
} }
/* Add HW button controls */ /* Add dim/mute controls */
if (info->line_out_hw_vol) if (info->line_out_hw_vol)
for (i = 0; i < SCARLETT2_BUTTON_MAX; i++) { for (i = 0; i < SCARLETT2_DIM_MUTE_COUNT; i++) {
err = scarlett2_add_new_ctl( err = scarlett2_add_new_ctl(
mixer, &scarlett2_button_ctl, mixer, &scarlett2_dim_mute_ctl,
i, 1, scarlett2_button_names[i], i, 1, scarlett2_dim_mute_names[i],
&private->button_ctls[i]); &private->dim_mute_ctls[i]);
if (err < 0) if (err < 0)
return err; return err;
} }
...@@ -1962,8 +1962,8 @@ static int scarlett2_read_configs(struct usb_mixer_interface *mixer) ...@@ -1962,8 +1962,8 @@ static int scarlett2_read_configs(struct usb_mixer_interface *mixer)
} }
if (info->line_out_hw_vol) if (info->line_out_hw_vol)
for (i = 0; i < SCARLETT2_BUTTON_MAX; i++) for (i = 0; i < SCARLETT2_DIM_MUTE_COUNT; i++)
private->buttons[i] = !!volume_status.buttons[i]; private->dim_mute[i] = !!volume_status.dim_mute[i];
for (i = 0; i < num_mixer_out; i++) { for (i = 0; i < num_mixer_out; i++) {
err = scarlett2_usb_get_mix(mixer, i); err = scarlett2_usb_get_mix(mixer, i);
...@@ -1974,8 +1974,8 @@ static int scarlett2_read_configs(struct usb_mixer_interface *mixer) ...@@ -1974,8 +1974,8 @@ static int scarlett2_read_configs(struct usb_mixer_interface *mixer)
return scarlett2_usb_get_mux(mixer); return scarlett2_usb_get_mux(mixer);
} }
/* Notify on volume change */ /* Notify on monitor change */
static void scarlett2_mixer_interrupt_vol_change( static void scarlett2_notify_monitor(
struct usb_mixer_interface *mixer) struct usb_mixer_interface *mixer)
{ {
struct scarlett2_mixer_data *private = mixer->private_data; struct scarlett2_mixer_data *private = mixer->private_data;
...@@ -1997,8 +1997,8 @@ static void scarlett2_mixer_interrupt_vol_change( ...@@ -1997,8 +1997,8 @@ static void scarlett2_mixer_interrupt_vol_change(
} }
} }
/* Notify on button change */ /* Notify on dim/mute change */
static void scarlett2_mixer_interrupt_button_change( static void scarlett2_notify_dim_mute(
struct usb_mixer_interface *mixer) struct usb_mixer_interface *mixer)
{ {
struct scarlett2_mixer_data *private = mixer->private_data; struct scarlett2_mixer_data *private = mixer->private_data;
...@@ -2010,13 +2010,13 @@ static void scarlett2_mixer_interrupt_button_change( ...@@ -2010,13 +2010,13 @@ static void scarlett2_mixer_interrupt_button_change(
if (!info->line_out_hw_vol) if (!info->line_out_hw_vol)
return; return;
for (i = 0; i < SCARLETT2_BUTTON_MAX; i++) for (i = 0; i < SCARLETT2_DIM_MUTE_COUNT; i++)
snd_ctl_notify(mixer->chip->card, SNDRV_CTL_EVENT_MASK_VALUE, snd_ctl_notify(mixer->chip->card, SNDRV_CTL_EVENT_MASK_VALUE,
&private->button_ctls[i]->id); &private->dim_mute_ctls[i]->id);
} }
/* Interrupt callback */ /* Interrupt callback */
static void scarlett2_mixer_interrupt(struct urb *urb) static void scarlett2_notify(struct urb *urb)
{ {
struct usb_mixer_interface *mixer = urb->context; struct usb_mixer_interface *mixer = urb->context;
int len = urb->actual_length; int len = urb->actual_length;
...@@ -2027,10 +2027,10 @@ static void scarlett2_mixer_interrupt(struct urb *urb) ...@@ -2027,10 +2027,10 @@ static void scarlett2_mixer_interrupt(struct urb *urb)
goto requeue; goto requeue;
data = le32_to_cpu(*(__le32 *)urb->transfer_buffer); data = le32_to_cpu(*(__le32 *)urb->transfer_buffer);
if (data & SCARLETT2_USB_INTERRUPT_VOL_CHANGE) if (data & SCARLETT2_USB_NOTIFY_MONITOR)
scarlett2_mixer_interrupt_vol_change(mixer); scarlett2_notify_monitor(mixer);
if (data & SCARLETT2_USB_INTERRUPT_BUTTON_CHANGE) if (data & SCARLETT2_USB_NOTIFY_DIM_MUTE)
scarlett2_mixer_interrupt_button_change(mixer); scarlett2_notify_dim_mute(mixer);
requeue: requeue:
if (ustatus != -ENOENT && if (ustatus != -ENOENT &&
...@@ -2041,7 +2041,7 @@ static void scarlett2_mixer_interrupt(struct urb *urb) ...@@ -2041,7 +2041,7 @@ static void scarlett2_mixer_interrupt(struct urb *urb)
} }
} }
static int scarlett2_mixer_status_create(struct usb_mixer_interface *mixer) static int scarlett2_init_notify(struct usb_mixer_interface *mixer)
{ {
struct usb_device *dev = mixer->chip->dev; struct usb_device *dev = mixer->chip->dev;
unsigned int pipe = usb_rcvintpipe(dev, unsigned int pipe = usb_rcvintpipe(dev,
...@@ -2067,7 +2067,7 @@ static int scarlett2_mixer_status_create(struct usb_mixer_interface *mixer) ...@@ -2067,7 +2067,7 @@ static int scarlett2_mixer_status_create(struct usb_mixer_interface *mixer)
usb_fill_int_urb(mixer->urb, dev, pipe, usb_fill_int_urb(mixer->urb, dev, pipe,
transfer_buffer, SCARLETT2_USB_INTERRUPT_MAX_DATA, transfer_buffer, SCARLETT2_USB_INTERRUPT_MAX_DATA,
scarlett2_mixer_interrupt, mixer, scarlett2_notify, mixer,
SCARLETT2_USB_INTERRUPT_INTERVAL); SCARLETT2_USB_INTERRUPT_INTERVAL);
return usb_submit_urb(mixer->urb, GFP_KERNEL); return usb_submit_urb(mixer->urb, GFP_KERNEL);
...@@ -2115,7 +2115,7 @@ static int snd_scarlett_gen2_controls_create(struct usb_mixer_interface *mixer, ...@@ -2115,7 +2115,7 @@ static int snd_scarlett_gen2_controls_create(struct usb_mixer_interface *mixer,
/* Set up the interrupt polling if there are hardware buttons */ /* Set up the interrupt polling if there are hardware buttons */
if (info->line_out_hw_vol) { if (info->line_out_hw_vol) {
err = scarlett2_mixer_status_create(mixer); err = scarlett2_init_notify(mixer);
if (err < 0) if (err < 0)
return err; return err;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment