platform/x86: oxpec: Add support for the OneXPlayer G1

The OneXPlayer G1 is a new clamshell formfactor by OneXPlayer.
It has the same registers as an OneXPlayer X1, with the only
difference being the lack of a turbo led.

Tested-by: Joshua Tam <csinaction@pm.me>
Suggested-by: Joshua Tam <csinaction@pm.me>
Signed-off-by: Joshua Tam <csinaction@pm.me>
Signed-off-by: Antheas Kapenekakis <lkml@antheas.dev>
Link: https://lore.kernel.org/r/20250426172955.13957-3-lkml@antheas.dev
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
This commit is contained in:
Antheas Kapenekakis 2025-04-26 19:29:55 +02:00 committed by Ilpo Järvinen
parent e25a982b38
commit b369395c89
No known key found for this signature in database
GPG key ID: 59AC4F6153E5CE31

View file

@ -58,6 +58,7 @@ enum oxp_board {
oxp_mini_amd_a07, oxp_mini_amd_a07,
oxp_mini_amd_pro, oxp_mini_amd_pro,
oxp_x1, oxp_x1,
oxp_g1,
}; };
static enum oxp_board board; static enum oxp_board board;
@ -241,6 +242,20 @@ static const struct dmi_system_id dmi_table[] = {
}, },
.driver_data = (void *)oxp_fly, .driver_data = (void *)oxp_fly,
}, },
{
.matches = {
DMI_MATCH(DMI_BOARD_VENDOR, "ONE-NETBOOK"),
DMI_EXACT_MATCH(DMI_BOARD_NAME, "ONEXPLAYER G1 A"),
},
.driver_data = (void *)oxp_g1,
},
{
.matches = {
DMI_MATCH(DMI_BOARD_VENDOR, "ONE-NETBOOK"),
DMI_EXACT_MATCH(DMI_BOARD_NAME, "ONEXPLAYER G1 i"),
},
.driver_data = (void *)oxp_g1,
},
{ {
.matches = { .matches = {
DMI_MATCH(DMI_BOARD_VENDOR, "ONE-NETBOOK"), DMI_MATCH(DMI_BOARD_VENDOR, "ONE-NETBOOK"),
@ -337,6 +352,7 @@ static umode_t tt_toggle_is_visible(struct kobject *kobj,
case oxp_mini_amd_a07: case oxp_mini_amd_a07:
case oxp_mini_amd_pro: case oxp_mini_amd_pro:
case oxp_x1: case oxp_x1:
case oxp_g1:
return attr->mode; return attr->mode;
default: default:
break; break;
@ -370,6 +386,7 @@ static ssize_t tt_toggle_store(struct device *dev,
break; break;
case oxp_2: case oxp_2:
case oxp_x1: case oxp_x1:
case oxp_g1:
reg = OXP_2_TURBO_SWITCH_REG; reg = OXP_2_TURBO_SWITCH_REG;
mask = OXP_TURBO_TAKE_VAL; mask = OXP_TURBO_TAKE_VAL;
break; break;
@ -414,6 +431,7 @@ static ssize_t tt_toggle_show(struct device *dev,
break; break;
case oxp_2: case oxp_2:
case oxp_x1: case oxp_x1:
case oxp_g1:
reg = OXP_2_TURBO_SWITCH_REG; reg = OXP_2_TURBO_SWITCH_REG;
mask = OXP_TURBO_TAKE_VAL; mask = OXP_TURBO_TAKE_VAL;
break; break;
@ -502,6 +520,7 @@ static bool oxp_psy_ext_supported(void)
{ {
switch (board) { switch (board) {
case oxp_x1: case oxp_x1:
case oxp_g1:
case oxp_fly: case oxp_fly:
return true; return true;
default: default:
@ -640,6 +659,7 @@ static int oxp_pwm_enable(void)
case oxp_mini_amd_a07: case oxp_mini_amd_a07:
case oxp_mini_amd_pro: case oxp_mini_amd_pro:
case oxp_x1: case oxp_x1:
case oxp_g1:
return write_to_ec(OXP_SENSOR_PWM_ENABLE_REG, PWM_MODE_MANUAL); return write_to_ec(OXP_SENSOR_PWM_ENABLE_REG, PWM_MODE_MANUAL);
default: default:
return -EINVAL; return -EINVAL;
@ -666,6 +686,7 @@ static int oxp_pwm_disable(void)
case oxp_mini_amd_a07: case oxp_mini_amd_a07:
case oxp_mini_amd_pro: case oxp_mini_amd_pro:
case oxp_x1: case oxp_x1:
case oxp_g1:
return write_to_ec(OXP_SENSOR_PWM_ENABLE_REG, PWM_MODE_AUTO); return write_to_ec(OXP_SENSOR_PWM_ENABLE_REG, PWM_MODE_AUTO);
default: default:
return -EINVAL; return -EINVAL;
@ -692,6 +713,7 @@ static int oxp_pwm_read(long *val)
case oxp_mini_amd_a07: case oxp_mini_amd_a07:
case oxp_mini_amd_pro: case oxp_mini_amd_pro:
case oxp_x1: case oxp_x1:
case oxp_g1:
return read_from_ec(OXP_SENSOR_PWM_ENABLE_REG, 1, val); return read_from_ec(OXP_SENSOR_PWM_ENABLE_REG, 1, val);
default: default:
return -EOPNOTSUPP; return -EOPNOTSUPP;
@ -720,6 +742,7 @@ static int oxp_pwm_fan_speed(long *val)
return read_from_ec(ORANGEPI_SENSOR_FAN_REG, 2, val); return read_from_ec(ORANGEPI_SENSOR_FAN_REG, 2, val);
case oxp_2: case oxp_2:
case oxp_x1: case oxp_x1:
case oxp_g1:
return read_from_ec(OXP_2_SENSOR_FAN_REG, 2, val); return read_from_ec(OXP_2_SENSOR_FAN_REG, 2, val);
case aok_zoe_a1: case aok_zoe_a1:
case aya_neo_2: case aya_neo_2:
@ -753,6 +776,7 @@ static int oxp_pwm_input_write(long val)
return write_to_ec(ORANGEPI_SENSOR_PWM_REG, val); return write_to_ec(ORANGEPI_SENSOR_PWM_REG, val);
case oxp_2: case oxp_2:
case oxp_x1: case oxp_x1:
case oxp_g1:
/* scale to range [0-184] */ /* scale to range [0-184] */
val = (val * 184) / 255; val = (val * 184) / 255;
return write_to_ec(OXP_SENSOR_PWM_REG, val); return write_to_ec(OXP_SENSOR_PWM_REG, val);
@ -792,6 +816,7 @@ static int oxp_pwm_input_read(long *val)
break; break;
case oxp_2: case oxp_2:
case oxp_x1: case oxp_x1:
case oxp_g1:
ret = read_from_ec(OXP_SENSOR_PWM_REG, 1, val); ret = read_from_ec(OXP_SENSOR_PWM_REG, 1, val);
if (ret) if (ret)
return ret; return ret;