ALSA: scarlett2: Add support for Solo, 2i2, and 4i4 Gen 4
authorGeoffrey D. Bennett <g@b4.vu>
Tue, 26 Dec 2023 18:08:58 +0000 (04:38 +1030)
committerTakashi Iwai <tiwai@suse.de>
Fri, 29 Dec 2023 14:52:14 +0000 (15:52 +0100)
Add new Focusrite Scarlett Gen 4 USB IDs, notification arrays, config
sets, and device info data.

Signed-off-by: Geoffrey D. Bennett <g@b4.vu>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Link: https://lore.kernel.org/r/b33526d3b7a56bb2c86aa4eb2137a415bd23f1ce.1703612638.git.g@b4.vu
include/uapi/sound/scarlett2.h
sound/usb/mixer_quirks.c
sound/usb/mixer_scarlett2.c

index d0ff38ffa1540315989dad604b6544b19e7e8bd5..91467ab0ed7031e75573975d217779277dffeff3 100644 (file)
@@ -1,8 +1,8 @@
 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
 /*
  *   Focusrite Scarlett 2 Protocol Driver for ALSA
- *   (including Scarlett 2nd Gen, 3rd Gen, Clarett USB, and Clarett+
- *   series products)
+ *   (including Scarlett 2nd Gen, 3rd Gen, 4th Gen, Clarett USB, and
+ *   Clarett+ series products)
  *
  *   Copyright (c) 2023 by Geoffrey D. Bennett <g at b4.vu>
  */
index c8d48566e17598df4e7c390240512ac25c84128d..065a4be0d771488e053573ee4378048622762589 100644 (file)
@@ -3447,6 +3447,9 @@ int snd_usb_mixer_apply_create_quirk(struct usb_mixer_interface *mixer)
        case USB_ID(0x1235, 0x8213): /* Focusrite Scarlett 8i6 3rd Gen */
        case USB_ID(0x1235, 0x8214): /* Focusrite Scarlett 18i8 3rd Gen */
        case USB_ID(0x1235, 0x8215): /* Focusrite Scarlett 18i20 3rd Gen */
+       case USB_ID(0x1235, 0x8218): /* Focusrite Scarlett Solo 4th Gen */
+       case USB_ID(0x1235, 0x8219): /* Focusrite Scarlett 2i2 4th Gen */
+       case USB_ID(0x1235, 0x821a): /* Focusrite Scarlett 4i4 4th Gen */
        case USB_ID(0x1235, 0x8206): /* Focusrite Clarett 2Pre USB */
        case USB_ID(0x1235, 0x8207): /* Focusrite Clarett 4Pre USB */
        case USB_ID(0x1235, 0x8208): /* Focusrite Clarett 8Pre USB */
