Delete sys-kernel/pinephone-sources directory
This commit is contained in:
		
				
					committed by
					
						
						GitHub
					
				
			
			
				
	
			
			
			
						parent
						
							5ef5cf8294
						
					
				
				
					commit
					12e8b009ec
				
			@@ -1,16 +0,0 @@
 | 
			
		||||
DIST all-5.11.10.patch 15061885 BLAKE2B 8e5c483f90e1d2832dd74f26e8078b91fc16a50a5a2d6970c60760e899ec0bc4b39c9399691b31d9ebabc111878edcd09f2417b269b5379a645c02c0517d1f86 SHA512 c8d3d80b7a087c622863cdd17c88fdaf1b0432fbb91e4e8f36463fdcb038d38c0112c0ef31b6e9f7c6af54b3e8bbb9ccd2bd99354c46a34aaa5606e10d7172df
 | 
			
		||||
DIST all-5.11.11.patch 15061885 BLAKE2B 8e5c483f90e1d2832dd74f26e8078b91fc16a50a5a2d6970c60760e899ec0bc4b39c9399691b31d9ebabc111878edcd09f2417b269b5379a645c02c0517d1f86 SHA512 c8d3d80b7a087c622863cdd17c88fdaf1b0432fbb91e4e8f36463fdcb038d38c0112c0ef31b6e9f7c6af54b3e8bbb9ccd2bd99354c46a34aaa5606e10d7172df
 | 
			
		||||
DIST all-5.11.12.patch 15061885 BLAKE2B 8e5c483f90e1d2832dd74f26e8078b91fc16a50a5a2d6970c60760e899ec0bc4b39c9399691b31d9ebabc111878edcd09f2417b269b5379a645c02c0517d1f86 SHA512 c8d3d80b7a087c622863cdd17c88fdaf1b0432fbb91e4e8f36463fdcb038d38c0112c0ef31b6e9f7c6af54b3e8bbb9ccd2bd99354c46a34aaa5606e10d7172df
 | 
			
		||||
DIST all-5.11.8.patch 15061885 BLAKE2B 8e5c483f90e1d2832dd74f26e8078b91fc16a50a5a2d6970c60760e899ec0bc4b39c9399691b31d9ebabc111878edcd09f2417b269b5379a645c02c0517d1f86 SHA512 c8d3d80b7a087c622863cdd17c88fdaf1b0432fbb91e4e8f36463fdcb038d38c0112c0ef31b6e9f7c6af54b3e8bbb9ccd2bd99354c46a34aaa5606e10d7172df
 | 
			
		||||
DIST all-5.12_rc3.patch 15033523 BLAKE2B 29ff7d60b71856994d727f36c33c8352c963f8b59befbbef421f6798e5001c601dd2f2080faddf4c4d711931130604665af1e5e7e3bd7c22a84da1a0f198b559 SHA512 a2761ca964ad02b0fab029b6ee2cf84040f5cc86909227dca62255edd33bf49aef167e8ecbc8e899a86daff8d5e5b3814c56b18f4f8e371e2ab85dac7f22de6a
 | 
			
		||||
DIST all.patch 14517437 BLAKE2B ec81c49d07cf9cf20081050be80ad1bcb5ed5f08b5940a34dcf4156b4eaf260a100d6fe690fc38dc83631862b9177583146ee4b67fcd548b9285bd8f5551c800 SHA512 326898b0bf4f8d737d9e44a45eb6d6bd78f240829c28735b78936823e2031565e11882780389a152889a6b27ff40f789851fe991b5c43e8ecf64f2aa2ced6c49
 | 
			
		||||
DIST genpatches-5.9-12.base.tar.xz 628408 BLAKE2B 6dbb2c992971cf3ee1c0a0c7a7b70876bcc41e93dd6def0fe87e2a4ddaf62ebfe808487ac117b79eb629c34e66ef1a02bf7adc2191c3273bf77ea384260a5bd3 SHA512 bde0614ff1eb3dc9f681fa8a5f8207c8d2f9a959984fd3a0c8bc4da8ca432d6e1a32992735a8c59074de738a6d1341aa688efc75eaca6cb575f41e694f333d7f
 | 
			
		||||
DIST genpatches-5.9-12.experimental.tar.xz 6088 BLAKE2B e6773b615967443b961e498e50ce50c48608b71f0373bbf8c68d2aac4906c18dcca3e1578157ab0413c700ac2f67140fc47901c757d8292e1d1051f6ef77c21b SHA512 bf21c813045ecd51d2fef01f15269eb77c9c672e3133dcbb60461190e6c5b5f7f3bacf557b7d48f4bed702ba3135a665d319ed218cce1b8319ee83d93d1eeb19
 | 
			
		||||
DIST genpatches-5.9-12.extras.tar.xz 1764 BLAKE2B 8bfbde759342d00f10d6fe12e313d449de35aba13a5ba3564043d0489205eafa709a6481e7249bb79f54c84c759f50ca7f630e2e2bbfebc71942f72b3c8ea6e8 SHA512 274a2d2fce2f446503c4540d30daa3c3d6a86e6e6c206f0a2e1e89ee1ebd496f6ce2706add35ca6fc39df2c0758719faf332a230db18dfa9f81dab787f24eb3d
 | 
			
		||||
DIST linux-5.11.tar.xz 117619104 BLAKE2B 81300c27bd5476387a83123aaeb4163c73eb61e9245806c23660cb5e6a4fa88ffc9def027031335fa0270fc4080506cd415990014364e3a98b9d2e8c58a29524 SHA512 a567ec133018bb5ec00c60281479b466c26e02137a93a9c690e83997947df02b6fd94e76e8df748f6d70ceb58a19bacc3b1467de10b7a1fad2763db32b3f1330
 | 
			
		||||
DIST linux-5.9.tar.xz 115507140 BLAKE2B e8d11472d63a9f8409ca12a2e8c97c6963a3d4516b5a398b627d6ece565584526f9b5a1377a2fa4bd184c09c7db94c987428bc5d52df0c788464a67e9e8d6dcb SHA512 d3d92ce4246bad74c9a784212f160d98449b1e8793970c2c308276568d852b8effe0528686bdb87d55d691f09a826abf7938d69bdd4759ce65ddd5c05ffe4eca
 | 
			
		||||
DIST patch-5.11.10.xz 426380 BLAKE2B 434458f668f17e79ebecce4085b027f3485f465efc56d8c3f5c28f30a18937237e39b4f30bcd81e033ea258f37c43dcc38cdb586dbb3983004471c3a6302079b SHA512 5c7a3dc972169363feab6f007af1105a9fb0ad52dbca2cb9d7546ab8bccee28f8faceb443a154a6349b2329400e264e91153d01685e48604dd9cb967eab04e1f
 | 
			
		||||
DIST patch-5.11.11.xz 497760 BLAKE2B 277e6427be5aefffadf613fcfd4383c8a4e26ddd6e568ed7217453b3592882c90810fce65f475afbb70574767a84deb270d17bc943d04e25d5e2a7d8ebf81477 SHA512 2aed1fb05c93dcb1d8825639c5aba004a16d53af24b278eb036d0b85675e6a5f2738579d35301c9b6624fb7cc16bf3394d4a0e50fcaad5f030c91dd1382777a9
 | 
			
		||||
DIST patch-5.11.12.xz 540552 BLAKE2B 9056711279a2b1f54b02b13bec3eb870e8369ddef52768ede6d59e8fa3be84110e6d2d2a62e6a2c164e3cd8b4e9252b3da376d9a585ff693c6d94f1a1b8a7fe2 SHA512 feaf70c5d418792d2954ce70e8168397cfb053db4f6c98aa9cd1db935c850cfbe5f75dd23dcfeb5aa1127c63823b2e3ec0393a19a8d253387c6a537c2518f7a4
 | 
			
		||||
DIST patch-5.11.8.xz 401900 BLAKE2B 0f0a92236328844fd75fe536912195bcad5f7f3c9288b342b84a26702c500df312eb1183fe979cdc286d08dc82527a43d081b3acfe3bafb81a58fa0fd646a312 SHA512 44edcabf7894cbfd32191200fad810141f42cd3cf885a100ce37c796232f2217673c3e407c91132b9ee08741ccc9a53f882b6c86d0a606c4462830799c8f94fb
 | 
			
		||||
DIST patch-5.12-rc3.patch 38689504 BLAKE2B 25962d05cfd031ea45347f339da8dd206c38ee16c78fd5ff39edb564474b11d4321e450904f9db491f62bb6002e338ef3136327d656c028eaae6f8a3b9207229 SHA512 585a883af66641247e3a44ca56788dc5afe5a2f3a8bd0d9aaabba0324cbbbd4dffdad0d9bc65e30f77903c870985bfbfe1a3283cc709b92417f89d2c94ab8f16
 | 
			
		||||
@@ -1,61 +0,0 @@
 | 
			
		||||
From 33212e529708fd480eaf9cc76579f8e7044c0505 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Martijn Braam <martijn@brixit.nl>
 | 
			
		||||
Date: Tue, 20 Oct 2020 14:42:01 +0200
 | 
			
		||||
Subject: [PATCH] dts: add pinetab-dev (old display panel)
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/Makefile        |  1 +
 | 
			
		||||
 .../dts/allwinner/sun50i-a64-pinetab-dev.dts  | 29 +++++++++++++++++++
 | 
			
		||||
 2 files changed, 30 insertions(+)
 | 
			
		||||
 create mode 100644 arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab-dev.dts
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/Makefile b/arch/arm64/boot/dts/allwinner/Makefile
 | 
			
		||||
index a21cfdd8924d..2936092002b5 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/Makefile
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/Makefile
 | 
			
		||||
@@ -15,6 +15,7 @@ dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinephone-1.0.dtb
 | 
			
		||||
 dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinephone-1.1.dtb
 | 
			
		||||
 dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinephone-1.2.dtb
 | 
			
		||||
 dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinetab.dtb
 | 
			
		||||
+dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-pinetab-dev.dtb
 | 
			
		||||
 dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-sopine-baseboard.dtb
 | 
			
		||||
 dtb-$(CONFIG_ARCH_SUNXI) += sun50i-a64-teres-i.dtb
 | 
			
		||||
 dtb-$(CONFIG_ARCH_SUNXI) += sun50i-h5-bananapi-m2-plus.dtb
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab-dev.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab-dev.dts
 | 
			
		||||
new file mode 100644
 | 
			
		||||
index 000000000000..1e287f2fb9f3
 | 
			
		||||
--- /dev/null
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab-dev.dts
 | 
			
		||||
@@ -0,0 +1,29 @@
 | 
			
		||||
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
 | 
			
		||||
+/*
 | 
			
		||||
+ * Copyright (C) 2019 Icenowy Zheng <icenowy@aosc.xyz>
 | 
			
		||||
+ *
 | 
			
		||||
+ */
 | 
			
		||||
+
 | 
			
		||||
+/dts-v1/;
 | 
			
		||||
+
 | 
			
		||||
+#include "sun50i-a64-pinetab.dts"
 | 
			
		||||
+
 | 
			
		||||
