diff options
-rw-r--r-- | drivers/hid/hid-3m-pct.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/drivers/hid/hid-3m-pct.c b/drivers/hid/hid-3m-pct.c index 39628e02a428..02d8cd3b1b1b 100644 --- a/drivers/hid/hid-3m-pct.c +++ b/drivers/hid/hid-3m-pct.c | |||
@@ -166,16 +166,18 @@ static void mmm_filter_event(struct mmm_data *md, struct input_dev *input) | |||
166 | if (f->touch) { | 166 | if (f->touch) { |
167 | /* this finger is on the screen */ | 167 | /* this finger is on the screen */ |
168 | int wide = (f->w > f->h); | 168 | int wide = (f->w > f->h); |
169 | /* divided by two to match visual scale of touch */ | ||
170 | int major = max(f->w, f->h) >> 1; | ||
171 | int minor = min(f->w, f->h) >> 1; | ||
172 | |||
169 | if (!f->prev_touch) | 173 | if (!f->prev_touch) |
170 | f->id = md->id++; | 174 | f->id = md->id++; |
171 | input_event(input, EV_ABS, ABS_MT_TRACKING_ID, f->id); | 175 | input_event(input, EV_ABS, ABS_MT_TRACKING_ID, f->id); |
172 | input_event(input, EV_ABS, ABS_MT_POSITION_X, f->x); | 176 | input_event(input, EV_ABS, ABS_MT_POSITION_X, f->x); |
173 | input_event(input, EV_ABS, ABS_MT_POSITION_Y, f->y); | 177 | input_event(input, EV_ABS, ABS_MT_POSITION_Y, f->y); |
174 | input_event(input, EV_ABS, ABS_MT_ORIENTATION, wide); | 178 | input_event(input, EV_ABS, ABS_MT_ORIENTATION, wide); |
175 | input_event(input, EV_ABS, ABS_MT_TOUCH_MAJOR, | 179 | input_event(input, EV_ABS, ABS_MT_TOUCH_MAJOR, major); |
176 | wide ? f->w : f->h); | 180 | input_event(input, EV_ABS, ABS_MT_TOUCH_MINOR, minor); |
177 | input_event(input, EV_ABS, ABS_MT_TOUCH_MINOR, | ||
178 | wide ? f->h : f->w); | ||
179 | /* touchscreen emulation: pick the oldest contact */ | 181 | /* touchscreen emulation: pick the oldest contact */ |
180 | if (!oldest || ((f->id - oldest->id) & (SHRT_MAX + 1))) | 182 | if (!oldest || ((f->id - oldest->id) & (SHRT_MAX + 1))) |
181 | oldest = f; | 183 | oldest = f; |