index 94413fca2b6c826fd3919f349cea077cc143097e..74305447218428608db2a7cc0326f1c3dc7c854f 100644 (file)
@@ -1,12 +1,13 @@
 // SPDX-License-Identifier: GPL-2.0
 /*
  *   Focusrite Scarlett 2 Protocol Driver for ALSA
- *   (including Scarlett 2nd Gen, 3rd Gen, Clarett USB, and Clarett+
- *   series products)
+ *   (including Scarlett 2nd Gen, 3rd Gen, 4th Gen, Clarett USB, and
+ *   Clarett+ series products)
  *
  *   Supported models:
  *   - 6i6/18i8/18i20 Gen 2
  *   - Solo/2i2/4i4/8i6/18i8/18i20 Gen 3
+ *   - Solo/2i2/4i4 Gen 4
  *   - Clarett 2Pre/4Pre/8Pre USB
  *   - Clarett+ 2Pre/4Pre/8Pre
  *
  *
  * Support for Clarett 2Pre and 4Pre USB added in Oct 2023.
  *
+ * Support for firmware updates added in Dec 2023.
+ *
+ * Support for Scarlett Solo/2i2/4i4 Gen 4 added in Dec 2023 (thanks
+ * to many LinuxMusicians people and to Focusrite for hardware
+ * donations).
+ *
  * This ALSA mixer gives access to (model-dependent):
  *  - input, output, mixer-matrix muxes
  *  - mixer-matrix gain stages
@@ -78,6 +85,8 @@
  *    controls
  *  - disable/enable MSD mode
  *  - disable/enable standalone mode
+ *  - input gain, autogain, safe mode
+ *  - direct monitor mixes
  *
  * <ditaa>
  *    /--------------\    18chn            20chn     /--------------\
  *  \--------------/
  * </ditaa>
  *
- * Gen 3 devices have a Mass Storage Device (MSD) mode where a small
+ * Gen 3/4 devices have a Mass Storage Device (MSD) mode where a small
  * disk with registration and driver download information is presented
  * to the host. To access the full functionality of the device without
  * proprietary software, MSD mode can be disabled by:
@@ -302,9 +311,19 @@ struct scarlett2_notification {
 static void scarlett2_notify_sync(struct usb_mixer_interface *mixer);
 static void scarlett2_notify_dim_mute(struct usb_mixer_interface *mixer);
 static void scarlett2_notify_monitor(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_volume(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_level(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_pad(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_air(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_phantom(struct usb_mixer_interface *mixer);
 static void scarlett2_notify_input_other(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_select(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_gain(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_autogain(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_input_safe(struct usb_mixer_interface *mixer);
 static void scarlett2_notify_monitor_other(struct usb_mixer_interface *mixer);
 static void scarlett2_notify_direct_monitor(struct usb_mixer_interface *mixer);
+static void scarlett2_notify_power_status(struct usb_mixer_interface *mixer);
 
 /* Arrays of notification callback functions */
 
@@ -325,6 +344,48 @@ static const struct scarlett2_notification scarlett3a_notifications[] = {
        { 0, NULL }
 };
 
+static const struct scarlett2_notification scarlett4_solo_notifications[] = {
+       { 0x00000001, NULL }, /* ack, gets ignored */
+       { 0x00000008, scarlett2_notify_sync },
+       { 0x00400000, scarlett2_notify_input_air },
+       { 0x00800000, scarlett2_notify_direct_monitor },
+       { 0x01000000, scarlett2_notify_input_level },
+       { 0x02000000, scarlett2_notify_input_phantom },
+       { 0, NULL }
+};
+
+static const struct scarlett2_notification scarlett4_2i2_notifications[] = {
+       { 0x00000001, NULL }, /* ack, gets ignored */
+       { 0x00000008, scarlett2_notify_sync },
+       { 0x00200000, scarlett2_notify_input_safe },
+       { 0x00400000, scarlett2_notify_autogain },
+       { 0x00800000, scarlett2_notify_input_air },
+       { 0x01000000, scarlett2_notify_direct_monitor },
+       { 0x02000000, scarlett2_notify_input_select },
+       { 0x04000000, scarlett2_notify_input_level },
+       { 0x08000000, scarlett2_notify_input_phantom },
+       { 0x10000000, NULL }, /* power status, ignored */
+       { 0x40000000, scarlett2_notify_input_gain },
+       { 0x80000000, NULL }, /* power status, ignored */
+       { 0, NULL }
+};
+
+static const struct scarlett2_notification scarlett4_4i4_notifications[] = {
+       { 0x00000001, NULL }, /* ack, gets ignored */
+       { 0x00000008, scarlett2_notify_sync },
+       { 0x00200000, scarlett2_notify_input_safe },
+       { 0x00400000, scarlett2_notify_autogain },
+       { 0x00800000, scarlett2_notify_input_air },
+       { 0x01000000, scarlett2_notify_input_select },
+       { 0x02000000, scarlett2_notify_input_level },
+       { 0x04000000, scarlett2_notify_input_phantom },
+       { 0x08000000, scarlett2_notify_power_status }, /* power external */
+       { 0x20000000, scarlett2_notify_input_gain },
+       { 0x40000000, scarlett2_notify_power_status }, /* power status */
+       { 0x80000000, scarlett2_notify_volume },
+       { 0, NULL }
+};
+
 /* Configuration parameters that can be read and written */
 enum {
        SCARLETT2_CONFIG_DIM_MUTE,
@@ -543,6 +604,123 @@ static const struct scarlett2_config_set scarlett2_config_set_gen3c = {
        }
 };
 
