{"id":2222973,"url":"http://patchwork.ozlabs.org/api/patches/2222973/?format=json","web_url":"http://patchwork.ozlabs.org/project/rtc-linux/patch/20260414-s2mu005-pmic-v4-13-7fe7480577e6@disroot.org/","project":{"id":9,"url":"http://patchwork.ozlabs.org/api/projects/9/?format=json","name":"Linux RTC development","link_name":"rtc-linux","list_id":"linux-rtc.vger.kernel.org","list_email":"linux-rtc@vger.kernel.org","web_url":"","scm_url":"","webscm_url":"","list_archive_url":"","list_archive_url_format":"","commit_url_format":""},"msgid":"<20260414-s2mu005-pmic-v4-13-7fe7480577e6@disroot.org>","list_archive_url":null,"date":"2026-04-14T06:33:05","name":"[v4,13/13] power: supply: add support for Samsung S2M series PMIC charger device","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"b9f1cfbf7213361ef3083531b78f0cc20520e19d","submitter":{"id":88698,"url":"http://patchwork.ozlabs.org/api/people/88698/?format=json","name":"Kaustabh Chakraborty","email":"kauschluss@disroot.org"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/rtc-linux/patch/20260414-s2mu005-pmic-v4-13-7fe7480577e6@disroot.org/mbox/","series":[{"id":499781,"url":"http://patchwork.ozlabs.org/api/series/499781/?format=json","web_url":"http://patchwork.ozlabs.org/project/rtc-linux/list/?series=499781","date":"2026-04-14T06:32:53","name":"Support for Samsung S2MU005 PMIC and its sub-devices","version":4,"mbox":"http://patchwork.ozlabs.org/series/499781/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2222973/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2222973/checks/","tags":{},"related":[],"headers":{"Return-Path":"\n <linux-rtc+bounces-6329-incoming=patchwork.ozlabs.org@vger.kernel.org>","X-Original-To":["incoming@patchwork.ozlabs.org","linux-rtc@vger.kernel.org"],"Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n secure) header.d=disroot.org header.i=@disroot.org header.a=rsa-sha256\n header.s=mail header.b=KtyhWiPJ;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=172.105.105.114; helo=tor.lore.kernel.org;\n envelope-from=linux-rtc+bounces-6329-incoming=patchwork.ozlabs.org@vger.kernel.org;\n receiver=patchwork.ozlabs.org)","smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=disroot.org header.i=@disroot.org\n header.b=\"KtyhWiPJ\"","smtp.subspace.kernel.org;\n arc=none smtp.client-ip=178.21.23.139","smtp.subspace.kernel.org;\n dmarc=pass (p=reject dis=none) header.from=disroot.org","smtp.subspace.kernel.org;\n spf=pass smtp.mailfrom=disroot.org"],"Received":["from tor.lore.kernel.org (tor.lore.kernel.org [172.105.105.114])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4fvvkl11Tnz1y2d\n\tfor <incoming@patchwork.ozlabs.org>; Tue, 14 Apr 2026 16:39:11 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby tor.lore.kernel.org (Postfix) with ESMTP id 37857307B413\n\tfor <incoming@patchwork.ozlabs.org>; Tue, 14 Apr 2026 06:34:47 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id EB4AB36EAAB;\n\tTue, 14 Apr 2026 06:34:43 +0000 (UTC)","from layka.disroot.org (layka.disroot.org [178.21.23.139])\n\t(using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits))\n\t(No client certificate requested)\n\tby smtp.subspace.kernel.org (Postfix) with ESMTPS id 0E17836EA82;\n\tTue, 14 Apr 2026 06:34:41 +0000 (UTC)","from [127.0.0.1] (localhost [127.0.0.1])\n\tby disroot.org (Postfix) with ESMTP id 9E94825D82;\n\tTue, 14 Apr 2026 08:34:40 +0200 (CEST)","from layka.disroot.org ([127.0.0.1])\n by localhost (disroot.org [127.0.0.1]) (amavis, port 10024) with ESMTP\n id w0t6YYEf_u20; Tue, 14 Apr 2026 08:34:39 +0200 (CEST)"],"ARC-Seal":"i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1776148483; cv=none;\n b=byv/ZJ32Fs40APIZmb5IEDZqC0Mvuij9SvSO3xiswSHEMhNaA/kITdqDAtUwymgS5K4N8eh08aDe0HJ23KMMOQL5H7lRxrYKzEVlSK0+Vj6LnjBUNzVrNoUePkXnaFKIGS7wXDhtW0blEGlArQ5Lt7TOVvLmbHblKes3/BO5OWQ=","ARC-Message-Signature":"i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1776148483; c=relaxed/simple;\n\tbh=0c6lfJuH7ZJGsVDLlmGmYTAoyFwCX6EtPs7P4iHdSsU=;\n\th=From:Date:Subject:MIME-Version:Content-Type:Message-Id:References:\n\t In-Reply-To:To:Cc;\n b=TW91BbuRx7e1XjWW7prpRFiNdHUNu/xYaXqqLsZpy9JfChmH8tGFCHp+JEvw0XBk5AM3SgmNFJUcVvJ2f55yXyTOOtEh5aggEp5V5E94AbpIif8yWWCF6GCLRDU8TxpSGGqQuWU+0M+EzUN4RH1LnCFJT5EiR8ued3PBaeRA9Vs=","ARC-Authentication-Results":"i=1; smtp.subspace.kernel.org;\n dmarc=pass (p=reject dis=none) header.from=disroot.org;\n spf=pass smtp.mailfrom=disroot.org;\n dkim=pass (2048-bit key) header.d=disroot.org header.i=@disroot.org\n header.b=KtyhWiPJ; arc=none smtp.client-ip=178.21.23.139","X-Virus-Scanned":"SPAM Filter at disroot.org","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/simple; d=disroot.org; s=mail;\n\tt=1776148479; bh=0c6lfJuH7ZJGsVDLlmGmYTAoyFwCX6EtPs7P4iHdSsU=;\n\th=From:Date:Subject:References:In-Reply-To:To:Cc;\n\tb=KtyhWiPJ8uLlZkBvVIku/Ayzhv6AJtTSY5D8SqeYjRHUgIi6ataMjyUA2ccEXQ9a+\n\t tpwgko2RKbxms04APMltNmj7ZZLtynrCB1YENuyQ5pfvOX5YJuRi6bv05kVIschaL2\n\t ko6J8LnLJJNhgkGaRKSa+x0Kc7z2D53RqR1ssitR3AoK1UhWVhZ+lhhyjDkIb7HaFf\n\t hT6zAo5Bdob8gSJIU2LM2iqpu59J4mHBzZYZl4lfkNw2YnwgU3mlOgub/pBDAQLHej\n\t ZEIV/7K2WNUDVHrrwpmAk7rntJLLors0Fwn93/YPIdHVesIjFDtkif0JjKOT/tFVfX\n\t Tf47y99Mu8HIg==","From":"Kaustabh Chakraborty <kauschluss@disroot.org>","Date":"Tue, 14 Apr 2026 12:03:05 +0530","Subject":"[PATCH v4 13/13] power: supply: add support for Samsung S2M series\n PMIC charger device","Precedence":"bulk","X-Mailing-List":"linux-rtc@vger.kernel.org","List-Id":"<linux-rtc.vger.kernel.org>","List-Subscribe":"<mailto:linux-rtc+subscribe@vger.kernel.org>","List-Unsubscribe":"<mailto:linux-rtc+unsubscribe@vger.kernel.org>","MIME-Version":"1.0","Content-Type":"text/plain; charset=\"utf-8\"","Content-Transfer-Encoding":"8bit","Message-Id":"<20260414-s2mu005-pmic-v4-13-7fe7480577e6@disroot.org>","References":"<20260414-s2mu005-pmic-v4-0-7fe7480577e6@disroot.org>","In-Reply-To":"<20260414-s2mu005-pmic-v4-0-7fe7480577e6@disroot.org>","To":"Lee Jones <lee@kernel.org>, Pavel Machek <pavel@kernel.org>,\n  Rob Herring <robh@kernel.org>, Krzysztof Kozlowski <krzk+dt@kernel.org>,\n  Conor Dooley <conor+dt@kernel.org>, MyungJoo Ham <myungjoo.ham@samsung.com>,\n  Chanwoo Choi <cw00.choi@samsung.com>, Sebastian Reichel <sre@kernel.org>,\n  Krzysztof Kozlowski <krzk@kernel.org>,\n =?utf-8?q?Andr=C3=A9_Draszik?= <andre.draszik@linaro.org>,\n  Alexandre Belloni <alexandre.belloni@bootlin.com>,\n  Jonathan Corbet <corbet@lwn.net>, Shuah Khan <skhan@linuxfoundation.org>,\n  Nam Tran <trannamatk@gmail.com>,\n =?utf-8?b?xYF1a2FzeiBMZWJpZWR6acWEc2tp?= <kernel@lvkasz.us>","Cc":"linux-leds@vger.kernel.org, devicetree@vger.kernel.org,\n linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org,\n linux-samsung-soc@vger.kernel.org, linux-rtc@vger.kernel.org,\n linux-doc@vger.kernel.org, Kaustabh Chakraborty <kauschluss@disroot.org>"},"content":"Add a driver for charger controllers found in certain Samsung S2M series\nPMICs. The driver has very basic support for the device, with only\ncharger online reporting working, and USB 2.0 device negotiations\nworking.\n\nThe driver includes initial support for the S2MU005 PMIC charger.\n\nCo-developed-by: Łukasz Lebiedziński <kernel@lvkasz.us>\nSigned-off-by: Łukasz Lebiedziński <kernel@lvkasz.us>\nSigned-off-by: Kaustabh Chakraborty <kauschluss@disroot.org>\n---\n drivers/power/supply/Kconfig        |  11 ++\n drivers/power/supply/Makefile       |   1 +\n drivers/power/supply/s2m-charger.c  | 300 ++++++++++++++++++++++++++++++++++++\n include/linux/mfd/samsung/s2mu005.h |   5 +\n 4 files changed, 317 insertions(+)","diff":"diff --git a/drivers/power/supply/Kconfig b/drivers/power/supply/Kconfig\nindex 83392ed6a8da9..6270e6d16fbbb 100644\n--- a/drivers/power/supply/Kconfig\n+++ b/drivers/power/supply/Kconfig\n@@ -856,6 +856,17 @@ config CHARGER_RK817\n \thelp\n \t  Say Y to include support for Rockchip RK817 Battery Charger.\n \n+config CHARGER_S2M\n+\ttristate \"Samsung S2M series PMIC battery charger support\"\n+\tdepends on EXTCON_S2M\n+\tdepends on MFD_SEC_CORE\n+\tselect REGMAP_IRQ\n+\thelp\n+\t  This option enables support for charger devices found in\n+\t  certain Samsung S2M series PMICs, such as the S2MU005. These\n+\t  devices provide USB power supply information and also required\n+\t  for USB OTG role switching.\n+\n config CHARGER_SMB347\n \ttristate \"Summit Microelectronics SMB3XX Battery Charger\"\n \tdepends on I2C\ndiff --git a/drivers/power/supply/Makefile b/drivers/power/supply/Makefile\nindex 7ee839dca7f33..738814650ea0f 100644\n--- a/drivers/power/supply/Makefile\n+++ b/drivers/power/supply/Makefile\n@@ -107,6 +107,7 @@ obj-$(CONFIG_CHARGER_BQ25890)\t+= bq25890_charger.o\n obj-$(CONFIG_CHARGER_BQ25980)\t+= bq25980_charger.o\n obj-$(CONFIG_CHARGER_BQ256XX)\t+= bq256xx_charger.o\n obj-$(CONFIG_CHARGER_RK817)\t+= rk817_charger.o\n+obj-$(CONFIG_CHARGER_S2M)\t+= s2m-charger.o\n obj-$(CONFIG_CHARGER_SMB347)\t+= smb347-charger.o\n obj-$(CONFIG_CHARGER_TPS65090)\t+= tps65090-charger.o\n obj-$(CONFIG_CHARGER_TPS65217)\t+= tps65217_charger.o\ndiff --git a/drivers/power/supply/s2m-charger.c b/drivers/power/supply/s2m-charger.c\nnew file mode 100644\nindex 0000000000000..8836943f14faa\n--- /dev/null\n+++ b/drivers/power/supply/s2m-charger.c\n@@ -0,0 +1,300 @@\n+// SPDX-License-Identifier: GPL-2.0\n+/*\n+ * Battery Charger Driver for Samsung S2M series PMICs.\n+ *\n+ * Copyright (c) 2015 Samsung Electronics Co., Ltd\n+ * Copyright (c) 2026 Kaustabh Chakraborty <kauschluss@disroot.org>\n+ * Copyright (c) 2026 Łukasz Lebiedziński <kernel@lvkasz.us>\n+ */\n+\n+#include <linux/devm-helpers.h>\n+#include <linux/extcon.h>\n+#include <linux/mfd/samsung/core.h>\n+#include <linux/mfd/samsung/s2mu005.h>\n+#include <linux/module.h>\n+#include <linux/of.h>\n+#include <linux/of_graph.h>\n+#include <linux/platform_device.h>\n+#include <linux/power_supply.h>\n+#include <linux/regmap.h>\n+\n+struct s2m_chgr {\n+\tstruct device *dev;\n+\tstruct regmap *regmap;\n+\tstruct power_supply *psy;\n+\tstruct extcon_dev *extcon;\n+\tstruct work_struct extcon_work;\n+\tstruct notifier_block extcon_nb;\n+};\n+\n+static int s2mu005_chgr_get_online(struct s2m_chgr *priv, int *value)\n+{\n+\tu32 val;\n+\tint ret = 0;\n+\n+\tret = regmap_read(priv->regmap, S2MU005_REG_CHGR_STATUS0, &val);\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to read register (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t*value = !!(val & S2MU005_CHGR_CHG);\n+\n+\treturn ret;\n+}\n+\n+static int s2mu005_chgr_get_property(struct power_supply *psy,\n+\t\t\t\t     enum power_supply_property psp,\n+\t\t\t\t     union power_supply_propval *val)\n+{\n+\tstruct s2m_chgr *priv = power_supply_get_drvdata(psy);\n+\tint ret = 0;\n+\n+\tswitch (psp) {\n+\tcase POWER_SUPPLY_PROP_ONLINE:\n+\t\tret = s2mu005_chgr_get_online(priv, &val->intval);\n+\t\tbreak;\n+\tdefault:\n+\t\treturn -EINVAL;\n+\t}\n+\n+\treturn ret;\n+}\n+\n+static int s2mu005_chgr_mode_set_host(struct s2m_chgr *priv)\n+{\n+\tint ret;\n+\n+\t/* set mode to OTG */\n+\tret = regmap_update_bits(priv->regmap, S2MU005_REG_CHGR_CTRL0,\n+\t\t\t\t S2MU005_CHGR_OP_MODE,\n+\t\t\t\t FIELD_PREP(S2MU005_CHGR_OP_MODE,\n+\t\t\t\t\t    S2MU005_CHGR_OP_MODE_OTG));\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to set OTG mode (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* set boost frequency to 2MHz */\n+\tret = regmap_update_bits(priv->regmap, S2MU005_REG_CHGR_CTRL11,\n+\t\t\t\t S2MU005_CHGR_OSC_BOOST,\n+\t\t\t\t FIELD_PREP(S2MU005_CHGR_OSC_BOOST,\n+\t\t\t\t\t    S2MU005_CHGR_OSC_BOOST_2MHZ));\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to set boost frequency (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* set OTG current limit to 1.5 A */\n+\tret = regmap_update_bits(priv->regmap, S2MU005_REG_CHGR_CTRL4,\n+\t\t\t\t S2MU005_CHGR_OTG_OCP,\n+\t\t\t\t FIELD_PREP(S2MU005_CHGR_OTG_OCP,\n+\t\t\t\t\t    S2MU005_CHGR_OTG_OCP_1P5A));\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to set OTG current limit (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* VBUS switches are OFF when OTG over-current happens */\n+\tret = regmap_set_bits(priv->regmap, S2MU005_REG_CHGR_CTRL4,\n+\t\t\t      S2MU005_CHGR_OTG_OCP_OFF);\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to set OTG OCP switch (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* set OTG voltage to 5.1 V */\n+\tret = regmap_update_bits(priv->regmap, S2MU005_REG_CHGR_CTRL5,\n+\t\t\t\t S2MU005_CHGR_VMID_BOOST,\n+\t\t\t\t FIELD_PREP(S2MU005_CHGR_VMID_BOOST,\n+\t\t\t\t\t    S2MU005_CHGR_VMID_BOOST_5P1V));\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to set OTG voltage (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* turn on OTG */\n+\tret = regmap_update_bits(priv->regmap, S2MU005_REG_CHGR_CTRL15,\n+\t\t\t\t S2MU005_CHGR_OTG_EN,\n+\t\t\t\t FIELD_PREP(S2MU005_CHGR_OTG_EN,\n+\t\t\t\t\t    S2MU005_CHGR_OTG_EN_ON));\n+\tif (ret < 0)\n+\t\tdev_err(priv->dev, \"failed to turn on OTG (%d)\\n\", ret);\n+\treturn ret;\n+}\n+\n+static int s2mu005_chgr_mode_set_charger(struct s2m_chgr *priv)\n+{\n+\tint ret;\n+\n+\t/* first reset to mode 0 */\n+\tret = regmap_clear_bits(priv->regmap, S2MU005_REG_CHGR_CTRL0,\n+\t\t\t\tS2MU005_CHGR_OP_MODE);\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to reset opmode (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* wait for the charger to settle before switching to charging mode */\n+\tmsleep(50);\n+\t/* then set to charging mode */\n+\tret = regmap_update_bits(priv->regmap, S2MU005_REG_CHGR_CTRL0,\n+\t\t\t\t S2MU005_CHGR_OP_MODE,\n+\t\t\t\t FIELD_PREP(S2MU005_CHGR_OP_MODE,\n+\t\t\t\t\t    S2MU005_CHGR_OP_MODE_CHG));\n+\tif (ret < 0)\n+\t\tdev_err(priv->dev, \"failed to set opmode to charging (%d)\\n\", ret);\n+\t\treturn ret;\n+}\n+\n+static int s2mu005_chgr_mode_unset(struct s2m_chgr *priv)\n+{\n+\tint ret;\n+\n+\t/* turn off OTG */\n+\tret = regmap_clear_bits(priv->regmap, S2MU005_REG_CHGR_CTRL15,\n+\t\t\t\tS2MU005_CHGR_OTG_EN);\n+\tif (ret < 0) {\n+\t\tdev_err(priv->dev, \"failed to turn off OTG (%d)\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\t/* reset operation mode */\n+\tret = regmap_clear_bits(priv->regmap, S2MU005_REG_CHGR_CTRL0,\n+\t\t\t\tS2MU005_CHGR_OP_MODE);\n+\tif (ret < 0)\n+\t\tdev_err(priv->dev, \"failed to reset opmode (%d)\\n\", ret);\n+\treturn ret;\n+}\n+\n+static void s2mu005_chgr_extcon_work(struct work_struct *work)\n+{\n+\tstruct s2m_chgr *priv = container_of(work, struct s2m_chgr,\n+\t\t\t\t\t\t extcon_work);\n+\n+\tif (extcon_get_state(priv->extcon, EXTCON_USB_HOST))\n+\t\ts2mu005_chgr_mode_set_host(priv);\n+\telse if (extcon_get_state(priv->extcon, EXTCON_USB))\n+\t\ts2mu005_chgr_mode_set_charger(priv);\n+\telse\n+\t\ts2mu005_chgr_mode_unset(priv);\n+\n+\tpower_supply_changed(priv->psy);\n+}\n+\n+static const enum power_supply_property s2mu005_chgr_properties[] = {\n+\tPOWER_SUPPLY_PROP_ONLINE,\n+};\n+\n+static const struct power_supply_desc s2mu005_chgr_psy_desc = {\n+\t.name = \"s2mu005-charger\",\n+\t.type = POWER_SUPPLY_TYPE_USB,\n+\t.properties = s2mu005_chgr_properties,\n+\t.num_properties = ARRAY_SIZE(s2mu005_chgr_properties),\n+\t.get_property = s2mu005_chgr_get_property,\n+};\n+\n+static int s2m_chgr_extcon_notifier(struct notifier_block *nb,\n+\t\t\t\t\tunsigned long event, void *param)\n+{\n+\tstruct s2m_chgr *priv = container_of(nb, struct s2m_chgr, extcon_nb);\n+\n+\tschedule_work(&priv->extcon_work);\n+\n+\treturn NOTIFY_OK;\n+}\n+\n+static int s2m_chgr_probe(struct platform_device *pdev)\n+{\n+\tstruct device *dev = &pdev->dev;\n+\tstruct sec_pmic_dev *pmic_drvdata = dev_get_drvdata(dev->parent);\n+\tstruct s2m_chgr *priv;\n+\tstruct device_node *extcon_node __free(device_node) = NULL;\n+\tstruct power_supply_config psy_cfg = {};\n+\tconst struct power_supply_desc *psy_desc;\n+\twork_func_t extcon_work_func;\n+\tint ret;\n+\n+\tpriv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);\n+\tif (!priv)\n+\t\treturn -ENOMEM;\n+\n+\tplatform_set_drvdata(pdev, priv);\n+\tpriv->dev = dev;\n+\tpriv->regmap = pmic_drvdata->regmap_pmic;\n+\n+\tswitch (platform_get_device_id(pdev)->driver_data) {\n+\tcase S2MU005:\n+\t\tpsy_desc = &s2mu005_chgr_psy_desc;\n+\t\textcon_work_func = s2mu005_chgr_extcon_work;\n+\t\tbreak;\n+\tdefault:\n+\t\treturn dev_err_probe(dev, -ENODEV,\n+\t\t\t\t     \"device type %d is not supported by driver\\n\",\n+\t\t\t\t     pmic_drvdata->device_type);\n+\t}\n+\n+\tpsy_cfg.drv_data = priv;\n+\tpriv->psy = devm_power_supply_register(dev, psy_desc, &psy_cfg);\n+\tif (IS_ERR(priv->psy))\n+\t\treturn dev_err_probe(dev, PTR_ERR(priv->psy),\n+\t\t\t\t     \"failed to register power supply subsystem\\n\");\n+\n+\t/* MUIC is mandatory. If unavailable, request probe deferral */\n+\tif (!of_graph_is_present(dev->of_node))\n+\t\treturn -ENODEV;\n+\textcon_node = of_graph_get_remote_node(dev->of_node, 0, 0);\n+\tpriv->extcon = extcon_find_edev_by_node(extcon_node);\n+\tif (IS_ERR(priv->extcon))\n+\t\treturn -EPROBE_DEFER;\n+\n+\tret = devm_work_autocancel(dev, &priv->extcon_work, extcon_work_func);\n+\tif (ret)\n+\t\treturn dev_err_probe(dev, ret, \"failed to initialize extcon work\\n\");\n+\n+\tpriv->extcon_nb.notifier_call = s2m_chgr_extcon_notifier;\n+\tret = devm_extcon_register_notifier_all(dev, priv->extcon, &priv->extcon_nb);\n+\tif (ret)\n+\t\tdev_err_probe(dev, ret, \"failed to register extcon notifier\\n\");\n+\n+\treturn 0;\n+}\n+\n+static const struct platform_device_id s2m_chgr_id_table[] = {\n+\t{ \"s2mu005-charger\", S2MU005 },\n+\t{ /* sentinel */ },\n+};\n+MODULE_DEVICE_TABLE(platform, s2m_chgr_id_table);\n+\n+/*\n+ * Device is instantiated through parent MFD device and device matching\n+ * is done through platform_device_id.\n+ *\n+ * However if device's DT node contains proper compatible and driver is\n+ * built as a module, then the *module* matching will be done through DT\n+ * aliases. This requires of_device_id table. In the same time this will\n+ * not change the actual *device* matching so do not add .of_match_table.\n+ */\n+static const struct of_device_id s2m_chgr_of_match_table[] = {\n+\t{\n+\t\t.compatible = \"samsung,s2mu005-charger\",\n+\t\t.data = (void *)S2MU005,\n+\t}, {\n+\t\t/* sentinel */\n+\t},\n+};\n+MODULE_DEVICE_TABLE(of, s2m_chgr_of_match_table);\n+\n+static struct platform_driver s2m_chgr_driver = {\n+\t.driver = {\n+\t\t.name = \"s2m-charger\",\n+\t},\n+\t.probe = s2m_chgr_probe,\n+\t.id_table = s2m_chgr_id_table,\n+};\n+module_platform_driver(s2m_chgr_driver);\n+\n+MODULE_DESCRIPTION(\"Battery Charger Driver For Samsung S2M Series PMICs\");\n+MODULE_AUTHOR(\"Kaustabh Chakraborty <kauschluss@disroot.org>\");\n+MODULE_AUTHOR(\"Łukasz Lebiedziński <kernel@lvkasz.us>\");\n+MODULE_LICENSE(\"GPL\");\ndiff --git a/include/linux/mfd/samsung/s2mu005.h b/include/linux/mfd/samsung/s2mu005.h\nindex 07f4ae664950d..00b5450cf1c60 100644\n--- a/include/linux/mfd/samsung/s2mu005.h\n+++ b/include/linux/mfd/samsung/s2mu005.h\n@@ -2,6 +2,7 @@\n /*\n  * Copyright (c) 2015 Samsung Electronics Co., Ltd\n  * Copyright (c) 2025 Kaustabh Chakraborty <kauschluss@disroot.org>\n+ * Copyright (c) 2026 Łukasz Lebiedziński <kernel@lvkasz.us>\n  */\n \n #ifndef __LINUX_MFD_S2MU005_H\n@@ -186,9 +187,11 @@ enum s2mu005_reg {\n #define S2MU005_CHGR_OTG_OCP_ON\t\tBIT(5)\n #define S2MU005_CHGR_OTG_OCP_OFF\tBIT(4)\n #define S2MU005_CHGR_OTG_OCP\t\tGENMASK(3, 2)\n+#define S2MU005_CHGR_OTG_OCP_1P5A\t0x3\n \n /* S2MU005_REG_CHGR_CTRL5 */\n #define S2MU005_CHGR_VMID_BOOST\t\tGENMASK(4, 0)\n+#define S2MU005_CHGR_VMID_BOOST_5P1V\t0x16\n \n /* S2MU005_REG_CHGR_CTRL6 */\n #define S2MU005_CHGR_COOL_CHG_CURR\tGENMASK(5, 0)\n@@ -205,6 +208,7 @@ enum s2mu005_reg {\n /* S2MU005_REG_CHGR_CTRL11 */\n #define S2MU005_CHGR_OSC_BOOST\t\tGENMASK(6, 5)\n #define S2MU005_CHGR_OSC_BUCK\t\tGENMASK(4, 3)\n+#define S2MU005_CHGR_OSC_BOOST_2MHZ\t0x3\n \n /* S2MU005_REG_CHGR_CTRL12 */\n #define S2MU005_CHGR_WDT\t\tGENMASK(2, 0)\n@@ -214,6 +218,7 @@ enum s2mu005_reg {\n \n /* S2MU005_REG_CHGR_CTRL15 */\n #define S2MU005_CHGR_OTG_EN\t\tGENMASK(3, 2)\n+#define S2MU005_CHGR_OTG_EN_ON\t\t0x3\n \n /* S2MU005_REG_FLED_STATUS */\n #define S2MU005_FLED_FLASH_STATUS(x)\t(BIT(7) >> 2 * (x))\n","prefixes":["v4","13/13"]}