Merge remote-tracking branch 'origin/master' into fix_debug_message

This commit is contained in:
Werner Sembach 2023-05-15 19:55:07 +02:00
commit d289adea61
4 changed files with 31 additions and 4 deletions

View file

@ -64,6 +64,17 @@ void clevo_leds_set_color_extern(u32 color);
static enum clevo_kb_backlight_types clevo_kb_backlight_type = CLEVO_KB_BACKLIGHT_TYPE_NONE;
static bool leds_initialized = false;
/**
* Color scaling quirk list
*/
static void color_scaling(enum clevo_kb_backlight_types *type, u8 *red, u8 *green, u8 *blue)
{
if (*type == CLEVO_KB_BACKLIGHT_TYPE_1_ZONE_RGB) {
*red = (180 * *red) / 255;
*blue = (200 * *blue) / 255;
}
}
static int clevo_evaluate_set_white_brightness(u8 brightness)
{
pr_debug("Set white brightness to %d\n", brightness);
@ -134,6 +145,7 @@ static struct led_classdev_mc clevo_mcled_cdevs[3]; // forward declaration
static void clevo_leds_set_brightness_mc(struct led_classdev *led_cdev, enum led_brightness brightness) {
int ret;
u32 zone, color;
u8 red, green, blue;
struct led_classdev_mc *mcled_cdev = lcdev_to_mccdev(led_cdev);
ret = clevo_evaluate_set_rgb_brightness(brightness);
@ -147,9 +159,15 @@ static void clevo_leds_set_brightness_mc(struct led_classdev *led_cdev, enum led
zone = mcled_cdev->subled_info[0].channel;
color = (mcled_cdev->subled_info[0].intensity << 16) +
(mcled_cdev->subled_info[1].intensity << 8) +
mcled_cdev->subled_info[2].intensity;
red = mcled_cdev->subled_info[0].intensity;
green = mcled_cdev->subled_info[1].intensity;
blue = mcled_cdev->subled_info[2].intensity;
color_scaling(&clevo_kb_backlight_type, &red, &green, &blue);
color = (red << 16) +
(green << 8) +
blue;
ret = clevo_evaluate_set_rgb_color(zone, color);
if (ret) {

View file

@ -82,6 +82,9 @@ static int tdp_max_ph4tqx[] = { 0x32, 0x32, 0x00 };
static int tdp_min_ph4axx[] = { 0x05, 0x05, 0x00 };
static int tdp_max_ph4axx[] = { 0x2d, 0x3c, 0x00 };
static int tdp_min_phxpxx[] = { 0x05, 0x05, 0x05 };
static int tdp_max_phxpxx[] = { 0x2a, 0x32, 0x5a };
static int tdp_min_pfxluxg[] = { 0x05, 0x05, 0x05 };
static int tdp_max_pfxluxg[] = { 0x23, 0x23, 0x28 };
@ -124,6 +127,9 @@ void uw_id_tdp(void)
tdp_min_defs = tdp_min_ph4axx;
tdp_max_defs = tdp_max_ph4axx;
#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 18, 0)
} else if (dmi_match(DMI_PRODUCT_SKU, "IBP1XI08MK1")) {
tdp_min_defs = tdp_min_phxpxx;
tdp_max_defs = tdp_max_phxpxx;
} else if (dmi_match(DMI_PRODUCT_SKU, "PULSE1502")) {
tdp_min_defs = tdp_min_pfxluxg;
tdp_max_defs = tdp_max_pfxluxg;

View file

@ -64,6 +64,7 @@ typedef void (uniwill_event_callb_t)(u32);
#define UW_EC_REG_BAREBONE_ID_VALUE_PH6TRX1 0x15
#define UW_EC_REG_BAREBONE_ID_VALUE_PH6TQxx 0x16
#define UW_EC_REG_BAREBONE_ID_VALUE_PH4Axxx 0x17
#define UW_EC_REG_BAREBONE_ID_VALUE_PH4Pxxx 0x18
#define UW_EC_REG_FEATURES_0 0x0765
#define UW_EC_REG_FEATURES_1 0x0766

View file

@ -179,6 +179,7 @@ int uniwill_leds_init_early(struct platform_device *dev)
pr_err("Reading barebone ID failed.\n");
return ret;
}
pr_debug("EC Barebone ID: %#04x\n", data);
if (data == UW_EC_REG_BAREBONE_ID_VALUE_PFxxxxx ||
data == UW_EC_REG_BAREBONE_ID_VALUE_PFxMxxx ||
@ -187,7 +188,8 @@ int uniwill_leds_init_early(struct platform_device *dev)
data == UW_EC_REG_BAREBONE_ID_VALUE_PH4TQx1 ||
data == UW_EC_REG_BAREBONE_ID_VALUE_PH6TRX1 ||
data == UW_EC_REG_BAREBONE_ID_VALUE_PH6TQxx ||
data == UW_EC_REG_BAREBONE_ID_VALUE_PH4Axxx) {
data == UW_EC_REG_BAREBONE_ID_VALUE_PH4Axxx ||
data == UW_EC_REG_BAREBONE_ID_VALUE_PH4Pxxx) {
ret = uniwill_read_ec_ram(UW_EC_REG_KBD_BL_STATUS, &data);
if (ret) {
pr_err("Reading keyboard backlight status failed.\n");