+/* Solo Gen 4 */
+static const struct scarlett2_config_set scarlett2_config_set_gen4_solo = {
+       .notifications = scarlett4_solo_notifications,
+       .gen4_write_addr = 0xd8,
+       .items = {
+               [SCARLETT2_CONFIG_MSD_SWITCH] = {
+                       .offset = 0x47, .size = 8, .activate = 4 },
+
+               [SCARLETT2_CONFIG_DIRECT_MONITOR] = {
+                       .offset = 0x108, .activate = 12 },
+
+               [SCARLETT2_CONFIG_PHANTOM_SWITCH] = {
+                       .offset = 0x46, .activate = 9, .mute = 1 },
+
+               [SCARLETT2_CONFIG_LEVEL_SWITCH] = {
+                       .offset = 0x3d, .activate = 10, .mute = 1 },
+
+               [SCARLETT2_CONFIG_AIR_SWITCH] = {
+                       .offset = 0x3e, .activate = 11 },
+
+               [SCARLETT2_CONFIG_DIRECT_MONITOR_GAIN] = {
+                       .offset = 0x232, .size = 16, .activate = 26 }
+       }
+};
+
+/* 2i2 Gen 4 */
+static const struct scarlett2_config_set scarlett2_config_set_gen4_2i2 = {
+       .notifications = scarlett4_2i2_notifications,
+       .gen4_write_addr = 0xfc,
+       .items = {
+               [SCARLETT2_CONFIG_MSD_SWITCH] = {
+                       .offset = 0x49, .size = 8, .activate = 4 }, // 0x41 ??
+
+               [SCARLETT2_CONFIG_DIRECT_MONITOR] = {
+                       .offset = 0x14a, .activate = 16 },
+
+               [SCARLETT2_CONFIG_AUTOGAIN_SWITCH] = {
+                       .offset = 0x135, .activate = 10 },
+
+               [SCARLETT2_CONFIG_AUTOGAIN_STATUS] = {
+                       .offset = 0x137 },
+
+               [SCARLETT2_CONFIG_PHANTOM_SWITCH] = {
+                       .offset = 0x48, .activate = 11, .mute = 1 },
+
+               [SCARLETT2_CONFIG_INPUT_GAIN] = {
+                       .offset = 0x4b, .activate = 12 },
+
+               [SCARLETT2_CONFIG_LEVEL_SWITCH] = {
+                       .offset = 0x3c, .activate = 13, .mute = 1 },
+
+               [SCARLETT2_CONFIG_SAFE_SWITCH] = {
+                       .offset = 0x147, .activate = 14 },
+
+               [SCARLETT2_CONFIG_AIR_SWITCH] = {
+                       .offset = 0x3e, .activate = 15 },
+
+               [SCARLETT2_CONFIG_INPUT_SELECT_SWITCH] = {
+                       .offset = 0x14b, .activate = 17 },
+
+               [SCARLETT2_CONFIG_INPUT_LINK_SWITCH] = {
+                       .offset = 0x14e, .activate = 18 },
+
+               [SCARLETT2_CONFIG_DIRECT_MONITOR_GAIN] = {
+                       .offset = 0x2a0, .size = 16, .activate = 36 }
+       }
+};
+
+/* 4i4 Gen 4 */
+static const struct scarlett2_config_set scarlett2_config_set_gen4_4i4 = {
+       .notifications = scarlett4_4i4_notifications,
+       .gen4_write_addr = 0x130,
+       .items = {
+               [SCARLETT2_CONFIG_MSD_SWITCH] = {
+                       .offset = 0x5c, .size = 8, .activate = 4 },
+
+               [SCARLETT2_CONFIG_AUTOGAIN_SWITCH] = {
+                       .offset = 0x13e, .activate = 10 },
+
+               [SCARLETT2_CONFIG_AUTOGAIN_STATUS] = {
+                       .offset = 0x140 },
+
+               [SCARLETT2_CONFIG_PHANTOM_SWITCH] = {
+                       .offset = 0x5a, .activate = 11, .mute = 1 },
+
+               [SCARLETT2_CONFIG_INPUT_GAIN] = {
+                       .offset = 0x5e, .activate = 12 },
+
+               [SCARLETT2_CONFIG_LEVEL_SWITCH] = {
+                       .offset = 0x4e, .activate = 13, .mute = 1 },
+
+               [SCARLETT2_CONFIG_SAFE_SWITCH] = {
+                       .offset = 0x150, .activate = 14 },
+
+               [SCARLETT2_CONFIG_AIR_SWITCH] = {
+                       .offset = 0x50, .activate = 15 },
+
+               [SCARLETT2_CONFIG_INPUT_SELECT_SWITCH] = {
+                       .offset = 0x153, .activate = 16 },
+
+               [SCARLETT2_CONFIG_INPUT_LINK_SWITCH] = {
+                       .offset = 0x156, .activate = 17 },
+
+               [SCARLETT2_CONFIG_MASTER_VOLUME] = {
+                       .offset = 0x32, .size = 16 },
+
+               [SCARLETT2_CONFIG_HEADPHONE_VOLUME] = {
+                       .offset = 0x3a, .size = 16 },
+
+               [SCARLETT2_CONFIG_POWER_EXT] = {
+                       .offset = 0x168 },
+
+               [SCARLETT2_CONFIG_POWER_STATUS] = {
+                       .offset = 0x66 }
+       }
+};
+
 /* Clarett USB and Clarett+ devices: 2Pre, 4Pre, 8Pre */
 static const struct scarlett2_config_set scarlett2_config_set_clarett = {
        .notifications = scarlett2_notifications,
@@ -1274,6 +1452,160 @@ static const struct scarlett2_device_info s18i20_gen3_info = {
        }
 };
 
