git: 19c804b74f67 - main - bcm5974(4): Make Magic Trackpad 2 support endian-safe.

From: Vladimir Kondratyev <wulf_at_FreeBSD.org>
Date: Tue, 25 Apr 2023 09:21:58 UTC
The branch main has been updated by wulf:

URL: https://cgit.FreeBSD.org/src/commit/?id=19c804b74f67b08aad6315c0f47839d56e52caa5

commit 19c804b74f67b08aad6315c0f47839d56e52caa5
Author:     Vladimir Kondratyev <wulf@FreeBSD.org>
AuthorDate: 2023-04-25 09:20:53 +0000
Commit:     Vladimir Kondratyev <wulf@FreeBSD.org>
CommitDate: 2023-04-25 09:20:53 +0000

    bcm5974(4): Make Magic Trackpad 2 support endian-safe.
    
    While here make touch orientation event matching with Linux
    
    MFC after:      1 month
---
 sys/dev/hid/bcm5974.c | 37 +++++++++++++------------------------
 1 file changed, 13 insertions(+), 24 deletions(-)

diff --git a/sys/dev/hid/bcm5974.c b/sys/dev/hid/bcm5974.c
index dc0edc8dd27d..b403aa115523 100644
--- a/sys/dev/hid/bcm5974.c
+++ b/sys/dev/hid/bcm5974.c
@@ -167,23 +167,11 @@ struct tp_finger_compact {
 	uint8_t touch_minor;
 	uint8_t size;
 	uint8_t pressure;
-	unsigned int orientation: 3;
-	unsigned int _unknown1: 1;
-	unsigned int id: 4;
+	uint8_t id_ori;
 } __packed;
 
 _Static_assert((sizeof(struct tp_finger_compact) == 9), "tp_finger struct size must be 9");
 
-union tp_finger_compact_coords {
-	uint32_t num;
-	struct {
-		signed int x: 13;
-		signed int y: 13;
-		signed int _unknown: 4;
-		signed int state: 2;
-	} __packed;
-};
-
 /* trackpad finger structure - little endian */
 struct tp_finger {
 	uint16_t	origin;		/* zero when switching track finger */
@@ -381,8 +369,7 @@ static const struct bcm5974_dev_params bcm5974_dev_params[BCM5974_FLAG_MAX] = {
 		.w = { SN_WIDTH, 0, 2048, 0 },
 		.x = { SN_COORD, -3678, 3934, 48 },
 		.y = { SN_COORD, -2478, 2587, 44 },
-		.o = { SN_ORIENT,
-		    -MAX_FINGER_ORIENTATION, MAX_FINGER_ORIENTATION, 0 },
+		.o = { SN_ORIENT, -3, 4, 0 },
 	},
 };
 
@@ -744,7 +731,7 @@ bcm5974_intr(void *context, void *data, hid_size_t len)
 	union evdev_mt_slot slot_data;
 	struct tp_finger *f;
 	struct tp_finger_compact *fc;
-	union tp_finger_compact_coords coords;
+	int coords;
 	int ntouch;			/* the finger number in touch */
 	int ibt;			/* button status */
 	int i;
@@ -768,24 +755,26 @@ bcm5974_intr(void *context, void *data, hid_size_t len)
 		if ((params->tp->caps & USES_COMPACT_REPORT) != 0) {
 			fc = (struct tp_finger_compact *)(((uint8_t *)data) +
 			     params->tp->offset + params->tp->delta + i * fsize);
-			coords.num = le32toh(fc->coords);
+			coords = (int)le32toh(fc->coords);
 			DPRINTFN(BCM5974_LLEVEL_INFO,
 			    "[%d]ibt=%d, taps=%d, x=%5d, y=%5d, state=%4d, "
 			    "tchmaj=%4d, tchmin=%4d, size=%4d, pressure=%4d, "
 			    "ot=%4x, id=%4x\n",
-			    i, ibt, ntouch, coords.x, coords.y,
-			    fc->state, fc->touch_major, fc->touch_minor, fc->size,
-			    fc->pressure, fc->orientation, fc->id);
+			    i, ibt, ntouch, coords << 19 >> 19,
+			    coords << 6 >> 19, (u_int)coords >> 30,
+			    fc->touch_major, fc->touch_minor, fc->size,
+			    fc->pressure, fc->id_ori >> 5, fc->id_ori & 0x0f);
 			if (fc->touch_major == 0)
 				continue;
 			slot_data = (union evdev_mt_slot) {
-				.id = fc->id,
-				.x = coords.x,
-				.y = params->y.min + params->y.max - coords.y,
+				.id = fc->id_ori & 0x0f,
+				.x = coords << 19 >> 19,
+				.y = params->y.min + params->y.max -
+				    ((coords << 6) >> 19),
 				.p = fc->pressure,
 				.maj = fc->touch_major << 2,
 				.min = fc->touch_minor << 2,
-				.ori = -fc->orientation,
+				.ori = (int)(fc->id_ori >> 5) - 4,
 			};
 			evdev_mt_push_slot(sc->sc_evdev, slot, &slot_data);
 			slot++;