about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--machines/aszlig/tishtushi.nix4
-rw-r--r--pkgs/default.nix1
-rw-r--r--pkgs/kpatches/dragonfly/0001-ALSA-usb-audio-Add-a-volume-scale-quirk-for-AudioQue.patch95
-rw-r--r--pkgs/kpatches/dragonfly/0002-ALSA-usb-audio-Add-sample-rate-inquiry-quirk-for-Aud.patch31
-rw-r--r--pkgs/kpatches/dragonfly/0003-ALSA-Revert-add-dB-range-mapping-for-Dragonfly.patch49
-rw-r--r--pkgs/kpatches/dragonfly/default.nix16
6 files changed, 1 insertions, 195 deletions
diff --git a/machines/aszlig/tishtushi.nix b/machines/aszlig/tishtushi.nix
index d7175d94..92af4a9e 100644
--- a/machines/aszlig/tishtushi.nix
+++ b/machines/aszlig/tishtushi.nix
@@ -24,9 +24,7 @@ in {
         '';
       };
       kernel = origKernel.override {
-        kernelPatches = origKernel.kernelPatches ++ [
-          bfqsched pkgs.vuizvui.kernelPatches.dragonfly
-        ];
+        kernelPatches = origKernel.kernelPatches ++ singleton bfqsched;
       };
     in linuxPackagesFor kernel kernelPackages;
 
diff --git a/pkgs/default.nix b/pkgs/default.nix
index 41598357..3b56fbd2 100644
--- a/pkgs/default.nix
+++ b/pkgs/default.nix
@@ -23,7 +23,6 @@ let
 
     kernelPatches = {
       bfqsched = callPackage ./kpatches/bfqsched.nix { };
-      dragonfly = callPackage ./kpatches/dragonfly { };
     };
   };
 in pkgs // self
