From: Daniel Stone <daniel.stone@xxxxxxxxxxxxxxx> Signed-off-by: Derek Foreman <derek.foreman@xxxxxxxxxxxxxxx> --- drivers/input/mouse/synaptics.c | 35 ++++++++++++++++++++++++++--------- drivers/input/mouse/synaptics.h | 2 ++ 2 files changed, 28 insertions(+), 9 deletions(-) diff --git a/drivers/input/mouse/synaptics.c b/drivers/input/mouse/synaptics.c index 40748e3..3c68663 100644 --- a/drivers/input/mouse/synaptics.c +++ b/drivers/input/mouse/synaptics.c @@ -162,6 +162,11 @@ static int synaptics_capability(struct psmouse *psmouse) } else { priv->ext_cap = (cap[0] << 16) | (cap[1] << 8) | cap[2]; + if (priv->model_id == 0x1e2b1) + priv->use_bounding_box = 0; + else + priv->use_bounding_box = 1; + /* * if nExtBtn is greater than 8 it should be considered * invalid and treated as 0 @@ -485,7 +490,8 @@ static int synaptics_parse_hw_state(const unsigned char buf[], return 0; } -static void set_slot(struct input_dev *dev, int slot, bool active, int x, int y) +static void set_slot(struct input_dev *dev, int slot, bool active, int x, int y, + int z) { input_mt_slot(dev, slot); input_mt_report_slot_state(dev, MT_TOOL_FINGER, active); @@ -493,23 +499,30 @@ static void set_slot(struct input_dev *dev, int slot, bool active, int x, int y) input_report_abs(dev, ABS_MT_POSITION_X, x); input_report_abs(dev, ABS_MT_POSITION_Y, YMAX_NOMINAL + YMIN_NOMINAL - y); + input_report_abs(dev, ABS_MT_PRESSURE, z); } } static void synaptics_report_semi_mt_data(struct input_dev *dev, + struct synaptics_data *priv, const struct synaptics_hw_state *a, const struct synaptics_hw_state *b, int num_fingers) { - if (num_fingers >= 2) { - set_slot(dev, 0, true, min(a->x, b->x), min(a->y, b->y)); - set_slot(dev, 1, true, max(a->x, b->x), max(a->y, b->y)); + if (num_fingers >= 2 && priv->use_bounding_box) { + set_slot(dev, 0, true, min(a->x, b->x), min(a->y, b->y), + min(a->z, b->z)); + set_slot(dev, 1, true, max(a->x, b->x), max(a->y, b->y), + max(a->z, b->z)); + } else if (num_fingers >= 2) { + set_slot(dev, 0, true, a->x, a->y, a->z); + set_slot(dev, 1, true, b->x, b->y, b->z); } else if (num_fingers == 1) { - set_slot(dev, 0, true, a->x, a->y); - set_slot(dev, 1, false, 0, 0); + set_slot(dev, 0, true, a->x, a->y, a->z); + set_slot(dev, 1, false, 0, 0, 0); } else { - set_slot(dev, 0, false, 0, 0); - set_slot(dev, 1, false, 0, 0); + set_slot(dev, 0, false, 0, 0, 0); + set_slot(dev, 1, false, 0, 0, 0); } } @@ -573,7 +586,8 @@ static void synaptics_process_packet(struct psmouse *psmouse) } if (SYN_CAP_ADV_GESTURE(priv->ext_cap_0c)) - synaptics_report_semi_mt_data(dev, &hw, &priv->mt, num_fingers); + synaptics_report_semi_mt_data(dev, priv, &hw, &priv->mt, + num_fingers); /* Post events * BTN_TOUCH has to be first as mousedev relies on it when doing @@ -702,6 +716,7 @@ static void set_input_params(struct input_dev *dev, struct synaptics_data *priv) priv->x_max ?: XMAX_NOMINAL, 0, 0); input_set_abs_params(dev, ABS_MT_POSITION_Y, YMIN_NOMINAL, priv->y_max ?: YMAX_NOMINAL, 0, 0); + input_set_abs_params(dev, ABS_MT_PRESSURE, 0, 255, 0, 0); } if (SYN_CAP_PALMDETECT(priv->capabilities)) @@ -736,6 +751,8 @@ static void set_input_params(struct input_dev *dev, struct synaptics_data *priv) input_abs_set_res(dev, ABS_X, priv->x_res); input_abs_set_res(dev, ABS_Y, priv->y_res); + input_abs_set_res(dev, ABS_MT_POSITION_X, priv->x_res); + input_abs_set_res(dev, ABS_MT_POSITION_Y, priv->y_res); if (SYN_CAP_CLICKPAD(priv->ext_cap_0c)) { __set_bit(INPUT_PROP_BUTTONPAD, dev->propbit); diff --git a/drivers/input/mouse/synaptics.h b/drivers/input/mouse/synaptics.h index 7453938..9a2b0a7 100644 --- a/drivers/input/mouse/synaptics.h +++ b/drivers/input/mouse/synaptics.h @@ -136,6 +136,8 @@ struct synaptics_data { unsigned char mode; /* current mode byte */ int scroll; + unsigned int use_bounding_box:1; /* report bounding box for MT */ + struct serio *pt_port; /* Pass-through serio port */ struct synaptics_hw_state mt; /* current gesture packet */ -- 1.7.5.3 -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html