2017-03-30 17:53:36 +02:00
/****************************************************************************
* Copyright ( C ) 2016 , 2017 Maschell
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2017-05-07 14:44:09 +02:00
# include "ControllerPatcherUtils.hpp"
2017-03-30 17:53:36 +02:00
# include <math.h>
# include <string.h>
2017-10-29 09:34:47 +01:00
# include <utils/logger.h>
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getDataByHandle ( int32_t handle , my_cb_user * * data ) {
for ( int32_t i = 0 ; i < gHIDMaxDevices ; i + + ) {
for ( int32_t j = 0 ; j < 4 ; j + + ) {
2020-12-16 02:04:31 +01:00
//log_printf("%d %d %d %d",i,j,gHID_Devices[i].pad_data[j].handle,(uint32_t)handle);
2023-04-10 11:45:58 +02:00
if ( gHID_Devices [ i ] . pad_data [ j ] . handle = = ( uint32_t ) handle ) {
2017-03-30 17:53:36 +02:00
* data = gHID_Devices [ i ] . pad_data [ j ] . user_data ;
return CONTROLLER_PATCHER_ERROR_NONE ;
}
}
}
return CONTROLLER_PATCHER_ERROR_UNKNOWN ;
}
/*----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
* Analyse inputs
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getButtonPressed ( HID_Data * data , int32_t * buttons_hold , int32_t VPADButton ) {
if ( data = = NULL | | buttons_hold = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t deviceslot = data - > slotdata . deviceslot ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t result = - 1 ;
2017-03-30 17:53:36 +02:00
2018-06-19 17:46:37 +02:00
do {
2023-04-10 11:45:58 +02:00
if ( data - > type = = DEVICE_TYPE_MOUSE ) {
HID_Mouse_Data * ms_data = & data - > data_union . mouse . cur_mouse_data ;
if ( ms_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
if ( gHID_Mouse_Mode = = HID_MOUSE_MODE_TOUCH ) {
if ( VPADButton = = VPAD_BUTTON_TOUCH ) {
if ( ms_data - > left_click & 0x01 ) {
2018-06-19 17:46:37 +02:00
result = 1 ;
break ;
2017-03-30 17:53:36 +02:00
}
}
2023-04-10 11:45:58 +02:00
} else if ( gHID_Mouse_Mode = = HID_MOUSE_MODE_AIM ) {
if ( config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_LEFT ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
if ( VPADButton = = ( int ) gGamePadValues [ config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_LEFT ] [ 1 ] ] ) {
if ( ms_data - > left_click & 0x01 ) {
2018-06-19 17:46:37 +02:00
result = 1 ;
break ;
2017-03-30 17:53:36 +02:00
}
}
}
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_RIGHT ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
if ( VPADButton = = ( int ) gGamePadValues [ config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_RIGHT ] [ 1 ] ] ) {
if ( ms_data - > right_click & 0x01 ) {
2018-06-19 17:46:37 +02:00
result = 1 ;
break ;
2017-03-30 17:53:36 +02:00
}
}
}
}
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
uint8_t * cur_data = & data - > data_union . controller . cur_hid_data [ 0 ] ;
if ( cur_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t cur_config = 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( VPADButton = = VPAD_BUTTON_A ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_A ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_B ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_B ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_X ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_X ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_Y ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_Y ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_L ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_L ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_R ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_R ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_ZL ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_ZL ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_ZR ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_ZR ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_STICK_L ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_STICK_L ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_STICK_R ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_STICK_R ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_PLUS ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_PLUS ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_MINUS ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_MINUS ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_HOME ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_HOME ;
}
//! Special DPAD treatment.
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_DPAD_MODE ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
if ( config_controller [ deviceslot ] [ CONTRPS_DPAD_MODE ] [ 1 ] = = CONTRPDM_Hat ) {
2018-06-20 15:07:15 +02:00
uint8_t mask = 0x0F ;
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_DPAD_MASK ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
2018-06-19 17:46:37 +02:00
mask = config_controller [ deviceslot ] [ CONTRPS_DPAD_MASK ] [ 1 ] ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
if ( cur_data [ config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NEUTRAL ] [ 0 ] ] ! = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NEUTRAL ] [ 1 ] ) { // Not neutral
uint8_t dir1_0 = 0 , dir1_1 = 0 ;
uint8_t dir2_0 = 0 , dir2_1 = 0 ;
uint8_t dir3_0 = 0 , dir3_1 = 0 ;
2018-06-20 15:07:15 +02:00
uint8_t direction = 0 ;
2023-04-10 11:45:58 +02:00
if ( VPADButton = = VPAD_BUTTON_LEFT ) {
dir1_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_W ] [ 0 ] ;
dir2_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NW ] [ 0 ] ;
dir3_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SW ] [ 0 ] ;
dir1_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_W ] [ 1 ] ;
dir2_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NW ] [ 1 ] ;
dir3_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SW ] [ 1 ] ;
2017-03-30 17:53:36 +02:00
direction = 1 ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_RIGHT ) {
dir1_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_E ] [ 0 ] ;
dir2_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SE ] [ 0 ] ;
dir3_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NE ] [ 0 ] ;
dir1_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_E ] [ 1 ] ;
dir2_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SE ] [ 1 ] ;
dir3_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NE ] [ 1 ] ;
2017-03-30 17:53:36 +02:00
direction = 1 ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_DOWN ) {
dir1_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_S ] [ 0 ] ;
dir2_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SE ] [ 0 ] ;
dir3_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SW ] [ 0 ] ;
dir1_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_S ] [ 1 ] ;
dir2_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SE ] [ 1 ] ;
dir3_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_SW ] [ 1 ] ;
2017-03-30 17:53:36 +02:00
direction = 1 ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_UP ) {
dir1_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_N ] [ 0 ] ;
dir2_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NW ] [ 0 ] ;
dir3_0 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NE ] [ 0 ] ;
dir1_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_N ] [ 1 ] ;
dir2_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NW ] [ 1 ] ;
dir3_1 = config_controller [ deviceslot ] [ CONTRPS_VPAD_BUTTON_DPAD_NE ] [ 1 ] ;
2017-03-30 17:53:36 +02:00
direction = 1 ;
}
2023-04-10 11:45:58 +02:00
if ( direction & & ( ( ( cur_data [ dir1_0 ] & mask ) = = dir1_1 ) | |
( ( cur_data [ dir2_0 ] & mask ) = = dir2_1 ) | |
( ( cur_data [ dir3_0 ] & mask ) = = dir3_1 ) ) ) {
2018-06-19 17:46:37 +02:00
result = 1 ;
break ;
}
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
} else if ( config_controller [ deviceslot ] [ CONTRPS_DPAD_MODE ] [ 1 ] = = CONTRPDM_Absolute_2Values ) {
2018-06-20 15:07:15 +02:00
int32_t contrps_value = 0 ;
2023-04-10 11:45:58 +02:00
if ( VPADButton = = VPAD_BUTTON_LEFT ) {
2017-03-30 17:53:36 +02:00
contrps_value = CONTRPS_VPAD_BUTTON_DPAD_ABS_LEFT ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_RIGHT ) {
2017-03-30 17:53:36 +02:00
contrps_value = CONTRPS_VPAD_BUTTON_DPAD_ABS_RIGHT ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_UP ) {
2017-03-30 17:53:36 +02:00
contrps_value = CONTRPS_VPAD_BUTTON_DPAD_ABS_UP ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_DOWN ) {
2017-03-30 17:53:36 +02:00
contrps_value = CONTRPS_VPAD_BUTTON_DPAD_ABS_DOWN ;
}
2023-04-10 11:45:58 +02:00
if ( contrps_value ! = 0 ) {
2018-06-20 15:07:15 +02:00
int32_t value_byte = CONTROLLER_PATCHER_INVALIDVALUE ;
2023-04-10 11:45:58 +02:00
if ( ( value_byte = config_controller [ deviceslot ] [ contrps_value ] [ 0 ] ) ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
if ( cur_data [ config_controller [ deviceslot ] [ contrps_value ] [ 0 ] ] = = config_controller [ deviceslot ] [ contrps_value ] [ 1 ] ) {
2017-03-30 17:53:36 +02:00
result = 1 ;
break ;
}
}
}
}
}
//! Normal DPAD treatment.
2023-04-10 11:45:58 +02:00
if ( VPADButton = = VPAD_BUTTON_LEFT ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_LEFT ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_RIGHT ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_RIGHT ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_DOWN ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_DOWN ;
2023-04-10 11:45:58 +02:00
} else if ( VPADButton = = VPAD_BUTTON_UP ) {
2017-03-30 17:53:36 +02:00
cur_config = CONTRPS_VPAD_BUTTON_UP ;
}
2023-04-10 11:45:58 +02:00
if ( result & & config_controller [ deviceslot ] [ CONTRPS_DOUBLE_USE ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
if ( config_controller [ deviceslot ] [ CONTRPS_DOUBLE_USE ] [ 1 ] = = CONTROLLER_PATCHER_GC_DOUBLE_USE ) {
if ( cur_data [ config_controller [ deviceslot ] [ CONTRPS_DOUBLE_USE_BUTTON_ACTIVATOR ] [ 0 ] ] & config_controller [ deviceslot ] [ CONTRPS_DOUBLE_USE_BUTTON_ACTIVATOR ] [ 1 ] ) {
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_1_RELEASED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_2_RELEASED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_3_RELEASED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_4_RELEASED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_5_RELEASED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
} else {
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_1_PRESSED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_2_PRESSED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_3_PRESSED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_4_PRESSED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2023-04-10 11:45:58 +02:00
if ( checkValueinConfigController ( deviceslot , CONTRPS_DOUBLE_USE_BUTTON_5_PRESSED , cur_config ) ) {
2018-06-19 17:46:37 +02:00
result = 0 ;
break ;
}
2017-03-30 17:53:36 +02:00
}
}
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , cur_config ) = = 1 ) {
2018-06-19 17:46:37 +02:00
result = 1 ;
break ;
} else {
2020-12-16 02:04:31 +01:00
//log_printf("Invalid data! deviceslot(slot): %d config: %d",deviceslot,cur_config);
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
} while ( 0 ) ; //The break will become handy ;)
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( result = = 1 ) {
2017-03-30 17:53:36 +02:00
* buttons_hold | = VPADButton ; // -1 would be also true.
return 1 ;
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : isValueSet ( HID_Data * data , int32_t cur_config ) {
if ( data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
uint8_t * cur_data = & data - > data_union . controller . cur_hid_data [ 0 ] ;
if ( cur_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
uint32_t hidmask = data - > slotdata . hidmask ;
2018-06-20 15:07:15 +02:00
int32_t deviceslot = data - > slotdata . deviceslot ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t result = CONTROLLER_PATCHER_ERROR_NONE ;
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ cur_config ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) { //Invalid data
if ( hidmask & gHID_LIST_KEYBOARD ) {
if ( isInKeyboardData ( cur_data , config_controller [ deviceslot ] [ cur_config ] [ 1 ] ) > 0 ) {
2017-03-30 17:53:36 +02:00
result = 1 ;
}
2018-06-19 17:46:37 +02:00
} else {
2023-04-10 11:45:58 +02:00
if ( ( cur_data [ config_controller [ deviceslot ] [ cur_config ] [ 0 ] ] & config_controller [ deviceslot ] [ cur_config ] [ 1 ] ) = = config_controller [ deviceslot ] [ cur_config ] [ 1 ] ) {
2017-03-30 17:53:36 +02:00
result = 1 ;
}
}
}
return result ;
2018-06-19 17:46:37 +02:00
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : isInKeyboardData ( unsigned char * keyboardData , int32_t key ) {
if ( keyboardData = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
for ( int32_t i = 0 ; i < HID_KEYBOARD_DATA_LENGTH ; i + + ) {
if ( keyboardData [ i ] = = 0 & & i > 1 ) {
2018-06-19 17:46:37 +02:00
break ;
} else if ( keyboardData [ i ] = = key ) {
2017-03-30 17:53:36 +02:00
return 1 ;
}
}
return 0 ;
}
/*----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
* Utils for setting the Button data
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : setButtonRemappingData ( VPADStatus * old_buffer , VPADStatus * new_buffer , uint32_t VPADButton , int32_t CONTRPS_SLOT ) {
if ( old_buffer = = NULL | | new_buffer = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2018-06-20 15:07:15 +02:00
uint32_t new_value = VPADButton ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( config_controller [ gGamePadSlot ] [ CONTRPS_SLOT ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) { //using new value!
2018-06-19 17:46:37 +02:00
new_value = gGamePadValues [ config_controller [ gGamePadSlot ] [ CONTRPS_SLOT ] [ 1 ] ] ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
setButtonData ( old_buffer , new_buffer , VPADButton , new_value ) ;
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : setButtonData ( VPADStatus * old_buffer , VPADStatus * new_buffer , uint32_t oldVPADButton , uint32_t newVPADButton ) {
if ( old_buffer = = NULL | | new_buffer = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
if ( ( old_buffer - > hold & oldVPADButton ) = = oldVPADButton ) {
2018-06-17 20:33:39 +02:00
new_buffer - > hold | = newVPADButton ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
if ( ( old_buffer - > release & oldVPADButton ) = = oldVPADButton ) {
2018-06-17 20:33:39 +02:00
new_buffer - > release | = newVPADButton ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
if ( ( old_buffer - > trigger & oldVPADButton ) = = oldVPADButton ) {
2018-06-17 20:33:39 +02:00
new_buffer - > trigger | = newVPADButton ;
2017-03-30 17:53:36 +02:00
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
/*----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
* Pad Status functions
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : checkActivePad ( uint32_t hidmask , int32_t pad ) {
if ( hidmask & gHID_LIST_GC & & pad > = 0 & & pad < = 3 ) {
2017-03-30 17:53:36 +02:00
if ( ! ( ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ pad ] . data_union . controller . cur_hid_data [ 0 ] & 0x10 ) = = 0 ) & & ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ pad ] . data_union . controller . cur_hid_data [ 0 ] & 0x22 ) ! = 0x22 ) ) ) return 1 ;
return CONTROLLER_PATCHER_ERROR_NO_PAD_CONNECTED ;
2018-06-19 17:46:37 +02:00
} else {
2018-06-20 15:07:15 +02:00
int32_t deviceslot = getDeviceSlot ( hidmask ) ;
2023-04-10 11:45:58 +02:00
if ( deviceslot < 0 ) return CONTROLLER_PATCHER_ERROR_DEVICE_SLOT_NOT_FOUND ;
2018-06-20 15:07:15 +02:00
int32_t connected_pads = config_controller [ deviceslot ] [ CONTRPS_CONNECTED_PADS ] [ 1 ] ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( ( connected_pads & ( 1 < < pad ) ) > 0 ) {
2017-03-30 17:53:36 +02:00
return 1 ;
}
}
return CONTROLLER_PATCHER_ERROR_NO_PAD_CONNECTED ;
}
/*
2018-06-20 15:07:15 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getActivePad ( uint32_t hidmask ) {
2017-03-30 17:53:36 +02:00
if ( hidmask & gHID_LIST_GC ) {
if ( ! ( ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 0 ] . data_union . controller . cur_hid_data [ 0 ] & 0x10 ) = = 0 ) & & ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 0 ] . data_union . controller . cur_hid_data [ 0 ] & 0x22 ) ! = 0x22 ) ) ) return 0 ;
if ( ! ( ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 1 ] . data_union . controller . cur_hid_data [ 0 ] & 0x10 ) = = 0 ) & & ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 1 ] . data_union . controller . cur_hid_data [ 0 ] & 0x22 ) ! = 0x22 ) ) ) return 1 ;
if ( ! ( ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 2 ] . data_union . controller . cur_hid_data [ 0 ] & 0x10 ) = = 0 ) & & ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 2 ] . data_union . controller . cur_hid_data [ 0 ] & 0x22 ) ! = 0x22 ) ) ) return 2 ;
if ( ! ( ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 3 ] . data_union . controller . cur_hid_data [ 0 ] & 0x10 ) = = 0 ) & & ( ( gHID_Devices [ gHID_SLOT_GC ] . pad_data [ 3 ] . data_union . controller . cur_hid_data [ 0 ] & 0x22 ) ! = 0x22 ) ) ) return 3 ;
return CONTROLLER_PATCHER_ERROR_NO_PAD_CONNECTED ;
}
return 0 ;
} */
/*----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
* Stick functions
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2024-10-26 20:28:15 +01:00
int16_t ControllerPatcherUtils : : signExtendValue ( uint16_t input , uint8_t bit_length ) {
// Check if the input is negative in its original bit length
if ( input & ( 1 < < ( bit_length - 1 ) ) ) {
// Sign-extend the value
return ( int16_t ) ( input | ( ~ ( ( 1 < < bit_length ) - 1 ) ) ) ;
} else {
// Input is non-negative; return it directly with proper casting
return ( int16_t ) input ;
}
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : normalizeStickValues ( VPADVec2D * stick ) {
if ( stick = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
float max_val = 0.0f ;
float mul_val = 0.0f ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( ( max_val = ( fabs ( stick - > x ) ) + fabs ( stick - > y ) ) > 1.414f ) {
2017-03-30 17:53:36 +02:00
mul_val = 1.414f / max_val ;
stick - > x * = mul_val ;
stick - > y * = mul_val ;
}
2023-04-10 11:45:58 +02:00
if ( stick - > x > 1.0f ) {
2018-06-19 17:46:37 +02:00
stick - > x = 1.0f ;
}
2023-04-10 11:45:58 +02:00
if ( stick - > y > 1.0f ) {
2018-06-19 17:46:37 +02:00
stick - > y = 1.0f ;
}
2023-04-10 11:45:58 +02:00
if ( stick - > x < - 1.0f ) {
2018-06-19 17:46:37 +02:00
stick - > x = - 1.0f ;
}
2023-04-10 11:45:58 +02:00
if ( stick - > y < - 1.0f ) {
2018-06-19 17:46:37 +02:00
stick - > y = - 1.0f ;
}
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2024-10-26 20:28:15 +01:00
float ControllerPatcherUtils : : convertAnalogValue ( int32_t value , int32_t default_val , int32_t min , int32_t max , uint8_t invert , uint8_t deadzone ) {
if ( value > = max ) return invert = = 0x01 ? - 1.0f : 1.0f ;
if ( value < = min ) return invert = = 0x01 ? 1.0f : - 1.0f ;
int32_t range = 0 ;
int32_t adjustedValue = value - default_val ;
if ( std : : abs ( adjustedValue ) < = ( int32_t ) deadzone ) return 0.0f ;
if ( adjustedValue > 0 ) {
range = max - ( default_val + deadzone ) ;
adjustedValue - = deadzone ;
2018-06-19 17:46:37 +02:00
} else {
2024-10-26 20:28:15 +01:00
range = ( default_val - deadzone ) - min ;
adjustedValue + = deadzone ;
2017-03-30 17:53:36 +02:00
}
2024-10-26 20:28:15 +01:00
float normalizedValue = ( float ) adjustedValue / range ;
return invert = = 0x01 ? - normalizedValue : normalizedValue ;
2017-03-30 17:53:36 +02:00
}
2018-06-20 15:07:15 +02:00
VPADVec2D ControllerPatcherUtils : : getAnalogValueByButtons ( uint8_t stick_values ) {
2018-06-17 20:33:39 +02:00
VPADVec2D stick ;
2017-03-30 17:53:36 +02:00
stick . x = 0.0f ;
stick . y = 0.0f ;
2023-04-10 11:45:58 +02:00
uint8_t up = ( ( stick_values & STICK_VALUE_UP ) = = STICK_VALUE_UP ) ;
uint8_t down = ( ( stick_values & STICK_VALUE_DOWN ) = = STICK_VALUE_DOWN ) ;
uint8_t left = ( ( stick_values & STICK_VALUE_LEFT ) = = STICK_VALUE_LEFT ) ;
uint8_t right = ( ( stick_values & STICK_VALUE_RIGHT ) = = STICK_VALUE_RIGHT ) ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( up ) {
if ( ! down ) {
2017-03-30 17:53:36 +02:00
stick . y = 1.0f ;
}
2023-04-10 11:45:58 +02:00
if ( left | | right ) {
2017-03-30 17:53:36 +02:00
stick . y = 0.707f ;
2023-04-10 11:45:58 +02:00
if ( left ) stick . x = - 0.707f ;
if ( right ) stick . x = 0.707f ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
} else if ( down ) {
if ( ! up ) {
2017-03-30 17:53:36 +02:00
stick . y = - 1.0f ;
}
2023-04-10 11:45:58 +02:00
if ( left | | right ) {
2017-03-30 17:53:36 +02:00
stick . y = - 0.707f ;
2023-04-10 11:45:58 +02:00
if ( left ) stick . x = - 0.707f ;
if ( right ) stick . x = 0.707f ;
2017-03-30 17:53:36 +02:00
}
2018-06-19 17:46:37 +02:00
} else {
2023-04-10 11:45:58 +02:00
if ( left ) {
if ( ! right ) {
2017-03-30 17:53:36 +02:00
stick . x = - 1.0f ;
2018-06-19 17:46:37 +02:00
}
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
} else if ( right ) {
if ( ! down ) {
2017-03-30 17:53:36 +02:00
stick . x = 1.0f ;
2018-06-19 17:46:37 +02:00
}
2017-03-30 17:53:36 +02:00
}
}
return stick ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : convertAnalogSticks ( HID_Data * data , VPADStatus * buffer ) {
if ( buffer = = NULL | | data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t deviceslot = data - > slotdata . deviceslot ;
2018-06-19 17:46:37 +02:00
if ( data - > type = = DEVICE_TYPE_MOUSE ) {
2023-04-10 11:45:58 +02:00
if ( gHID_Mouse_Mode = = HID_MOUSE_MODE_AIM ) { // TODO: tweak values
HID_Mouse_Data * ms_data = & data - > data_union . mouse . cur_mouse_data ;
if ( ms_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
float x_value = ms_data - > deltaX / 10.0f ;
float y_value = - 1.0f * ( ms_data - > deltaY / 10.0f ) ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_MOUSE_STICK ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
if ( config_controller [ deviceslot ] [ CONTRPS_MOUSE_STICK ] [ 1 ] = = DEF_L_STICK ) {
2018-06-17 20:33:39 +02:00
buffer - > leftStick . x + = x_value ;
buffer - > leftStick . y + = y_value ;
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
}
}
2018-06-17 20:33:39 +02:00
buffer - > rightStick . x + = x_value ;
buffer - > rightStick . y + = y_value ;
2017-03-30 17:53:36 +02:00
}
2018-06-19 17:46:37 +02:00
} else {
2023-04-10 11:45:58 +02:00
uint8_t * cur_data = & data - > data_union . controller . cur_hid_data [ 0 ] ;
if ( cur_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2024-11-02 15:18:57 +00:00
processStickAxis ( buffer - > leftStick . x , cur_data , deviceslot ,
CONTRPS_VPAD_BUTTON_L_STICK_X , CONTRPS_VPAD_BUTTON_L_STICK_X_DEADZONE ,
CONTRPS_VPAD_BUTTON_L_STICK_X_MINMAX , CONTRPS_VPAD_BUTTON_L_STICK_X_BIT_LENGTH ,
CONTRPS_VPAD_BUTTON_L_STICK_X_BIT_OFFSET , CONTRPS_VPAD_BUTTON_L_STICK_X_MINMAX_MSB ,
CONTRPS_VPAD_BUTTON_L_STICK_X_DEFAULT_MSB , CONTRPS_VPAD_BUTTON_L_STICK_X_SIGNED ,
CONTRPS_VPAD_BUTTON_L_STICK_X_INVERT ) ;
processStickAxis ( buffer - > leftStick . y , cur_data , deviceslot ,
CONTRPS_VPAD_BUTTON_L_STICK_Y , CONTRPS_VPAD_BUTTON_L_STICK_Y_DEADZONE ,
CONTRPS_VPAD_BUTTON_L_STICK_Y_MINMAX , CONTRPS_VPAD_BUTTON_L_STICK_Y_BIT_LENGTH ,
CONTRPS_VPAD_BUTTON_L_STICK_Y_BIT_OFFSET , CONTRPS_VPAD_BUTTON_L_STICK_Y_MINMAX_MSB ,
CONTRPS_VPAD_BUTTON_L_STICK_Y_DEFAULT_MSB , CONTRPS_VPAD_BUTTON_L_STICK_Y_SIGNED ,
CONTRPS_VPAD_BUTTON_L_STICK_Y_INVERT ) ;
processStickAxis ( buffer - > rightStick . x , cur_data , deviceslot ,
CONTRPS_VPAD_BUTTON_R_STICK_X , CONTRPS_VPAD_BUTTON_R_STICK_X_DEADZONE ,
CONTRPS_VPAD_BUTTON_R_STICK_X_MINMAX , CONTRPS_VPAD_BUTTON_R_STICK_X_BIT_LENGTH ,
CONTRPS_VPAD_BUTTON_R_STICK_X_BIT_OFFSET , CONTRPS_VPAD_BUTTON_R_STICK_X_MINMAX_MSB ,
CONTRPS_VPAD_BUTTON_R_STICK_X_DEFAULT_MSB , CONTRPS_VPAD_BUTTON_R_STICK_X_SIGNED ,
CONTRPS_VPAD_BUTTON_R_STICK_X_INVERT ) ;
processStickAxis ( buffer - > rightStick . y , cur_data , deviceslot ,
CONTRPS_VPAD_BUTTON_R_STICK_Y , CONTRPS_VPAD_BUTTON_R_STICK_Y_DEADZONE ,
CONTRPS_VPAD_BUTTON_R_STICK_Y_MINMAX , CONTRPS_VPAD_BUTTON_R_STICK_Y_BIT_LENGTH ,
CONTRPS_VPAD_BUTTON_R_STICK_Y_BIT_OFFSET , CONTRPS_VPAD_BUTTON_R_STICK_Y_MINMAX_MSB ,
CONTRPS_VPAD_BUTTON_R_STICK_Y_DEFAULT_MSB , CONTRPS_VPAD_BUTTON_R_STICK_Y_SIGNED ,
CONTRPS_VPAD_BUTTON_R_STICK_Y_INVERT ) ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
uint8_t stick_values = 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_L_STICK_UP ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_UP ;
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_L_STICK_DOWN ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_DOWN ;
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_L_STICK_LEFT ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_LEFT ;
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_L_STICK_RIGHT ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_RIGHT ;
}
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( stick_values > 0 ) {
2018-06-17 20:33:39 +02:00
VPADVec2D stick = getAnalogValueByButtons ( stick_values ) ;
buffer - > leftStick . x + = stick . x ;
buffer - > leftStick . y + = stick . y ;
2017-03-30 17:53:36 +02:00
}
stick_values = 0 ;
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_R_STICK_UP ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_UP ;
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_R_STICK_DOWN ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_DOWN ;
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_R_STICK_LEFT ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_LEFT ;
}
2023-04-10 11:45:58 +02:00
if ( isValueSet ( data , CONTRPS_VPAD_BUTTON_R_STICK_RIGHT ) ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_RIGHT ;
}
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( stick_values > 0 ) {
2018-06-17 20:33:39 +02:00
VPADVec2D stick = getAnalogValueByButtons ( stick_values ) ;
buffer - > rightStick . x + = stick . x ;
buffer - > rightStick . y + = stick . y ;
2017-03-30 17:53:36 +02:00
}
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_VPAD_STICK_L_COPY_DPAD ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
if ( config_controller [ deviceslot ] [ CONTRPS_VPAD_STICK_L_COPY_DPAD ] [ 0 ] = = 1 ) {
2018-06-20 15:07:15 +02:00
uint8_t stick_values = 0 ;
2018-02-16 19:25:43 +01:00
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_UP ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_UP ;
}
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_DOWN ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_DOWN ;
}
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_LEFT ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_LEFT ;
}
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_RIGHT ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_RIGHT ;
}
2018-02-16 19:25:43 +01:00
2023-04-10 11:45:58 +02:00
if ( stick_values > 0 ) {
2018-06-17 20:33:39 +02:00
VPADVec2D stick = getAnalogValueByButtons ( stick_values ) ;
buffer - > leftStick . x + = stick . x ;
buffer - > leftStick . y + = stick . y ;
2018-02-16 19:25:43 +01:00
}
}
}
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_VPAD_STICK_R_COPY_DPAD ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
if ( config_controller [ deviceslot ] [ CONTRPS_VPAD_STICK_R_COPY_DPAD ] [ 0 ] = = 1 ) {
2018-06-20 15:07:15 +02:00
uint8_t stick_values = 0 ;
2018-02-16 19:25:43 +01:00
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_UP ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_UP ;
}
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_DOWN ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_DOWN ;
}
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_LEFT ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_LEFT ;
}
2023-04-10 11:45:58 +02:00
if ( buffer - > hold & VPAD_BUTTON_RIGHT ) {
2018-06-19 17:46:37 +02:00
stick_values | = STICK_VALUE_RIGHT ;
}
2018-02-16 19:25:43 +01:00
2023-04-10 11:45:58 +02:00
if ( stick_values > 0 ) {
2018-06-17 20:33:39 +02:00
VPADVec2D stick = getAnalogValueByButtons ( stick_values ) ;
buffer - > rightStick . x + = stick . x ;
buffer - > rightStick . y + = stick . y ;
2018-02-16 19:25:43 +01:00
}
}
}
2024-11-02 15:18:57 +00:00
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : processStickAxis (
float & buffer_axis , const uint8_t * cur_data , int32_t deviceslot ,
uint8_t axis_code , uint8_t axis_deadzone_code ,
uint8_t axis_minmax_code , uint8_t axis_bit_length_code ,
uint8_t axis_bit_offset_code , uint8_t axis_minmax_msb_code ,
uint8_t axis_default_msb_code , uint8_t axis_signed_code ,
uint8_t axis_invert_code ) {
if ( cur_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
if ( config_controller [ deviceslot ] [ axis_code ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
uint8_t deadzone = ( config_controller [ deviceslot ] [ axis_deadzone_code ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET )
? config_controller [ deviceslot ] [ axis_deadzone_code ] [ 1 ]
: 0 ;
2018-02-16 19:25:43 +01:00
2024-11-02 15:18:57 +00:00
// Read 1st byte of axis HID data & Min/Max/Default values
uint16_t axis_input = cur_data [ config_controller [ deviceslot ] [ axis_code ] [ 0 ] ] ;
uint16_t axis_min = config_controller [ deviceslot ] [ axis_minmax_code ] [ 0 ] ;
uint16_t axis_max = config_controller [ deviceslot ] [ axis_minmax_code ] [ 1 ] ;
uint16_t axis_default = config_controller [ deviceslot ] [ axis_code ] [ 1 ] ;
2024-10-26 20:28:15 +01:00
2024-11-02 15:18:57 +00:00
// Axis report larger than 8 bits?
if ( config_controller [ deviceslot ] [ axis_bit_length_code ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET & &
config_controller [ deviceslot ] [ axis_bit_length_code ] [ 1 ] > 8 ) {
// Read 2nd byte of axis HID data
axis_input | = ( cur_data [ config_controller [ deviceslot ] [ axis_code ] [ 0 ] + 1 ] < < 8 ) ;
if ( config_controller [ deviceslot ] [ axis_bit_offset_code ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
// Shift right to trim unwanted leading bits
axis_input > > = config_controller [ deviceslot ] [ axis_bit_offset_code ] [ 1 ] ;
}
// Mask off unwanted trailing bits
axis_input & = ( ( 1 < < config_controller [ deviceslot ] [ axis_bit_length_code ] [ 1 ] ) - 1 ) ;
// Combine most significant bytes of Min/Max/Default values
axis_min | = ( config_controller [ deviceslot ] [ axis_minmax_msb_code ] [ 0 ] < < 8 ) ;
axis_max | = ( config_controller [ deviceslot ] [ axis_minmax_msb_code ] [ 1 ] < < 8 ) ;
if ( config_controller [ deviceslot ] [ axis_default_msb_code ] [ 0 ] = = CONTROLLER_PATCHER_VALUE_SET ) {
axis_default | = ( config_controller [ deviceslot ] [ axis_default_msb_code ] [ 1 ] < < 8 ) ;
}
}
if ( config_controller [ deviceslot ] [ axis_signed_code ] [ 1 ] ) {
// Extend sign bits if axis HID data is signed
int16_t signed_input = signExtendValue ( axis_input , config_controller [ deviceslot ] [ axis_bit_length_code ] [ 1 ] ) ;
buffer_axis + = convertAnalogValue ( signed_input , ( int16_t ) axis_default , ( int16_t ) axis_min , ( int16_t ) axis_max ,
config_controller [ deviceslot ] [ axis_invert_code ] [ 1 ] , deadzone ) ;
} else {
buffer_axis + = convertAnalogValue ( axis_input , axis_default , axis_min , axis_max ,
config_controller [ deviceslot ] [ axis_invert_code ] [ 1 ] , deadzone ) ;
}
2017-03-30 17:53:36 +02:00
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2024-11-02 15:18:57 +00:00
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : setEmulatedSticks ( VPADStatus * buffer , uint32_t * last_emulatedSticks ) {
if ( buffer = = NULL | | last_emulatedSticks = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
uint32_t emulatedSticks = 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
int32_t l_x_full = ( buffer - > leftStick . x > 0.5f | | buffer - > leftStick . x < - 0.5f ) ? 1 : 0 ;
int32_t l_y_full = ( buffer - > leftStick . y > 0.5f | | buffer - > leftStick . y < - 0.5f ) ? 1 : 0 ;
int32_t r_x_full = ( buffer - > rightStick . x > 0.5f | | buffer - > rightStick . x < - 0.5f ) ? 1 : 0 ;
int32_t r_y_full = ( buffer - > rightStick . y > 0.5f | | buffer - > rightStick . y < - 0.5f ) ? 1 : 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( ( buffer - > leftStick . x > 0.5f ) | | ( buffer - > leftStick . x > 0.1f & & ! l_y_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_L_EMULATION_RIGHT ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > leftStick . x < - 0.5f ) | | ( buffer - > leftStick . x < - 0.1f & & ! l_y_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_L_EMULATION_LEFT ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > leftStick . y > 0.5f ) | | ( buffer - > leftStick . y > 0.1f & & ! l_x_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_L_EMULATION_UP ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > leftStick . y < - 0.5f ) | | ( buffer - > leftStick . y < - 0.1f & & ! l_x_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_L_EMULATION_DOWN ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > rightStick . x > 0.5f ) | | ( buffer - > rightStick . x > 0.1f & & ! r_y_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_R_EMULATION_RIGHT ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > rightStick . x < - 0.5f ) | | ( buffer - > rightStick . x < - 0.1f & & ! r_y_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_R_EMULATION_LEFT ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > rightStick . y > 0.5f ) | | ( buffer - > rightStick . y > 0.1f & & ! r_x_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_R_EMULATION_UP ;
}
2023-04-10 11:45:58 +02:00
if ( ( buffer - > rightStick . y < - 0.5f ) | | ( buffer - > rightStick . y < - 0.1f & & ! r_x_full ) ) {
2017-03-30 17:53:36 +02:00
emulatedSticks | = VPAD_STICK_R_EMULATION_DOWN ;
}
//Setting the emulated sticks
2018-06-17 20:33:39 +02:00
buffer - > hold | = emulatedSticks ;
buffer - > trigger | = ( emulatedSticks & ( ~ * last_emulatedSticks ) ) ;
buffer - > release | = ( * last_emulatedSticks & ( ~ emulatedSticks ) ) ;
2017-03-30 17:53:36 +02:00
* last_emulatedSticks = emulatedSticks ;
return CONTROLLER_PATCHER_ERROR_NONE ;
}
/*----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
* Touch functions
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : setTouch ( HID_Data * data , VPADStatus * buffer ) {
if ( buffer = = NULL | | data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
if ( data - > type = = DEVICE_TYPE_MOUSE & & gHID_Mouse_Mode = = HID_MOUSE_MODE_TOUCH ) {
2018-06-20 15:07:15 +02:00
int32_t buttons_hold ;
2023-04-10 11:45:58 +02:00
if ( getButtonPressed ( data , & buttons_hold , VPAD_BUTTON_TOUCH ) ) {
HID_Mouse_Data * ms_data = & data - > data_union . mouse . cur_mouse_data ;
if ( ms_data = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
int32_t x_mouse = 80 + ( ( int ) ( ( ( ms_data - > X ) * 1.0f / 1280.0 ) * 3890.0f ) ) ;
int32_t y_mouse = 3910 - ( ( int ) ( ( ( ms_data - > Y ) * 1.0f / 720.0 ) * 3760.0f ) ) ;
buffer - > tpNormal . x = x_mouse ;
buffer - > tpNormal . y = y_mouse ;
buffer - > tpNormal . touched = 1 ;
buffer - > tpNormal . validity = 0 ;
buffer - > tpFiltered1 . x = x_mouse ;
buffer - > tpFiltered1 . y = y_mouse ;
buffer - > tpFiltered1 . touched = 1 ;
2018-06-19 17:46:37 +02:00
buffer - > tpFiltered1 . validity = 0 ;
2023-04-10 11:45:58 +02:00
buffer - > tpFiltered2 . x = x_mouse ;
buffer - > tpFiltered2 . y = y_mouse ;
buffer - > tpFiltered2 . touched = 1 ;
2018-06-19 17:46:37 +02:00
buffer - > tpFiltered2 . validity = 0 ;
2017-03-30 17:53:36 +02:00
}
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : checkAndSetMouseMode ( HID_Data * data ) {
2018-06-20 15:07:15 +02:00
uint32_t hidmask = data - > slotdata . hidmask ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( hidmask & gHID_LIST_KEYBOARD ) {
uint8_t * cur_data = & data - > data_union . controller . cur_hid_data [ 0 ] ;
uint8_t * last_data = & data - > data_union . controller . last_hid_data [ 0 ] ;
if ( ( isInKeyboardData ( cur_data , HID_KEYBOARD_BUTTON_F1 ) > 0 ) & & ( ( isInKeyboardData ( cur_data , HID_KEYBOARD_BUTTON_F1 ) > 0 ) ! = ( isInKeyboardData ( last_data , HID_KEYBOARD_BUTTON_F1 ) > 0 ) ) & & gMouseModeCoolDown = = 0 ) {
2018-02-16 18:57:45 +01:00
gMouseModeCoolDown = 60 ;
2023-04-10 11:45:58 +02:00
if ( gHID_Mouse_Mode = = HID_MOUSE_MODE_AIM ) {
2017-03-30 17:53:36 +02:00
gHID_Mouse_Mode = HID_MOUSE_MODE_TOUCH ;
2020-12-16 02:04:31 +01:00
//log_printf("ControllerPatcherUtils::checkAndSetMouseMode(line %d): Mouse mode changed! to touch ",__LINE__);
2023-04-10 11:45:58 +02:00
} else if ( gHID_Mouse_Mode = = HID_MOUSE_MODE_TOUCH ) {
2020-12-16 02:04:31 +01:00
//log_printf("ControllerPatcherUtils::checkAndSetMouseMode(line %d): Mouse mode changed! to aim ",__LINE__);
2017-03-30 17:53:36 +02:00
gHID_Mouse_Mode = HID_MOUSE_MODE_AIM ;
}
}
2023-04-10 11:45:58 +02:00
if ( gMouseModeCoolDown > 0 ) {
2018-02-16 18:57:45 +01:00
gMouseModeCoolDown - - ;
}
2017-03-30 17:53:36 +02:00
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
/*----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
* Other functions
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : translateToPro ( VPADStatus * vpad_buffer , KPADStatus * pro_buffer , uint32_t * lastButtonsPressesPRO ) {
if ( vpad_buffer = = NULL | | pro_buffer = = NULL | | lastButtonsPressesPRO = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t buttons_hold = 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_A ) buttons_hold | = WPAD_PRO_BUTTON_A ;
if ( vpad_buffer - > hold & VPAD_BUTTON_B ) buttons_hold | = WPAD_PRO_BUTTON_B ;
if ( vpad_buffer - > hold & VPAD_BUTTON_X ) buttons_hold | = WPAD_PRO_BUTTON_X ;
if ( vpad_buffer - > hold & VPAD_BUTTON_Y ) buttons_hold | = WPAD_PRO_BUTTON_Y ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_PLUS ) buttons_hold | = WPAD_PRO_BUTTON_PLUS ;
if ( vpad_buffer - > hold & VPAD_BUTTON_MINUS ) buttons_hold | = WPAD_PRO_BUTTON_MINUS ;
if ( vpad_buffer - > hold & VPAD_BUTTON_HOME ) buttons_hold | = WPAD_PRO_BUTTON_HOME ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_LEFT ) buttons_hold | = WPAD_PRO_BUTTON_LEFT ;
if ( vpad_buffer - > hold & VPAD_BUTTON_RIGHT ) buttons_hold | = WPAD_PRO_BUTTON_RIGHT ;
if ( vpad_buffer - > hold & VPAD_BUTTON_UP ) buttons_hold | = WPAD_PRO_BUTTON_UP ;
if ( vpad_buffer - > hold & VPAD_BUTTON_DOWN ) buttons_hold | = WPAD_PRO_BUTTON_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_L ) buttons_hold | = WPAD_PRO_TRIGGER_L ;
if ( vpad_buffer - > hold & VPAD_BUTTON_ZL ) buttons_hold | = WPAD_PRO_TRIGGER_ZL ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_R ) buttons_hold | = WPAD_PRO_TRIGGER_R ;
if ( vpad_buffer - > hold & VPAD_BUTTON_ZR ) buttons_hold | = WPAD_PRO_TRIGGER_ZR ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_STICK_L ) buttons_hold | = WPAD_PRO_BUTTON_STICK_L ;
if ( vpad_buffer - > hold & VPAD_BUTTON_STICK_R ) buttons_hold | = WPAD_PRO_BUTTON_STICK_R ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_LEFT ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_LEFT ;
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_RIGHT ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_RIGHT ;
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_UP ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_UP ;
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_DOWN ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_LEFT ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_LEFT ;
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_RIGHT ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_RIGHT ;
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_UP ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_UP ;
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_DOWN ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
pro_buffer - > pro . leftStick . x = vpad_buffer - > leftStick . x ;
pro_buffer - > pro . leftStick . y = vpad_buffer - > leftStick . y ;
2018-06-17 20:33:39 +02:00
pro_buffer - > pro . rightStick . x = vpad_buffer - > rightStick . x ;
pro_buffer - > pro . rightStick . y = vpad_buffer - > rightStick . y ;
2017-03-30 17:53:36 +02:00
2017-04-23 15:19:21 +02:00
/*
pro_buffer - > unused_1 [ 1 ] = 0xBF800000 ;
pro_buffer - > unused_1 [ 3 ] = 0x3F800000 ;
pro_buffer - > angle_x = 0x3F800000 ;
pro_buffer - > unused_3 [ 4 ] = 0x3F800000 ;
pro_buffer - > unused_3 [ 7 ] = 0x3F800000 ;
pro_buffer - > unused_6 [ 17 ] = 0x3F800000 ;
pro_buffer - > unused_7 [ 1 ] = 0x3F800000 ;
pro_buffer - > unused_7 [ 5 ] = 0x3F800000 ; */
2023-04-10 11:45:58 +02:00
pro_buffer - > pro . hold = buttons_hold ;
2018-06-17 20:33:39 +02:00
pro_buffer - > pro . trigger = ( buttons_hold & ( ~ * lastButtonsPressesPRO ) ) ;
pro_buffer - > pro . release = ( * lastButtonsPressesPRO & ( ~ buttons_hold ) ) ;
2017-03-30 17:53:36 +02:00
* lastButtonsPressesPRO = buttons_hold ;
2023-04-10 11:45:58 +02:00
pro_buffer - > format = WPAD_FMT_PRO_CONTROLLER ;
pro_buffer - > error = 0x00 ;
2018-06-19 17:39:20 +02:00
pro_buffer - > extensionType = WPAD_EXT_PRO_CONTROLLER ;
2023-04-10 11:45:58 +02:00
pro_buffer - > pro . wired = 1 ;
pro_buffer - > pro . charging = 1 ;
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : translateToProWPADRead ( VPADStatus * vpad_buffer , WPADStatusProController * pro_buffer ) {
if ( vpad_buffer = = NULL | | pro_buffer = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t buttons_hold = 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_A ) buttons_hold | = WPAD_PRO_BUTTON_A ;
if ( vpad_buffer - > hold & VPAD_BUTTON_B ) buttons_hold | = WPAD_PRO_BUTTON_B ;
if ( vpad_buffer - > hold & VPAD_BUTTON_X ) buttons_hold | = WPAD_PRO_BUTTON_X ;
if ( vpad_buffer - > hold & VPAD_BUTTON_Y ) buttons_hold | = WPAD_PRO_BUTTON_Y ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_PLUS ) buttons_hold | = WPAD_PRO_BUTTON_PLUS ;
if ( vpad_buffer - > hold & VPAD_BUTTON_MINUS ) buttons_hold | = WPAD_PRO_BUTTON_MINUS ;
if ( vpad_buffer - > hold & VPAD_BUTTON_HOME ) buttons_hold | = WPAD_PRO_BUTTON_HOME ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_LEFT ) buttons_hold | = WPAD_PRO_BUTTON_LEFT ;
if ( vpad_buffer - > hold & VPAD_BUTTON_RIGHT ) buttons_hold | = WPAD_PRO_BUTTON_RIGHT ;
if ( vpad_buffer - > hold & VPAD_BUTTON_UP ) buttons_hold | = WPAD_PRO_BUTTON_UP ;
if ( vpad_buffer - > hold & VPAD_BUTTON_DOWN ) buttons_hold | = WPAD_PRO_BUTTON_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_L ) buttons_hold | = WPAD_PRO_TRIGGER_L ;
if ( vpad_buffer - > hold & VPAD_BUTTON_ZL ) buttons_hold | = WPAD_PRO_TRIGGER_ZL ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_R ) buttons_hold | = WPAD_PRO_TRIGGER_R ;
if ( vpad_buffer - > hold & VPAD_BUTTON_ZR ) buttons_hold | = WPAD_PRO_TRIGGER_ZR ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_BUTTON_STICK_L ) buttons_hold | = WPAD_PRO_BUTTON_STICK_L ;
if ( vpad_buffer - > hold & VPAD_BUTTON_STICK_R ) buttons_hold | = WPAD_PRO_BUTTON_STICK_R ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_LEFT ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_LEFT ;
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_RIGHT ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_RIGHT ;
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_UP ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_UP ;
if ( vpad_buffer - > hold & VPAD_STICK_L_EMULATION_DOWN ) buttons_hold | = WPAD_PRO_STICK_L_EMULATION_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_LEFT ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_LEFT ;
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_RIGHT ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_RIGHT ;
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_UP ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_UP ;
if ( vpad_buffer - > hold & VPAD_STICK_R_EMULATION_DOWN ) buttons_hold | = WPAD_PRO_STICK_R_EMULATION_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
pro_buffer - > leftStick . x = ( int16_t ) ( vpad_buffer - > leftStick . x * 950.0f ) ;
pro_buffer - > leftStick . y = ( int16_t ) ( vpad_buffer - > leftStick . y * 950.0f ) ;
2018-06-20 15:07:15 +02:00
pro_buffer - > rightStick . x = ( int16_t ) ( vpad_buffer - > rightStick . x * 950.0f ) ;
pro_buffer - > rightStick . y = ( int16_t ) ( vpad_buffer - > rightStick . y * 950.0f ) ;
2017-03-30 17:53:36 +02:00
pro_buffer - > buttons = buttons_hold ;
2023-04-10 11:45:58 +02:00
pro_buffer - > dataFormat = WPAD_FMT_PRO_CONTROLLER ;
pro_buffer - > err = 0x00 ;
2018-06-19 17:39:20 +02:00
pro_buffer - > extensionType = WPAD_EXT_PRO_CONTROLLER ;
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : translateToVPAD ( VPADStatus * vpad_buffer , KPADStatus * pro_buffer , uint32_t * lastButtonsPressesVPAD ) {
if ( vpad_buffer = = NULL | | pro_buffer = = NULL | | lastButtonsPressesVPAD = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
2017-03-30 17:53:36 +02:00
2018-06-20 15:07:15 +02:00
int32_t buttons_hold = 0 ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_A ) buttons_hold | = VPAD_BUTTON_A ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_B ) buttons_hold | = VPAD_BUTTON_B ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_X ) buttons_hold | = VPAD_BUTTON_X ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_Y ) buttons_hold | = VPAD_BUTTON_Y ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_PLUS ) buttons_hold | = VPAD_BUTTON_PLUS ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_MINUS ) buttons_hold | = VPAD_BUTTON_MINUS ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_HOME ) buttons_hold | = VPAD_BUTTON_HOME ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_LEFT ) buttons_hold | = VPAD_BUTTON_LEFT ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_RIGHT ) buttons_hold | = VPAD_BUTTON_RIGHT ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_UP ) buttons_hold | = VPAD_BUTTON_UP ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_DOWN ) buttons_hold | = VPAD_BUTTON_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_TRIGGER_L ) buttons_hold | = VPAD_BUTTON_L ;
if ( pro_buffer - > pro . hold & WPAD_PRO_TRIGGER_ZL ) buttons_hold | = VPAD_BUTTON_ZL ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_TRIGGER_R ) buttons_hold | = VPAD_BUTTON_R ;
if ( pro_buffer - > pro . hold & WPAD_PRO_TRIGGER_ZR ) buttons_hold | = VPAD_BUTTON_ZR ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_STICK_L ) buttons_hold | = VPAD_BUTTON_STICK_L ;
if ( pro_buffer - > pro . hold & WPAD_PRO_BUTTON_STICK_R ) buttons_hold | = VPAD_BUTTON_STICK_R ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_L_EMULATION_LEFT ) buttons_hold | = VPAD_STICK_L_EMULATION_LEFT ;
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_L_EMULATION_RIGHT ) buttons_hold | = VPAD_STICK_L_EMULATION_RIGHT ;
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_L_EMULATION_UP ) buttons_hold | = VPAD_STICK_L_EMULATION_UP ;
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_L_EMULATION_DOWN ) buttons_hold | = VPAD_STICK_L_EMULATION_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_R_EMULATION_LEFT ) buttons_hold | = VPAD_STICK_R_EMULATION_LEFT ;
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_R_EMULATION_RIGHT ) buttons_hold | = VPAD_STICK_R_EMULATION_RIGHT ;
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_R_EMULATION_UP ) buttons_hold | = VPAD_STICK_R_EMULATION_UP ;
if ( pro_buffer - > pro . hold & WPAD_PRO_STICK_R_EMULATION_DOWN ) buttons_hold | = VPAD_STICK_R_EMULATION_DOWN ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
vpad_buffer - > leftStick . x = pro_buffer - > pro . leftStick . x ;
vpad_buffer - > leftStick . y = pro_buffer - > pro . leftStick . y ;
2018-06-17 20:33:39 +02:00
vpad_buffer - > rightStick . x = pro_buffer - > pro . rightStick . x ;
vpad_buffer - > rightStick . y = pro_buffer - > pro . rightStick . y ;
2017-03-30 17:53:36 +02:00
2018-06-17 20:33:39 +02:00
vpad_buffer - > hold | = buttons_hold ;
vpad_buffer - > trigger | = ( buttons_hold & ( ~ * lastButtonsPressesVPAD ) ) ;
vpad_buffer - > release | = ( * lastButtonsPressesVPAD & ( ~ buttons_hold ) ) ;
2017-03-30 17:53:36 +02:00
* lastButtonsPressesVPAD = buttons_hold ;
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : checkValueinConfigController ( int32_t deviceslot , int32_t CONTRPS_slot , int32_t expectedValue ) {
if ( config_controller [ deviceslot ] [ CONTRPS_slot ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
if ( expectedValue = = config_controller [ deviceslot ] [ CONTRPS_slot ] [ 1 ] ) return 1 ;
2017-03-30 17:53:36 +02:00
}
return 0 ;
}
2023-04-10 11:45:58 +02:00
void ControllerPatcherUtils : : setConfigValue ( uint8_t * dest , uint8_t first , uint8_t second ) {
2017-03-30 17:53:36 +02:00
dest [ 0 ] = first ;
dest [ 1 ] = second ;
}
2018-06-20 15:07:15 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getDeviceSlot ( uint32_t hidmask ) {
2023-04-10 11:45:58 +02:00
for ( int32_t i = 0 ; i < gHIDMaxDevices ; i + + ) {
if ( hidmask & config_controller_hidmask [ i ] ) {
2018-06-19 17:46:37 +02:00
return i ;
2017-03-30 17:53:36 +02:00
}
}
return CONTROLLER_PATCHER_ERROR_DEVICE_SLOT_NOT_FOUND ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getDeviceInfoFromVidPid ( DeviceInfo * info ) {
if ( info ! = NULL ) {
for ( int32_t i = 0 ; i < gHIDMaxDevices ; i + + ) {
2018-06-20 15:07:15 +02:00
uint16_t my_vid = config_controller [ i ] [ CONTRPS_VID ] [ 0 ] * 0x100 + config_controller [ i ] [ CONTRPS_VID ] [ 1 ] ;
uint16_t my_pid = config_controller [ i ] [ CONTRPS_PID ] [ 0 ] * 0x100 + config_controller [ i ] [ CONTRPS_PID ] [ 1 ] ;
2020-12-16 02:04:31 +01:00
//log_printf("info->vidpid.vid (%04X) == my_vid (%04X) && info->vidpid.pid (%04X) == my_pid (%04X)",info->vidpid.vid,my_vid,info->vidpid.pid,my_pid);
2023-04-10 11:45:58 +02:00
if ( info - > vidpid . vid = = my_vid & & info - > vidpid . pid = = my_pid ) {
info - > slotdata . hidmask = config_controller_hidmask [ i ] ;
2017-03-30 17:53:36 +02:00
info - > slotdata . deviceslot = i ;
2023-04-10 11:45:58 +02:00
info - > pad_count = 1 ;
if ( config_controller [ i ] [ CONTRPS_PAD_COUNT ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
2018-06-19 17:46:37 +02:00
info - > pad_count = config_controller [ i ] [ CONTRPS_PAD_COUNT ] [ 1 ] ;
2023-04-10 11:45:58 +02:00
if ( info - > pad_count > HID_MAX_PADS_COUNT ) {
2017-04-23 15:19:21 +02:00
info - > pad_count = HID_MAX_PADS_COUNT ;
2018-06-19 17:46:37 +02:00
}
2017-04-23 15:19:21 +02:00
}
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
2020-12-16 02:04:31 +01:00
//log_printf("Found device: device: %s slot: %d",byte_to_binary(device),deviceSlot);
2017-03-30 17:53:36 +02:00
break ;
}
}
return CONTROLLER_PATCHER_ERROR_UNKNOWN_VID_PID ;
}
return CONTROLLER_PATCHER_ERROR_INVALID_BUFFER ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getNextSlotData ( HIDSlotData * slotdata ) {
if ( slotdata = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
if ( gHIDRegisteredDevices > = gHIDMaxDevices ) return CONTROLLER_PATCHER_ERROR_NO_FREE_SLOT ;
2017-03-30 17:53:36 +02:00
slotdata - > deviceslot = gHIDRegisteredDevices ;
2023-04-10 11:45:58 +02:00
slotdata - > hidmask = ( 1 < < ( gHIDRegisteredDevices ) ) ;
2017-03-30 17:53:36 +02:00
gHIDRegisteredDevices + + ;
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : getVIDPIDbyDeviceSlot ( int32_t deviceslot , DeviceVIDPIDInfo * vidpid ) {
if ( vidpid = = NULL ) return CONTROLLER_PATCHER_ERROR_NULL_POINTER ;
if ( deviceslot > = gHIDMaxDevices | | deviceslot < 0 ) return CONTROLLER_PATCHER_ERROR_DEVICE_SLOT_NOT_FOUND ;
2017-03-30 17:53:36 +02:00
vidpid - > vid = config_controller [ deviceslot ] [ CONTRPS_VID ] [ 0 ] * 0x100 + config_controller [ deviceslot ] [ CONTRPS_VID ] [ 1 ] ;
vidpid - > pid = config_controller [ deviceslot ] [ CONTRPS_PID ] [ 0 ] * 0x100 + config_controller [ deviceslot ] [ CONTRPS_PID ] [ 1 ] ;
2023-04-10 11:45:58 +02:00
if ( vidpid - > vid = = 0x0000 ) return CONTROLLER_PATCHER_ERROR_FAILED_TO_GET_HIDDATA ;
2017-03-30 17:53:36 +02:00
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
int32_t ControllerPatcherUtils : : getPadSlotInAdapter ( int32_t deviceslot , uint8_t * input_data ) {
2018-06-20 15:07:15 +02:00
int32_t slot_incr = 0 ;
2023-04-10 11:45:58 +02:00
if ( config_controller [ deviceslot ] [ CONTRPS_PAD_COUNT ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
2018-06-20 15:07:15 +02:00
int32_t pad_count = config_controller [ deviceslot ] [ CONTRPS_PAD_COUNT ] [ 1 ] ;
2023-04-10 11:45:58 +02:00
if ( pad_count > HID_MAX_PADS_COUNT ) {
2017-03-30 17:53:36 +02:00
pad_count = HID_MAX_PADS_COUNT ;
}
2023-04-10 11:45:58 +02:00
for ( int32_t i = 0 ; i < pad_count ; i + + ) {
if ( config_controller [ deviceslot ] [ CONTRPS_PAD1_FILTER + i ] [ 0 ] ! = CONTROLLER_PATCHER_INVALIDVALUE ) {
if ( input_data [ config_controller [ deviceslot ] [ CONTRPS_PAD1_FILTER + i ] [ 0 ] ] = = config_controller [ deviceslot ] [ CONTRPS_PAD1_FILTER + i ] [ 1 ] ) {
2017-03-30 17:53:36 +02:00
slot_incr = i ;
break ;
}
}
}
}
return slot_incr ;
}
2023-04-10 11:45:58 +02:00
ControllerMappingPAD * ControllerPatcherUtils : : getControllerMappingByType ( UController_Type type ) {
ControllerMappingPAD * cm_map_pad = NULL ;
2017-03-30 17:53:36 +02:00
2023-04-10 11:45:58 +02:00
if ( type = = UController_Type_Gamepad ) {
2017-03-30 17:53:36 +02:00
cm_map_pad = & ( gControllerMapping . gamepad ) ;
2023-04-10 11:45:58 +02:00
} else if ( type = = UController_Type_Pro1 ) {
2017-03-30 17:53:36 +02:00
cm_map_pad = & ( gControllerMapping . proController [ 0 ] ) ;
2023-04-10 11:45:58 +02:00
} else if ( type = = UController_Type_Pro2 ) {
2017-03-30 17:53:36 +02:00
cm_map_pad = & ( gControllerMapping . proController [ 1 ] ) ;
2023-04-10 11:45:58 +02:00
} else if ( type = = UController_Type_Pro3 ) {
2017-03-30 17:53:36 +02:00
cm_map_pad = & ( gControllerMapping . proController [ 2 ] ) ;
2023-04-10 11:45:58 +02:00
} else if ( type = = UController_Type_Pro4 ) {
2017-03-30 17:53:36 +02:00
cm_map_pad = & ( gControllerMapping . proController [ 3 ] ) ;
}
return cm_map_pad ;
}
2017-04-23 15:19:21 +02:00
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : doSampling ( uint16_t deviceslot , uint8_t padslot = 0 , BOOL ignorePadSlot = false ) {
2024-10-13 10:37:09 +02:00
if ( gSamplingCallback ! = nullptr ) {
2018-06-19 17:46:37 +02:00
doSamplingSingle ( WPAD_CHAN_0 , deviceslot , padslot , ignorePadSlot ) ;
doSamplingSingle ( WPAD_CHAN_1 , deviceslot , padslot , ignorePadSlot ) ;
doSamplingSingle ( WPAD_CHAN_2 , deviceslot , padslot , ignorePadSlot ) ;
doSamplingSingle ( WPAD_CHAN_3 , deviceslot , padslot , ignorePadSlot ) ;
2018-06-19 17:39:20 +02:00
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}
2023-04-10 11:45:58 +02:00
CONTROLLER_PATCHER_RESULT_OR_ERROR ControllerPatcherUtils : : doSamplingSingle ( WPADChan chan , uint16_t deviceslot , uint8_t padslot = 0 , BOOL ignorePadSlot = false ) {
ControllerMappingPADInfo * padinfo = gProPadInfo [ chan ] ;
if ( padinfo - > active ) {
2018-06-19 17:39:20 +02:00
DeviceInfo device_info ;
2023-04-10 11:45:58 +02:00
memset ( & device_info , 0 , sizeof ( device_info ) ) ;
2018-06-19 17:39:20 +02:00
device_info . vidpid = padinfo - > vidpid ;
2018-06-20 15:07:15 +02:00
int32_t res = - 1 ;
2023-04-10 11:45:58 +02:00
if ( ( res = ControllerPatcherUtils : : getDeviceInfoFromVidPid ( & device_info ) ) > = 0 ) {
if ( ! ignorePadSlot ) {
int32_t real_pad = ( padinfo - > pad / ( device_info . pad_count ) ) * device_info . pad_count ;
if ( real_pad = = padslot & & device_info . slotdata . deviceslot = = deviceslot ) {
if ( ControllerPatcherUtils : : checkActivePad ( device_info . slotdata . hidmask , padinfo - > pad ) ) {
2018-06-19 17:39:20 +02:00
gSamplingCallback ( chan ) ;
2017-04-23 15:19:21 +02:00
}
}
2018-06-19 17:46:37 +02:00
} else {
2018-06-19 17:39:20 +02:00
gSamplingCallback ( chan ) ;
2017-04-23 15:19:21 +02:00
}
}
}
return CONTROLLER_PATCHER_ERROR_NONE ;
}