diff --git a/pkgs/kpatches/dragonfly/0001-ALSA-usb-audio-Add-a-volume-scale-quirk-for-AudioQue.patch b/pkgs/kpatches/dragonfly/0001-ALSA-usb-audio-Add-a-volume-scale-quirk-for-AudioQue.patch
deleted file mode 100644
index e04df9ed..00000000
--- a/pkgs/kpatches/dragonfly/0001-ALSA-usb-audio-Add-a-volume-scale-quirk-for-AudioQue.patch
+++ /dev/null
@@ -1,95 +0,0 @@
-From 8ccfffa0584532d9a98646bc39ead0e2361a86a2 Mon Sep 17 00:00:00 2001
-From: Anssi Hannula <anssi.hannula@iki.fi>
-Date: Sun, 16 Aug 2015 15:50:12 +0300
-Subject: [PATCH 1/3] ALSA: usb-audio: Add a volume scale quirk for AudioQuest
- DragonFly
-
-AudioQuest DragonFly DAC reports a volume control range of 0..50
-(0x0000..0x0032) which in USB Audio means a range of 0 .. 0.2dB, which
-is obviously incorrect and causes software using the dB information in
-e.g. volume sliders to have a massive volume difference in 100..102%
-range.
-
-The actual volume mapping seems to be neither linear volume nor linear
-dB scale, but instead quite close to the cubic mapping e.g. alsamixer
-uses, with a range of -53...0 dB.
-
-Add a quirk for DragonFly to use a custom dB mapping, based on my
-measurements, using a 10-item range TLV (so it still fits in alsa-lib
-MAX_TLV_RANGE_SIZE).
-
-Tested on AudioQuest DragonFly HW v1.2. The quirk is only applied if the
-range is 0..50, so if this gets fixed/changed in later HW revisions it
-will no longer be applied.
-
-Signed-off-by: Anssi Hannula <anssi.hannula@iki.fi>
-Cc: <stable@vger.kernel.org>
----
- sound/usb/mixer_quirks.c | 37 +++++++++++++++++++++++++++++++++++++
- 1 file changed, 37 insertions(+)
-
-diff --git a/sound/usb/mixer_quirks.c b/sound/usb/mixer_quirks.c
-index d3608c0..dee73fa 100644
---- a/sound/usb/mixer_quirks.c
-+++ b/sound/usb/mixer_quirks.c
-@@ -37,6 +37,7 @@
- #include <sound/control.h>
- #include <sound/hwdep.h>
- #include <sound/info.h>
-+#include <sound/tlv.h>
- 
- #include "usbaudio.h"
- #include "mixer.h"
-@@ -1715,6 +1716,38 @@ static int snd_microii_controls_create(struct usb_mixer_interface *mixer)
- 	return 0;
- }
- 
-+static void snd_dragonfly_quirk_db_scale(struct usb_mixer_interface *mixer)
-+{
-+	struct usb_mixer_elem_list *list;
-+	struct usb_mixer_elem_info *cval;
-+	static const int unit_id = 7;
-+
-+	/* approximation using 10 ranges based on output measurement on hw v1.2 */
-+	static const DECLARE_TLV_DB_RANGE(scale,
-+		 0,  1, TLV_DB_MINMAX_ITEM(-5300, -4970),
-+		 2,  5, TLV_DB_MINMAX_ITEM(-4710, -4160),
-+		 6,  7, TLV_DB_MINMAX_ITEM(-3884, -3710),
-+		 8, 14, TLV_DB_MINMAX_ITEM(-3443, -2560),
-+		15, 16, TLV_DB_MINMAX_ITEM(-2475, -2324),
-+		17, 19, TLV_DB_MINMAX_ITEM(-2228, -2031),
-+		20, 26, TLV_DB_MINMAX_ITEM(-1910, -1393),
-+		27, 31, TLV_DB_MINMAX_ITEM(-1322, -1032),
-+		32, 40, TLV_DB_MINMAX_ITEM(-968, -490),
-+		41, 50, TLV_DB_MINMAX_ITEM(-441, 0),
-+	);
-+
-+	for (list = mixer->id_elems[unit_id]; list; list = list->next_id_elem) {
-+		cval = (struct usb_mixer_elem_info *)list;
-+		if (cval->control == UAC_FU_VOLUME &&
-+		    cval->min == 0 && cval->max == 50) {
-+			usb_audio_info(mixer->chip, "applying DragonFly dB scale quirk\n");
-+			list->kctl->tlv.p = scale;
-+			list->kctl->vd[0].access |=  SNDRV_CTL_ELEM_ACCESS_TLV_READ;
-+			list->kctl->vd[0].access &= ~SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK;
-+		}
-+	}
-+}
-+
- int snd_usb_mixer_apply_create_quirk(struct usb_mixer_interface *mixer)
- {
- 	int err = 0;
-@@ -1792,6 +1825,10 @@ int snd_usb_mixer_apply_create_quirk(struct usb_mixer_interface *mixer)
- 	case USB_ID(0x1235, 0x800c): /* Focusrite Scarlett 18i20 */
- 		err = snd_scarlett_controls_create(mixer);
- 		break;
-+
-+	case USB_ID(0x21b4, 0x0081): /* AudioQuest DragonFly */
-+		snd_dragonfly_quirk_db_scale(mixer);
-+		break;
- 	}
- 
- 	return err;
--- 
-2.5.3
-
diff --git a/pkgs/kpatches/dragonfly/0002-ALSA-usb-audio-Add-sample-rate-inquiry-quirk-for-Aud.patch b/pkgs/kpatches/dragonfly/0002-ALSA-usb-audio-Add-sample-rate-inquiry-quirk-for-Aud.patch
deleted file mode 100644
index 60347325..00000000
--- a/pkgs/kpatches/dragonfly/0002-ALSA-usb-audio-Add-sample-rate-inquiry-quirk-for-Aud.patch
+++ /dev/null
@@ -1,31 +0,0 @@
-From 546503d2e0b621fc1ae4d4d99bc272f5f46e4de8 Mon Sep 17 00:00:00 2001
-From: Anssi Hannula <anssi.hannula@iki.fi>
-Date: Sun, 16 Aug 2015 15:50:13 +0300
-Subject: [PATCH 2/3] ALSA: usb-audio: Add sample rate inquiry quirk for
- AudioQuest DragonFly
-
-Avoid getting sample rate on AudioQuest DragonFly as it is unsupported
-and causes noisy "cannot get freq at ep 0x1" messages when playback
-starts.
-
-Signed-off-by: Anssi Hannula <anssi.hannula@iki.fi>
-Cc: <stable@vger.kernel.org>
----
- sound/usb/quirks.c | 1 +
- 1 file changed, 1 insertion(+)
-
-diff --git a/sound/usb/quirks.c b/sound/usb/quirks.c
-index 00ebc0c..b2ff580 100644
---- a/sound/usb/quirks.c
-+++ b/sound/usb/quirks.c
-@@ -1121,6 +1121,7 @@ bool snd_usb_get_sample_rate_quirk(struct snd_usb_audio *chip)
- 	case USB_ID(0x045E, 0x0779): /* MS Lifecam HD-3000 */
- 	case USB_ID(0x04D8, 0xFEEA): /* Benchmark DAC1 Pre */
- 	case USB_ID(0x074D, 0x3553): /* Outlaw RR2150 (Micronas UAC3553B) */
-+	case USB_ID(0x21B4, 0x0081): /* AudioQuest DragonFly */
- 		return true;
- 	}
- 	return false;
--- 
-2.5.3
-
diff --git a/pkgs/kpatches/dragonfly/0003-ALSA-Revert-add-dB-range-mapping-for-Dragonfly.patch b/pkgs/kpatches/dragonfly/0003-ALSA-Revert-add-dB-range-mapping-for-Dragonfly.patch
deleted file mode 100644
index 69b42c38..00000000
--- a/pkgs/kpatches/dragonfly/0003-ALSA-Revert-add-dB-range-mapping-for-Dragonfly.patch
+++ /dev/null
@@ -1,49 +0,0 @@
-From b81246424561904823492aa551e7b22b16157a94 Mon Sep 17 00:00:00 2001
-From: aszlig <aszlig@redmoonstudios.org>
-Date: Fri, 16 Oct 2015 18:31:41 +0200
-Subject: [PATCH 3/3] ALSA: Revert add dB range mapping for Dragonfly.
-
-This partially reverts commit 2d1cb7f658fb9c3ba8f9dab8aca297d4dfdec835.
-
-We now have a better patch coming from:
-
-http://mailman.alsa-project.org/pipermail/alsa-devel/2015-August/096516.html
-
-Signed-off-by: aszlig <aszlig@redmoonstudios.org>
----
- sound/usb/mixer_maps.c | 12 ------------
- 1 file changed, 12 deletions(-)
-
-diff --git a/sound/usb/mixer_maps.c b/sound/usb/mixer_maps.c
-index 6a803ef..ddca654 100644
---- a/sound/usb/mixer_maps.c
-+++ b/sound/usb/mixer_maps.c
-@@ -348,13 +348,6 @@ static struct usbmix_name_map bose_companion5_map[] = {
- 	{ 0 }	/* terminator */
- };
- 
--/* Dragonfly DAC 1.2, the dB conversion factor is 1 instead of 256 */
--static struct usbmix_dB_map dragonfly_1_2_dB = {0, 5000};
--static struct usbmix_name_map dragonfly_1_2_map[] = {
--	{ 7, NULL, .dB = &dragonfly_1_2_dB },
--	{ 0 }	/* terminator */
--};
--
- /*
-  * Control map entries
-  */
-@@ -470,11 +463,6 @@ static struct usbmix_ctl_map usbmix_ctl_maps[] = {
- 		.id = USB_ID(0x05a7, 0x1020),
- 		.map = bose_companion5_map,
- 	},
--	{
--		/* Dragonfly DAC 1.2 */
--		.id = USB_ID(0x21b4, 0x0081),
--		.map = dragonfly_1_2_map,
--	},
- 	{ 0 } /* terminator */
- };
- 
--- 
-2.5.3
-
diff --git a/pkgs/kpatches/dragonfly/default.nix b/pkgs/kpatches/dragonfly/default.nix
deleted file mode 100644
index 2c5d88b0..00000000
--- a/pkgs/kpatches/dragonfly/default.nix
+++ /dev/null
@@ -1,16 +0,0 @@
-{ stdenv }:
-
-{
-  name = "dragonfly";
-  patch = stdenv.mkDerivation {
-    name = "dragonfly.patch";
-    patches = [
-      ./0001-ALSA-usb-audio-Add-a-volume-scale-quirk-for-AudioQue.patch
-      ./0002-ALSA-usb-audio-Add-sample-rate-inquiry-quirk-for-Aud.patch
-      ./0003-ALSA-Revert-add-dB-range-mapping-for-Dragonfly.patch
-    ];
-    buildCommand = ''
-      cat $patches > "$out"
-    '';
-  };
-}