+/ {
 | 
			
		||||
+	model = "PineTab";
 | 
			
		||||
+	compatible = "pine64,pinetab", "allwinner,sun50i-a64";
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
+&dsi {
 | 
			
		||||
+	vcc-dsi-supply = <®_dldo1>;
 | 
			
		||||
+	status = "okay";
 | 
			
		||||
+
 | 
			
		||||
+	panel@0 {
 | 
			
		||||
+		compatible = "feixin,k101-im2ba02";
 | 
			
		||||
+		reg = <0>;
 | 
			
		||||
+		avdd-supply = <®_dc1sw>;
 | 
			
		||||
+		dvdd-supply = <®_dc1sw>;
 | 
			
		||||
+		cvdd-supply = <®_ldo_io1>;
 | 
			
		||||
+		reset-gpios = <&pio 3 24 GPIO_ACTIVE_HIGH>; /* PD24 */
 | 
			
		||||
+		backlight = <&backlight>;
 | 
			
		||||
+	};
 | 
			
		||||
+};
 | 
			
		||||
-- 
 | 
			
		||||
2.25.4
 | 
			
		||||
 | 
			
		||||
@@ -1,56 +0,0 @@
 | 
			
		||||
From 05044b9e4e4ae03f66e1c504d6fef57a1d135897 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Dylan Van Assche <me@dylanvanassche.be>
 | 
			
		||||
Date: Thu, 24 Dec 2020 19:57:12 +0100
 | 
			
		||||
Subject: [PATCH] dts: pinephone: Add 'pine64,pinephone' to compat list
 | 
			
		||||
 | 
			
		||||
Indicates that all PinePhone models share most of the hardware with each other.
 | 
			
		||||
Used for feedbackd configuration when retrieving a device specific config for
 | 
			
		||||
haptic feedbackd.
 | 
			
		||||
---
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts | 2 +-
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts | 2 +-
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts | 2 +-
 | 
			
		||||
 3 files changed, 3 insertions(+), 3 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts
 | 
			
		||||
index 0f6faa44c..2e0892b32 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts
 | 
			
		||||
@@ -7,7 +7,7 @@
 | 
			
		||||
 
 | 
			
		||||
 / {
 | 
			
		||||
 	model = "Pine64 PinePhone Developer Batch (1.0)";
 | 
			
		||||
-	compatible = "pine64,pinephone-1.0", "allwinner,sun50i-a64";
 | 
			
		||||
+	compatible = "pine64,pinephone-1.0", "pine64,pinephone", "allwinner,sun50i-a64";
 | 
			
		||||
 
 | 
			
		||||
 	reg_vbus: usb0-vbus {
 | 
			
		||||
 		compatible = "regulator-fixed";
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
index 95a880fdc..d6bad0838 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
@@ -7,7 +7,7 @@
 | 
			
		||||
 
 | 
			
		||||
 / {
 | 
			
		||||
 	model = "Pine64 PinePhone Braveheart (1.1)";
 | 
			
		||||
-	compatible = "pine64,pinephone-1.1", "allwinner,sun50i-a64";
 | 
			
		||||
+	compatible = "pine64,pinephone-1.1", "pine64,pinephone", "allwinner,sun50i-a64";
 | 
			
		||||
 
 | 
			
		||||
 	reg_vbus: usb0-vbus {
 | 
			
		||||
 		compatible = "regulator-fixed";
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
index 23ba72508..710493186 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
@@ -7,7 +7,7 @@
 | 
			
		||||
 
 | 
			
		||||
 / {
 | 
			
		||||
 	model = "Pine64 PinePhone (1.2)";
 | 
			
		||||
-	compatible = "pine64,pinephone-1.2", "allwinner,sun50i-a64";
 | 
			
		||||
+	compatible = "pine64,pinephone-1.2", "pine64,pinephone", "allwinner,sun50i-a64";
 | 
			
		||||
 
 | 
			
		||||
 	wifi_pwrseq: wifi-pwrseq {
 | 
			
		||||
 		compatible = "mmc-pwrseq-simple";
 | 
			
		||||
-- 
 | 
			
		||||
2.26.2
 | 
			
		||||
 | 
			
		||||
@@ -1,29 +0,0 @@
 | 
			
		||||
From c965cb8a004c6cc370b4bf297c61fe5ac8ab0583 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Martijn Braam <martijn@brixit.nl>
 | 
			
		||||
Date: Wed, 6 Jan 2021 03:11:17 +0100
 | 
			
		||||
Subject: [PATCH] arm64: dts: sunxi: Add mmc aliases for the PineTab
 | 
			
		||||
 | 
			
		||||
The order for the mmc devices changed in the kernel without this change.
 | 
			
		||||
 | 
			
		||||
Signed-off-by: Martijn Braam <martijn@brixit.nl>
 | 
			
		||||
---
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts | 3 +++
 | 
			
		||||
 1 file changed, 3 insertions(+)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
index a87790df94b3..1cf3c3a9ad7f 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
@@ -18,6 +18,9 @@ / {
 | 
			
		||||
 	compatible = "pine64,pinetab", "allwinner,sun50i-a64";
 | 
			
		||||
 
 | 
			
		||||
 	aliases {
 | 
			
		||||
+		mmc0 = &mmc0;
 | 
			
		||||
+		mmc1 = &mmc1;
 | 
			
		||||
+		mmc2 = &mmc2;
 | 
			
		||||
 		serial0 = &uart0;
 | 
			
		||||
 		ethernet0 = &rtl8723cs;
 | 
			
		||||
 	};
 | 
			
		||||
-- 
 | 
			
		||||
2.29.2
 | 
			
		||||
 | 
			
		||||
@@ -1,29 +0,0 @@
 | 
			
		||||
From d753557c64f6e85f63cffab53496d6271d724074 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Martijn Braam <martijn@brixit.nl>
 | 
			
		||||
Date: Mon, 15 Feb 2021 13:10:37 -0800
 | 
			
		||||
Subject: [PATCH] pinephone: fix pogopin i2c
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi | 6 +-----
 | 
			
		||||
 1 file changed, 1 insertion(+), 5 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
index 39fdf96fe95d..7d0dd52e2f9d 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
@@ -635,11 +635,7 @@ &pio {
 | 
			
		||||
 	vcc-pb-supply = <®_dcdc1>;
 | 
			
		||||
 	vcc-pc-supply = <®_dcdc1>;
 | 
			
		||||
 	vcc-pd-supply = <®_dcdc1>;
 | 
			
		||||
-	/* pinctrl would enable this even if no camera is powered,
 | 
			
		||||
-	 * which is wrong/not necessary
 | 
			
		||||
-	 *
 | 
			
		||||
-	 * vcc-pe-supply = <®_aldo1>; (also used by pogo pins i2c)
 | 
			
		||||
-	 */
 | 
			
		||||
+	vcc-pe-supply = <®_aldo1>; /* (also used by pogo pins i2c) */
 | 
			
		||||
 	vcc-pf-supply = <®_dcdc1>;
 | 
			
		||||
 	vcc-pg-supply = <®_dldo4>;
 | 
			
		||||
 	vcc-ph-supply = <®_dcdc1>;
 | 
			
		||||
-- 
 | 
			
		||||
2.30.1
 | 
			
		||||
 | 
			
		||||
@@ -1,12 +0,0 @@
 | 
			
		||||
diff --git a/drivers/bluetooth/btusb.c b/drivers/bluetooth/btusb.c
 | 
			
		||||
index 03b83aa91277..dfc6c7d1b0e7 100644
 | 
			
		||||
--- a/drivers/bluetooth/btusb.c
 | 
			
		||||
+++ b/drivers/bluetooth/btusb.c
 | 
			
		||||
@@ -4070,6 +4070,7 @@ static int btusb_setup_qca(struct hci_dev *hdev)
 | 
			
		||||
 	}
 | 
			
		||||
 	if (!info) {
 | 
			
		||||
 		bt_dev_err(hdev, "don't support firmware rome 0x%x", ver_rom);
 | 
			
		||||
+		if (ver_rom & ~0xffffU) return 0;
 | 
			
		||||
 		return -ENODEV;
 | 
			
		||||
 	}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,49 +0,0 @@
 | 
			
		||||
From cb408fb65a08bd45543724c1e9b8f38ae1bebc4a Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Arnaud Ferraris <arnaud.ferraris@gmail.com>
 | 
			
		||||
Date: Tue, 4 Aug 2020 15:12:59 +0200
 | 
			
		||||
Subject: [PATCH 177/183] leds-gpio: make max_brightness configurable
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 drivers/leds/leds-gpio.c | 4 ++++
 | 
			
		||||
 include/linux/leds.h     | 3 ++-
 | 
			
		||||
 2 files changed, 6 insertions(+), 1 deletion(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/drivers/leds/leds-gpio.c b/drivers/leds/leds-gpio.c
 | 
			
		||||
index 93f5b1b60fde..f8483fab1164 100644
 | 
			
		||||
--- a/drivers/leds/leds-gpio.c
 | 
			
		||||
+++ b/drivers/leds/leds-gpio.c
 | 
			
		||||
@@ -108,6 +108,8 @@ static int create_gpio_led(const struct gpio_led *template,
 | 
			
		||||
 	if (ret < 0)
 | 
			
		||||
 		return ret;
 | 
			
		||||
 
 | 
			
		||||
+	led_dat->cdev.max_brightness = template->max_brightness;
 | 
			
		||||
+
 | 
			
		||||
 	if (template->name) {
 | 
			
		||||
 		led_dat->cdev.name = template->name;
 | 
			
		||||
 		ret = devm_led_classdev_register(parent, &led_dat->cdev);
 | 
			
		||||
@@ -177,6 +179,8 @@ static struct gpio_leds_priv *gpio_leds_create(struct platform_device *pdev)
 | 
			
		||||
 		if (fwnode_property_present(child, "panic-indicator"))
 | 
			
		||||
 			led.panic_indicator = 1;
 | 
			
		||||
 
 | 
			
		||||
+		fwnode_property_read_u32(child, "max-brightness", &led.max_brightness);
 | 
			
		||||
+
 | 
			
		||||
 		ret = create_gpio_led(&led, led_dat, dev, child, NULL);
 | 
			
		||||
 		if (ret < 0) {
 | 
			
		||||
 			fwnode_handle_put(child);
 | 
			
		||||
diff --git a/include/linux/leds.h b/include/linux/leds.h
 | 
			
		||||
index 6a8d6409c993..99a80092114d 100644
 | 
			
		||||
--- a/include/linux/leds.h
 | 
			
		||||
+++ b/include/linux/leds.h
 | 
			
		||||
@@ -513,7 +513,8 @@ typedef int (*gpio_blink_set_t)(struct gpio_desc *desc, int state,
 | 
			
		||||
 struct gpio_led {
 | 
			
		||||
 	const char *name;
 | 
			
		||||
 	const char *default_trigger;
 | 
			
		||||
-	unsigned 	gpio;
 | 
			
		||||
+	unsigned	gpio;
 | 
			
		||||
+	unsigned	max_brightness;
 | 
			
		||||
 	unsigned	active_low : 1;
 | 
			
		||||
 	unsigned	retain_state_suspended : 1;
 | 
			
		||||
 	unsigned	panic_indicator : 1;
 | 
			
		||||
-- 
 | 
			
		||||
2.30.0
 | 
			
		||||
 | 
			
		||||
@@ -1,25 +0,0 @@
 | 
			
		||||
From 2253c0d31cf17debb97db418bec21ad59cd47c14 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Arnaud Ferraris <arnaud.ferraris@collabora.com>
 | 
			
		||||
Date: Tue, 3 Nov 2020 17:04:35 +0100
 | 
			
		||||
Subject: [PATCH 178/183] sun8i-codec: fix headphone jack pin name
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 sound/soc/sunxi/sun8i-codec.c | 2 +-
 | 
			
		||||
 1 file changed, 1 insertion(+), 1 deletion(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/sound/soc/sunxi/sun8i-codec.c b/sound/soc/sunxi/sun8i-codec.c
 | 
			
		||||
index 6128d861df90..ab751fd7c426 100644
 | 
			
		||||
--- a/sound/soc/sunxi/sun8i-codec.c
 | 
			
		||||
+++ b/sound/soc/sunxi/sun8i-codec.c
 | 
			
		||||
@@ -1272,7 +1272,7 @@ static const struct snd_soc_dapm_route sun8i_codec_legacy_routes[] = {
 | 
			
		||||
 
 | 
			
		||||
 static struct snd_soc_jack_pin sun8i_codec_jack_pins[] = {
 | 
			
		||||
 	{
 | 
			
		||||
-		.pin	= "Headphone Jack",
 | 
			
		||||
+		.pin	= "Headphone",
 | 
			
		||||
 		.mask	= SND_JACK_HEADPHONE,
 | 
			
		||||
 	},
 | 
			
		||||
 	{
 | 
			
		||||
-- 
 | 
			
		||||
2.30.0
 | 
			
		||||
 | 
			
		||||
@@ -1,130 +0,0 @@
 | 
			
		||||
From 465a75a727ae5eb4c94859bfac4742cb14e38b3e Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Arnaud Ferraris <arnaud.ferraris@collabora.com>
 | 
			
		||||
Date: Fri, 3 Apr 2020 17:13:55 +0200
 | 
			
		||||
Subject: [PATCH 179/183] arm64: dts: allwinner: pinephone: improve device tree
 | 
			
		||||
 | 
			
		||||
On PinePhone, the headset mic bias resistor isn't populated on the
 | 
			
		||||
schematics (R811), therefore we need to enable the codec's internal
 | 
			
		||||
resistor. Additionnally, the jack detection IRQ's are inverted due to the
 | 
			
		||||
connector wiring, so the necessary property is added to the codec node
 | 
			
		||||
to made the driver aware of this fact.
 | 
			
		||||
 | 
			
		||||
We also stop LEDs during suspend to improve battery life, lower
 | 
			
		||||
cpu_alert* temperatures so the phone doesn't get too hot and improve the
 | 
			
		||||
backlight brightness values so we have a wider usable range.
 | 
			
		||||
 | 
			
		||||
Finally, the RGB LED max_brightness is set to 1 as it isn't using a PWM
 | 
			
		||||
output.
 | 
			
		||||
---
 | 
			
		||||
 .../dts/allwinner/sun50i-a64-pinephone-1.1.dts | 10 +++++-----
 | 
			
		||||
 .../dts/allwinner/sun50i-a64-pinephone-1.2.dts | 13 ++++++-------
 | 
			
		||||
 .../dts/allwinner/sun50i-a64-pinephone.dtsi    | 18 +++++++++++++-----
 | 
			
		||||
 3 files changed, 24 insertions(+), 17 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
index f084c4f21f12..573f1929da4f 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
@@ -29,11 +29,11 @@ &backlight {
 | 
			
		||||
 	 * value here was chosen as a safe default.
 | 
			
		||||
 	 */
 | 
			
		||||
 	brightness-levels = <
 | 
			
		||||
-		774  793  814  842
 | 
			
		||||
-		882  935  1003 1088
 | 
			
		||||
-		1192 1316 1462 1633
 | 
			
		||||
-		1830 2054 2309 2596
 | 
			
		||||
-		2916 3271 3664 4096>;
 | 
			
		||||
+		392  413  436  468
 | 
			
		||||
+		512  571  647  742
 | 
			
		||||
+		857  995  1159 1349
 | 
			
		||||
+		1568 1819 2103 2423
 | 
			
		||||
+		2779 3176 3614 4096>;
 | 
			
		||||
 	num-interpolated-steps = <50>;
 | 
			
		||||
 	default-brightness-level = <400>;
 | 
			
		||||
 };
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
index bbf64677c22b..6c3922543fec 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
@@ -34,14 +34,13 @@ &backlight {
 | 
			
		||||
 	 * chosen as a safe default.
 | 
			
		||||
 	 */
 | 
			
		||||
 	brightness-levels = <
 | 
			
		||||
-		5000 5248 5506 5858 6345
 | 
			
		||||
-		6987 7805 8823 10062 11543
 | 
			
		||||
-		13287 15317 17654 20319 23336
 | 
			
		||||
-		26724 30505 34702 39335 44427
 | 
			
		||||
-		50000
 | 
			
		||||
-	>;
 | 
			
		||||
+		392  413  436  468
 | 
			
		||||
+		512  571  647  742
 | 
			
		||||
+		857  995  1159 1349
 | 
			
		||||
+		1568 1819 2103 2423
 | 
			
		||||
+		2779 3176 3614 4096>;
 | 
			
		||||
 	num-interpolated-steps = <50>;
 | 
			
		||||
-	default-brightness-level = <500>;
 | 
			
		||||
+	default-brightness-level = <400>;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 &lis3mdl {
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
index c55709197804..441358592072 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
@@ -80,21 +80,21 @@ blue {
 | 
			
		||||
 			function = LED_FUNCTION_INDICATOR;
 | 
			
		||||
 			color = <LED_COLOR_ID_BLUE>;
 | 
			
		||||
 			gpios = <&pio 3 20 GPIO_ACTIVE_HIGH>; /* PD20 */
 | 
			
		||||
-			retain-state-suspended;
 | 
			
		||||
+			max-brightness = <1>;
 | 
			
		||||
 		};
 | 
			
		||||
 
 | 
			
		||||
 		green {
 | 
			
		||||
 			function = LED_FUNCTION_INDICATOR;
 | 
			
		||||
 			color = <LED_COLOR_ID_GREEN>;
 | 
			
		||||
 			gpios = <&pio 3 18 GPIO_ACTIVE_HIGH>; /* PD18 */
 | 
			
		||||
-			retain-state-suspended;
 | 
			
		||||
+			max-brightness = <1>;
 | 
			
		||||
 		};
 | 
			
		||||
 
 | 
			
		||||
 		red {
 | 
			
		||||
 			function = LED_FUNCTION_INDICATOR;
 | 
			
		||||
 			color = <LED_COLOR_ID_RED>;
 | 
			
		||||
 			gpios = <&pio 3 19 GPIO_ACTIVE_HIGH>; /* PD19 */
 | 
			
		||||
-			retain-state-suspended;
 | 
			
		||||
+			max-brightness = <1>;
 | 
			
		||||
 		};
 | 
			
		||||
 	};
 | 
			
		||||
 
 | 
			
		||||
@@ -198,6 +198,14 @@ &cpu3 {
 | 
			
		||||
 	cpu-supply = <®_dcdc2>;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
+&cpu_alert0 {
 | 
			
		||||
+	temperature = <60000>;
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
+&cpu_alert1 {
 | 
			
		||||
+	temperature = <80000>;
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
 &csi {
 | 
			
		||||
 	pinctrl-0 = <&csi_pins>, <&csi_mclk_pin>;
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
@@ -671,11 +679,11 @@ &sound {
 | 
			
		||||
 	simple-audio-card,aux-devs = <&codec_analog>, <&speaker_amp>;
 | 
			
		||||
 	simple-audio-card,widgets = "Microphone", "Headset Microphone",
 | 
			
		||||
 				    "Microphone", "Internal Microphone",
 | 
			
		||||
-				    "Headphone", "Headphone Jack",
 | 
			
		||||
+				    "Headphone", "Headphone",
 | 
			
		||||
 				    "Speaker", "Internal Earpiece",
 | 
			
		||||
 				    "Speaker", "Internal Speaker";
 | 
			
		||||
 	simple-audio-card,routing =
 | 
			
		||||
-			"Headphone Jack", "HP",
 | 
			
		||||
+			"Headphone", "HP",
 | 
			
		||||
 			"Internal Earpiece", "EARPIECE",
 | 
			
		||||
 			"Internal Speaker", "Speaker Amp OUTL",
 | 
			
		||||
 			"Internal Speaker", "Speaker Amp OUTR",
 | 
			
		||||
-- 
 | 
			
		||||
2.30.0
 | 
			
		||||
 | 
			
		||||
@@ -1,118 +0,0 @@
 | 
			
		||||
From mboxrd@z Thu Jan  1 00:00:00 1970
 | 
			
		||||
Return-Path: <linux-kernel-owner@kernel.org>
 | 
			
		||||
X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on
 | 
			
		||||
	aws-us-west-2-korg-lkml-1.web.codeaurora.org
 | 
			
		||||
X-Spam-Level: 
 | 
			
		||||
X-Spam-Status: No, score=-15.8 required=3.0 tests=BAYES_00,DKIM_SIGNED,
 | 
			
		||||
	DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,
 | 
			
		||||
	HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI,
 | 
			
		||||
	MENTIONS_GIT_HOSTING,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham
 | 
			
		||||
	autolearn_force=no version=3.4.0
 | 
			
		||||
Received: from mail.kernel.org (mail.kernel.org [198.145.29.99])
 | 
			
		||||
	by smtp.lore.kernel.org (Postfix) with ESMTP id 30CB3C433DB
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:07:07 +0000 (UTC)
 | 
			
		||||
Received: from vger.kernel.org (vger.kernel.org [23.128.96.18])
 | 
			
		||||
	by mail.kernel.org (Postfix) with ESMTP id F053961971
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:07:06 +0000 (UTC)
 | 
			
		||||
Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand
 | 
			
		||||
        id S230259AbhC0NGA (ORCPT <rfc822;linux-kernel@archiver.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:06:00 -0400
 | 
			
		||||
Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59650 "EHLO
 | 
			
		||||
        lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org
 | 
			
		||||
        with ESMTP id S229582AbhC0NFz (ORCPT
 | 
			
		||||
        <rfc822;linux-kernel@vger.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:05:55 -0400
 | 
			
		||||
Received: from mail-pf1-x435.google.com (mail-pf1-x435.google.com [IPv6:2607:f8b0:4864:20::435])
 | 
			
		||||
        by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7DAA2C0613B1
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:05:55 -0700 (PDT)
 | 
			
		||||
Received: by mail-pf1-x435.google.com with SMTP id j25so6773824pfe.2
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:05:55 -0700 (PDT)
 | 
			
		||||
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=gmail.com; s=20161025;
 | 
			
		||||
        h=from:to:cc:subject:date:message-id:mime-version
 | 
			
		||||
         :content-transfer-encoding;
 | 
			
		||||
        bh=j1vEagJw59z7NUkgTmJto/iZqe4yWAoKFE4cIPL6KSA=;
 | 
			
		||||
        b=W++BsAIwl+3ucDDq6J9gfd2LQIPwdj2biEakUpnxpy/YsK+3iCoF33X3sftQWOxfP7
 | 
			
		||||
         IPnjeO9Rde2kHHrwJMlMu2vkeccABUo1mLD6uTVGrEfxwUsN9YJWo9jUzaSY3cyvbGI2
 | 
			
		||||
         ehpcqqnKgU3Fn5s/X8mIRCamioqbkc4WM23kxCZTaHn+XhPN+SWL6FLKRXDgGS2ivbn1
 | 
			
		||||
         OER7kHG7/pVx6TS91PpzwDFvN3Rnt6x9672uUa2Evpoapzy9P2POwsDV4zxWpGjlEc44
 | 
			
		||||
         x99r44072+JXwATmacsPj8yOAksyAgxYYzYtUqJdpS51qpCmDWMBwE12Glc6HXWJKDrZ
 | 
			
		||||
         V2jw==
 | 
			
		||||
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=1e100.net; s=20161025;
 | 
			
		||||
        h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version
 | 
			
		||||
         :content-transfer-encoding;
 | 
			
		||||
        bh=j1vEagJw59z7NUkgTmJto/iZqe4yWAoKFE4cIPL6KSA=;
 | 
			
		||||
        b=kBUfAu8SPEqgcOJWgnRXoXkAISBVy5hrC8mdP43B3bJdOtUy3ckGem52OQlxU4JiZ9
 | 
			
		||||
         fRLzgQhtoaEPJwBegty5xhiBi7a9Z8jtP5y9BGPLtHnPY0vj7Q5WoLeJW8VQSdnTfIea
 | 
			
		||||
         LWI0QFW1FPejnWt1OkpKrg23YuIwnAy4JeS4ppYqwxoJLaA2CK49uIgHZvkO/KUWTZ1u
 | 
			
		||||
         H4FTpR1COt4JDajdNEO9PXbgAIn7Zhc84m4BrHeFhPPMguGgiORNl8CiVYnEidYMOYB4
 | 
			
		||||
         xKZysxTMak3CltRje+eBSpYQa9T1mcAv1kMsc7OY2YJYnK7TadU5FcwBnEGYEGtI6pK9
 | 
			
		||||
         kbyg==
 | 
			
		||||
X-Gm-Message-State: AOAM531ZZkAzAjwe4lLioYqlb3vcaxOF8kBIHnAElR+v7R84d5htjzCI
 | 
			
		||||
        w2CjFLBp7ZYpGnOW93HhwfMMXbvyGk6rb63y
 | 
			
		||||
X-Google-Smtp-Source: ABdhPJwtfu5Tfa4UYXfW8whmzPPLMc8XbemaxfI6PdBR3nuuwqL4rugT9FibIaSdi/j6K0J4cIJCqg==
 | 
			
		||||
X-Received: by 2002:a63:e906:: with SMTP id i6mr16394983pgh.132.1616850352891;
 | 
			
		||||
        Sat, 27 Mar 2021 06:05:52 -0700 (PDT)
 | 
			
		||||
Received: from johnchen902-arch-ryzen.. (2001-b011-3815-3a1f-9afa-9bff-fe6e-3ce2.dynamic-ip6.hinet.net. [2001:b011:3815:3a1f:9afa:9bff:fe6e:3ce2])
 | 
			
		||||
        by smtp.gmail.com with ESMTPSA id ot17sm6413787pjb.50.2021.03.27.06.05.51
 | 
			
		||||
        (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);
 | 
			
		||||
        Sat, 27 Mar 2021 06:05:52 -0700 (PDT)
 | 
			
		||||
From:   John Chen <johnchen902@gmail.com>
 | 
			
		||||
To:     linux-kernel@vger.kernel.org
 | 
			
		||||
Cc:     Rohit Pidaparthi <rohitpid@gmail.com>,
 | 
			
		||||
        RicardoEPRodrigues <ricardo.e.p.rodrigues@gmail.com>,
 | 
			
		||||
        Jiri Kosina <jikos@kernel.org>,
 | 
			
		||||
        Benjamin Tissoires <benjamin.tissoires@redhat.com>,
 | 
			
		||||
        John Chen <johnchen902@gmail.com>
 | 
			
		||||
Subject: [PATCH 0/4] HID: add Apple Magic Mouse 2 support
 | 
			
		||||
Date:   Sat, 27 Mar 2021 21:05:04 +0800
 | 
			
		||||
Message-Id: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
X-Mailer: git-send-email 2.31.0
 | 
			
		||||
MIME-Version: 1.0
 | 
			
		||||
Content-Transfer-Encoding: 8bit
 | 
			
		||||
Precedence: bulk
 | 
			
		||||
List-ID: <linux-kernel.vger.kernel.org>
 | 
			
		||||
X-Mailing-List: linux-kernel@vger.kernel.org
 | 
			
		||||
Archived-At: <https://lore.kernel.org/lkml/20210327130508.24849-1-johnchen902@gmail.com/>
 | 
			
		||||
List-Archive: <https://lore.kernel.org/lkml/>
 | 
			
		||||
List-Post: <mailto:linux-kernel@vger.kernel.org>
 | 
			
		||||
 | 
			
		||||
The HID descriptor of Magic Mouse 2 contains BTN_LEFT, BTN_RIGHT, REL_X,
 | 
			
		||||
REL_Y, whether it's charging, whether it's fully charged, and battery
 | 
			
		||||
capacity.
 | 
			
		||||
 | 
			
		||||
$ xxd -p report_descriptor
 | 
			
		||||
05010902a101851205091901290215002501950275018102950175068103
 | 
			
		||||
05010901a1001601f826ff073601fb46ff046513550d0930093175109502
 | 
			
		||||
8106750895028101c00602ff09558555150026ff0075089540b1a2c00600
 | 
			
		||||
ff0914a10185900584750195031500250109610585094409468102950581
 | 
			
		||||
0175089501150026ff0009658102c000
 | 
			
		||||
 | 
			
		||||
As hidinput can handle the BTNs and RELs, the Magic Mouse 2 already
 | 
			
		||||
functions as a basic mouse. Nevertheless, It should be reasonable to
 | 
			
		||||
extend hid-magicmouse to support Magic Mouse 2 as well. Furthermore,
 | 
			
		||||
hidinput is patched to handle the battery capacity.
 | 
			
		||||
 | 
			
		||||
This work is based on Recardo's, which is in turned based on Rohitpid's.
 | 
			
		||||
Their GitHub repositories are linked below:
 | 
			
		||||
https://github.com/RicardoEPRodrigues/magicmouse-hid
 | 
			
		||||
https://github.com/rohitpid/Linux-Magic-Trackpad-2-Driver
 | 
			
		||||
 | 
			
		||||
John Chen (4):
 | 
			
		||||
  HID: magicmouse: add Apple Magic Mouse 2 support
 | 
			
		||||
  HID: magicmouse: fix 3 button emulation of Mouse 2
 | 
			
		||||
  HID: magicmouse: fix reconnection of Magic Mouse 2
 | 
			
		||||
  HID: input: map battery capacity (00850065)
 | 
			
		||||
 | 
			
		||||
 drivers/hid/hid-debug.c      |   1 +
 | 
			
		||||
 drivers/hid/hid-ids.h        |   1 +
 | 
			
		||||
 drivers/hid/hid-input.c      |  11 +++
 | 
			
		||||
 drivers/hid/hid-magicmouse.c | 156 ++++++++++++++++++++++++++++-------
 | 
			
		||||
 include/linux/hid.h          |   3 +
 | 
			
		||||
 5 files changed, 140 insertions(+), 32 deletions(-)
 | 
			
		||||
 | 
			
		||||
-- 
 | 
			
		||||
2.31.0
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -1,247 +0,0 @@
 | 
			
		||||
From mboxrd@z Thu Jan  1 00:00:00 1970
 | 
			
		||||
Return-Path: <linux-kernel-owner@kernel.org>
 | 
			
		||||
X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on
 | 
			
		||||
	aws-us-west-2-korg-lkml-1.web.codeaurora.org
 | 
			
		||||
X-Spam-Level: 
 | 
			
		||||
X-Spam-Status: No, score=-15.8 required=3.0 tests=BAYES_00,DKIM_SIGNED,
 | 
			
		||||
	DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,
 | 
			
		||||
	HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH,
 | 
			
		||||
	MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham
 | 
			
		||||
	autolearn_force=no version=3.4.0
 | 
			
		||||
Received: from mail.kernel.org (mail.kernel.org [198.145.29.99])
 | 
			
		||||
	by smtp.lore.kernel.org (Postfix) with ESMTP id 4888EC433C1
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:07:07 +0000 (UTC)
 | 
			
		||||
Received: from vger.kernel.org (vger.kernel.org [23.128.96.18])
 | 
			
		||||
	by mail.kernel.org (Postfix) with ESMTP id 0E6E861981
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:07:07 +0000 (UTC)
 | 
			
		||||
Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand
 | 
			
		||||
        id S230295AbhC0NGh (ORCPT <rfc822;linux-kernel@archiver.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:06:37 -0400
 | 
			
		||||
Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59740 "EHLO
 | 
			
		||||
        lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org
 | 
			
		||||
        with ESMTP id S229582AbhC0NGT (ORCPT
 | 
			
		||||
        <rfc822;linux-kernel@vger.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:06:19 -0400
 | 
			
		||||
Received: from mail-pg1-x529.google.com (mail-pg1-x529.google.com [IPv6:2607:f8b0:4864:20::529])
 | 
			
		||||
        by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 82262C0613B1
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:06:19 -0700 (PDT)
 | 
			
		||||
Received: by mail-pg1-x529.google.com with SMTP id v10so6405578pgs.12
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:06:19 -0700 (PDT)
 | 
			
		||||
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=gmail.com; s=20161025;
 | 
			
		||||
        h=from:to:cc:subject:date:message-id:in-reply-to:references
 | 
			
		||||
         :mime-version:content-transfer-encoding;
 | 
			
		||||
        bh=/43es5lmfTvSMg9V9lh/7OQVghMj1iNxFqwqD88gyCk=;
 | 
			
		||||
        b=JA8+yZao+x/DmyoiRUpwr0wP9XgaNgDVez40dXm+yEd6Wlgs1dQvO3DkU8n7trJWcL
 | 
			
		||||
         TCj7NqBp0z4pf3pSHrTxX7rWZX4yRyZJAXo7fqTPqfN2R0PkRIp5gnvcDv+7/BRM4nqx
 | 
			
		||||
         3pI6ubgKZ+rxYph8XNAuO94/oOjxgItIhOqYGbLPHwa2eoI60mUbrF/ukBsw8OwQ+Vli
 | 
			
		||||
         0siGyaoTCPP/h+9uuHJqQJ1yw6CCkCAxMwZXD79abtLytL6WkhuvoFJ6exRYGHawcHMs
 | 
			
		||||
         bel32ifzIlv+7ULbcTI2uVNhxvdrD51tRSNrAZ77n+Tk8RivXMeSqSzPVngWZCs0uk6s
 | 
			
		||||
         JryA==
 | 
			
		||||
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=1e100.net; s=20161025;
 | 
			
		||||
        h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to
 | 
			
		||||
         :references:mime-version:content-transfer-encoding;
 | 
			
		||||
        bh=/43es5lmfTvSMg9V9lh/7OQVghMj1iNxFqwqD88gyCk=;
 | 
			
		||||
        b=fAhjI90TZfQpcQBqM4rN69d8uN92OH3j+lhm/dYYlmqdchK6ZZsPD3wt6VW8/ObU+0
 | 
			
		||||
         BpTic3inOmn0aVasSmAkbNxaVAUJ339klb/WnO9RfaemBLXDCBMgGjVr+ofhpIbfKxiZ
 | 
			
		||||
         0aBswW4Dc2uY39zmxm7wtJ2sRHHwj/Ltdt7B+NYes7Kzohvfg98YLvm8I5mloimR02U9
 | 
			
		||||
         HRlPKK2YbMcZ5i2Y8Q3faX8356caUUU7l91utK4EXdrVFCbNftXBEmRej6gXSZudCBga
 | 
			
		||||
         7w6Rgymaox0hfMZzYLWtJJp2fo3BcKA4+TD6bJ1yrxIdPmK59QMGoyMUIKqTIZIjN2c/
 | 
			
		||||
         gvpg==
 | 
			
		||||
X-Gm-Message-State: AOAM531lA6V8bOmQPsuLmZx3iv59gcixbI4HEH5eqWzOJ/N3DRaX/hb9
 | 
			
		||||
        NavPhvckezEkR22O7uWWvZAUxOplQlRwSsX5
 | 
			
		||||
X-Google-Smtp-Source: ABdhPJyaSIYZWu4pp8j7TnxkxYd0BP77HzgDaIZFIDeoL910Tkv+L4VuoQLEw0GNu+5Zxi80enV/YQ==
 | 
			
		||||
X-Received: by 2002:a65:498b:: with SMTP id r11mr16491362pgs.364.1616850378733;
 | 
			
		||||
        Sat, 27 Mar 2021 06:06:18 -0700 (PDT)
 | 
			
		||||
Received: from johnchen902-arch-ryzen.. (2001-b011-3815-3a1f-9afa-9bff-fe6e-3ce2.dynamic-ip6.hinet.net. [2001:b011:3815:3a1f:9afa:9bff:fe6e:3ce2])
 | 
			
		||||
        by smtp.gmail.com with ESMTPSA id ot17sm6413787pjb.50.2021.03.27.06.06.17
 | 
			
		||||
        (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);
 | 
			
		||||
        Sat, 27 Mar 2021 06:06:18 -0700 (PDT)
 | 
			
		||||
From:   John Chen <johnchen902@gmail.com>
 | 
			
		||||
To:     linux-kernel@vger.kernel.org
 | 
			
		||||
Cc:     Rohit Pidaparthi <rohitpid@gmail.com>,
 | 
			
		||||
        RicardoEPRodrigues <ricardo.e.p.rodrigues@gmail.com>,
 | 
			
		||||
        Jiri Kosina <jikos@kernel.org>,
 | 
			
		||||
        Benjamin Tissoires <benjamin.tissoires@redhat.com>,
 | 
			
		||||
        John Chen <johnchen902@gmail.com>
 | 
			
		||||
Subject: [PATCH 1/4] HID: magicmouse: add Apple Magic Mouse 2 support
 | 
			
		||||
Date:   Sat, 27 Mar 2021 21:05:05 +0800
 | 
			
		||||
Message-Id: <20210327130508.24849-2-johnchen902@gmail.com>
 | 
			
		||||
X-Mailer: git-send-email 2.31.0
 | 
			
		||||
In-Reply-To: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
References: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
MIME-Version: 1.0
 | 
			
		||||
Content-Transfer-Encoding: 8bit
 | 
			
		||||
Precedence: bulk
 | 
			
		||||
List-ID: <linux-kernel.vger.kernel.org>
 | 
			
		||||
X-Mailing-List: linux-kernel@vger.kernel.org
 | 
			
		||||
Archived-At: <https://lore.kernel.org/lkml/20210327130508.24849-2-johnchen902@gmail.com/>
 | 
			
		||||
List-Archive: <https://lore.kernel.org/lkml/>
 | 
			
		||||
List-Post: <mailto:linux-kernel@vger.kernel.org>
 | 
			
		||||
 | 
			
		||||
Bluetooth device
 | 
			
		||||
	Vendor 004c (Apple)
 | 
			
		||||
	Device 0269 (Magic Mouse 2)
 | 
			
		||||
 | 
			
		||||
Add support for Apple Magic Mouse 2, putting the device in multi-touch
 | 
			
		||||
mode.
 | 
			
		||||
 | 
			
		||||
Co-authored-by: Rohit Pidaparthi <rohitpid@gmail.com>
 | 
			
		||||
Co-authored-by: RicardoEPRodrigues <ricardo.e.p.rodrigues@gmail.com>
 | 
			
		||||
Signed-off-by: John Chen <johnchen902@gmail.com>
 | 
			
		||||
---
 | 
			
		||||
 drivers/hid/hid-ids.h        |  1 +
 | 
			
		||||
 drivers/hid/hid-magicmouse.c | 53 ++++++++++++++++++++++++++++++++----
 | 
			
		||||
 2 files changed, 49 insertions(+), 5 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h
 | 
			
		||||
index e42aaae3138f..fa0edf03570a 100644
 | 
			
		||||
--- a/drivers/hid/hid-ids.h
 | 
			
		||||
+++ b/drivers/hid/hid-ids.h
 | 
			
		||||
@@ -93,6 +93,7 @@
 | 
			
		||||
 #define BT_VENDOR_ID_APPLE		0x004c
 | 
			
		||||
 #define USB_DEVICE_ID_APPLE_MIGHTYMOUSE	0x0304
 | 
			
		||||
 #define USB_DEVICE_ID_APPLE_MAGICMOUSE	0x030d
 | 
			
		||||
+#define USB_DEVICE_ID_APPLE_MAGICMOUSE2	0x0269
 | 
			
		||||
 #define USB_DEVICE_ID_APPLE_MAGICTRACKPAD	0x030e
 | 
			
		||||
 #define USB_DEVICE_ID_APPLE_MAGICTRACKPAD2	0x0265
 | 
			
		||||
 #define USB_DEVICE_ID_APPLE_FOUNTAIN_ANSI	0x020e
 | 
			
		||||
diff --git a/drivers/hid/hid-magicmouse.c b/drivers/hid/hid-magicmouse.c
 | 
			
		||||
index abd86903875f..7aad6ca56780 100644
 | 
			
		||||
--- a/drivers/hid/hid-magicmouse.c
 | 
			
		||||
+++ b/drivers/hid/hid-magicmouse.c
 | 
			
		||||
@@ -54,6 +54,7 @@ MODULE_PARM_DESC(report_undeciphered, "Report undeciphered multi-touch state fie
 | 
			
		||||
 #define TRACKPAD2_USB_REPORT_ID 0x02
 | 
			
		||||
 #define TRACKPAD2_BT_REPORT_ID 0x31
 | 
			
		||||
 #define MOUSE_REPORT_ID    0x29
 | 
			
		||||
+#define MOUSE2_REPORT_ID   0x12
 | 
			
		||||
 #define DOUBLE_REPORT_ID   0xf7
 | 
			
		||||
 /* These definitions are not precise, but they're close enough.  (Bits
 | 
			
		||||
  * 0x03 seem to indicate the aspect ratio of the touch, bits 0x70 seem
 | 
			
		||||
@@ -195,7 +196,8 @@ static void magicmouse_emit_touch(struct magicmouse_sc *msc, int raw_id, u8 *tda
 | 
			
		||||
 	int id, x, y, size, orientation, touch_major, touch_minor, state, down;
 | 
			
		||||
 	int pressure = 0;
 | 
			
		||||
 
 | 
			
		||||
-	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE) {
 | 
			
		||||
+	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE ||
 | 
			
		||||
+	    input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
 		id = (tdata[6] << 2 | tdata[5] >> 6) & 0xf;
 | 
			
		||||
 		x = (tdata[1] << 28 | tdata[0] << 20) >> 20;
 | 
			
		||||
 		y = -((tdata[2] << 24 | tdata[1] << 16) >> 20);
 | 
			
		||||
@@ -296,7 +298,8 @@ static void magicmouse_emit_touch(struct magicmouse_sc *msc, int raw_id, u8 *tda
 | 
			
		||||
 			input_report_abs(input, ABS_MT_PRESSURE, pressure);
 | 
			
		||||
 
 | 
			
		||||
 		if (report_undeciphered) {
 | 
			
		||||
-			if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE)
 | 
			
		||||
+			if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE ||
 | 
			
		||||
+			    input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE2)
 | 
			
		||||
 				input_event(input, EV_MSC, MSC_RAW, tdata[7]);
 | 
			
		||||
 			else if (input->id.product !=
 | 
			
		||||
 					USB_DEVICE_ID_APPLE_MAGICTRACKPAD2)
 | 
			
		||||
@@ -380,6 +383,34 @@ static int magicmouse_raw_event(struct hid_device *hdev,
 | 
			
		||||
 		 * ts = data[3] >> 6 | data[4] << 2 | data[5] << 10;
 | 
			
		||||
 		 */
 | 
			
		||||
 		break;
 | 
			
		||||
+	case MOUSE2_REPORT_ID:
 | 
			
		||||
+		/* Size is either 8 or (14 + 8 * N) */
 | 
			
		||||
+		if (size != 8 && (size < 14 || (size - 14) % 8 != 0))
 | 
			
		||||
+			return 0;
 | 
			
		||||
+		npoints = (size - 14) / 8;
 | 
			
		||||
+		if (npoints > 15) {
 | 
			
		||||
+			hid_warn(hdev, "invalid size value (%d) for MOUSE2_REPORT_ID\n",
 | 
			
		||||
+					size);
 | 
			
		||||
+			return 0;
 | 
			
		||||
+		}
 | 
			
		||||
+		msc->ntouches = 0;
 | 
			
		||||
+		for (ii = 0; ii < npoints; ii++)
 | 
			
		||||
+			magicmouse_emit_touch(msc, ii, data + ii * 8 + 14);
 | 
			
		||||
+
 | 
			
		||||
+		/* When emulating three-button mode, it is important
 | 
			
		||||
+		 * to have the current touch information before
 | 
			
		||||
+		 * generating a click event.
 | 
			
		||||
+		 */
 | 
			
		||||
+		x = (int)((data[3] << 24) | (data[2] << 16)) >> 16;
 | 
			
		||||
+		y = (int)((data[5] << 24) | (data[4] << 16)) >> 16;
 | 
			
		||||
+		clicks = data[1];
 | 
			
		||||
+
 | 
			
		||||
+		/* The following bits provide a device specific timestamp. They
 | 
			
		||||
+		 * are unused here.
 | 
			
		||||
+		 *
 | 
			
		||||
+		 * ts = data[11] >> 6 | data[12] << 2 | data[13] << 10;
 | 
			
		||||
+		 */
 | 
			
		||||
+		break;
 | 
			
		||||
 	case DOUBLE_REPORT_ID:
 | 
			
		||||
 		/* Sometimes the trackpad sends two touch reports in one
 | 
			
		||||
 		 * packet.
 | 
			
		||||
@@ -392,7 +423,8 @@ static int magicmouse_raw_event(struct hid_device *hdev,
 | 
			
		||||
 		return 0;
 | 
			
		||||
 	}
 | 
			
		||||
 
 | 
			
		||||
-	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE) {
 | 
			
		||||
+	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE ||
 | 
			
		||||
+	    input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
 		magicmouse_emit_buttons(msc, clicks & 3);
 | 
			
		||||
 		input_report_rel(input, REL_X, x);
 | 
			
		||||
 		input_report_rel(input, REL_Y, y);
 | 
			
		||||
@@ -415,7 +447,8 @@ static int magicmouse_setup_input(struct input_dev *input, struct hid_device *hd
 | 
			
		||||
 
 | 
			
		||||
 	__set_bit(EV_KEY, input->evbit);
 | 
			
		||||
 
 | 
			
		||||
-	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE) {
 | 
			
		||||
+	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE ||
 | 
			
		||||
+	    input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
 		__set_bit(BTN_LEFT, input->keybit);
 | 
			
		||||
 		__set_bit(BTN_RIGHT, input->keybit);
 | 
			
		||||
 		if (emulate_3button)
 | 
			
		||||
@@ -480,7 +513,8 @@ static int magicmouse_setup_input(struct input_dev *input, struct hid_device *hd
 | 
			
		||||
 	 * the origin at the same position, and just uses the additive
 | 
			
		||||
 	 * inverse of the reported Y.
 | 
			
		||||
 	 */
 | 
			
		||||
-	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE) {
 | 
			
		||||
+	if (input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE ||
 | 
			
		||||
+	    input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
 		input_set_abs_params(input, ABS_MT_ORIENTATION, -31, 32, 1, 0);
 | 
			
		||||
 		input_set_abs_params(input, ABS_MT_POSITION_X,
 | 
			
		||||
 				     MOUSE_MIN_X, MOUSE_MAX_X, 4, 0);
 | 
			
		||||
@@ -586,6 +620,7 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 {
 | 
			
		||||
 	const u8 *feature;
 | 
			
		||||
 	const u8 feature_mt[] = { 0xD7, 0x01 };
 | 
			
		||||
+	const u8 feature_mt_mouse2[] = { 0xF1, 0x02, 0x01 };
 | 
			
		||||
 	const u8 feature_mt_trackpad2_usb[] = { 0x02, 0x01 };
 | 
			
		||||
 	const u8 feature_mt_trackpad2_bt[] = { 0xF1, 0x02, 0x01 };
 | 
			
		||||
 	u8 *buf;
 | 
			
		||||
@@ -631,6 +666,9 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 	if (id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE)
 | 
			
		||||
 		report = hid_register_report(hdev, HID_INPUT_REPORT,
 | 
			
		||||
 			MOUSE_REPORT_ID, 0);
 | 
			
		||||
+	else if (id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2)
 | 
			
		||||
+		report = hid_register_report(hdev, HID_INPUT_REPORT,
 | 
			
		||||
+			MOUSE2_REPORT_ID, 0);
 | 
			
		||||
 	else if (id->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2) {
 | 
			
		||||
 		if (id->vendor == BT_VENDOR_ID_APPLE)
 | 
			
		||||
 			report = hid_register_report(hdev, HID_INPUT_REPORT,
 | 
			
		||||
@@ -660,6 +698,9 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 			feature_size = sizeof(feature_mt_trackpad2_usb);
 | 
			
		||||
 			feature = feature_mt_trackpad2_usb;
 | 
			
		||||
 		}
 | 
			
		||||
+	} else if (id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
+		feature_size = sizeof(feature_mt_mouse2);
 | 
			
		||||
+		feature = feature_mt_mouse2;
 | 
			
		||||
 	} else {
 | 
			
		||||
 		feature_size = sizeof(feature_mt);
 | 
			
		||||
 		feature = feature_mt;
 | 
			
		||||
@@ -696,6 +737,8 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 static const struct hid_device_id magic_mice[] = {
 | 
			
		||||
 	{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE,
 | 
			
		||||
 		USB_DEVICE_ID_APPLE_MAGICMOUSE), .driver_data = 0 },
 | 
			
		||||
+	{ HID_BLUETOOTH_DEVICE(BT_VENDOR_ID_APPLE,
 | 
			
		||||
+		USB_DEVICE_ID_APPLE_MAGICMOUSE2), .driver_data = 0 },
 | 
			
		||||
 	{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE,
 | 
			
		||||
 		USB_DEVICE_ID_APPLE_MAGICTRACKPAD), .driver_data = 0 },
 | 
			
		||||
 	{ HID_BLUETOOTH_DEVICE(BT_VENDOR_ID_APPLE,
 | 
			
		||||
-- 
 | 
			
		||||
2.31.0
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -1,134 +0,0 @@
 | 
			
		||||
From mboxrd@z Thu Jan  1 00:00:00 1970
 | 
			
		||||
Return-Path: <linux-kernel-owner@kernel.org>
 | 
			
		||||
X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on
 | 
			
		||||
	aws-us-west-2-korg-lkml-1.web.codeaurora.org
 | 
			
		||||
X-Spam-Level: 
 | 
			
		||||
X-Spam-Status: No, score=-15.8 required=3.0 tests=BAYES_00,DKIM_SIGNED,
 | 
			
		||||
	DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,
 | 
			
		||||
	HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH,
 | 
			
		||||
	MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham
 | 
			
		||||
	autolearn_force=no version=3.4.0
 | 
			
		||||
Received: from mail.kernel.org (mail.kernel.org [198.145.29.99])
 | 
			
		||||
	by smtp.lore.kernel.org (Postfix) with ESMTP id 06C18C433E1
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:07:08 +0000 (UTC)
 | 
			
		||||
Received: from vger.kernel.org (vger.kernel.org [23.128.96.18])
 | 
			
		||||
	by mail.kernel.org (Postfix) with ESMTP id D1CE16193D
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:07:07 +0000 (UTC)
 | 
			
		||||
Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand
 | 
			
		||||
        id S230328AbhC0NGi (ORCPT <rfc822;linux-kernel@archiver.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:06:38 -0400
 | 
			
		||||
Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59770 "EHLO
 | 
			
		||||
        lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org
 | 
			
		||||
        with ESMTP id S230266AbhC0NG1 (ORCPT
 | 
			
		||||
        <rfc822;linux-kernel@vger.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:06:27 -0400
 | 
			
		||||
Received: from mail-pl1-x634.google.com (mail-pl1-x634.google.com [IPv6:2607:f8b0:4864:20::634])
 | 
			
		||||
        by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5086BC0613B1
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:06:27 -0700 (PDT)
 | 
			
		||||
Received: by mail-pl1-x634.google.com with SMTP id h8so2235029plt.7
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:06:27 -0700 (PDT)
 | 
			
		||||
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=gmail.com; s=20161025;
 | 
			
		||||
        h=from:to:cc:subject:date:message-id:in-reply-to:references
 | 
			
		||||
         :mime-version:content-transfer-encoding;
 | 
			
		||||
        bh=NeWUvZBV3NAy1b0eckELIbBZ7sti/n1sLYnD4r2cjaU=;
 | 
			
		||||
        b=V7uM0AaI1Vy/mmqpuTVu5F6+98YPDzOa3QS6tRkWeJqhrflMONfCXtOxXVR+CeiPil
 | 
			
		||||
         OOfaxOtAMeVEW9wE0EU3U/8aNghtzuUvVN+0Tj57+W+4g0ilQOODiDLDu4ZqAo1Q5eDZ
 | 
			
		||||
         gA+He13KWVwNYaYTNUNParLXG5GYDbblaqABSUDurI1FTjn1US0ZZytlzdZy1GfL9eTj
 | 
			
		||||
         6AiiVM3A4YdUGUWE7qQQE8jI92o4qKYvaNjn1M+d5ypKCue3NJWeRTSPKLu0QD2qL02+
 | 
			
		||||
         QPga2RPtmLpztA8/lPGTRpgVNY3C5jdCBZyWgFtvZg5dNoDfe5bQnAmF2J2ka+A7JBSD
 | 
			
		||||
         VHtw==
 | 
			
		||||
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=1e100.net; s=20161025;
 | 
			
		||||
        h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to
 | 
			
		||||
         :references:mime-version:content-transfer-encoding;
 | 
			
		||||
        bh=NeWUvZBV3NAy1b0eckELIbBZ7sti/n1sLYnD4r2cjaU=;
 | 
			
		||||
        b=OQek2lJ5JINezfYdN/FzSPFL1N9Hrs+KstU7K4gEHavdffvSAOBebg2MG5VSzkf93H
 | 
			
		||||
         o1iOiAOoXY7cx7j7Vx5CFZUuJOLilpC6gPTJpZlaP8YtEFfGkPaUPPh5FSTyM463Sir8
 | 
			
		||||
         n6DupTSrFUI1y44GOBZ2bM2pf9hRN1Yj1oiCT6upmfoHw0/PaKEZt5aOEI8se7HRJp94
 | 
			
		||||
         td6+SEZok3uxKEglKEqAG8cnj7Pt4tKVQlg+MI1AQDLQ/ytdYJlMPmrqVyNpnsv44wYa
 | 
			
		||||
         dxBf0TaMvqn9SYDIDcGct3toAVm5DfVUqXm1nkYcYMOdvPrmLoH52NtCyi5cYC+2TR6i
 | 
			
		||||
         jUpA==
 | 
			
		||||
X-Gm-Message-State: AOAM532sXgN0NNpKjilSMBewUXwwXz+MOfd7J5FRI6zAWA5st7gy5LmE
 | 
			
		||||
        Sw/QHj4cm3zT07LU1kWYSO9puwFV+yK0Hquf
 | 
			
		||||
X-Google-Smtp-Source: ABdhPJyDnhcP7BeBHXX2rPqMXwkOQiZdussDPATmYqyQnp7HAsi0OqWSUVIloMNi3QBpMsmjXTtyew==
 | 
			
		||||
X-Received: by 2002:a17:903:2285:b029:e6:faf5:eaff with SMTP id b5-20020a1709032285b02900e6faf5eaffmr19574014plh.70.1616850386727;
 | 
			
		||||
        Sat, 27 Mar 2021 06:06:26 -0700 (PDT)
 | 
			
		||||
Received: from johnchen902-arch-ryzen.. (2001-b011-3815-3a1f-9afa-9bff-fe6e-3ce2.dynamic-ip6.hinet.net. [2001:b011:3815:3a1f:9afa:9bff:fe6e:3ce2])
 | 
			
		||||
        by smtp.gmail.com with ESMTPSA id ot17sm6413787pjb.50.2021.03.27.06.06.25
 | 
			
		||||
        (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);
 | 
			
		||||
        Sat, 27 Mar 2021 06:06:26 -0700 (PDT)
 | 
			
		||||
From:   John Chen <johnchen902@gmail.com>
 | 
			
		||||
To:     linux-kernel@vger.kernel.org
 | 
			
		||||
Cc:     Rohit Pidaparthi <rohitpid@gmail.com>,
 | 
			
		||||
        RicardoEPRodrigues <ricardo.e.p.rodrigues@gmail.com>,
 | 
			
		||||
        Jiri Kosina <jikos@kernel.org>,
 | 
			
		||||
        Benjamin Tissoires <benjamin.tissoires@redhat.com>,
 | 
			
		||||
        John Chen <johnchen902@gmail.com>
 | 
			
		||||
Subject: [PATCH 2/4] HID: magicmouse: fix 3 button emulation of Mouse 2
 | 
			
		||||
Date:   Sat, 27 Mar 2021 21:05:06 +0800
 | 
			
		||||
Message-Id: <20210327130508.24849-3-johnchen902@gmail.com>
 | 
			
		||||
X-Mailer: git-send-email 2.31.0
 | 
			
		||||
In-Reply-To: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
References: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
MIME-Version: 1.0
 | 
			
		||||
Content-Transfer-Encoding: 8bit
 | 
			
		||||
Precedence: bulk
 | 
			
		||||
List-ID: <linux-kernel.vger.kernel.org>
 | 
			
		||||
X-Mailing-List: linux-kernel@vger.kernel.org
 | 
			
		||||
Archived-At: <https://lore.kernel.org/lkml/20210327130508.24849-3-johnchen902@gmail.com/>
 | 
			
		||||
List-Archive: <https://lore.kernel.org/lkml/>
 | 
			
		||||
List-Post: <mailto:linux-kernel@vger.kernel.org>
 | 
			
		||||
 | 
			
		||||
It is observed that, with 3 button emulation, when middle button is
 | 
			
		||||
clicked, either the left button or right button is clicked as well. It
 | 
			
		||||
is caused by hidinput "correctly" acting on the event, oblivious to the
 | 
			
		||||
3 button emulation.
 | 
			
		||||
 | 
			
		||||
As raw_event has taken care of everything, no further processing is
 | 
			
		||||
needed. However, the only way to stop at raw_event is to return an error
 | 
			
		||||
(negative) value. Therefore, the processing is stopped at event instead.
 | 
			
		||||
 | 
			
		||||
Signed-off-by: John Chen <johnchen902@gmail.com>
 | 
			
		||||
---
 | 
			
		||||
 drivers/hid/hid-magicmouse.c | 16 ++++++++++++++++
 | 
			
		||||
 1 file changed, 16 insertions(+)
 | 
			
		||||
 | 
			
		||||
diff --git a/drivers/hid/hid-magicmouse.c b/drivers/hid/hid-magicmouse.c
 | 
			
		||||
index 7aad6ca56780..c646b4cd3783 100644
 | 
			
		||||
--- a/drivers/hid/hid-magicmouse.c
 | 
			
		||||
+++ b/drivers/hid/hid-magicmouse.c
 | 
			
		||||
@@ -440,6 +440,21 @@ static int magicmouse_raw_event(struct hid_device *hdev,
 | 
			
		||||
 	return 1;
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+static int magicmouse_event(struct hid_device *hdev, struct hid_field *field,
 | 
			
		||||
+		struct hid_usage *usage, __s32 value)
 | 
			
		||||
+{
 | 
			
		||||
+	struct magicmouse_sc *msc = hid_get_drvdata(hdev);
 | 
			
		||||
+	if (msc->input->id.product == USB_DEVICE_ID_APPLE_MAGICMOUSE2 &&
 | 
			
		||||
+	    field->report->id == MOUSE2_REPORT_ID) {
 | 
			
		||||
+		// magic_mouse_raw_event has done all the work. Skip hidinput.
 | 
			
		||||
+		//
 | 
			
		||||
+		// Specifically, hidinput may modify BTN_LEFT and BTN_RIGHT,
 | 
			
		||||
+		// breaking emulate_3button.
 | 
			
		||||
+		return 1;
 | 
			
		||||
+	}
 | 
			
		||||
+	return 0;
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
 static int magicmouse_setup_input(struct input_dev *input, struct hid_device *hdev)
 | 
			
		||||
 {
 | 
			
		||||
 	int error;
 | 
			
		||||
@@ -754,6 +769,7 @@ static struct hid_driver magicmouse_driver = {
 | 
			
		||||
 	.id_table = magic_mice,
 | 
			
		||||
 	.probe = magicmouse_probe,
 | 
			
		||||
 	.raw_event = magicmouse_raw_event,
 | 
			
		||||
+	.event = magicmouse_event,
 | 
			
		||||
 	.input_mapping = magicmouse_input_mapping,
 | 
			
		||||
 	.input_configured = magicmouse_input_configured,
 | 
			
		||||
 };
 | 
			
		||||
-- 
 | 
			
		||||
2.31.0
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@@ -1,265 +0,0 @@
 | 
			
		||||
From mboxrd@z Thu Jan  1 00:00:00 1970
 | 
			
		||||
Return-Path: <linux-kernel-owner@kernel.org>
 | 
			
		||||
X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on
 | 
			
		||||
	aws-us-west-2-korg-lkml-1.web.codeaurora.org
 | 
			
		||||
X-Spam-Level: 
 | 
			
		||||
X-Spam-Status: No, score=-15.8 required=3.0 tests=BAYES_00,DKIM_SIGNED,
 | 
			
		||||
	DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM,
 | 
			
		||||
	HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH,
 | 
			
		||||
	MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,USER_AGENT_GIT autolearn=ham
 | 
			
		||||
	autolearn_force=no version=3.4.0
 | 
			
		||||
Received: from mail.kernel.org (mail.kernel.org [198.145.29.99])
 | 
			
		||||
	by smtp.lore.kernel.org (Postfix) with ESMTP id 9A212C433DB
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:10:34 +0000 (UTC)
 | 
			
		||||
Received: from vger.kernel.org (vger.kernel.org [23.128.96.18])
 | 
			
		||||
	by mail.kernel.org (Postfix) with ESMTP id 60FCC61981
 | 
			
		||||
	for <linux-kernel@archiver.kernel.org>; Sat, 27 Mar 2021 13:10:34 +0000 (UTC)
 | 
			
		||||
Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand
 | 
			
		||||
        id S230394AbhC0NHJ (ORCPT <rfc822;linux-kernel@archiver.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:07:09 -0400
 | 
			
		||||
Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59810 "EHLO
 | 
			
		||||
        lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org
 | 
			
		||||
        with ESMTP id S230307AbhC0NGi (ORCPT
 | 
			
		||||
        <rfc822;linux-kernel@vger.kernel.org>);
 | 
			
		||||
        Sat, 27 Mar 2021 09:06:38 -0400
 | 
			
		||||
Received: from mail-pf1-x432.google.com (mail-pf1-x432.google.com [IPv6:2607:f8b0:4864:20::432])
 | 
			
		||||
        by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1EDFCC0613B1
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:06:38 -0700 (PDT)
 | 
			
		||||
Received: by mail-pf1-x432.google.com with SMTP id q5so6741894pfh.10
 | 
			
		||||
        for <linux-kernel@vger.kernel.org>; Sat, 27 Mar 2021 06:06:38 -0700 (PDT)
 | 
			
		||||
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=gmail.com; s=20161025;
 | 
			
		||||
        h=from:to:cc:subject:date:message-id:in-reply-to:references
 | 
			
		||||
         :mime-version:content-transfer-encoding;
 | 
			
		||||
        bh=fWEWnDB7IS15Aoqul4RZDergwEtbUe4NAH8lKjv7p/s=;
 | 
			
		||||
        b=CGLrSHoDnG8b5CL6asLWP1Ym/QFl+wtwIF8PhKlW7RJ5IhavVtdO6Fd7/cY/3GQTDa
 | 
			
		||||
         wvX9Q1wfBsakVlG9/sM9CuozOsra6Ec9c1B+0beWTAKj/tBjwvsVHtMoCiqOPL/Vbig6
 | 
			
		||||
         4zkWMb6dwWSzAgmCqPEaYlyJYqBrDLzzXxqGhchwTfcNgNZQGq0xhh7tZsukEPz4XLIC
 | 
			
		||||
         LNCy6+hPSVdRG1ADbyPpOGFn3fSeFs5KAwl3y1Cn0TvTPxgpckTLcFz5TsTF/w7VLGW1
 | 
			
		||||
         bn9Gakn+MaATqxahU0lDwyzI1sMK2er7/ddjV9VugYN4PzgL9DHGu/iGzXGFftDoLdaJ
 | 
			
		||||
         tBIQ==
 | 
			
		||||
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;
 | 
			
		||||
        d=1e100.net; s=20161025;
 | 
			
		||||
        h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to
 | 
			
		||||
         :references:mime-version:content-transfer-encoding;
 | 
			
		||||
        bh=fWEWnDB7IS15Aoqul4RZDergwEtbUe4NAH8lKjv7p/s=;
 | 
			
		||||
        b=PQiPlj7RSTzmBU6u/2xzL9qv8jrelC7cJFFiOHjwKfz43PMzm0nEj6PxY5ZFMSjmbs
 | 
			
		||||
         JEfC8iDjJh39FJdthBrvaZX4yuTv4QmOdmRMWrN77sQYbZOaKOhbNrCx2/LdHzAFjLBY
 | 
			
		||||
         qTHW0+siiP/ATBf1M0cSP200UZAjBwU8MRapxAlaIUmlrfr5+oM8ZrL2tMhzDYcn5b51
 | 
			
		||||
         TwXEVVI5Ep0YZxyGYQ04yaMBZxb1hSKev6UhrFpk96Ukg4IY3qBQBRpjWHIWqZY21aUl
 | 
			
		||||
         EeDLmlWZaqDbp6UQQrAd2p1kIVyrxKD2Cf4aPnk2JcvzR9qGfMwV8cpR9rqwrXBEiyLj
 | 
			
		||||
         KZFg==
 | 
			
		||||
X-Gm-Message-State: AOAM532lFsZyg8BiLek2pS5Ftc0rOopeD1Q9b7d5Lc7gC8pPIjHcnizK
 | 
			
		||||
        2/grg+4GExN9zVerojORiZgGkTwU1/c2DswO
 | 
			
		||||
X-Google-Smtp-Source: ABdhPJwECFbuV2SwesS0pF6L0s23ghF61g6whXAjcLZpxYe6b6OsgENBMa3gmTj9FFMF+68uJYhPPw==
 | 
			
		||||
X-Received: by 2002:a63:1d26:: with SMTP id d38mr17032822pgd.385.1616850397389;
 | 
			
		||||
        Sat, 27 Mar 2021 06:06:37 -0700 (PDT)
 | 
			
		||||
Received: from johnchen902-arch-ryzen.. (2001-b011-3815-3a1f-9afa-9bff-fe6e-3ce2.dynamic-ip6.hinet.net. [2001:b011:3815:3a1f:9afa:9bff:fe6e:3ce2])
 | 
			
		||||
        by smtp.gmail.com with ESMTPSA id ot17sm6413787pjb.50.2021.03.27.06.06.36
 | 
			
		||||
        (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);
 | 
			
		||||
        Sat, 27 Mar 2021 06:06:37 -0700 (PDT)
 | 
			
		||||
From:   John Chen <johnchen902@gmail.com>
 | 
			
		||||
To:     linux-kernel@vger.kernel.org
 | 
			
		||||
Cc:     Rohit Pidaparthi <rohitpid@gmail.com>,
 | 
			
		||||
        RicardoEPRodrigues <ricardo.e.p.rodrigues@gmail.com>,
 | 
			
		||||
        Jiri Kosina <jikos@kernel.org>,
 | 
			
		||||
        Benjamin Tissoires <benjamin.tissoires@redhat.com>,
 | 
			
		||||
        John Chen <johnchen902@gmail.com>
 | 
			
		||||
Subject: [PATCH 3/4] HID: magicmouse: fix reconnection of Magic Mouse 2
 | 
			
		||||
Date:   Sat, 27 Mar 2021 21:05:07 +0800
 | 
			
		||||
Message-Id: <20210327130508.24849-4-johnchen902@gmail.com>
 | 
			
		||||
X-Mailer: git-send-email 2.31.0
 | 
			
		||||
In-Reply-To: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
References: <20210327130508.24849-1-johnchen902@gmail.com>
 | 
			
		||||
MIME-Version: 1.0
 | 
			
		||||
Content-Transfer-Encoding: 8bit
 | 
			
		||||
Precedence: bulk
 | 
			
		||||
List-ID: <linux-kernel.vger.kernel.org>
 | 
			
		||||
X-Mailing-List: linux-kernel@vger.kernel.org
 | 
			
		||||
Archived-At: <https://lore.kernel.org/lkml/20210327130508.24849-4-johnchen902@gmail.com/>
 | 
			
		||||
List-Archive: <https://lore.kernel.org/lkml/>
 | 
			
		||||
List-Post: <mailto:linux-kernel@vger.kernel.org>
 | 
			
		||||
 | 
			
		||||
It is observed that the Magic Mouse 2 would not enter multi-touch mode
 | 
			
		||||
unless the mouse is connected before loading the module. It seems to be
 | 
			
		||||
a quirk specific to Magic Mouse 2
 | 
			
		||||
 | 
			
		||||
Retrying after 500ms fixes the problem for me. The delay can't be
 | 
			
		||||
reduced much further --- 300ms didn't work for me. Retrying immediately
 | 
			
		||||
after receiving an event didn't work either.
 | 
			
		||||
 | 
			
		||||
Signed-off-by: John Chen <johnchen902@gmail.com>
 | 
			
		||||
---
 | 
			
		||||
 drivers/hid/hid-magicmouse.c | 93 ++++++++++++++++++++++++------------
 | 
			
		||||
 1 file changed, 63 insertions(+), 30 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/drivers/hid/hid-magicmouse.c b/drivers/hid/hid-magicmouse.c
 | 
			
		||||
index c646b4cd3783..69aefef9fe07 100644
 | 
			
		||||
--- a/drivers/hid/hid-magicmouse.c
 | 
			
		||||
+++ b/drivers/hid/hid-magicmouse.c
 | 
			
		||||
@@ -16,6 +16,7 @@
 | 
			
		||||
 #include <linux/input/mt.h>
 | 
			
		||||
 #include <linux/module.h>
 | 
			
		||||
 #include <linux/slab.h>
 | 
			
		||||
+#include <linux/workqueue.h>
 | 
			
		||||
 
 | 
			
		||||
 #include "hid-ids.h"
 | 
			
		||||
 
 | 
			
		||||
@@ -128,6 +129,9 @@ struct magicmouse_sc {
 | 
			
		||||
 		u8 size;
 | 
			
		||||
 	} touches[16];
 | 
			
		||||
 	int tracking_ids[16];
 | 
			
		||||
+
 | 
			
		||||
+	struct hid_device *hdev;
 | 
			
		||||
+	struct delayed_work work;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 static int magicmouse_firm_touch(struct magicmouse_sc *msc)
 | 
			
		||||
@@ -629,9 +633,7 @@ static int magicmouse_input_configured(struct hid_device *hdev,
 | 
			
		||||
 	return 0;
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
-
 | 
			
		||||
-static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
-	const struct hid_device_id *id)
 | 
			
		||||
+static int magicmouse_enable_multitouch(struct hid_device *hdev)
 | 
			
		||||
 {
 | 
			
		||||
 	const u8 *feature;
 | 
			
		||||
 	const u8 feature_mt[] = { 0xD7, 0x01 };
 | 
			
		||||
@@ -639,10 +641,52 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 	const u8 feature_mt_trackpad2_usb[] = { 0x02, 0x01 };
 | 
			
		||||
 	const u8 feature_mt_trackpad2_bt[] = { 0xF1, 0x02, 0x01 };
 | 
			
		||||
 	u8 *buf;
 | 
			
		||||
+	int ret;
 | 
			
		||||
+	int feature_size;
 | 
			
		||||
+
 | 
			
		||||
+	if (hdev->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2) {
 | 
			
		||||
+		if (hdev->vendor == BT_VENDOR_ID_APPLE) {
 | 
			
		||||
+			feature_size = sizeof(feature_mt_trackpad2_bt);
 | 
			
		||||
+			feature = feature_mt_trackpad2_bt;
 | 
			
		||||
+		} else { /* USB_VENDOR_ID_APPLE */
 | 
			
		||||
+			feature_size = sizeof(feature_mt_trackpad2_usb);
 | 
			
		||||
+			feature = feature_mt_trackpad2_usb;
 | 
			
		||||
+		}
 | 
			
		||||
+	} else if (hdev->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
+		feature_size = sizeof(feature_mt_mouse2);
 | 
			
		||||
+		feature = feature_mt_mouse2;
 | 
			
		||||
+	} else {
 | 
			
		||||
+		feature_size = sizeof(feature_mt);
 | 
			
		||||
+		feature = feature_mt;
 | 
			
		||||
+	}
 | 
			
		||||
+
 | 
			
		||||
+	buf = kmemdup(feature, feature_size, GFP_KERNEL);
 | 
			
		||||
+	if (!buf)
 | 
			
		||||
+		return -ENOMEM;
 | 
			
		||||
+
 | 
			
		||||
+	ret = hid_hw_raw_request(hdev, buf[0], buf, feature_size,
 | 
			
		||||
+				HID_FEATURE_REPORT, HID_REQ_SET_REPORT);
 | 
			
		||||
+	kfree(buf);
 | 
			
		||||
+	return ret;
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
+static void magicmouse_enable_mt_work(struct work_struct *work)
 | 
			
		||||
+{
 | 
			
		||||
+	struct magicmouse_sc *msc =
 | 
			
		||||
+		container_of(work, struct magicmouse_sc, work.work);
 | 
			
		||||
+	int ret;
 | 
			
		||||
+
 | 
			
		||||
+	ret = magicmouse_enable_multitouch(msc->hdev);
 | 
			
		||||
+	if (ret < 0)
 | 
			
		||||
+		hid_err(msc->hdev, "unable to request touch data (%d)\n", ret);
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
+static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
+	const struct hid_device_id *id)
 | 
			
		||||
+{
 | 
			
		||||
 	struct magicmouse_sc *msc;
 | 
			
		||||
 	struct hid_report *report;
 | 
			
		||||
 	int ret;
 | 
			
		||||
-	int feature_size;
 | 
			
		||||
 
 | 
			
		||||
 	if (id->vendor == USB_VENDOR_ID_APPLE &&
 | 
			
		||||
 	    id->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2 &&
 | 
			
		||||
@@ -656,6 +700,8 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 	}
 | 
			
		||||
 
 | 
			
		||||
 	msc->scroll_accel = SCROLL_ACCEL_DEFAULT;
 | 
			
		||||
+	msc->hdev = hdev;
 | 
			
		||||
+	INIT_DEFERRABLE_WORK(&msc->work, magicmouse_enable_mt_work);
 | 
			
		||||
 
 | 
			
		||||
 	msc->quirks = id->driver_data;
 | 
			
		||||
 	hid_set_drvdata(hdev, msc);
 | 
			
		||||
@@ -705,28 +751,6 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 	}
 | 
			
		||||
 	report->size = 6;
 | 
			
		||||
 
 | 
			
		||||
-	if (id->product == USB_DEVICE_ID_APPLE_MAGICTRACKPAD2) {
 | 
			
		||||
-		if (id->vendor == BT_VENDOR_ID_APPLE) {
 | 
			
		||||
-			feature_size = sizeof(feature_mt_trackpad2_bt);
 | 
			
		||||
-			feature = feature_mt_trackpad2_bt;
 | 
			
		||||
-		} else { /* USB_VENDOR_ID_APPLE */
 | 
			
		||||
-			feature_size = sizeof(feature_mt_trackpad2_usb);
 | 
			
		||||
-			feature = feature_mt_trackpad2_usb;
 | 
			
		||||
-		}
 | 
			
		||||
-	} else if (id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
-		feature_size = sizeof(feature_mt_mouse2);
 | 
			
		||||
-		feature = feature_mt_mouse2;
 | 
			
		||||
-	} else {
 | 
			
		||||
-		feature_size = sizeof(feature_mt);
 | 
			
		||||
-		feature = feature_mt;
 | 
			
		||||
-	}
 | 
			
		||||
-
 | 
			
		||||
-	buf = kmemdup(feature, feature_size, GFP_KERNEL);
 | 
			
		||||
-	if (!buf) {
 | 
			
		||||
-		ret = -ENOMEM;
 | 
			
		||||
-		goto err_stop_hw;
 | 
			
		||||
-	}
 | 
			
		||||
-
 | 
			
		||||
 	/*
 | 
			
		||||
 	 * Some devices repond with 'invalid report id' when feature
 | 
			
		||||
 	 * report switching it into multitouch mode is sent to it.
 | 
			
		||||
@@ -735,13 +759,14 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 	 * but there seems to be no other way of switching the mode.
 | 
			
		||||
 	 * Thus the super-ugly hacky success check below.
 | 
			
		||||
 	 */
 | 
			
		||||
-	ret = hid_hw_raw_request(hdev, buf[0], buf, feature_size,
 | 
			
		||||
-				HID_FEATURE_REPORT, HID_REQ_SET_REPORT);
 | 
			
		||||
-	kfree(buf);
 | 
			
		||||
-	if (ret != -EIO && ret != feature_size) {
 | 
			
		||||
+	ret = magicmouse_enable_multitouch(hdev);
 | 
			
		||||
+	if (ret != -EIO && ret < 0) {
 | 
			
		||||
 		hid_err(hdev, "unable to request touch data (%d)\n", ret);
 | 
			
		||||
 		goto err_stop_hw;
 | 
			
		||||
 	}
 | 
			
		||||
+	if (ret == -EIO && id->product == USB_DEVICE_ID_APPLE_MAGICMOUSE2) {
 | 
			
		||||
+		schedule_delayed_work(&msc->work, msecs_to_jiffies(500));
 | 
			
		||||
+	}
 | 
			
		||||
 
 | 
			
		||||
 	return 0;
 | 
			
		||||
 err_stop_hw:
 | 
			
		||||
@@ -749,6 +774,13 @@ static int magicmouse_probe(struct hid_device *hdev,
 | 
			
		||||
 	return ret;
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+static void magicmouse_remove(struct hid_device *hdev)
 | 
			
		||||
+{
 | 
			
		||||
+	struct magicmouse_sc *msc = hid_get_drvdata(hdev);
 | 
			
		||||
+	cancel_delayed_work_sync(&msc->work);
 | 
			
		||||
+	hid_hw_stop(hdev);
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
 static const struct hid_device_id magic_mice[] = {
 | 
			
		||||
 	{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE,
 | 
			
		||||
 		USB_DEVICE_ID_APPLE_MAGICMOUSE), .driver_data = 0 },
 | 
			
		||||
@@ -768,6 +800,7 @@ static struct hid_driver magicmouse_driver = {
 | 
			
		||||
 	.name = "magicmouse",
 | 
			
		||||
 	.id_table = magic_mice,
 | 
			
		||||
 	.probe = magicmouse_probe,
 | 
			
		||||
+	.remove = magicmouse_remove,
 | 
			
		||||
 	.raw_event = magicmouse_raw_event,
 | 
			
		||||
 	.event = magicmouse_event,
 | 
			
		||||
 	.input_mapping = magicmouse_input_mapping,
 | 
			
		||||
-- 
 | 
			
		||||
2.31.0
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -1,18 +0,0 @@
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
index 086b5ebfa512..b4a71b02c474 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
@@ -304,11 +304,13 @@ &codec {
 | 
			
		||||
 	pinctrl-names = "default";
 | 
			
		||||
 	pinctrl-0 = <&aif2_pins>, <&aif3_pins>;
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
+	allwinner,inverted-jack-detection;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 &codec_analog {
 | 
			
		||||
 	cpvdd-supply = <®_eldo1>;
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
+	allwinner,internal-bias-resistor;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 &cpu0 {
 | 
			
		||||
@@ -1,175 +0,0 @@
 | 
			
		||||
From 5da6a7e3f4d6e11f4887893672f849d2d4fa5b58 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Clayton Craft <clayton@craftyguy.net>
 | 
			
		||||
Date: Wed, 16 Dec 2020 20:16:14 -0800
 | 
			
		||||
Subject: [PATCH] dts: pinephone: drop modem-power node
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 .../allwinner/sun50i-a64-pinephone-1.0.dts    | 26 +++---------------
 | 
			
		||||
 .../allwinner/sun50i-a64-pinephone-1.1.dts    | 27 +++----------------
 | 
			
		||||
 .../allwinner/sun50i-a64-pinephone-1.2.dts    | 27 +++----------------
 | 
			
		||||
 .../dts/allwinner/sun50i-a64-pinephone.dtsi   | 12 +++++++++
 | 
			
		||||
 4 files changed, 24 insertions(+), 68 deletions(-)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts
 | 
			
		||||
index 0f6faa44ce3e..2cc513772172 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.0.dts
 | 
			
		||||
@@ -86,28 +86,6 @@ ®_drivevbus {
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
-&uart3 {
 | 
			
		||||
-	modem {
 | 
			
		||||
-		compatible = "quectel,eg25";
 | 
			
		||||
-		char-device-name = "modem-power";
 | 
			
		||||
-
 | 
			
		||||
-		power-supply = <®_vbat_bb>; /* PL7 */
 | 
			
		||||
-
 | 
			
		||||
-		enable-gpios = <&pio 7 8 GPIO_ACTIVE_LOW>; /* PH8 */
 | 
			
		||||
-		reset-gpios = <&pio 2 4 GPIO_ACTIVE_HIGH>; /* PC4 */
 | 
			
		||||
-		pwrkey-gpios = <&pio 1 3 GPIO_ACTIVE_HIGH>; /* PB3 */
 | 
			
		||||
-
 | 
			
		||||
-		sleep-gpios = <&pio 7 7 GPIO_ACTIVE_HIGH>; /* PH7 */
 | 
			
		||||
-		wakeup-gpios = <&pio 1 2 GPIO_ACTIVE_HIGH>; /* PB2-RI */
 | 
			
		||||
-
 | 
			
		||||
-		cts-gpios = <&pio 3 5 GPIO_ACTIVE_HIGH>; /* PD5-CTS */
 | 
			
		||||
-		dtr-gpios = <&r_pio 0 6 GPIO_ACTIVE_HIGH>; /* PL6-DTR */
 | 
			
		||||
-		rts-gpios = <&pio 3 4 GPIO_ACTIVE_HIGH>; /* PD4-RTS */
 | 
			
		||||
-
 | 
			
		||||
-		quectel,qdai = "1,1,0,1,0,0,1,1";
 | 
			
		||||
-	};
 | 
			
		||||
-};
 | 
			
		||||
-
 | 
			
		||||
 &usbphy {
 | 
			
		||||
 	usb-role-switch;
 | 
			
		||||
 
 | 
			
		||||
@@ -118,6 +96,10 @@ usb0_drd_sw: endpoint {
 | 
			
		||||
 	};
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
+&ring_indicator {
 | 
			
		||||
+	gpios = <&pio 1 2 GPIO_ACTIVE_LOW>; /* PB2 */
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
 &sgm3140 {
 | 
			
		||||
 	flash-gpios = <&pio 3 24 GPIO_ACTIVE_HIGH>; /* PD24 */
 | 
			
		||||
 	enable-gpios = <&pio 2 3 GPIO_ACTIVE_HIGH>; /* PC3 */
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
index 95a880fdc9ce..5f3b6a1a142f 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.1.dts
 | 
			
		||||
@@ -109,34 +109,15 @@
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
+&ring_indicator {
 | 
			
		||||
+	gpios = <&pio 1 2 GPIO_ACTIVE_LOW>; /* PB2 */
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
 &sgm3140 {
 | 
			
		||||
 	enable-gpios = <&pio 3 24 GPIO_ACTIVE_HIGH>; /* PD24 */
 | 
			
		||||
 	flash-gpios = <&pio 2 3 GPIO_ACTIVE_HIGH>; /* PC3 */
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
-&uart3 {
 | 
			
		||||
-	modem {
 | 
			
		||||
-		compatible = "quectel,eg25";
 | 
			
		||||
-		char-device-name = "modem-power";
 | 
			
		||||
-
 | 
			
		||||
-		power-supply = <®_vbat_bb>; /* PL7 */
 | 
			
		||||
-
 | 
			
		||||
-		enable-gpios = <&pio 7 8 GPIO_ACTIVE_LOW>; /* PH8 */
 | 
			
		||||
-		reset-gpios = <&pio 2 4 GPIO_ACTIVE_HIGH>; /* PC4 */
 | 
			
		||||
-		pwrkey-gpios = <&pio 1 3 GPIO_ACTIVE_HIGH>; /* PB3 */
 | 
			
		||||
-		//status-pwrkey-multiplexed; /* status acts as pwrkey */
 | 
			
		||||
-
 | 
			
		||||
-		sleep-gpios = <&pio 7 7 GPIO_ACTIVE_HIGH>; /* PH7 */
 | 
			
		||||
-		wakeup-gpios = <&pio 1 2 GPIO_ACTIVE_HIGH>; /* PB2-RI */
 | 
			
		||||
-
 | 
			
		||||
-		dtr-gpios = <&r_pio 0 6 GPIO_ACTIVE_HIGH>; /* PL6-DTR */
 | 
			
		||||
-		cts-gpios = <&pio 3 5 GPIO_ACTIVE_HIGH>; /* PD5-CTS */
 | 
			
		||||
-		rts-gpios = <&pio 3 4 GPIO_ACTIVE_HIGH>; /* PD4-RTS */
 | 
			
		||||
-
 | 
			
		||||
-		quectel,qdai = "1,1,0,1,0,0,1,1";
 | 
			
		||||
-	};
 | 
			
		||||
-};
 | 
			
		||||
-
 | 
			
		||||
 &usbphy {
 | 
			
		||||
 	usb-role-switch;
 | 
			
		||||
 
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
index 23ba72508cfc..889841ca5b8a 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone-1.2.dts
 | 
			
		||||
@@ -101,34 +101,15 @@
 | 
			
		||||
 	enable-active-high;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
+&ring_indicator {
 | 
			
		||||
+	gpios = <&r_pio 0 6 GPIO_ACTIVE_LOW>; /* PL6 */
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
 &sgm3140 {
 | 
			
		||||
 	enable-gpios = <&pio 3 24 GPIO_ACTIVE_HIGH>; /* PD24 */
 | 
			
		||||
 	flash-gpios = <&pio 2 3 GPIO_ACTIVE_HIGH>; /* PC3 */
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
-&uart3 {
 | 
			
		||||
-	modem {
 | 
			
		||||
-		compatible = "quectel,eg25";
 | 
			
		||||
-		char-device-name = "modem-power";
 | 
			
		||||
-
 | 
			
		||||
-		power-supply = <®_vbat_bb>; /* PL7 */
 | 
			
		||||
-
 | 
			
		||||
-		enable-gpios = <&pio 7 8 GPIO_ACTIVE_LOW>; /* PH8 */
 | 
			
		||||
-		reset-gpios = <&pio 2 4 GPIO_ACTIVE_HIGH>; /* PC4 */
 | 
			
		||||
-		status-gpios = <&pio 7 9 GPIO_ACTIVE_HIGH>; /* PH9 */
 | 
			
		||||
-		pwrkey-gpios = <&pio 1 3 GPIO_ACTIVE_HIGH>; /* PB3 */
 | 
			
		||||
-
 | 
			
		||||
-		host-ready-gpios = <&pio 7 7 GPIO_ACTIVE_HIGH>; /* PH7 */
 | 
			
		||||
-		wakeup-gpios = <&r_pio 0 6 GPIO_ACTIVE_HIGH>; /* PL6-RI */
 | 
			
		||||
-
 | 
			
		||||
-		dtr-gpios = <&pio 1 2 GPIO_ACTIVE_HIGH>; /* PB2-DTR */
 | 
			
		||||
-		cts-gpios = <&pio 3 5 GPIO_ACTIVE_HIGH>; /* PD5-CTS */
 | 
			
		||||
-		rts-gpios = <&pio 3 4 GPIO_ACTIVE_HIGH>; /* PD4-RTS */
 | 
			
		||||
-
 | 
			
		||||
-		quectel,qdai = "1,1,0,1,0,0,1,1";
 | 
			
		||||
-	};
 | 
			
		||||
-};
 | 
			
		||||
-
 | 
			
		||||
 &usbphy {
 | 
			
		||||
 	usb-role-switch;
 | 
			
		||||
 
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
index 02d82980cf39..979d01de8d84 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
@@ -192,6 +192,17 @@ ec25_codec: ec25-codec {
 | 
			
		||||
 		compatible = "quectel,ec25";
 | 
			
		||||
 	};
 | 
			
		||||
 
 | 
			
		||||
+	gpio-keys {
 | 
			
		||||
+		compatible = "gpio-keys";
 | 
			
		||||
+
 | 
			
		||||
+		ring_indicator: ring-indicator {
 | 
			
		||||
+			label = "Ring Indicator";
 | 
			
		||||
+			linux,can-disable;
 | 
			
		||||
+			linux,code = <KEY_WAKEUP>;
 | 
			
		||||
+			wakeup-source;
 | 
			
		||||
+		};
 | 
			
		||||
+	};
 | 
			
		||||
+
 | 
			
		||||
 	i2c_csi: i2c-csi {
 | 
			
		||||
 		compatible = "i2c-gpio";
 | 
			
		||||
 		sda-gpios = <&pio 4 13 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>; /* PE13 */
 | 
			
		||||
@@ -256,6 +267,7 @@ reg_usb_5v: usb-5v {
 | 
			
		||||
 	reg_vbat_bb: vbat-bb {
 | 
			
		||||
 		compatible = "regulator-fixed";
 | 
			
		||||
 		regulator-name = "vbat-bb";
 | 
			
		||||
+		regulator-always-on;
 | 
			
		||||
 		regulator-min-microvolt = <3500000>;
 | 
			
		||||
 		regulator-max-microvolt = <3500000>;
 | 
			
		||||
 		gpio = <&r_pio 0 7 GPIO_ACTIVE_HIGH>; /* PL7 */
 | 
			
		||||
-- 
 | 
			
		||||
2.29.2
 | 
			
		||||
 | 
			
		||||
@@ -1,57 +0,0 @@
 | 
			
		||||
From c8da73c7ae6192f0229aa728c6443c768bf3450f Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Danct12 <danct12@disroot.org>
 | 
			
		||||
Date: Tue, 13 Oct 2020 08:30:32 +0700
 | 
			
		||||
Subject: [PATCH] arm64: dts: allwinner: pinetab: enable HDMI
 | 
			
		||||
 | 
			
		||||
Signed-off-by: Danct12 <danct12@disroot.org>
 | 
			
		||||
---
 | 
			
		||||
 .../boot/dts/allwinner/sun50i-a64-pinetab.dts | 26 +++++++++++++++++++
 | 
			
		||||
 1 file changed, 26 insertions(+)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
index 407837d7fbec..9c96c1532a1e 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
@@ -35,6 +35,17 @@ chosen {
 | 
			
		||||
 		stdout-path = "serial0:115200n8";
 | 
			
		||||
 	};
 | 
			
		||||
 
 | 
			
		||||
+	hdmi-connector {
 | 
			
		||||
+		compatible = "hdmi-connector";
 | 
			
		||||
+		type = "a";
 | 
			
		||||
+
 | 
			
		||||
+		port {
 | 
			
		||||
+			hdmi_con_in: endpoint {
 | 
			
		||||
+				remote-endpoint = <&hdmi_out_con>;
 | 
			
		||||
+			};
 | 
			
		||||
+		};
 | 
			
		||||
+	};
 | 
			
		||||
+
 | 
			
		||||
 	i2c-csi {
 | 
			
		||||
 		compatible = "i2c-gpio";
 | 
			
		||||
 		sda-gpios = <&pio 4 13 GPIO_ACTIVE_HIGH>; /* PE13 */
 | 
			
		||||
@@ -462,6 +473,21 @@ ®_rtc_ldo {
 | 
			
		||||
 	regulator-name = "vcc-rtc";
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
+&simplefb_hdmi {
 | 
			
		||||
+	vcc-hdmi-supply = <®_dldo1>;
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
+&hdmi {
 | 
			
		||||
+	hvcc-supply = <®_dldo1>;
 | 
			
		||||
+	status = "okay";
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
+&hdmi_out {
 | 
			
		||||
+	hdmi_out_con: endpoint {
 | 
			
		||||
+		remote-endpoint = <&hdmi_con_in>;
 | 
			
		||||
+	};
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
 &sound {
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 	simple-audio-card,aux-devs = <&codec_analog>, <&speaker_amp>;
 | 
			
		||||
-- 
 | 
			
		||||
2.28.0
 | 
			
		||||
 | 
			
		||||
@@ -1,38 +0,0 @@
 | 
			
		||||
From 7dd3866d9c2bef4bb73a781861aeeec595510509 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Arnaud Ferraris <arnaud.ferraris@collabora.com>
 | 
			
		||||
Date: Fri, 3 Apr 2020 17:13:55 +0200
 | 
			
		||||
Subject: [PATCH] arm64: dts: allwinner: pinetab: enable jack detection
 | 
			
		||||
 | 
			
		||||
---
 | 
			
		||||
 arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts | 3 +++
 | 
			
		||||
 1 file changed, 3 insertions(+)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
index a87790df9..a72c2ec8c 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
@@ -117,11 +117,13 @@ wifi_pwrseq: wifi_pwrseq {
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 &codec {
 | 
			
		||||
+	allwinner,inverted-jack-detection;
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 &codec_analog {
 | 
			
		||||
 	cpvdd-supply = <®_eldo1>;
 | 
			
		||||
+	allwinner,internal-bias-resistor;
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
@@ -448,6 +450,7 @@ ®_rtc_ldo {
 | 
			
		||||
 
 | 
			
		||||
 &sound {
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
+	simple-audio-card,name = "PineTab";
 | 
			
		||||
 	simple-audio-card,aux-devs = <&codec_analog>, <&speaker_amp>;
 | 
			
		||||
 	simple-audio-card,widgets = "Microphone", "Internal Microphone Left",
 | 
			
		||||
 				    "Microphone", "Internal Microphone Right",
 | 
			
		||||
-- 
 | 
			
		||||
2.28.0
 | 
			
		||||
 | 
			
		||||
@@ -1,9 +0,0 @@
 | 
			
		||||
post_upgrade() {
 | 
			
		||||
  if findmnt --fstab -uno SOURCE /boot &>/dev/null && ! mountpoint -q /boot; then
 | 
			
		||||
    echo "WARNING: /boot appears to be a separate partition but is not mounted."
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
post_remove() {
 | 
			
		||||
  rm -f boot/initramfs-linux.img
 | 
			
		||||
}
 | 
			
		||||
@@ -1,11 +0,0 @@
 | 
			
		||||
# mkinitcpio preset file for the '%PKGBASE%' package
 | 
			
		||||
 | 
			
		||||
ALL_config="/etc/mkinitcpio.conf"
 | 
			
		||||
ALL_kver="%KERNVER%"
 | 
			
		||||
 | 
			
		||||
PRESETS=('default')
 | 
			
		||||
 | 
			
		||||
#default_config="/etc/mkinitcpio.conf"
 | 
			
		||||
default_image="/boot/initramfs-linux.img"
 | 
			
		||||
#default_options=""
 | 
			
		||||
 | 
			
		||||
@@ -1,409 +0,0 @@
 | 
			
		||||
From f062022f2a2781d6b8ca63c460b0e72ebac30870 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Martijn Braam <martijn@brixit.nl>
 | 
			
		||||
Date: Mon, 28 Sep 2020 14:26:11 +0200
 | 
			
		||||
Subject: [PATCH] media: ov5640: Implement autofocus
 | 
			
		||||
 | 
			
		||||
The autofocus functionality needs a firmware blob loaded into the
 | 
			
		||||
internal microcontroller.
 | 
			
		||||
 | 
			
		||||
V4L2 doesn't have an api to control all autofocus functionality, but
 | 
			
		||||
this at least makes it possible to focus on the center of the sensor.
 | 
			
		||||
 | 
			
		||||
Signed-off-by: Martijn Braam <martijn@brixit.nl>
 | 
			
		||||
---
 | 
			
		||||
 drivers/media/i2c/ov5640.c | 254 +++++++++++++++++++++++++++++++++++++
 | 
			
		||||
 1 file changed, 254 insertions(+)
 | 
			
		||||
 | 
			
		||||
diff --git a/drivers/media/i2c/ov5640.c b/drivers/media/i2c/ov5640.c
 | 
			
		||||
index df0a507c211f..08a5304c0e95 100644
 | 
			
		||||
--- a/drivers/media/i2c/ov5640.c
 | 
			
		||||
+++ b/drivers/media/i2c/ov5640.c
 | 
			
		||||
@@ -9,6 +9,7 @@
 | 
			
		||||
 #include <linux/clkdev.h>
 | 
			
		||||
 #include <linux/ctype.h>
 | 
			
		||||
 #include <linux/delay.h>
 | 
			
		||||
+#include <linux/firmware.h>
 | 
			
		||||
 #include <linux/device.h>
 | 
			
		||||
 #include <linux/gpio/consumer.h>
 | 
			
		||||
 #include <linux/i2c.h>
 | 
			
		||||
@@ -31,7 +32,11 @@
 | 
			
		||||
 
 | 
			
		||||
 #define OV5640_DEFAULT_SLAVE_ID 0x3c
 | 
			
		||||
 
 | 
			
		||||
+#define OV5640_REG_SYS_RESET00		0x3000
 | 
			
		||||
+#define OV5640_REG_SYS_RESET01		0x3001
 | 
			
		||||
 #define OV5640_REG_SYS_RESET02		0x3002
 | 
			
		||||
+#define OV5640_REG_SYS_CLOCK_ENABLE00	0x3004
 | 
			
		||||
+#define OV5640_REG_SYS_CLOCK_ENABLE01	0x3005
 | 
			
		||||
 #define OV5640_REG_SYS_CLOCK_ENABLE02	0x3006
 | 
			
		||||
 #define OV5640_REG_SYS_CTRL0		0x3008
 | 
			
		||||
 #define OV5640_REG_SYS_CTRL0_SW_PWDN	0x42
 | 
			
		||||
@@ -41,6 +46,14 @@
 | 
			
		||||
 #define OV5640_REG_PAD_OUTPUT_ENABLE01	0x3017
 | 
			
		||||
 #define OV5640_REG_PAD_OUTPUT_ENABLE02	0x3018
 | 
			
		||||
 #define OV5640_REG_PAD_OUTPUT00		0x3019
 | 
			
		||||
+#define OV5640_REG_FW_CMD_MAIN		0x3022
 | 
			
		||||
+#define OV5640_REG_FW_CMD_ACK		0x3023
 | 
			
		||||
+#define OV5640_REG_FW_CMD_PARA0		0x3024
 | 
			
		||||
+#define OV5640_REG_FW_CMD_PARA1		0x3025
 | 
			
		||||
+#define OV5640_REG_FW_CMD_PARA2		0x3026
 | 
			
		||||
+#define OV5640_REG_FW_CMD_PARA3		0x3027
 | 
			
		||||
+#define OV5640_REG_FW_CMD_PARA4		0x3028
 | 
			
		||||
+#define OV5640_REG_FW_STATUS		0x3029
 | 
			
		||||
 #define OV5640_REG_SYSTEM_CONTROL1	0x302e
 | 
			
		||||
 #define OV5640_REG_SC_PLL_CTRL0		0x3034
 | 
			
		||||
 #define OV5640_REG_SC_PLL_CTRL1		0x3035
 | 
			
		||||
@@ -59,6 +72,7 @@
 | 
			
		||||
 #define OV5640_REG_AEC_PK_MANUAL	0x3503
 | 
			
		||||
 #define OV5640_REG_AEC_PK_REAL_GAIN	0x350a
 | 
			
		||||
 #define OV5640_REG_AEC_PK_VTS		0x350c
 | 
			
		||||
+#define OV5640_REG_VCM_CONTROL4		0x3606
 | 
			
		||||
 #define OV5640_REG_TIMING_DVPHO		0x3808
 | 
			
		||||
 #define OV5640_REG_TIMING_DVPVO		0x380a
 | 
			
		||||
 #define OV5640_REG_TIMING_HTS		0x380c
 | 
			
		||||
@@ -95,6 +109,20 @@
 | 
			
		||||
 #define OV5640_REG_SDE_CTRL4		0x5584
 | 
			
		||||
 #define OV5640_REG_SDE_CTRL5		0x5585
 | 
			
		||||
 #define OV5640_REG_AVG_READOUT		0x56a1
 | 
			
		||||
+#define OV5640_REG_FIRMWARE_BASE	0x8000
 | 
			
		||||
+
 | 
			
		||||
+#define OV5640_FW_STATUS_S_FIRMWARE	0x7f
 | 
			
		||||
+#define OV5640_FW_STATUS_S_STARTUP	0x7e
 | 
			
		||||
+#define OV5640_FW_STATUS_S_IDLE		0x70
 | 
			
		||||
+#define OV5640_FW_STATUS_S_FOCUSING	0x00
 | 
			
		||||
+#define OV5640_FW_STATUS_S_FOCUSED	0x10
 | 
			
		||||
+
 | 
			
		||||
+#define OV5640_FW_CMD_TRIGGER_FOCUS	0x03
 | 
			
		||||
+#define OV5640_FW_CMD_CONTINUOUS_FOCUS	0x04
 | 
			
		||||
+#define OV5640_FW_CMD_GET_FOCUS_RESULT	0x07
 | 
			
		||||
+#define OV5640_FW_CMD_RELEASE_FOCUS	0x08
 | 
			
		||||
+#define OV5640_FW_CMD_ZONE_CONFIG	0x12
 | 
			
		||||
+#define OV5640_FW_CMD_DEFAULT_ZONES	0x80
 | 
			
		||||
 
 | 
			
		||||
 enum ov5640_mode_id {
 | 
			
		||||
 	OV5640_MODE_QCIF_176_144 = 0,
 | 
			
		||||
@@ -218,6 +246,12 @@ struct ov5640_ctrls {
 | 
			
		||||
 		struct v4l2_ctrl *auto_gain;
 | 
			
		||||
 		struct v4l2_ctrl *gain;
 | 
			
		||||
 	};
 | 
			
		||||
+	struct {
 | 
			
		||||
+		struct v4l2_ctrl *focus_auto;
 | 
			
		||||
+		struct v4l2_ctrl *af_start;
 | 
			
		||||
+		struct v4l2_ctrl *af_stop;
 | 
			
		||||
+		struct v4l2_ctrl *af_status;
 | 
			
		||||
+	};
 | 
			
		||||
 	struct v4l2_ctrl *brightness;
 | 
			
		||||
 	struct v4l2_ctrl *light_freq;
 | 
			
		||||
 	struct v4l2_ctrl *saturation;
 | 
			
		||||
@@ -261,6 +295,8 @@ struct ov5640_dev {
 | 
			
		||||
 
 | 
			
		||||
 	bool pending_mode_change;
 | 
			
		||||
 	bool streaming;
 | 
			
		||||
+
 | 
			
		||||
+	bool af_initialized;
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 static inline struct ov5640_dev *to_ov5640_dev(struct v4l2_subdev *sd)
 | 
			
		||||
@@ -1967,6 +2003,118 @@ static void ov5640_reset(struct ov5640_dev *sensor)
 | 
			
		||||
 	usleep_range(20000, 25000);
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+static int ov5640_copy_fw_to_device(struct ov5640_dev *sensor,
 | 
			
		||||
+					const struct firmware *fw)
 | 
			
		||||
+{
 | 
			
		||||
+	struct i2c_client *client = sensor->i2c_client;
 | 
			
		||||
+	const u8 *data = (const u8 *)fw->data;
 | 
			
		||||
+	u8 fw_status;
 | 
			
		||||
+	int i;
 | 
			
		||||
+	int ret;
 | 
			
		||||
+
 | 
			
		||||
+	// Putting MCU in reset state
 | 
			
		||||
+	ret = ov5640_write_reg(sensor, OV5640_REG_SYS_RESET00, 0x20);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	// Write firmware
 | 
			
		||||
+	for (i = 0; i < fw->size / sizeof(u8); i++)
 | 
			
		||||
+		ov5640_write_reg(sensor,
 | 
			
		||||
+				OV5640_REG_FIRMWARE_BASE + i, 
 | 
			
		||||
+				data[i]);
 | 
			
		||||
+
 | 
			
		||||
+	// Reset MCU state
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_MAIN, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_ACK, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_PARA0, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_PARA1, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_PARA2, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_PARA3, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_CMD_PARA4, 0x00);
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_FW_STATUS, 0x7f);
 | 
			
		||||
+
 | 
			
		||||
+	// Start AF MCU
 | 
			
		||||
+	ret = ov5640_write_reg(sensor, OV5640_REG_SYS_RESET00, 0x00);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	dev_info(&client->dev, "firmware upload success\n");
 | 
			
		||||
+
 | 
			
		||||
+	// Wait for firmware to be ready
 | 
			
		||||
+	for (i = 0; i < 5; i++) {
 | 
			
		||||
+		ret = ov5640_read_reg(sensor, OV5640_REG_FW_STATUS, &fw_status);
 | 
			
		||||
+		if (fw_status == OV5640_FW_STATUS_S_IDLE) {
 | 
			
		||||
+			dev_info(&client->dev, "fw started after %d ms\n", i * 50);
 | 
			
		||||
+			return ret;
 | 
			
		||||
+		}
 | 
			
		||||
+		msleep(50);
 | 
			
		||||
+	}
 | 
			
		||||
+	dev_err(&client->dev, "uploaded firmware didn't start, got to 0x%x, retrying...\n", fw_status);
 | 
			
		||||
+
 | 
			
		||||
+	// Putting MCU in reset state
 | 
			
		||||
+	ret = ov5640_write_reg(sensor, OV5640_REG_SYS_RESET00, 0x20);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+	// Start AF MCU
 | 
			
		||||
+	ret = ov5640_write_reg(sensor, OV5640_REG_SYS_RESET00, 0x00);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+	// Wait for firmware to be ready
 | 
			
		||||
+	for (i = 0; i < 5; i++) {
 | 
			
		||||
+		ret = ov5640_read_reg(sensor, OV5640_REG_FW_STATUS, &fw_status);
 | 
			
		||||
+		if (fw_status == OV5640_FW_STATUS_S_IDLE) {
 | 
			
		||||
+			dev_info(&client->dev, "fw started after %d ms\n", i * 50);
 | 
			
		||||
+			return ret;
 | 
			
		||||
+		}
 | 
			
		||||
+		msleep(50);
 | 
			
		||||
+	}
 | 
			
		||||
+	dev_err(&client->dev, "uploaded firmware didn't start, got to 0x%x\n", fw_status);
 | 
			
		||||
+	return -ETIMEDOUT;
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
+static int ov5640_af_init(struct ov5640_dev *sensor)
 | 
			
		||||
+{
 | 
			
		||||
+	struct i2c_client *client = sensor->i2c_client;
 | 
			
		||||
+	const char* fwname = "ov5640_af.bin";
 | 
			
		||||
+	const struct firmware *fw;
 | 
			
		||||
+	int ret;
 | 
			
		||||
+
 | 
			
		||||
+	if (sensor->af_initialized) {
 | 
			
		||||
+		return 0;
 | 
			
		||||
+	}
 | 
			
		||||
+
 | 
			
		||||
+	if (firmware_request_nowarn(&fw, fwname, &client->dev) == 0) {
 | 
			
		||||
+		ret = ov5640_copy_fw_to_device(sensor, fw);
 | 
			
		||||
+		if (ret == 0)
 | 
			
		||||
+			sensor->af_initialized = 1;
 | 
			
		||||
+	} else {
 | 
			
		||||
+		dev_warn(&client->dev, "%s: no autofocus firmware available (%s)\n",
 | 
			
		||||
+			__func__, fwname);
 | 
			
		||||
+		ret = -1;
 | 
			
		||||
+	}
 | 
			
		||||
+	release_firmware(fw);
 | 
			
		||||
+
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	// Enable AF systems
 | 
			
		||||
+	ret = ov5640_mod_reg(sensor, OV5640_REG_SYS_CLOCK_ENABLE00,
 | 
			
		||||
+			     (BIT(6) | BIT(5)), (BIT(6) | BIT(5)));
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+	ret = ov5640_mod_reg(sensor, OV5640_REG_SYS_CLOCK_ENABLE01,
 | 
			
		||||
+			     BIT(6), BIT(6));
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	// Set lens focus driver on
 | 
			
		||||
+	ov5640_write_reg(sensor, OV5640_REG_VCM_CONTROL4, 0x3f);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	return ret;
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
 static int ov5640_set_power_on(struct ov5640_dev *sensor)
 | 
			
		||||
 {
 | 
			
		||||
 	struct i2c_client *client = sensor->i2c_client;
 | 
			
		||||
@@ -1988,6 +2117,8 @@ static int ov5640_set_power_on(struct ov5640_dev *sensor)
 | 
			
		||||
 		goto xclk_off;
 | 
			
		||||
 	}
 | 
			
		||||
 
 | 
			
		||||
+	sensor->af_initialized = 0;
 | 
			
		||||
+
 | 
			
		||||
 	ov5640_reset(sensor);
 | 
			
		||||
 	ov5640_power(sensor, true);
 | 
			
		||||
 
 | 
			
		||||
@@ -2416,6 +2547,35 @@ static int ov5640_set_framefmt(struct ov5640_dev *sensor,
 | 
			
		||||
 			      is_jpeg ? (BIT(5) | BIT(3)) : 0);
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+static int ov5640_fw_command(struct ov5640_dev *sensor, int command)
 | 
			
		||||
+{
 | 
			
		||||
+	u8 fw_ack;
 | 
			
		||||
+	int i;
 | 
			
		||||
+	int ret;
 | 
			
		||||
+
 | 
			
		||||
+	ret = ov5640_write_reg(sensor, OV5640_REG_FW_CMD_ACK, 0x01);
 | 
			
		||||
+	if(ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+	
 | 
			
		||||
+	ret = ov5640_write_reg(sensor, OV5640_REG_FW_CMD_MAIN, command);
 | 
			
		||||
+	if(ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	for (i = 0; i < 100; i++) {
 | 
			
		||||
+		ret = ov5640_read_reg(sensor, OV5640_REG_FW_CMD_ACK, &fw_ack);
 | 
			
		||||
+		if (ret)
 | 
			
		||||
+			return ret;
 | 
			
		||||
+
 | 
			
		||||
+		if (fw_ack == 0){
 | 
			
		||||
+			return ret;
 | 
			
		||||
+		}
 | 
			
		||||
+
 | 
			
		||||
+		msleep(50);
 | 
			
		||||
+	}
 | 
			
		||||
+	return -ETIMEDOUT;
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
+
 | 
			
		||||
 /*
 | 
			
		||||
  * Sensor Controls.
 | 
			
		||||
  */
 | 
			
		||||
@@ -2532,6 +2692,41 @@ static int ov5640_set_ctrl_exposure(struct ov5640_dev *sensor,
 | 
			
		||||
 	return ret;
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+static int ov5640_set_ctrl_focus(struct ov5640_dev *sensor, int command)
 | 
			
		||||
+{
 | 
			
		||||
+	struct i2c_client *client = sensor->i2c_client;
 | 
			
		||||
+	int ret;
 | 
			
		||||
+
 | 
			
		||||
+	ret = ov5640_af_init(sensor);
 | 
			
		||||
+	if (ret) {
 | 
			
		||||
+		dev_err(&client->dev, "%s: no autofocus firmware loaded\n",
 | 
			
		||||
+			__func__);
 | 
			
		||||
+		return 0;
 | 
			
		||||
+	}
 | 
			
		||||
+
 | 
			
		||||
+	if (command == OV5640_FW_CMD_RELEASE_FOCUS) {
 | 
			
		||||
+		dev_dbg(&client->dev, "%s: Releasing autofocus\n",
 | 
			
		||||
+			__func__);
 | 
			
		||||
+		return ov5640_fw_command(sensor, OV5640_FW_CMD_RELEASE_FOCUS);
 | 
			
		||||
+	}
 | 
			
		||||
+	
 | 
			
		||||
+	// Restart zone config
 | 
			
		||||
+	ret = ov5640_fw_command(sensor, OV5640_FW_CMD_ZONE_CONFIG);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	// Set default focus zones
 | 
			
		||||
+	ret = ov5640_fw_command(sensor, OV5640_FW_CMD_DEFAULT_ZONES);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	dev_dbg(&client->dev, "%s: Triggering autofocus\n",
 | 
			
		||||
+		__func__);
 | 
			
		||||
+
 | 
			
		||||
+	// Start focussing
 | 
			
		||||
+	return ov5640_fw_command(sensor, command);
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
 static int ov5640_set_ctrl_gain(struct ov5640_dev *sensor, bool auto_gain)
 | 
			
		||||
 {
 | 
			
		||||
 	struct ov5640_ctrls *ctrls = &sensor->ctrls;
 | 
			
		||||
@@ -2638,6 +2833,32 @@ static int ov5640_set_ctrl_vflip(struct ov5640_dev *sensor, int value)
 | 
			
		||||
 			      (BIT(2) | BIT(1)) : 0);
 | 
			
		||||
 }
 | 
			
		||||
 
 | 
			
		||||
+static int ov5640_get_af_status(struct ov5640_dev *sensor)
 | 
			
		||||
+{
 | 
			
		||||
+	u8 fw_status;
 | 
			
		||||
+	int ret;
 | 
			
		||||
+
 | 
			
		||||
+	ret = ov5640_read_reg(sensor, OV5640_REG_FW_STATUS, &fw_status);
 | 
			
		||||
+	if (ret)
 | 
			
		||||
+		return ret;
 | 
			
		||||
+
 | 
			
		||||
+	switch (fw_status) {
 | 
			
		||||
+		case OV5640_FW_STATUS_S_FIRMWARE:
 | 
			
		||||
+		case OV5640_FW_STATUS_S_STARTUP:
 | 
			
		||||
+			return V4L2_AUTO_FOCUS_STATUS_FAILED;
 | 
			
		||||
+			break;
 | 
			
		||||
+		case OV5640_FW_STATUS_S_IDLE:
 | 
			
		||||
+			return V4L2_AUTO_FOCUS_STATUS_IDLE;
 | 
			
		||||
+			break;
 | 
			
		||||
+		case OV5640_FW_STATUS_S_FOCUSED:
 | 
			
		||||
+			return V4L2_AUTO_FOCUS_STATUS_REACHED;
 | 
			
		||||
+			break;
 | 
			
		||||
+		default:
 | 
			
		||||
+			return V4L2_AUTO_FOCUS_STATUS_BUSY;
 | 
			
		||||
+			break;
 | 
			
		||||
+	}
 | 
			
		||||
+}
 | 
			
		||||
+
 | 
			
		||||
 static int ov5640_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
 | 
			
		||||
 {
 | 
			
		||||
 	struct v4l2_subdev *sd = ctrl_to_sd(ctrl);
 | 
			
		||||
@@ -2659,6 +2880,12 @@ static int ov5640_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
 | 
			
		||||
 			return val;
 | 
			
		||||
 		sensor->ctrls.exposure->val = val;
 | 
			
		||||
 		break;
 | 
			
		||||
+	case V4L2_CID_FOCUS_AUTO:
 | 
			
		||||
+		val = ov5640_get_af_status(sensor);
 | 
			
		||||
+		if (val < 0)
 | 
			
		||||
+			return val;
 | 
			
		||||
+		sensor->ctrls.af_status->val = val;
 | 
			
		||||
+		break;
 | 
			
		||||
 	}
 | 
			
		||||
 
 | 
			
		||||
 	return 0;
 | 
			
		||||
@@ -2690,6 +2917,18 @@ static int ov5640_s_ctrl(struct v4l2_ctrl *ctrl)
 | 
			
		||||
 	case V4L2_CID_AUTO_WHITE_BALANCE:
 | 
			
		||||
 		ret = ov5640_set_ctrl_white_balance(sensor, ctrl->val);
 | 
			
		||||
 		break;
 | 
			
		||||
+	case V4L2_CID_FOCUS_AUTO:
 | 
			
		||||
+		if (ctrl->val)
 | 
			
		||||
+			ret = ov5640_set_ctrl_focus(sensor, OV5640_FW_CMD_CONTINUOUS_FOCUS);
 | 
			
		||||
+		else
 | 
			
		||||
+			ret = ov5640_set_ctrl_focus(sensor, OV5640_FW_CMD_RELEASE_FOCUS);
 | 
			
		||||
+		break;
 | 
			
		||||
+	case V4L2_CID_AUTO_FOCUS_START:
 | 
			
		||||
+		ret = ov5640_set_ctrl_focus(sensor, OV5640_FW_CMD_TRIGGER_FOCUS);
 | 
			
		||||
+		break;
 | 
			
		||||
+	case V4L2_CID_AUTO_FOCUS_STOP:
 | 
			
		||||
+		ret = ov5640_set_ctrl_focus(sensor, OV5640_FW_CMD_RELEASE_FOCUS);
 | 
			
		||||
+		break;
 | 
			
		||||
 	case V4L2_CID_HUE:
 | 
			
		||||
 		ret = ov5640_set_ctrl_hue(sensor, ctrl->val);
 | 
			
		||||
 		break;
 | 
			
		||||
@@ -2762,6 +3001,20 @@ static int ov5640_init_controls(struct ov5640_dev *sensor)
 | 
			
		||||
 	ctrls->gain = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_GAIN,
 | 
			
		||||
 					0, 1023, 1, 0);
 | 
			
		||||
 
 | 
			
		||||
+	/* Autofocus */
 | 
			
		||||
+	ctrls->focus_auto = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_FOCUS_AUTO,
 | 
			
		||||
+					    0, 1, 1, 0);
 | 
			
		||||
+	ctrls->af_start = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_AUTO_FOCUS_START,
 | 
			
		||||
+					    0, 1, 1, 0);
 | 
			
		||||
+	ctrls->af_stop = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_AUTO_FOCUS_STOP,
 | 
			
		||||
+					   0, 1, 1, 0);
 | 
			
		||||
+	ctrls->af_status = v4l2_ctrl_new_std(hdl, ops,
 | 
			
		||||
+					     V4L2_CID_AUTO_FOCUS_STATUS, 0,
 | 
			
		||||
+					     (V4L2_AUTO_FOCUS_STATUS_BUSY |
 | 
			
		||||
+					      V4L2_AUTO_FOCUS_STATUS_REACHED |
 | 
			
		||||
+					      V4L2_AUTO_FOCUS_STATUS_FAILED),
 | 
			
		||||
+					     0, V4L2_AUTO_FOCUS_STATUS_IDLE);
 | 
			
		||||
+
 | 
			
		||||
 	ctrls->saturation = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_SATURATION,
 | 
			
		||||
 					      0, 255, 1, 64);
 | 
			
		||||
 	ctrls->hue = v4l2_ctrl_new_std(hdl, ops, V4L2_CID_HUE,
 | 
			
		||||
@@ -2795,6 +3048,7 @@ static int ov5640_init_controls(struct ov5640_dev *sensor)
 | 
			
		||||
 	v4l2_ctrl_auto_cluster(3, &ctrls->auto_wb, 0, false);
 | 
			
		||||
 	v4l2_ctrl_auto_cluster(2, &ctrls->auto_gain, 0, true);
 | 
			
		||||
 	v4l2_ctrl_auto_cluster(2, &ctrls->auto_exp, 1, true);
 | 
			
		||||
+	v4l2_ctrl_cluster(4, &ctrls->focus_auto);
 | 
			
		||||
 
 | 
			
		||||
 	sensor->sd.ctrl_handler = hdl;
 | 
			
		||||
 	return 0;
 | 
			
		||||
-- 
 | 
			
		||||
2.25.4
 | 
			
		||||
 | 
			
		||||
@@ -1,12 +0,0 @@
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
index 1c555456b..05fab5d79 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinephone.dtsi
 | 
			
		||||
@@ -78,6 +78,7 @@ green {
 | 
			
		||||
 		};
 | 
			
		||||
 
 | 
			
		||||
 		red {
 | 
			
		||||
+			linux,default-trigger = "panic";
 | 
			
		||||
 			function = LED_FUNCTION_INDICATOR;
 | 
			
		||||
 			color = <LED_COLOR_ID_RED>;
 | 
			
		||||
 			gpios = <&pio 3 19 GPIO_ACTIVE_HIGH>; /* PD19 */
 | 
			
		||||
@@ -1,21 +0,0 @@
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
index a72c2ec8c..b3a7bef13 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
@@ -227,7 +227,15 @@ &i2c0_pins {
 | 
			
		||||
 &i2c1 {
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 
 | 
			
		||||
-	/* TODO: add Bochs BMA223 accelerometer here */
 | 
			
		||||
+	bma223@18 {
 | 
			
		||||
+		compatible = "bosch,bma223", "bosch,bma222e";
 | 
			
		||||
+		reg = <0x18>;
 | 
			
		||||
+		interrupt-parent = <&pio>;
 | 
			
		||||
+		interrupts = <7 5 IRQ_TYPE_LEVEL_HIGH>; /* PH5 */
 | 
			
		||||
+		mount-matrix = "0", "-1", "0",
 | 
			
		||||
+			       "-1", "0", "0",
 | 
			
		||||
+			       "0", "0", "-1";
 | 
			
		||||
+	};
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
 &lradc {
 | 
			
		||||
@@ -1,44 +0,0 @@
 | 
			
		||||
From 330d05da1b6e8118c9c4655f0b234cf32a2f1ce4 Mon Sep 17 00:00:00 2001
 | 
			
		||||
From: Icenowy Zheng <icenowy@aosc.io>
 | 
			
		||||
Date: Sun, 14 Apr 2019 23:46:47 +0800
 | 
			
		||||
Subject: [PATCH] arm64: allwinner: a64: pinetab: enable RTL8723CS bluetooth
 | 
			
		||||
 | 
			
		||||
PineTab has a RTL8723CS Wi-Fi/BT combo chip on board, the bluetooth part
 | 
			
		||||
of it communicates with A64 via UART, and the power of it is controlled
 | 
			
		||||
with some GPIO at PL bank.
 | 
			
		||||
 | 
			
		||||
Enable the bluetooth in the device tree.
 | 
			
		||||
 | 
			
		||||
Signed-off-by: Icenowy Zheng <icenowy@aosc.io>
 | 
			
		||||
---
 | 
			
		||||
 .../boot/dts/allwinner/sun50i-a64-pinetab.dts      | 14 ++++++++++++++
 | 
			
		||||
 1 file changed, 14 insertions(+)
 | 
			
		||||
 | 
			
		||||
diff --git a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
index 84d6e8cb2b88..e8b823875740 100644
 | 
			
		||||
--- a/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
+++ b/arch/arm64/boot/dts/allwinner/sun50i-a64-pinetab.dts
 | 
			
		||||
@@ -447,6 +447,20 @@ &uart0 {
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
 };
 | 
			
		||||
 
 | 
			
		||||
+&uart1 {
 | 
			
		||||
+	pinctrl-names = "default";
 | 
			
		||||
+	pinctrl-0 = <&uart1_pins>, <&uart1_rts_cts_pins>;
 | 
			
		||||
+	status = "okay";
 | 
			
		||||
+
 | 
			
		||||
+	bluetooth {
 | 
			
		||||
+		compatible = "realtek,rtl8723cs-bt";
 | 
			
		||||
+		reset-gpios = <&r_pio 0 4 GPIO_ACTIVE_LOW>; /* PL4 */
 | 
			
		||||
+		device-wake-gpios = <&r_pio 0 5 GPIO_ACTIVE_LOW>; /* PL5 */
 | 
			
		||||
+		host-wake-gpios = <&r_pio 0 6 GPIO_ACTIVE_HIGH>; /* PL6 */
 | 
			
		||||
+		firmware-postfix = "pinebook";
 | 
			
		||||
+	};
 | 
			
		||||
+};
 | 
			
		||||
+
 | 
			
		||||
 &usb_otg {
 | 
			
		||||
 	dr_mode = "otg";
 | 
			
		||||
 	status = "okay";
 | 
			
		||||
-- 
 | 
			
		||||
GitLab
 | 
			
		||||
 | 
			
		||||
@@ -1,65 +0,0 @@
 | 
			
		||||
# Copyright 1999-2020 Gentoo Authors
 | 
			
		||||
# Distributed under the terms of the GNU General Public License v2
 | 
			
		||||
 | 
			
		||||
EAPI="6"
 | 
			
		||||
K_NOUSENAME="yes"
 | 
			
		||||
K_NOSETEXTRAVERSION="yes"
 | 
			
		||||
K_SECURITY_UNSUPPORTED="1"
 | 
			
		||||
ETYPE="sources"
 | 
			
		||||
inherit kernel-2
 | 
			
		||||
detect_version
 | 
			
		||||
 | 
			
		||||
DESCRIPTION="Full sources for the Linux kernel, with megi's patch for pinephone"
 | 
			
		||||
HOMEPAGE="https://www.kernel.org"
 | 
			
		||||
 | 
			
		||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sparc ~x86"
 | 
			
		||||
MEGI_PATCH_URI="https://xff.cz/kernels/${PV:0:4}/patches/all.patch"
 | 
			
		||||
SRC_URI="${KERNEL_URI} ${MEGI_PATCH_URI} -> all-${PV}.patch"
 | 
			
		||||
 | 
			
		||||
PATCHES=(
 | 
			
		||||
    ${DISTDIR}/all-${PV}.patch
 | 
			
		||||
    ${FILESDIR}/enable-hdmi-output-pinetab.patch
 | 
			
		||||
    ${FILESDIR}/enable-jack-detection-pinetab.patch
 | 
			
		||||
    ${FILESDIR}/pinetab-bluetooth.patch
 | 
			
		||||
    ${FILESDIR}/pinetab-accelerometer.patch
 | 
			
		||||
	${FILESDIR}/dts-pinephone-drop-modem-power-node.patch
 | 
			
		||||
	${FILESDIR}/dts-headphone-jack-detection.patch
 | 
			
		||||
	${FILESDIR}/media-ov5640-Implement-autofocus.patch
 | 
			
		||||
	${FILESDIR}/0011-dts-pinetab-hardcode-mmc-numbers.patch
 | 
			
		||||
	${FILESDIR}/0002-dts-add-pinetab-dev-old-display-panel.patch
 | 
			
		||||
	${FILESDIR}/0010-dts-pinephone-Add-pine64-pinephone-to-compat-list.patch
 | 
			
		||||
	${FILESDIR}/0012-pinephone-fix-pogopin-i2c.patch
 | 
			
		||||
	${FILESDIR}/0107-quirk-kernel-org-bug-210681-firmware_rome_error.patch
 | 
			
		||||
	${FILESDIR}/0177-leds-gpio-make-max_brightness-configurable.patch
 | 
			
		||||
	${FILESDIR}/0178-sun8i-codec-fix-headphone-jack-pin-name.patch
 | 
			
		||||
	${FILESDIR}/0179-arm64-dts-allwinner-pinephone-improve-device-tree.patch
 | 
			
		||||
    ${FILESDIR}/panic-led.patch
 | 
			
		||||
    ${FILESDIR}/PATCH-1-4-HID-magicmouse-add-Apple-Magic-Mouse-2-support.patch
 | 
			
		||||
    ${FILESDIR}/PATCH-2-4-HID-magicmouse-fix-3-button-emulation-of-Mouse-2.patch
 | 
			
		||||
    ${FILESDIR}/PATCH-3-4-HID-magicmouse-fix-reconnection-of-Magic-Mouse-2.patch
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
src_prepare() {
 | 
			
		||||
	default
 | 
			
		||||
	eapply_user
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_postinst() {
 | 
			
		||||
	kernel-2_pkg_postinst
 | 
			
		||||
	einfo "For more info on this patchset, and how to report problems, see:"
 | 
			
		||||
	einfo "${HOMEPAGE}"
 | 
			
		||||
	einfo "To build the kernel use the following command:"
 | 
			
		||||
	einfo "make Image Image.gz modules"
 | 
			
		||||
	einfo "make DTC_FLAGS="-@" dtbs"
 | 
			
		||||
	einfo "make install; make modules_intall; make dtbs_install"
 | 
			
		||||
	einfo "If you use kernel config coming with this ebuild, don't forget to also copy dracut-pp.conf to /etc/dracut.conf.d/"
 | 
			
		||||
	einfo "to make sure proper kernel modules are loaded into initramfs"
 | 
			
		||||
	einfo "if you want to cross compile pinephone kernel on amd64 host, follow the https://wiki.gentoo.org/wiki/Cross_build_environment"
 | 
			
		||||
	einfo "to setup cross toolchain environment, then create a xmake wrapper like the following, and replace make with xmake in above commands"
 | 
			
		||||
	einfo "#!/bin/sh"
 | 
			
		||||
	einfo "exec make ARCH='arm64' CROSS_COMPILE='aarch64-unknown-linux-gnu-' INSTALL_MOD_PATH='${SYSROOT}' '$@'"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
pkg_postrm() {
 | 
			
		||||
	kernel-2_pkg_postrm
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user