From nobody Mon May 11 04:52:06 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 969D1C433EF for ; Fri, 15 Apr 2022 11:00:33 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352571AbiDOLC6 (ORCPT ); Fri, 15 Apr 2022 07:02:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60374 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352543AbiDOLCz (ORCPT ); Fri, 15 Apr 2022 07:02:55 -0400 Received: from mail-lf1-x12a.google.com (mail-lf1-x12a.google.com [IPv6:2a00:1450:4864:20::12a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D1FC191341; Fri, 15 Apr 2022 04:00:26 -0700 (PDT) Received: by mail-lf1-x12a.google.com with SMTP id bi26so13540822lfb.2; Fri, 15 Apr 2022 04:00:26 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=/92dgGLUolkAH3AU+1is8vSs4x9gInGUtOx7kaljC1s=; b=PJPPb5ZuC8V3lOmHXIx64Vu5AmRc/Jp/EignkCeVcb9Ei9gdeesylm8kWLTE2yVj9F 9UIB0oUm2Lv7M+NB73NnSFEVRowcsCN+xyomxKD36poYdvv6a5FMknqJaBA6bO07i7P1 ILTh1279oStf73WDp7uUxVTdIlvq0k32UwL6kX1KmmPVH3Ztxet06LDgaLQhfhHEHMp0 vCZaG2vPII3erfc6nDnaa5JyM70eUkvvSYKjDaIk/NRMhJDJVa04z/p58jF+OBaQWLIp w9uMGPSmTRetT038ZWmgvCimc6aCh3dlxHG/a/tE1YqP3mjisR1RU/jbIiBFuv2yIGgC Y3bg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=/92dgGLUolkAH3AU+1is8vSs4x9gInGUtOx7kaljC1s=; b=MHwDjsBdnf6PM/nObueFtjUV8ikKm0zYjbWDjmV8I62hX8/NJEdMP4S5te8CMYooyk v3z5ik3VoV3d262cnqFpWve+LqT4bWlIgy7NxctAajL7gMNkTpl6YVR8ZsJVZqHFmLF2 2TiKvDGlWj+VK7XMLN/oJHIJJPpV/gXaOfCJPrpL9EKdnge6aOFbOA+roT9eXmBc5CTg AT8aIpis/LaXEc+IfDagPzGX9Ug4on3J2pMJaSKGCLi68kKKxT7pN1kcHZzH6Uk071TL FfD75CWNwYINWxAX8SV8wLJC/dXrIS4/Yn+9sW++CLt8AGU9AcXR0s6ZtCmqcW/+eDPU tNPg== X-Gm-Message-State: AOAM532rOQ2DmaKU00ndEQeSPKaxJktvCk2R+QVj6wWsO9589Tm7RGlX UEKP3viGfTGbfLJq3WgAtHsNf5zH2KY= X-Google-Smtp-Source: ABdhPJxXbhv9aIrRqoXY27+EgsCEXZzkjxj3rSJZ8gmlX6W403cjBG96eoG/q518yYQ3QntC1knwvA== X-Received: by 2002:ac2:4e70:0:b0:44a:866e:605f with SMTP id y16-20020ac24e70000000b0044a866e605fmr4774279lfs.678.1650020424732; Fri, 15 Apr 2022 04:00:24 -0700 (PDT) Received: from nergzd-desktop.localdomain ([194.39.226.133]) by smtp.gmail.com with ESMTPSA id q14-20020a0565123a8e00b0044a7b26ae1dsm292341lfu.109.2022.04.15.04.00.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Apr 2022 04:00:24 -0700 (PDT) From: Markuss Broks To: linux-kernel@vger.kernel.org Cc: phone-devel@vger.kernel.org, ~postmarketos/upstreaming@lists.sr.ht, Markuss Broks , Lee Jones , Rob Herring , Krzysztof Kozlowski , Liam Girdwood , Mark Brown , devicetree@vger.kernel.org Subject: [PATCH v2 1/4] dt-bindings: regulator: Add bindings for Silicon Mitus SM5703 regulators Date: Fri, 15 Apr 2022 14:00:10 +0300 Message-Id: <20220415110014.7384-2-markuss.broks@gmail.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220415110014.7384-1-markuss.broks@gmail.com> References: <20220415110014.7384-1-markuss.broks@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" This patch adds device-tree bindings for regulators on Silicon Mitus SM5703 MFD. Signed-off-by: Markuss Broks --- .../siliconmitus,sm5703-regulator.yaml | 48 +++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100644 Documentation/devicetree/bindings/regulator/siliconmitu= s,sm5703-regulator.yaml diff --git a/Documentation/devicetree/bindings/regulator/siliconmitus,sm570= 3-regulator.yaml b/Documentation/devicetree/bindings/regulator/siliconmitus= ,sm5703-regulator.yaml new file mode 100644 index 000000000000..560df4c020ca --- /dev/null +++ b/Documentation/devicetree/bindings/regulator/siliconmitus,sm5703-regul= ator.yaml @@ -0,0 +1,48 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/regulator/siliconmitus,sm5703-regulator= .yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Silicon Mitus SM5703 multi function device regulators + +maintainers: + - Markuss Broks + +description: | + SM5703 regulators node should be a sub node of the SM5703 MFD node. See = SM5703 MFD + bindings at Documentation/devicetree/bindings/mfd/siliconmitus,sm5703.ya= ml + Regulator nodes should be named as USBLDO_, BUCK, VBUS, LDO_. + The definition for each of these nodes is defined using the standard + binding for regulators at Documentation/devicetree/bindings/regulator/re= gulator.txt. + +properties: + compatible: + const: siliconmitus,sm5703-regulator + + buck: + type: object + $ref: regulator.yaml# + description: + Properties for the BUCK regulator. + + vbus: + type: object + $ref: regulator.yaml# + description: + Properties for the VBUS regulator. + +patternProperties: + "^ldo[1-3]$": + type: object + $ref: regulator.yaml# + description: + Properties for single LDO regulator. + + "^usbldo[1-2]$": + type: object + $ref: regulator.yaml# + description: + Properties for a single USBLDO regulator. + +additionalProperties: false --=20 2.35.1 From nobody Mon May 11 04:52:06 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 1485AC433EF for ; Fri, 15 Apr 2022 11:00:41 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352598AbiDOLDG (ORCPT ); Fri, 15 Apr 2022 07:03:06 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60802 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352572AbiDOLDA (ORCPT ); Fri, 15 Apr 2022 07:03:00 -0400 Received: from mail-lj1-x22f.google.com (mail-lj1-x22f.google.com [IPv6:2a00:1450:4864:20::22f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4E0F391341; Fri, 15 Apr 2022 04:00:29 -0700 (PDT) Received: by mail-lj1-x22f.google.com with SMTP id 17so9180458lji.1; Fri, 15 Apr 2022 04:00:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=ssUQClr8jde5M1FreVdIr0gWsq0efjPJU50BRXvcIoM=; b=aSV/2ebh7hy3wWulSUibASpo5ISs/8d46K8dKPc/stD4xNUPmdWfz0pHdTGvBLs7JA KhK99n/oweSwr0s5t7+QZTASKWcJ/hgMgiFYig1ab4YrT/l78ojGjy8SxvbulSZE2IHp FFo8OxMit+DyEgPFp+1diokpwcrUO4WZDwwPKlNJw3ga1GF4KhMIPd6GquF2i8iyVRkO 5iqLHcNgUp5s2j8cLJpDgVUvIYl2jW6fmHThGjrHmvmOKxYficZONo/xSBWVGpQVqGF/ efldWB5+FhWxLdmvD4ayJQzwaS5gM4TunXbbJ29q3/bG/QImB2/2Zy9Gd29cBQvypEug W/FA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=ssUQClr8jde5M1FreVdIr0gWsq0efjPJU50BRXvcIoM=; b=2SBA2+SWcnGAMkj5CMW2gDlWnw3GS87p/G0Q/11VC/b3Ul3yfjSir/DpSNxpFAxhVm sopJn5ZReO4Mb+KJA6twcBRPylmKucnjOHQahHc0Tg4vY6OR5i10ecc77TJm2fJwkpE4 zDHGRbii9iVRHTZGk2bvsdbvxB3iHFiP3C1BgO9llqpXj8UrihizZA1STE6YtDm9osIO 6JLoIR3EHj888/XARryuXqCfBLazRbA9qDTsD2/xzfB1r+TYUJaVfdzIV9HlJ/+EbIxg Q8A0Chpq0FhcDYPeHhYQ44EH4JMmaPSuQMVsrq7hfVFPU/BI8ng5NvsTKhhFizQaS7Sp EQlw== X-Gm-Message-State: AOAM533Zs2FTl38y51MdpoykN2LP/auyY74UpQteNdCvUnF9iQxEQ+9X YE033FjGfW6PKF2XDbmZVj2W/6kvFOE= X-Google-Smtp-Source: ABdhPJwgDo2CWcrv/a/aygSelZJ9PmM0AluIqJZlwGMD4pE1QnJxY9pXDdhJa8LNAXuAEg0G1BrLlA== X-Received: by 2002:a2e:6819:0:b0:244:c111:7444 with SMTP id c25-20020a2e6819000000b00244c1117444mr4134862lja.116.1650020427273; Fri, 15 Apr 2022 04:00:27 -0700 (PDT) Received: from nergzd-desktop.localdomain ([194.39.226.133]) by smtp.gmail.com with ESMTPSA id q14-20020a0565123a8e00b0044a7b26ae1dsm292341lfu.109.2022.04.15.04.00.25 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Apr 2022 04:00:26 -0700 (PDT) From: Markuss Broks To: linux-kernel@vger.kernel.org Cc: phone-devel@vger.kernel.org, ~postmarketos/upstreaming@lists.sr.ht, Markuss Broks , Lee Jones , Rob Herring , Krzysztof Kozlowski , Liam Girdwood , Mark Brown , devicetree@vger.kernel.org Subject: [PATCH v2 2/4] dt-bindings: mfd: Add bindings for Silicon Mitus SM5703 MFD Date: Fri, 15 Apr 2022 14:00:11 +0300 Message-Id: <20220415110014.7384-3-markuss.broks@gmail.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220415110014.7384-1-markuss.broks@gmail.com> References: <20220415110014.7384-1-markuss.broks@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" This patch adds device-tree bindings for the Silicon Mitus SM5703 MFD. Signed-off-by: Markuss Broks --- .../bindings/mfd/siliconmitus,sm5703.yaml | 96 +++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 Documentation/devicetree/bindings/mfd/siliconmitus,sm57= 03.yaml diff --git a/Documentation/devicetree/bindings/mfd/siliconmitus,sm5703.yaml= b/Documentation/devicetree/bindings/mfd/siliconmitus,sm5703.yaml new file mode 100644 index 000000000000..6665409bd541 --- /dev/null +++ b/Documentation/devicetree/bindings/mfd/siliconmitus,sm5703.yaml @@ -0,0 +1,96 @@ +# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/mfd/siliconmitus,sm5703.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: Silicon Mitus SM5703 multi-function device bindings + +maintainers: + - Markuss Broks + +description: | + Silicon Mitus SM5703 is a multi-function device, that consists of several + modules, designed for a mobile phone use. It consists of + LDO, Buck, USBLDO and VBUS regulators, a flash LED driver, a MUIC unit, + a fuel gauge and a battery charger circuit. The MUIC and Fuel-Gauge units + are separate from the main MFD, having their own i2c lines, while the + LED driver, regulators and charger are sharing the main i2c bus of the M= FD. + +properties: + compatible: + const: siliconmitus,sm5703-mfd + + reg: + description: + I2C slave address. + maxItems: 1 + + regulators: + $ref: ../regulator/siliconmitus,sm5703-regulator.yaml + description: + List of child nodes that specify the regulators. + + reset-gpio: + description: + GPIO which is connected to the MRSTB pin. + maxItems: 1 + +required: + - compatible + - reg + - regulators + +additionalProperties: false + +examples: + - | + i2c { + #address-cells =3D <1>; + #size-cells =3D <0>; + + mfd@49 { + compatible =3D "siliconmitus,sm5703-mfd"; + reg =3D <0x49>; + + reset-gpio =3D <&msmgpio 24 GPIO_ACTIVE_HIGH>; + pinctrl-0 =3D <&mrstb_default>; + + regulator { + compatible =3D "siliconmitus,sm5703-regulator"; + + regulators { + sm5703_ldo1: ldo1 { + regulator-min-microvolt =3D <2800000>; + regulator-max-microvolt =3D <2800000>; + }; + + sm5703_ldo2: ldo2 { + regulator-min-microvolt =3D <1500000>; + regulator-max-microvolt =3D <3300000>; + }; + + sm5703_ldo3: ldo3 { + regulator-min-microvolt =3D <3300000>; + regulator-max-microvolt =3D <3300000>; + }; + + sm5703_usbldo1: usbldo1 { + regulator-min-microvolt =3D <4800000>; + regulator-max-microvolt =3D <4800000>; + }; + + sm5703_usbldo2: usbldo2 { + regulator-min-microvolt =3D <4800000>; + regulator-max-microvolt =3D <4800000>; + }; + + sm5703_vbus: vbus { + regulator-min-microvolt =3D <5000000>; + regulator-max-microvolt =3D <5000000>; + }; + }; + }; + }; + }; +... --=20 2.35.1 From nobody Mon May 11 04:52:06 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 AD342C433EF for ; Fri, 15 Apr 2022 11:00:47 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352617AbiDOLDN (ORCPT ); Fri, 15 Apr 2022 07:03:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60910 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352582AbiDOLDB (ORCPT ); Fri, 15 Apr 2022 07:03:01 -0400 Received: from mail-lj1-x230.google.com (mail-lj1-x230.google.com [IPv6:2a00:1450:4864:20::230]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 23B669D046; Fri, 15 Apr 2022 04:00:32 -0700 (PDT) Received: by mail-lj1-x230.google.com with SMTP id a8so8919247ljq.5; Fri, 15 Apr 2022 04:00:32 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Zu1iv2slDEmPJIqcluQVGAP7gHAtNvDuvYomfYWCtOo=; b=fWBi2DQW7cTLNzmlI4SzWC5X2HG3LnFqoZJDYT0iZKb7Aiw9H0rJ+zl6NRcH0hS5k2 IQ6iF16zm0w7TDtIrdn1B1yLza1Lpvzj+UAn1/hUeBR1TK32XiujW+6wJW3TzyR2xLBS 9V7vwvicGSwWjuPmceuEJSX/pvBmiZ6IV4hD4j1ZFvd1bH1TPNm3H5F1Mm8kuRPBeVx+ 8UjCHhq8YmqeqsJqpjWQkexW0PL0wiYOK7+oNO9sd4z/WczGehiYemsgy7CzwjCFtYUm k0yqH1xXF29WE4M4V47niBEd0MHLi7ovb745CA71eTp0Ml2J18OFNcYZmvvSnkRs4EoU S3fA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Zu1iv2slDEmPJIqcluQVGAP7gHAtNvDuvYomfYWCtOo=; b=1uYSQhFl+J3iABbFee2qY+8k7S3M2S1aMhR4ZuTzzeHOWP6iby8ldLUxoeStw8dYQJ hsA6HEo8bpcPseU56b+D26YjZzmWs4IXzrZJ7sMl6L+AFY60mSe2A578Wl081xrL2uck m4wbNvak50ndWBcAC3/rujWvgHzjQu1UoRHfPd8EMAIxH9NQF9JcVO90bmM06wBAR9Ll NwEKWcKBQGtmhA+7JHJMlhW6pIYGU9e1vNt3vxOMo94YGO5pTtGZLPdIximySmiQNlsB SRrmv1U4eiJcUrKTTE3iKK7GAKJFdUgbAkjHieBpCJVA+wHFwxXrw9IA0VwgpMOoLewc svRw== X-Gm-Message-State: AOAM533NcyPiD0d3fcUjwEbCglkl3YlGkXTAobUkWAjDn1Ut7e818twJ nYSEEyQWShPyUCK24j9s5ce3xRQkIp8= X-Google-Smtp-Source: ABdhPJyf8xB8zkFeuphEF2JANXs3TLvwYUc1tWiprgJLYuP7qbX+g3X3hwpG6+QzdrVqNT/YVLUR7g== X-Received: by 2002:a05:651c:b13:b0:24d:a2fc:f434 with SMTP id b19-20020a05651c0b1300b0024da2fcf434mr2214181ljr.267.1650020430227; Fri, 15 Apr 2022 04:00:30 -0700 (PDT) Received: from nergzd-desktop.localdomain ([194.39.226.133]) by smtp.gmail.com with ESMTPSA id q14-20020a0565123a8e00b0044a7b26ae1dsm292341lfu.109.2022.04.15.04.00.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Apr 2022 04:00:29 -0700 (PDT) From: Markuss Broks To: linux-kernel@vger.kernel.org Cc: phone-devel@vger.kernel.org, ~postmarketos/upstreaming@lists.sr.ht, Markuss Broks , Lee Jones , Rob Herring , Krzysztof Kozlowski , Liam Girdwood , Mark Brown , devicetree@vger.kernel.org Subject: [PATCH v2 3/4] mfd: sm5703: Add support for SM5703 MFD Date: Fri, 15 Apr 2022 14:00:12 +0300 Message-Id: <20220415110014.7384-4-markuss.broks@gmail.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220415110014.7384-1-markuss.broks@gmail.com> References: <20220415110014.7384-1-markuss.broks@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" Silicon Mitus SM5703 is a multi-function device, meant to be used in mobile devices. It has several modules: LDO, BUCK regulators, charger circuit, flash LED driver, a fuel gauge for monitoring the battery and a MUIC USB switcher. The MUIC and fuel gauge parts are separate in that they use separate i2c lines to communicate with the device, while charger circuit, LED driver and regulators are on the main i2c line the device is controlled with. Signed-off-by: Markuss Broks --- MAINTAINERS | 8 +++ drivers/mfd/Kconfig | 12 +++++ drivers/mfd/Makefile | 1 + drivers/mfd/sm5703.c | 81 ++++++++++++++++++++++++++++ include/linux/mfd/sm5703.h | 105 +++++++++++++++++++++++++++++++++++++ 5 files changed, 207 insertions(+) create mode 100644 drivers/mfd/sm5703.c create mode 100644 include/linux/mfd/sm5703.h diff --git a/MAINTAINERS b/MAINTAINERS index 2a83ac6bfa4d..d3eef171eb8c 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -17886,6 +17886,14 @@ T: git git://git.kernel.org/pub/scm/linux/kernel/g= it/paulmck/linux-rcu.git dev F: include/linux/srcu*.h F: kernel/rcu/srcu*.c =20 +SM5703 MFD DRIVER +M: Markuss Broks +S: Maintained +F: Documentation/devicetree/bindings/mfd/siliconmitus,sm5703.yaml +F: Documentation/devicetree/bindings/regulator/siliconmitus,sm5703-regulat= or.yaml +F: drivers/mfd/sm5703.c +F: drivers/regulator/sm5703-regulator.c + SMACK SECURITY MODULE M: Casey Schaufler L: linux-security-module@vger.kernel.org diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig index e0d2fcb10a0c..e553a8db24c2 100644 --- a/drivers/mfd/Kconfig +++ b/drivers/mfd/Kconfig @@ -1223,6 +1223,18 @@ config MFD_SM501 interface. The device may be connected by PCI or local bus with varying functions enabled. =20 +config MFD_SM5703 + tristate "Silicon Mitus SM5703 MFD" + depends on I2C + select MFD_CORE + select REGMAP_I2C + help + This is the core driver for the Silicon Mitus SM5703 multi-function + device. This device is meant to be used in phones and it has numerous + modules, including LED controller, regulators, fuel gauge, MUIC and + charger circuit. It also support muxing a serial interface over USB + data lines. + config MFD_SM501_GPIO bool "Export GPIO via GPIO layer" depends on MFD_SM501 && GPIOLIB diff --git a/drivers/mfd/Makefile b/drivers/mfd/Makefile index df1ecc4a4c95..3278069d3461 100644 --- a/drivers/mfd/Makefile +++ b/drivers/mfd/Makefile @@ -275,3 +275,4 @@ rsmu-i2c-objs :=3D rsmu_core.o rsmu_i2c.o rsmu-spi-objs :=3D rsmu_core.o rsmu_spi.o obj-$(CONFIG_MFD_RSMU_I2C) +=3D rsmu-i2c.o obj-$(CONFIG_MFD_RSMU_SPI) +=3D rsmu-spi.o +obj-$(CONFIG_MFD_SM5703) +=3D sm5703.o diff --git a/drivers/mfd/sm5703.c b/drivers/mfd/sm5703.c new file mode 100644 index 000000000000..0eb6f257f109 --- /dev/null +++ b/drivers/mfd/sm5703.c @@ -0,0 +1,81 @@ +// SPDX-License-Identifier: GPL-2.0-only + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +static const struct mfd_cell sm5703_devs[] =3D { + { + .name =3D "sm5703-regulator", + .of_compatible =3D "siliconmitus,sm5703-regulator", + }, +}; + +static const struct regmap_config sm5703_regmap_config =3D { + .reg_bits =3D 8, + .val_bits =3D 8, +}; + +static int sm5703_i2c_probe(struct i2c_client *i2c, + const struct i2c_device_id *id) +{ + struct sm5703_dev *sm5703; + struct device *dev =3D &i2c->dev; + unsigned int dev_id; + int ret; + + sm5703 =3D devm_kzalloc(dev, sizeof(*sm5703), GFP_KERNEL); + if (!sm5703) + return -ENOMEM; + + i2c_set_clientdata(i2c, sm5703); + sm5703->dev =3D dev; + + sm5703->regmap =3D devm_regmap_init_i2c(i2c, &sm5703_regmap_config); + if (IS_ERR(sm5703->regmap)) + return dev_err_probe(dev, PTR_ERR(sm5703->regmap), + "Failed to allocate the register map\n"); + + sm5703->reset_gpio =3D devm_gpiod_get(dev, "reset", GPIOD_OUT_HIGH); + if (IS_ERR(sm5703->reset_gpio)) + return dev_err_probe(dev, PTR_ERR(sm5703->reset_gpio), "Cannot get reset= GPIO\n"); + + gpiod_set_value_cansleep(sm5703->reset_gpio, 1); + msleep(20); + + ret =3D regmap_read(sm5703->regmap, SM5703_DEVICE_ID, &dev_id); + if (ret) + return dev_err_probe(dev, -ENODEV, "Device not found\n"); + + ret =3D devm_mfd_add_devices(sm5703->dev, -1, sm5703_devs, + ARRAY_SIZE(sm5703_devs), NULL, 0, NULL); + if (ret) + return dev_err_probe(dev, ret, "Failed to add child devices\n"); + + return 0; +} + +static const struct of_device_id sm5703_of_match[] =3D { + { .compatible =3D "siliconmitus,sm5703-mfd", }, + { } +}; +MODULE_DEVICE_TABLE(of, sm5703_of_match); + +static struct i2c_driver sm5703_driver =3D { + .driver =3D { + .name =3D "sm5703", + .of_match_table =3D sm5703_of_match, + }, + .probe =3D sm5703_i2c_probe, +}; +module_i2c_driver(sm5703_driver); + +MODULE_DESCRIPTION("Silicon Mitus SM5703 multi-function device driver"); +MODULE_AUTHOR("Markuss Broks "); +MODULE_LICENSE("GPL"); diff --git a/include/linux/mfd/sm5703.h b/include/linux/mfd/sm5703.h new file mode 100644 index 000000000000..c62affa0d3f1 --- /dev/null +++ b/include/linux/mfd/sm5703.h @@ -0,0 +1,105 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +#ifndef _SM5703_H +#define _SM5703_H + +struct sm5703_dev { + struct device *dev; + struct regmap *regmap; + struct gpio_desc *reset_gpio; +}; + +// Regulator-related defines + +#define SM5703_REG_LDO1 0x1A +#define SM5703_REG_LDO2 0x1B +#define SM5703_REG_LDO3 0x1C +#define SM5703_LDO_EN BIT(3) +#define SM5703_LDO_VOLT_MASK 0x7 +#define SM5703_BUCK_VOLT_MASK 0x1F +#define SM5703_REG_USBLDO12 0x1C +#define SM5703_REG_EN_USBLDO1 BIT(6) +#define SM5703_REG_EN_USBLDO2 BIT(7) +#define SM5703_REG_BUCK 0x1D +#define SM5703_REG_EN_BUCK BIT(6) +#define SM5703_USBLDO_MICROVOLT 4800000 +#define SM5703_VBUS_MICROVOLT 5000000 + +// Fuel-Gauge-related defines + +#define SM5703_FG_REG_DEVICE_ID 0x00 +#define SM5703_FG_REG_CNTL 0x01 +#define SM5703_FG_REG_INTFG 0x02 +#define SM5703_FG_REG_INTFG_MASK 0x03 +#define SM5703_FG_REG_STATUS 0x04 +#define SM5703_FG_REG_SOC 0x05 +#define SM5703_FG_REG_OCV 0x06 +#define SM5703_FG_REG_VOLTAGE 0x07 +#define SM5703_FG_REG_CURRENT 0x08 +#define SM5703_FG_REG_TEMPERATURE 0x09 +#define SM5703_FG_REG_CURRENT_EST 0x85 +#define SM5703_FG_REG_FG_OP_STATUS 0x10 + +// Flash LED driver-related defines + +#define SM5703_FLEDCNTL1 0x14 +#define SM5703_FLEDCNTL2 0x15 +#define SM5703_FLEDCNTL3 0x16 +#define SM5703_FLEDCNTL4 0x17 +#define SM5703_FLEDCNTL5 0x18 +#define SM5703_FLEDCNTL6 0x19 + +#define SM5703_FLEDEN_MASK 0x03 +#define SM5703_FLEDEN_DISABLE 0x00 +#define SM5703_FLEDEN_MOVIE_MODE 0x01 +#define SM5703_FLEDEN_FLASH_MODE 0x02 +#define SM5703_FLEDEN_EXTERNAL 0x03 + +#define SM5703_IFLED_MASK 0x1F +#define SM5703_IMLED_MASK 0x1F + +// Charger-related, IRQ and device ID defines + +#define SM5703_REG_CNTL 0x0C +#define SM5703_VBUSCNTL 0x0D +#define SM5703_CHGCNTL1 0x0E +#define SM5703_CHGCNTL2 0x0F +#define SM5703_CHGCNTL3 0x10 +#define SM5703_CHGCNTL4 0x11 +#define SM5703_CHGCNTL5 0x12 +#define SM5703_CHGCNTL6 0x13 +#define SM5703_OTGCURRENTCNTL 0x60 +#define SM5703_Q3LIMITCNTL 0x66 +#define SM5703_DEVICE_ID 0x1E +#define SM5703_OPERATION_MODE 0x07 +#define SM5703_OPERATION_MODE_MASK 0x07 + +#define SM5703_OPERATION_MODE_SUSPEND 0x00 +#define SM5703_OPERATION_MODE_CHARGING_OFF 0x04 +#define SM5703_OPERATION_MODE_CHARGING_ON 0x05 +#define SM5703_OPERATION_MODE_FLASH_BOOST_MODE 0x06 +#define SM5703_OPERATION_MODE_USB_OTG_MODE 0x07 + +#define SM5703_BSTOUT 0x0F +#define SM5703_BSTOUT_MASK 0x0F +#define SM5703_BSTOUT_SHIFT 0 + +#define SM5703_BSTOUT_4P5 0x05 +#define SM5703_BSTOUT_5P0 0x0A +#define SM5703_BSTOUT_5P1 0x0B + +#define SM5703_IRQ_STATUS1 0x08 +#define SM5703_IRQ_STATUS2 0x09 +#define SM5703_IRQ_STATUS3 0x0A +#define SM5703_IRQ_STATUS4 0x0B +#define SM5703_IRQ_STATUS5 0x6B + +#define SM5703_STATUS1_OTGFAIL 0x80 +#define SM5703_STATUS3_DONE 0x08 +#define SM5703_STATUS3_TOPOFF 0x04 +#define SM5703_STATUS3_CHGON 0x01 +#define SM5703_STATUS5_VBUSOVP 0x80 +#define SM5703_STATUS5_VBUSUVLO 0x40 +#define SM5703_STATUS5_VBUSOK 0x20 + +#endif --=20 2.35.1 From nobody Mon May 11 04:52:06 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 17B2FC433EF for ; Fri, 15 Apr 2022 11:00:54 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1352625AbiDOLDR (ORCPT ); Fri, 15 Apr 2022 07:03:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60908 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352583AbiDOLDD (ORCPT ); Fri, 15 Apr 2022 07:03:03 -0400 Received: from mail-lf1-x131.google.com (mail-lf1-x131.google.com [IPv6:2a00:1450:4864:20::131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4E498A776F; Fri, 15 Apr 2022 04:00:35 -0700 (PDT) Received: by mail-lf1-x131.google.com with SMTP id bu29so13593930lfb.0; Fri, 15 Apr 2022 04:00:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=L/y6S893+XO+0gZ9aLfl1F/TXOKs2SRk/NNOfS2VZWA=; b=cZEaQheD862Z6pOQYM5fsXLuXjCWGj7IJUwc9AmgyMOv5khDImnu9cnl1hgXfS2opT fY6znJMhxk5+CbJkTn5YLcSBZGD2rZgZqj1sj3mElWIpkuooP1LPAewnqAm7yKZGYCtE eS/vrdW2dscJw859wHQ9sJqXTO9f+BgXVAswj3ikADJ7Z4lE6jgHazEeNyHsXIuewseO sb9sX1CZTKJpOv2nJ9DbYYFcROGKKudo/zr87o6JYiIANxEvY+6oCPYVYqw/dLtq0PBo OO+KqiziYBv1uI5Knm1SOVyrwljBOzJ3FNlRYZOZh61WwwRQdf7Rvw9pxDLxs/GC8uNz 8htA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=L/y6S893+XO+0gZ9aLfl1F/TXOKs2SRk/NNOfS2VZWA=; b=OCwE1/52cdHItYGAoowkQB8hBs5NSm9gs4vgIv71T51LnZAxMsoXqaBsfrh1FRkQkl TXyqr4De0+YbWGUOuEYxh7qakC57HKJ8ZtZlcEsn3TuqdqcMOtIpZp1RkyKf0PD5VA/u fR2Zte7V/cyBZ9ktO3M8qSHCXGLt7SJetU+3ULzzG+juZ2Lw5ndGZx3ySaqgNmmxCpPH EWmD46Jd1I9TL51XY49yNgJRfBPej/kvJtUgq3VbMYQ8mariQyjh8XRvfn0s5eosTlt/ SB9jJUeoIzMTRRv3hVM9NuUNHFHIbjjcoZH9exAVIIhYvcud3yFqE3q8t2fvQBFrSQZW MywQ== X-Gm-Message-State: AOAM533XG7xkGJ0Gf4CHrbZuuU4Ru1kRD/Qq9F3KOlyFhnE5vMdKzYaM AtGDuXMqQevCtKHW3+a5GN0qsEk0Cdo= X-Google-Smtp-Source: ABdhPJxoH5Ty+TdiFItfY/2AfwixV0evVy/VWVM9sdNJMYylZRKtendYaLZnphcq3NJiC5FdSdwKKA== X-Received: by 2002:a05:6512:2251:b0:44a:9707:b54e with SMTP id i17-20020a056512225100b0044a9707b54emr4840399lfu.189.1650020433282; Fri, 15 Apr 2022 04:00:33 -0700 (PDT) Received: from nergzd-desktop.localdomain ([194.39.226.133]) by smtp.gmail.com with ESMTPSA id q14-20020a0565123a8e00b0044a7b26ae1dsm292341lfu.109.2022.04.15.04.00.31 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 15 Apr 2022 04:00:32 -0700 (PDT) From: Markuss Broks To: linux-kernel@vger.kernel.org Cc: phone-devel@vger.kernel.org, ~postmarketos/upstreaming@lists.sr.ht, Markuss Broks , Lee Jones , Rob Herring , Krzysztof Kozlowski , Liam Girdwood , Mark Brown , devicetree@vger.kernel.org Subject: [PATCH v2 4/4] regulator: sm5703-regulator: Add regulators support for SM5703 MFD Date: Fri, 15 Apr 2022 14:00:13 +0300 Message-Id: <20220415110014.7384-5-markuss.broks@gmail.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220415110014.7384-1-markuss.broks@gmail.com> References: <20220415110014.7384-1-markuss.broks@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" Regulators block of SM5703 controls several voltage regulators which are used to power various components. There are 3 LDO outputs ranging from 1.5 to 3.3V, a buck regulator ranging from 1V to 3V, two fixed voltage LDO regulators for powering the USB devices and one high-power fixed voltage LDO line (actually two lines) meant to power high-power USB devices. Signed-off-by: Markuss Broks --- drivers/regulator/Kconfig | 7 ++ drivers/regulator/Makefile | 1 + drivers/regulator/sm5703-regulator.c | 162 +++++++++++++++++++++++++++ 3 files changed, 170 insertions(+) create mode 100644 drivers/regulator/sm5703-regulator.c diff --git a/drivers/regulator/Kconfig b/drivers/regulator/Kconfig index 5d0a360d7244..318bbdc27ae4 100644 --- a/drivers/regulator/Kconfig +++ b/drivers/regulator/Kconfig @@ -1147,6 +1147,13 @@ config REGULATOR_SLG51000 The SLG51000 is seven compact and customizable low dropout regulators. =20 +config REGULATOR_SM5703 + tristate "Silicon Mitus SM5703 regulators" + depends on SM5703_MFD + help + This driver provides support for voltage regulators of SM5703 + multi-function device. + config REGULATOR_STM32_BOOSTER tristate "STMicroelectronics STM32 BOOSTER" depends on ARCH_STM32 || COMPILE_TEST diff --git a/drivers/regulator/Makefile b/drivers/regulator/Makefile index 4b8794a73e17..c491fe528ba4 100644 --- a/drivers/regulator/Makefile +++ b/drivers/regulator/Makefile @@ -137,6 +137,7 @@ obj-$(CONFIG_REGULATOR_S5M8767) +=3D s5m8767.o obj-$(CONFIG_REGULATOR_SC2731) +=3D sc2731-regulator.o obj-$(CONFIG_REGULATOR_SKY81452) +=3D sky81452-regulator.o obj-$(CONFIG_REGULATOR_SLG51000) +=3D slg51000-regulator.o +obj-$(CONFIG_REGULATOR_SM5703) +=3D sm5703-regulator.o obj-$(CONFIG_REGULATOR_STM32_BOOSTER) +=3D stm32-booster.o obj-$(CONFIG_REGULATOR_STM32_VREFBUF) +=3D stm32-vrefbuf.o obj-$(CONFIG_REGULATOR_STM32_PWR) +=3D stm32-pwr.o diff --git a/drivers/regulator/sm5703-regulator.c b/drivers/regulator/sm570= 3-regulator.c new file mode 100644 index 000000000000..41004de69887 --- /dev/null +++ b/drivers/regulator/sm5703-regulator.c @@ -0,0 +1,162 @@ +// SPDX-License-Identifier: GPL-2.0-only + +#include +#include +#include +#include +#include +#include +#include + +enum sm5703_regulators { + SM5703_BUCK, + SM5703_LDO1, + SM5703_LDO2, + SM5703_LDO3, + SM5703_USBLDO1, + SM5703_USBLDO2, + SM5703_VBUS, + SM5703_MAX_REGULATORS, +}; + +static const int sm5703_ldo_voltagemap[] =3D { + 1500000, 1800000, 2600000, 2800000, 3000000, 3300000, +}; + +static const int sm5703_buck_voltagemap[] =3D { + 1000000, 1000000, 1000000, 1000000, + 1000000, 1000000, 1000000, 1000000, + 1000000, 1000000, 1000000, 1100000, + 1200000, 1300000, 1400000, 1500000, + 1600000, 1700000, 1800000, 1900000, + 2000000, 2100000, 2200000, 2300000, + 2400000, 2500000, 2600000, 2700000, + 2800000, 2900000, 3000000, 3000000, +}; + +#define SM5703USBLDO(_name, _id) \ + [SM5703_USBLDO ## _id] =3D { \ + .name =3D _name, \ + .of_match =3D _name, \ + .regulators_node =3D "regulators", \ + .type =3D REGULATOR_VOLTAGE, \ + .id =3D SM5703_USBLDO ## _id, \ + .ops =3D &sm5703_regulator_ops, \ + .fixed_uV =3D SM5703_USBLDO_MICROVOLT, \ + .enable_reg =3D SM5703_REG_USBLDO12, \ + .enable_mask =3D SM5703_REG_EN_USBLDO ##_id, \ + .owner =3D THIS_MODULE, \ + } + +#define SM5703VBUS(_name) \ + [SM5703_VBUS] =3D { \ + .name =3D _name, \ + .of_match =3D _name, \ + .regulators_node =3D "regulators", \ + .type =3D REGULATOR_VOLTAGE, \ + .id =3D SM5703_VBUS, \ + .ops =3D &sm5703_regulator_ops, \ + .fixed_uV =3D SM5703_VBUS_MICROVOLT, \ + .enable_reg =3D SM5703_REG_CNTL, \ + .enable_mask =3D SM5703_OPERATION_MODE_MASK, \ + .enable_val =3D SM5703_OPERATION_MODE_USB_OTG_MODE, \ + .disable_val =3D SM5703_OPERATION_MODE_CHARGING_ON, \ + .owner =3D THIS_MODULE, \ + } + +#define SM5703BUCK(_name) \ + [SM5703_BUCK] =3D { \ + .name =3D _name, \ + .of_match =3D _name, \ + .regulators_node =3D "regulators", \ + .type =3D REGULATOR_VOLTAGE, \ + .id =3D SM5703_BUCK, \ + .ops =3D &sm5703_regulator_ops, \ + .n_voltages =3D ARRAY_SIZE(sm5703_buck_voltagemap), \ + .volt_table =3D sm5703_buck_voltagemap, \ + .vsel_reg =3D SM5703_REG_BUCK, \ + .vsel_mask =3D SM5703_BUCK_VOLT_MASK, \ + .enable_reg =3D SM5703_REG_BUCK, \ + .enable_mask =3D SM5703_REG_EN_BUCK, \ + .owner =3D THIS_MODULE, \ + } + +#define SM5703LDO(_name, _id) \ + [SM5703_LDO ## _id] =3D { \ + .name =3D _name, \ + .of_match =3D _name, \ + .regulators_node =3D "regulators", \ + .type =3D REGULATOR_VOLTAGE, \ + .id =3D SM5703_LDO ## _id, \ + .ops =3D &sm5703_regulator_ops, \ + .n_voltages =3D ARRAY_SIZE(sm5703_ldo_voltagemap), \ + .volt_table =3D sm5703_ldo_voltagemap, \ + .vsel_reg =3D SM5703_REG_LDO ##_id, \ + .vsel_mask =3D SM5703_LDO_VOLT_MASK, \ + .enable_reg =3D SM5703_REG_LDO ##_id, \ + .enable_mask =3D SM5703_LDO_EN, \ + .owner =3D THIS_MODULE, \ + } + +static const struct regulator_ops sm5703_regulator_ops =3D { + .enable =3D regulator_enable_regmap, + .disable =3D regulator_disable_regmap, + .is_enabled =3D regulator_is_enabled_regmap, + .list_voltage =3D regulator_list_voltage_table, + .get_voltage_sel =3D regulator_get_voltage_sel_regmap, + .set_voltage_sel =3D regulator_set_voltage_sel_regmap, +}; + +static struct regulator_desc sm5703_regulators_desc[SM5703_MAX_REGULATORS]= =3D { + SM5703BUCK("buck"), + SM5703LDO("ldo1", 1), + SM5703LDO("ldo2", 2), + SM5703LDO("ldo3", 3), + SM5703USBLDO("usbldo1", 1), + SM5703USBLDO("usbldo2", 2), + SM5703VBUS("vbus"), +}; + +static int sm5703_regulator_probe(struct platform_device *pdev) +{ + struct device *dev =3D &pdev->dev; + struct regulator_config config =3D { NULL, }; + struct regulator_dev *rdev; + struct sm5703_dev *sm5703 =3D dev_get_drvdata(pdev->dev.parent); + int i; + + config.dev =3D dev; + config.of_node =3D dev->of_node; + config.regmap =3D sm5703->regmap; + + for (i =3D 0; i < SM5703_MAX_REGULATORS; i++) { + rdev =3D devm_regulator_register(dev, + &sm5703_regulators_desc[i], + &config); + if (IS_ERR(rdev)) + return dev_err_probe(dev, PTR_ERR(rdev), + "Failed to register a regulator\n"); + } + + return 0; +} + +static const struct platform_device_id sm5703_regulator_id[] =3D { + { "sm5703-regulator", 0 }, + {} +}; +MODULE_DEVICE_TABLE(platform, sm5703_regulator_id); + +static struct platform_driver sm5703_regulator_driver =3D { + .driver =3D { + .name =3D "sm5703-regulator", + }, + .probe =3D sm5703_regulator_probe, + .id_table =3D sm5703_regulator_id, +}; + +module_platform_driver(sm5703_regulator_driver); + +MODULE_DESCRIPTION("Silicon Mitus SM5703 LDO/Buck/USB regulator driver"); +MODULE_AUTHOR("Markuss Broks "); +MODULE_LICENSE("GPL"); --=20 2.35.1