+static const struct scarlett2_device_info solo_gen4_info = {
+       .config_set = &scarlett2_config_set_gen4_solo,
+       .min_firmware_version = 2115,
+
+       .level_input_count = 1,
+       .air_input_count = 1,
+       .air_input_first = 1,
+       .air_option = 1,
+       .phantom_count = 1,
+       .phantom_first = 1,
+       .inputs_per_phantom = 1,
+       .direct_monitor = 1,
+       .dsp_count = 2,
+
+       .port_count = {
+               [SCARLETT2_PORT_TYPE_NONE]     = { 1,  0 },
+               [SCARLETT2_PORT_TYPE_ANALOGUE] = { 2,  2 },
+               [SCARLETT2_PORT_TYPE_MIX]      = { 8,  6 },
+               [SCARLETT2_PORT_TYPE_PCM]      = { 2,  4 },
+       },
+
+       .mux_assignment = { {
+               { SCARLETT2_PORT_TYPE_MIX,       4,  2 },
+               { SCARLETT2_PORT_TYPE_MIX,       2,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  4 },
+               { SCARLETT2_PORT_TYPE_MIX,       0,  2 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  2 },
+               { 0,                             0,  0 },
+       }, {
+               { SCARLETT2_PORT_TYPE_MIX,       4,  2 },
+               { SCARLETT2_PORT_TYPE_MIX,       2,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  4 },
+               { SCARLETT2_PORT_TYPE_MIX,       0,  2 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  2 },
+               { 0,                             0,  0 },
+       }, {
+               { SCARLETT2_PORT_TYPE_MIX,       4,  2 },
+               { SCARLETT2_PORT_TYPE_MIX,       2,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  4 },
+               { SCARLETT2_PORT_TYPE_MIX,       0,  2 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  2 },
+               { 0,                             0,  0 },
+       } },
+
+       .meter_map = {
+               {  6,  2 },
+               {  4,  2 },
+               {  8,  4 },
+               {  2,  2 },
+               {  0,  2 },
+               {  0,  0 }
+       }
+};
+
+static const struct scarlett2_device_info s2i2_gen4_info = {
+       .config_set = &scarlett2_config_set_gen4_2i2,
+       .min_firmware_version = 2115,
+
+       .level_input_count = 2,
+       .air_input_count = 2,
+       .air_option = 1,
+       .phantom_count = 1,
+       .inputs_per_phantom = 2,
+       .gain_input_count = 2,
+       .direct_monitor = 2,
+       .dsp_count = 2,
+
+       .port_count = {
+               [SCARLETT2_PORT_TYPE_NONE]     = { 1,  0 },
+               [SCARLETT2_PORT_TYPE_ANALOGUE] = { 2,  2 },
+               [SCARLETT2_PORT_TYPE_MIX]      = { 6,  6 },
+               [SCARLETT2_PORT_TYPE_PCM]      = { 2,  4 },
+       },
+
+       .mux_assignment = { {
+               { SCARLETT2_PORT_TYPE_MIX,       4,  2 },
+               { SCARLETT2_PORT_TYPE_MIX,       2,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  4 },
+               { SCARLETT2_PORT_TYPE_MIX,       0,  2 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  2 },
+               { 0,                             0,  0 },
+       }, {
+               { SCARLETT2_PORT_TYPE_MIX,       4,  2 },
+               { SCARLETT2_PORT_TYPE_MIX,       2,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  4 },
+               { SCARLETT2_PORT_TYPE_MIX,       0,  2 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  2 },
+               { 0,                             0,  0 },
+       }, {
+               { SCARLETT2_PORT_TYPE_MIX,       4,  2 },
+               { SCARLETT2_PORT_TYPE_MIX,       2,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  4 },
+               { SCARLETT2_PORT_TYPE_MIX,       0,  2 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  2 },
+               { 0,                             0,  0 },
+       } },
+
+       .meter_map = {
+               {  6,  2 },
+               {  4,  2 },
+               {  8,  4 },
+               {  2,  2 },
+               {  0,  2 },
+               {  0,  0 }
+       }
+};
+
+static const struct scarlett2_device_info s4i4_gen4_info = {
+       .config_set = &scarlett2_config_set_gen4_4i4,
+       .min_firmware_version = 2089,
+
+       .level_input_count = 2,
+       .air_input_count = 2,
+       .air_option = 1,
+       .phantom_count = 2,
+       .inputs_per_phantom = 1,
+       .gain_input_count = 2,
+       .dsp_count = 2,
+
+       .port_count = {
+               [SCARLETT2_PORT_TYPE_NONE]     = { 1,  0 },
+               [SCARLETT2_PORT_TYPE_ANALOGUE] = { 4,  6 },
+               [SCARLETT2_PORT_TYPE_MIX]      = { 8, 12 },
+               [SCARLETT2_PORT_TYPE_PCM]      = { 6,  6 },
+       },
+
+       .mux_assignment = { {
+               { SCARLETT2_PORT_TYPE_MIX,      10,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  6 },
+               { SCARLETT2_PORT_TYPE_MIX,       0, 10 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  6 },
+               { 0,                             0,  0 },
+       }, {
+               { SCARLETT2_PORT_TYPE_MIX,      10,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  6 },
+               { SCARLETT2_PORT_TYPE_MIX,       0, 10 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  6 },
+               { 0,                             0,  0 },
+       }, {
+               { SCARLETT2_PORT_TYPE_MIX,      10,  2 },
+               { SCARLETT2_PORT_TYPE_PCM,       0,  6 },
+               { SCARLETT2_PORT_TYPE_MIX,       0, 10 },
+               { SCARLETT2_PORT_TYPE_ANALOGUE,  0,  6 },
+               { 0,                             0,  0 },
+       } },
+
+       .meter_map = {
+               { 16,  8 },
+               {  6, 10 },
+               {  0,  6 },
+               {  0,  0 }
+       }
+};
+
 static const struct scarlett2_device_info clarett_2pre_info = {
        .config_set = &scarlett2_config_set_clarett,
        .level_input_count = 2,
@@ -1451,6 +1783,11 @@ static const struct scarlett2_device_entry scarlett2_devices[] = {
        { USB_ID(0x1235, 0x8214), &s18i8_gen3_info, "Scarlett Gen 3" },
        { USB_ID(0x1235, 0x8215), &s18i20_gen3_info, "Scarlett Gen 3" },
 
+       /* Supported Gen 4 devices */
+       { USB_ID(0x1235, 0x8218), &solo_gen4_info, "Scarlett Gen 4" },
+       { USB_ID(0x1235, 0x8219), &s2i2_gen4_info, "Scarlett Gen 4" },
+       { USB_ID(0x1235, 0x821a), &s4i4_gen4_info, "Scarlett Gen 4" },
+
        /* Supported Clarett USB/Clarett+ devices */
        { USB_ID(0x1235, 0x8206), &clarett_2pre_info, "Clarett USB" },
        { USB_ID(0x1235, 0x8207), &clarett_4pre_info, "Clarett USB" },
@@ -6353,8 +6690,7 @@ static void scarlett2_notify_monitor(struct usb_mixer_interface *mixer)
 }
 
 /* Notify on volume change (Gen 4) */
-static __always_unused void scarlett2_notify_volume(
-       struct usb_mixer_interface *mixer)
+static void scarlett2_notify_volume(struct usb_mixer_interface *mixer)
 {
        struct scarlett2_data *private = mixer->private_data;
 
@@ -6460,8 +6796,7 @@ static void scarlett2_notify_input_other(struct usb_mixer_interface *mixer)
 }
 
 /* Notify on input select change */
-static __always_unused void scarlett2_notify_input_select(
-       struct usb_mixer_interface *mixer)
+static void scarlett2_notify_input_select(struct usb_mixer_interface *mixer)
 {
        struct snd_card *card = mixer->chip->card;
        struct scarlett2_data *private = mixer->private_data;
@@ -6483,8 +6818,7 @@ static __always_unused void scarlett2_notify_input_select(
 }
 
 /* Notify on input gain change */
-static __always_unused void scarlett2_notify_input_gain(
-       struct usb_mixer_interface *mixer)
+static void scarlett2_notify_input_gain(struct usb_mixer_interface *mixer)
 {
        struct snd_card *card = mixer->chip->card;
        struct scarlett2_data *private = mixer->private_data;
@@ -6502,8 +6836,7 @@ static __always_unused void scarlett2_notify_input_gain(
 }
 
 /* Notify on autogain change */
-static __always_unused void scarlett2_notify_autogain(
-       struct usb_mixer_interface *mixer)
+static void scarlett2_notify_autogain(struct usb_mixer_interface *mixer)
 {
        struct snd_card *card = mixer->chip->card;
        struct scarlett2_data *private = mixer->private_data;
@@ -6526,8 +6859,7 @@ static __always_unused void scarlett2_notify_autogain(
 }
 
 /* Notify on input safe switch change */
-static __always_unused void scarlett2_notify_input_safe(
-       struct usb_mixer_interface *mixer)
+static void scarlett2_notify_input_safe(struct usb_mixer_interface *mixer)
 {
        struct snd_card *card = mixer->chip->card;
        struct scarlett2_data *private = mixer->private_data;
@@ -6603,8 +6935,7 @@ static void scarlett2_notify_direct_monitor(struct usb_mixer_interface *mixer)
 }
 
 /* Notify on power change */
-static __always_unused void scarlett2_notify_power_status(
-       struct usb_mixer_interface *mixer)
+static void scarlett2_notify_power_status(struct usb_mixer_interface *mixer)
 {
        struct snd_card *card = mixer->chip->card;
        struct scarlett2_data *private = mixer->private_data;