From nobody Mon Dec 1 22:07:42 2025 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id D1949319879; Thu, 27 Nov 2025 15:22:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764256920; cv=none; b=rZoP8/3+m2apE59dD+LyCYVsnUNuwYPd3piLzbyAb7L/QmUinEGBSkZuAlt1KjQRZGmSj50TkQ49kBNcujLuzY13GHAQxZyfhJkS2jATA3Y0ehPZcK12WXcoVZYQbTcejYPqlpt5mVOVoBIAz72f8nNw+PpEaTsBIRsFLRCtGCs= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764256920; c=relaxed/simple; bh=gVhESOkmKjuGVV06aX411jDqb6iPlthW8WuYwx7lyUM=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=W6GIWar7zGfDAmHw2fepcxDGTXHLB2LIX9S87P6MAO/8kvaT4+4YxaLKUphOfpvNgPecvVyzZ2Oukv/nxX0qkHoHjqr9L9430w54a2Vf8uTNKCByvtRQCUVWIDJCe9uxZpEH6ZBHIjl3MAkWl1blpftfKWqZU6NtogyxCee3gqA= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=Wx/qw42/; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="Wx/qw42/" Received: by smtp.kernel.org (Postfix) with ESMTPS id 84427C116C6; Thu, 27 Nov 2025 15:22:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1764256920; bh=gVhESOkmKjuGVV06aX411jDqb6iPlthW8WuYwx7lyUM=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=Wx/qw42/w9E63rx2v1OoP+nndxbw4JSvLXrQ3vWpshG390S0YfcgQgQh5GBVsNeKC kIpklEv7JdgMw7KAWLmz3HXuUCb7KxTLo5qK5wGC+6d626osVKYz1FVtNTdUfLMpFN QJSjnaYSOAtbXx5ug5OJcfbx7X+UCU2I1izU2InNoJqSapz+hMght8ENExSPmue96c frLnJRmFvDKuvzqEhT6o6S/LS+ijih4Z1++EzDPrj5i2peb39iIIHS1O3vSYFk6kk6 sXIa0sxCTP9ieV9L7uvF+tBnzrYkKU0CGYOKh64XagqSt77jeFB1aOXCkFZ/JbTkH4 7xPPpmTyk1AMg== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 794BBCFD2F6; Thu, 27 Nov 2025 15:22:00 +0000 (UTC) From: Petri Karhula via B4 Relay Date: Thu, 27 Nov 2025 15:21:59 +0000 Subject: [PATCH v4 1/2] backlight: Add Congatec Board Controller (CGBC) backlight support Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20251127-cgbc-backlight-v4-1-626523b7173d@novatron.fi> References: <20251127-cgbc-backlight-v4-0-626523b7173d@novatron.fi> In-Reply-To: <20251127-cgbc-backlight-v4-0-626523b7173d@novatron.fi> To: Thomas Richard , Lee Jones , Daniel Thompson , Jingoo Han , Helge Deller Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, Petri Karhula X-Mailer: b4 0.14.3 X-Developer-Signature: v=1; a=ed25519-sha256; t=1764256919; l=7417; i=petri.karhula@novatron.fi; s=20251118; h=from:subject:message-id; bh=yHl1hy2ShanG6GuXCMZ/Oka+38X3BVs0xMSpmGxTwNA=; b=cC0V+gH/ZHawz8ISiNjNRDf8DSZmGPW4tbQ5XsaCiVQGKYa/o9RAhug6yTW3lXwdCCfb219sK MDHSxbLJ00TCh76PfBeHGIWEj3QeZP6vsIqxOSEYiLOKJUrvVsYzNgi X-Developer-Key: i=petri.karhula@novatron.fi; a=ed25519; pk=LRYJ99jPPsHJwdJEPkqlmzAMqo6oyw7I421aHEfDp7o= X-Endpoint-Received: by B4 Relay for petri.karhula@novatron.fi/20251118 with auth_id=567 X-Original-From: Petri Karhula Reply-To: petri.karhula@novatron.fi From: Petri Karhula This driver provides backlight brightness control through the Linux backlight subsystem. It communicates with the board controller to adjust LCD backlight using PWM signals. Communication is done through Congatec Board Controller core driver. Signed-off-by: Petri Karhula Reviewed-by: Daniel Thompson (RISCstar) Reviewed-by: Thomas Richard Tested-by: Thomas Richard --- drivers/video/backlight/Kconfig | 11 +++ drivers/video/backlight/Makefile | 1 + drivers/video/backlight/cgbc_bl.c | 179 ++++++++++++++++++++++++++++++++++= ++++ 3 files changed, 191 insertions(+) diff --git a/drivers/video/backlight/Kconfig b/drivers/video/backlight/Kcon= fig index d9374d208cee..702f3b8ed036 100644 --- a/drivers/video/backlight/Kconfig +++ b/drivers/video/backlight/Kconfig @@ -249,6 +249,17 @@ config BACKLIGHT_PWM If you have a LCD backlight adjustable by PWM, say Y to enable this driver. =20 +config BACKLIGHT_CGBC + tristate "Congatec Board Controller (CGBC) backlight support" + depends on MFD_CGBC && X86 + help + Say Y here to enable support for LCD backlight control on Congatec + x86-based boards via the CGBC (Congatec Board Controller). + + This driver provides backlight brightness control through the Linux + backlight subsystem. It communicates with the board controller to + adjust LCD backlight using PWM signals. + config BACKLIGHT_DA903X tristate "Backlight Driver for DA9030/DA9034 using WLED" depends on PMIC_DA903X diff --git a/drivers/video/backlight/Makefile b/drivers/video/backlight/Mak= efile index dfbb169bf6ea..0169fd8873ed 100644 --- a/drivers/video/backlight/Makefile +++ b/drivers/video/backlight/Makefile @@ -27,6 +27,7 @@ obj-$(CONFIG_BACKLIGHT_APPLE_DWI) +=3D apple_dwi_bl.o obj-$(CONFIG_BACKLIGHT_AS3711) +=3D as3711_bl.o obj-$(CONFIG_BACKLIGHT_BD6107) +=3D bd6107.o obj-$(CONFIG_BACKLIGHT_CLASS_DEVICE) +=3D backlight.o +obj-$(CONFIG_BACKLIGHT_CGBC) +=3D cgbc_bl.o obj-$(CONFIG_BACKLIGHT_DA903X) +=3D da903x_bl.o obj-$(CONFIG_BACKLIGHT_DA9052) +=3D da9052_bl.o obj-$(CONFIG_BACKLIGHT_EP93XX) +=3D ep93xx_bl.o diff --git a/drivers/video/backlight/cgbc_bl.c b/drivers/video/backlight/cg= bc_bl.c new file mode 100644 index 000000000000..74f80222d789 --- /dev/null +++ b/drivers/video/backlight/cgbc_bl.c @@ -0,0 +1,179 @@ +// SPDX-License-Identifier: GPL-2.0-only +/* + * Congatec Board Controller (CGBC) Backlight Driver + * + * This driver provides backlight control for LCD displays connected to + * Congatec boards via the CGBC (Congatec Board Controller). It integrates + * with the Linux backlight subsystem and communicates with hardware throu= gh + * the cgbc-core module. + * + * Copyright (C) 2025 Novatron Oy + * + * Author: Petri Karhula + */ + +#include +#include +#include +#include +#include +#include + +#define BLT_PWM_DUTY_MASK GENMASK(6, 0) + +/* CGBC command for PWM brightness control*/ +#define CGBC_CMD_BLT0_PWM 0x75 + +#define CGBC_BL_MAX_BRIGHTNESS 100 + +/** + * CGBC backlight driver data + * @dev: Pointer to the platform device + * @cgbc: Pointer to the parent CGBC device data + * @current_brightness: Current brightness level (0-100) + */ +struct cgbc_bl_data { + struct device *dev; + struct cgbc_device_data *cgbc; + unsigned int current_brightness; +}; + +static int cgbc_bl_read_brightness(struct cgbc_bl_data *bl_data) +{ + u8 cmd_buf[4] =3D { CGBC_CMD_BLT0_PWM }; + u8 reply_buf[3]; + int ret; + + ret =3D cgbc_command(bl_data->cgbc, cmd_buf, sizeof(cmd_buf), + reply_buf, sizeof(reply_buf), NULL); + if (ret < 0) + return ret; + + /* + * Get only PWM duty factor percentage, + * ignore polarity inversion bit (bit 7) + */ + bl_data->current_brightness =3D FIELD_GET(BLT_PWM_DUTY_MASK, reply_buf[0]= ); + + return 0; +} + +static int cgbc_bl_update_status(struct backlight_device *bl) +{ + struct cgbc_bl_data *bl_data =3D bl_get_data(bl); + u8 cmd_buf[4] =3D { CGBC_CMD_BLT0_PWM }; + u8 reply_buf[3]; + u8 brightness; + int ret; + + brightness =3D backlight_get_brightness(bl); + + if (brightness !=3D bl_data->current_brightness) { + /* Read the current values */ + ret =3D cgbc_command(bl_data->cgbc, cmd_buf, sizeof(cmd_buf), reply_buf, + sizeof(reply_buf), NULL); + if (ret < 0) { + dev_err(bl_data->dev, "Failed to read PWM settings: %d\n", ret); + return ret; + } + + /* + * Prepare command buffer for writing new settings. Only 2nd byte is cha= nged + * to set new brightness (PWM duty cycle %). Other values (polarity, fre= quency) + * are preserved from the read values. + */ + cmd_buf[1] =3D (reply_buf[0] & ~BLT_PWM_DUTY_MASK) | + FIELD_PREP(BLT_PWM_DUTY_MASK, brightness); + cmd_buf[2] =3D reply_buf[1]; + cmd_buf[3] =3D reply_buf[2]; + + ret =3D cgbc_command(bl_data->cgbc, cmd_buf, sizeof(cmd_buf), reply_buf, + sizeof(reply_buf), NULL); + if (ret < 0) { + dev_err(bl_data->dev, "Failed to set brightness: %d\n", ret); + return ret; + } + + bl_data->current_brightness =3D reply_buf[0] & BLT_PWM_DUTY_MASK; + + /* Verify the setting was applied correctly */ + if (bl_data->current_brightness !=3D brightness) { + dev_err(bl_data->dev, + "Brightness setting verification failed\n"); + return -EIO; + } + } + + return 0; +} + +static int cgbc_bl_get_brightness(struct backlight_device *bl) +{ + struct cgbc_bl_data *bl_data =3D bl_get_data(bl); + int ret; + + ret =3D cgbc_bl_read_brightness(bl_data); + if (ret < 0) { + dev_err(bl_data->dev, "Failed to read brightness: %d\n", ret); + return ret; + } + + return bl_data->current_brightness; +} + +static const struct backlight_ops cgbc_bl_ops =3D { + .options =3D BL_CORE_SUSPENDRESUME, + .update_status =3D cgbc_bl_update_status, + .get_brightness =3D cgbc_bl_get_brightness, +}; + +static int cgbc_bl_probe(struct platform_device *pdev) +{ + struct cgbc_device_data *cgbc =3D dev_get_drvdata(pdev->dev.parent); + struct backlight_properties props =3D { }; + struct backlight_device *bl_dev; + struct cgbc_bl_data *bl_data; + int ret; + + bl_data =3D devm_kzalloc(&pdev->dev, sizeof(*bl_data), GFP_KERNEL); + if (!bl_data) + return -ENOMEM; + + bl_data->dev =3D &pdev->dev; + bl_data->cgbc =3D cgbc; + + ret =3D cgbc_bl_read_brightness(bl_data); + if (ret < 0) + return dev_err_probe(&pdev->dev, ret, + "Failed to read initial brightness\n"); + + props.type =3D BACKLIGHT_PLATFORM; + props.max_brightness =3D CGBC_BL_MAX_BRIGHTNESS; + props.brightness =3D bl_data->current_brightness; + props.scale =3D BACKLIGHT_SCALE_LINEAR; + + bl_dev =3D devm_backlight_device_register(&pdev->dev, "cgbc-backlight", + &pdev->dev, bl_data, + &cgbc_bl_ops, &props); + if (IS_ERR(bl_dev)) + return dev_err_probe(&pdev->dev, PTR_ERR(bl_dev), + "Failed to register backlight device\n"); + + platform_set_drvdata(pdev, bl_data); + + return 0; +} + +static struct platform_driver cgbc_bl_driver =3D { + .driver =3D { + .name =3D "cgbc-backlight", + }, + .probe =3D cgbc_bl_probe, +}; + +module_platform_driver(cgbc_bl_driver); + +MODULE_AUTHOR("Petri Karhula "); +MODULE_DESCRIPTION("Congatec Board Controller (CGBC) Backlight Driver"); +MODULE_LICENSE("GPL"); +MODULE_ALIAS("platform:cgbc-backlight"); --=20 2.34.1 From nobody Mon Dec 1 22:07:42 2025 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id ED83A3358CC; Thu, 27 Nov 2025 15:22:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764256923; cv=none; b=OnZb81uc74m1I6bg1jxys9zJWE/Sm0WfK8vVQ6/tGTKJybHTWi/p799RWcnadPI1I3CXmT5eGlifdpespExwgLXwoys+zAB0kQbM794ypsHA/cnZiQjiOSl0h2m84B+y7SBlrc7S0nI6Y+2HjW/f7H5LBy30tbcRQIw7gvJ9qg4= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1764256923; c=relaxed/simple; bh=jcPepnZLZgpDua5txvocFEmcFpPGA3RIdeogtsflON8=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References: In-Reply-To:To:Cc; b=j4JxNJlh0z8I0RgL9LbjeAsJK/cWS+m5YLRe+cfH+fvEawpR/0hJGlrELMyj+35YaiRod8FWd9LPyHzV4y+gFfHw/EiFRHmQ9opVV8nVpUPl108cNSpuBBmvr8ZrN38X2kuHTzBQlWEJ1wvpqj5QNDYuceI8KaT96CcLlUztxb0= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=FJkPje3t; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="FJkPje3t" Received: by smtp.kernel.org (Postfix) with ESMTPS id 96300C116D0; Thu, 27 Nov 2025 15:22:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1764256920; bh=jcPepnZLZgpDua5txvocFEmcFpPGA3RIdeogtsflON8=; h=From:Date:Subject:References:In-Reply-To:To:Cc:Reply-To:From; b=FJkPje3tTCGdHtnTEx/KMCWBYmgJscR+W3TgsoJ5utstmrJd0gBb48OFttWsu35i4 rv+N13OGBJTLAX7wUBqKC00LktGNfdN3v7SqHej3j89VWJn3aLJbv5bovWwwnkOR0R CTfYTzBr16PqFvMVCsdxfYbMejQU+Sj+HYMnblPWLH5ZDs70VdFD2RU87bBZClafEv ZLITrV2Q8QyVogIuGImFfULlJchEsrbo/unqfHrqbfmwtXsyqXrtXNtYucUPIpfRRB mgp2Tkwu77Wkrd6EMnfe8kkHvfdv94eeaR0aLVEa4im7q2WGK0dv+MBvLZ5FZVvj5Q gm8NxJUac4R0w== Received: from aws-us-west-2-korg-lkml-1.web.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8CCABD116F5; Thu, 27 Nov 2025 15:22:00 +0000 (UTC) From: Petri Karhula via B4 Relay Date: Thu, 27 Nov 2025 15:22:00 +0000 Subject: [PATCH v4 2/2] mfd: cgbc: Add support for backlight Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20251127-cgbc-backlight-v4-2-626523b7173d@novatron.fi> References: <20251127-cgbc-backlight-v4-0-626523b7173d@novatron.fi> In-Reply-To: <20251127-cgbc-backlight-v4-0-626523b7173d@novatron.fi> To: Thomas Richard , Lee Jones , Daniel Thompson , Jingoo Han , Helge Deller Cc: linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, Petri Karhula X-Mailer: b4 0.14.3 X-Developer-Signature: v=1; a=ed25519-sha256; t=1764256919; l=730; i=petri.karhula@novatron.fi; s=20251118; h=from:subject:message-id; bh=KPNSZCbWidPbzGQwgMCbuFj/C6Dnnhi7zAXThQ+Pso8=; b=e2lTmkqyYL2lvoBpDSI9YvqxziY/8WcYfbee+pofEMx4BfEH0cI64hldpZ5qWBMQaPCGx+dbW wN4GsI6gxYtDJAQHmLwZwtRrftEmknjdQxiJrFL4zg8YRHtg+7/tIH4 X-Developer-Key: i=petri.karhula@novatron.fi; a=ed25519; pk=LRYJ99jPPsHJwdJEPkqlmzAMqo6oyw7I421aHEfDp7o= X-Endpoint-Received: by B4 Relay for petri.karhula@novatron.fi/20251118 with auth_id=567 X-Original-From: Petri Karhula Reply-To: petri.karhula@novatron.fi From: Petri Karhula The Board Controller has control for display backlight. Add backlight cell for the cgbc-backlight driver which adds support for backlight brightness control. Signed-off-by: Petri Karhula --- drivers/mfd/cgbc-core.c | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/mfd/cgbc-core.c b/drivers/mfd/cgbc-core.c index 4782ff1114a9..10bb4b414c34 100644 --- a/drivers/mfd/cgbc-core.c +++ b/drivers/mfd/cgbc-core.c @@ -237,6 +237,7 @@ static struct mfd_cell cgbc_devs[] =3D { { .name =3D "cgbc-i2c", .id =3D 1 }, { .name =3D "cgbc-i2c", .id =3D 2 }, { .name =3D "cgbc-hwmon" }, + { .name =3D "cgbc-backlight" }, }; =20 static int cgbc_map(struct cgbc_device_data *cgbc) --=20 2.34.1