From nobody Sat Apr 11 02:17:21 2026 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 6C2BBC32772 for ; Wed, 17 Aug 2022 06:43:47 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238574AbiHQGnq (ORCPT ); Wed, 17 Aug 2022 02:43:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53340 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230183AbiHQGno (ORCPT ); Wed, 17 Aug 2022 02:43:44 -0400 Received: from mail-pf1-x42d.google.com (mail-pf1-x42d.google.com [IPv6:2607:f8b0:4864:20::42d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 20AA82E9E7; Tue, 16 Aug 2022 23:43:43 -0700 (PDT) Received: by mail-pf1-x42d.google.com with SMTP id f28so11331909pfk.1; Tue, 16 Aug 2022 23:43:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=message-id:date:subject:cc:to:from:from:to:cc; bh=5OYkdXVJaJHBdA053v4ob2/qAthW3sWbUeF0xUKdcl4=; b=Mg15xkCqbtj9YUtaAxcJYYtr4fxKmgEw8RneeE+QJ13dgYPDwHn6o8+tEE7JL9BXXt hMPbcXw/JsrC+N3nw6LqY5kSgKxC5lsFdyO08tU4zFa/QLEuChqCaotudBUhmgX1Turx HpRtUjp68o1sRTdk2ouAu+mUS9RrGatxabdlyrAS0loiqiMq2NjT+Atsmh3UR5nYIwXy GrWdXqu8ByI4g4shaF7l/n5Y221TIgFeQvVr6FIlfeHBdV5ACjDz8RRbm2F+0wUWFy9S CGdPx310KiyEHw3/3auap4+QPouPM8HvomvS139gCj9NyI3MOCO1/XFK66mNXR7m8ayL Z6OQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc; bh=5OYkdXVJaJHBdA053v4ob2/qAthW3sWbUeF0xUKdcl4=; b=bwjL+VW5I3guNiMaQMJdWSEAU+pedsrgjjzvkBZepg+cXhe4fgPCOhjPTsvjyb+iAk 79roRhvVQFKaf/zbbnnv1d3Yhil8yGfFil/5Rwk4vcXz2svSoIoifpFiyJR7GB+9XjGP eb5SSfRbHTaGiYrG14a9zpUNtjxGmfrRXkQBwhN6uBqgZJw6WkehB1j4X4dIgZfRe0mV 5qMr1LNLHSTUBvAHr9Hzytbs1VWxWJ2NtvruTb4Hm9lU3xM64gyC7KxwPQKNBwcmlqcJ L3OOyRHcmyv02GdcaoH91+qFJj0yr8KIgjAHeJkoSYjrkXgf7Oz4nkADgXyRcarklGTl J90w== X-Gm-Message-State: ACgBeo3YqRnyDNZkV5iVDI+oXEXUePFJzHbSyaVLlJ9qF1s/1pMkY0Ve NsSlfVH5pl0bJv07C10kEAw= X-Google-Smtp-Source: AA6agR77fTdH7MC7xgRtG/hu86mRITrKWSuGhO/AqfTGuNbhBYxsKEYC+xeWU1AmYfUZfvSAHURm9Q== X-Received: by 2002:a05:6a00:1650:b0:52f:20d6:e858 with SMTP id m16-20020a056a00165000b0052f20d6e858mr23867545pfc.36.1660718622574; Tue, 16 Aug 2022 23:43:42 -0700 (PDT) Received: from dusj-System-Product-Name.dhcpserver.bu9bmc.local (125-228-123-29.hinet-ip.hinet.net. [125.228.123.29]) by smtp.gmail.com with ESMTPSA id d16-20020a17090a02d000b001f10c959aa2sm673003pjd.42.2022.08.16.23.43.39 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 16 Aug 2022 23:43:42 -0700 (PDT) From: Duke Du X-Google-Original-From: Duke Du To: jdelvare@suse.com, linux@roeck-us.net, corbet@lwn.net, linux-hwmon@vger.kernel.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org Cc: fran.hsu@quantatw.com, charles.hsu@quantatw.com, george.hung@quantatw.com, duke.du@quantatw.com Subject: [PATCH v2] hwmon: Add the pmbus driver for the TEXAS TPS546D24 Buck Converter. Date: Wed, 17 Aug 2022 14:41:37 +0800 Message-Id: <1660718497-7315-1-git-send-email-Duke.Du@quantatw.com> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Transfer-Encoding: quoted-printable MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" make the PMBUS_VOUT_MODE return value 0x17, VOUT returned value is linear11. V2: Correct the tps546d24.rst format. v1: Initial patchset. Signed-off-by: Duke Du --- Documentation/hwmon/index.rst | 1 + Documentation/hwmon/tps546d24.rst | 35 +++++++++++++++++++ MAINTAINERS | 7 ++++ drivers/hwmon/pmbus/Kconfig | 9 +++++ drivers/hwmon/pmbus/Makefile | 1 + drivers/hwmon/pmbus/tps546d24.c | 73 +++++++++++++++++++++++++++++++++++= ++++ 6 files changed, 126 insertions(+) create mode 100644 Documentation/hwmon/tps546d24.rst create mode 100644 drivers/hwmon/pmbus/tps546d24.c diff --git a/Documentation/hwmon/index.rst b/Documentation/hwmon/index.rst index f7113b0..d3eede4 100644 --- a/Documentation/hwmon/index.rst +++ b/Documentation/hwmon/index.rst @@ -205,6 +205,7 @@ Hardware Monitoring Kernel Drivers tps23861 tps40422 tps53679 + tps546d24 twl4030-madc-hwmon ucd9000 ucd9200 diff --git a/Documentation/hwmon/tps546d24.rst b/Documentation/hwmon/tps546= d24.rst new file mode 100644 index 0000000..3061fd8 --- /dev/null +++ b/Documentation/hwmon/tps546d24.rst @@ -0,0 +1,35 @@ +.. SPDX-License-Identifier: GPL-2.0-only + +Kernel driver tps546d24 +=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D + +Supported chips: + + * TI TPS546D24 + + Prefix: 'tps546d24' + + Addresses scanned: - + + Datasheet: https://www.ti.com/lit/gpn/tps546d24 + +Author: Duke Du + + +Description +----------- + +The TPS546D24A is a highly integrated, non-isolated DC/DC converter capable +of high frequency operation and 40-A current output from a 7-mm x 5-mm +package. + +Two, three, and four TPS546D24A devices can be interconnected +to provide up to 160 A on a single output. The device has an option to +overdrive the internal 5-V LDO with an external 5-V supply via the VDD5 +pin to improve efficiency and reduce power dissipation of the converter. + + +Platform data support +--------------------- + +The driver supports standard PMBus driver platform data. diff --git a/MAINTAINERS b/MAINTAINERS index 8a5012b..fa2d4fb 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -20583,6 +20583,13 @@ Q: https://patchwork.kernel.org/project/linux-inte= grity/list/ T: git git://git.kernel.org/pub/scm/linux/kernel/git/jarkko/linux-tpmdd.git F: drivers/char/tpm/ =20 +TPS546D24 DRIVER +M: Duke Du +L: linux-hwmon@vger.kernel.org +S: Maintained +F: Documentation/hwmon/tps546d24.rst +F: drivers/hwmon/pmbus/tps546d24.c + TRACING M: Steven Rostedt M: Ingo Molnar diff --git a/drivers/hwmon/pmbus/Kconfig b/drivers/hwmon/pmbus/Kconfig index 951e4a9..89668af 100644 --- a/drivers/hwmon/pmbus/Kconfig +++ b/drivers/hwmon/pmbus/Kconfig @@ -397,6 +397,15 @@ config SENSORS_TPS53679 This driver can also be built as a module. If so, the module will be called tps53679. =20 +config SENSORS_TPS546D24 + tristate "TPS546D24" + help + If you say yes here you get hardware monitoring support for TEXAS + TPS546D24. + + This driver can also be built as a module. If so, the module will + be called tps546d24 + config SENSORS_UCD9000 tristate "TI UCD90120, UCD90124, UCD90160, UCD90320, UCD9090, UCD90910" help diff --git a/drivers/hwmon/pmbus/Makefile b/drivers/hwmon/pmbus/Makefile index e2fe86f..0002dbe 100644 --- a/drivers/hwmon/pmbus/Makefile +++ b/drivers/hwmon/pmbus/Makefile @@ -41,6 +41,7 @@ obj-$(CONFIG_SENSORS_Q54SJ108A2) +=3D q54sj108a2.o obj-$(CONFIG_SENSORS_STPDDC60) +=3D stpddc60.o obj-$(CONFIG_SENSORS_TPS40422) +=3D tps40422.o obj-$(CONFIG_SENSORS_TPS53679) +=3D tps53679.o +obj-$(CONFIG_SENSORS_TPS546D24) +=3D tps546d24.o obj-$(CONFIG_SENSORS_UCD9000) +=3D ucd9000.o obj-$(CONFIG_SENSORS_UCD9200) +=3D ucd9200.o obj-$(CONFIG_SENSORS_XDPE122) +=3D xdpe12284.o diff --git a/drivers/hwmon/pmbus/tps546d24.c b/drivers/hwmon/pmbus/tps546d2= 4.c new file mode 100644 index 0000000..f6f79d3 --- /dev/null +++ b/drivers/hwmon/pmbus/tps546d24.c @@ -0,0 +1,73 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Hardware monitoring driver for TEXAS TPS546D24 buck converter + */ + +#include +#include +#include +#include +#include +#include +#include "pmbus.h" + +static int tps546d24_read_byte_data(struct i2c_client *client, int page, i= nt reg) +{ + int ret; + + switch (reg) { + case PMBUS_VOUT_MODE: + ret =3D 0x17; + break; + default: + ret =3D -ENODATA; + break; + } + return ret; +} + +static struct pmbus_driver_info tps546d24_info =3D { + .pages =3D 1, + .format[PSC_VOLTAGE_IN] =3D linear, + .format[PSC_VOLTAGE_OUT] =3D linear, + .format[PSC_TEMPERATURE] =3D linear, + .format[PSC_CURRENT_OUT] =3D linear, + .func[0] =3D PMBUS_HAVE_VIN | PMBUS_HAVE_IIN | + PMBUS_HAVE_IOUT | PMBUS_HAVE_VOUT | + PMBUS_HAVE_STATUS_IOUT | PMBUS_HAVE_STATUS_VOUT | + PMBUS_HAVE_TEMP | PMBUS_HAVE_STATUS_TEMP, + .read_byte_data =3D tps546d24_read_byte_data, +}; + +static int tps546d24_probe(struct i2c_client *client) +{ + return pmbus_do_probe(client, &tps546d24_info); +} + +static const struct i2c_device_id tps546d24_id[] =3D { + {"tps546d24", 0}, + {} +}; +MODULE_DEVICE_TABLE(i2c, tps546d24_id); + +static const struct of_device_id __maybe_unused tps546d24_of_match[] =3D { + {.compatible =3D "tps546d24"}, + {} +}; + +/* This is the driver that will be inserted */ +static struct i2c_driver tps546d24_driver =3D { + .driver =3D { + .name =3D "tps546d24", + .of_match_table =3D of_match_ptr(tps546d24_of_match), + }, + .probe_new =3D tps546d24_probe, + .id_table =3D tps546d24_id, +}; + +module_i2c_driver(tps546d24_driver); + +MODULE_AUTHOR("Duke Du "); +MODULE_DESCRIPTION("PMBus driver for TI tps546d24"); +MODULE_LICENSE("GPL"); +MODULE_IMPORT_NS(PMBUS); --=20 2.7.4