qt: Actually fix vJoy integer overflow issue
This commit is contained in:
@@ -98,8 +98,6 @@ joystick_add_button(raw_joystick_t *rawjoy, plat_joystick_t *joy, USAGE usage)
|
|||||||
void
|
void
|
||||||
joystick_add_axis(raw_joystick_t *rawjoy, plat_joystick_t *joy, PHIDP_VALUE_CAPS prop)
|
joystick_add_axis(raw_joystick_t *rawjoy, plat_joystick_t *joy, PHIDP_VALUE_CAPS prop)
|
||||||
{
|
{
|
||||||
LONG center;
|
|
||||||
|
|
||||||
if (joy->nr_axes >= 8)
|
if (joy->nr_axes >= 8)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -139,14 +137,11 @@ joystick_add_axis(raw_joystick_t *rawjoy, plat_joystick_t *joy, PHIDP_VALUE_CAPS
|
|||||||
* Some joysticks will send -1 in LogicalMax, like Xbox Controllers
|
* Some joysticks will send -1 in LogicalMax, like Xbox Controllers
|
||||||
* so we need to mask that to appropriate value (instead of 0xFFFFFFFF)
|
* so we need to mask that to appropriate value (instead of 0xFFFFFFFF)
|
||||||
*/
|
*/
|
||||||
rawjoy->axis[joy->nr_axes].max = prop->LogicalMax & ((1 << prop->BitSize) - 1);
|
rawjoy->axis[joy->nr_axes].max = prop->LogicalMax & ((1ULL << prop->BitSize) - 1);
|
||||||
}
|
}
|
||||||
rawjoy->axis[joy->nr_axes].min = prop->LogicalMin;
|
rawjoy->axis[joy->nr_axes].min = prop->LogicalMin;
|
||||||
|
|
||||||
center = (rawjoy->axis[joy->nr_axes].max - rawjoy->axis[joy->nr_axes].min + 1) / 2;
|
joy->nr_axes++;
|
||||||
|
|
||||||
if (center != 0x00)
|
|
||||||
joy->nr_axes++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|||||||
Reference in New Issue
Block a user