From nobody Mon Oct 6 03:16:34 2025 Received: from mail-io1-f53.google.com (mail-io1-f53.google.com [209.85.166.53]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7E36A24886E for ; Sat, 26 Jul 2025 13:10:15 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.166.53 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1753535418; cv=none; b=GiJfrK7Oq0X14smJTTL4EI9Q256nWMqJKvGazXP/RSeTruSFoYCNu9nyPVlP5qIXDmz7MYUwHi9dnINVkIcLUfghVmM0za9q9yyQD/Irkdz9WrDzsWcn++hmFOtvgIQMv2ck58jzmoFhdg4AolFYE0/idEF/hAj9hUVCeONGPtA= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1753535418; c=relaxed/simple; bh=Q38X3FLb9rUyS71bvg/6Qwxh+WP/snpwbPt/FQFY2Xw=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=HkCkOYaZCuRT94Sps/BIB7ivcfX9tJIMU45SknDiw8CNM79rYBHszHczl5iPmy36TVkmA59jBTQO2C3aS3/5gmCSo3mSMjMSUPrhHx75P8fYfaO1QLuOr9zNw4wVZyLmANmx1Okl1i8uu0BFr/r/BOeGqxdPDHiy7q4OC1K+pzo= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=riscstar.com; spf=pass smtp.mailfrom=riscstar.com; dkim=pass (2048-bit key) header.d=riscstar-com.20230601.gappssmtp.com header.i=@riscstar-com.20230601.gappssmtp.com header.b=GAM64i66; arc=none smtp.client-ip=209.85.166.53 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=riscstar.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=riscstar.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=riscstar-com.20230601.gappssmtp.com header.i=@riscstar-com.20230601.gappssmtp.com header.b="GAM64i66" Received: by mail-io1-f53.google.com with SMTP id ca18e2360f4ac-86cf3dd8c97so243050239f.2 for ; Sat, 26 Jul 2025 06:10:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=riscstar-com.20230601.gappssmtp.com; s=20230601; t=1753535415; x=1754140215; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=A31+naPc141WdyGnSXK5HnsnuvFJAqLMKGUUSxCKCSg=; b=GAM64i662JuErc2DkNjWKAnGCOw/Wz7mww1xvKkTf9sGycD13Cnv6E2bGJy4KAFRb7 ZqieVL+AYQsuet14pPu39ITCDa8k6jVlsjBcJvnPTSzfatLtlR3HcqBdQ4lcUTySHuqJ QzH6RLIXcnAvcFY3UjPczM4ejCTmeKCrmr0D1hxPmLP/MAHN4ZbB3pIKOf3HIm/W6J+j epMvGFMgWM9xxnlKEsIcyvcvqpuaryUEYn64IKC494ex/gji4L6X7fDgxdvJRfdWnCCl 5K3c3zzMudYRQhqrArsaRYQ8S+KeZyPhgkZRRuuCVSIypoqfTvgG7Z53K12dIpLgI+jb 12Xw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1753535415; x=1754140215; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=A31+naPc141WdyGnSXK5HnsnuvFJAqLMKGUUSxCKCSg=; b=e+NH9ySsgKqVrTd3dyHd2OXgQfxNsiyaRY5jZA6b/Qv1wgivuh886EyThL+Z49kt1H hyTmns9vKTKvrTjn6EWKquWQpxscQupF4QoSKAhJgNipBUvMnus0mk8CWTQREQdr2zdt Y+En0cm12HhXRmK4ti87OLvY3LX7nePvNdjrbfyi+AjuK9/cNAenoeNKH2S3BXcLYPMm KCEmQQbJESPt6i0Ndg+uXqMVXgx3fCgQuQb+6grzz2ooUCnohmQyxNiuOrdpzm18Hudt c5vBtxgAHokfmeD9Z7duEoPSG3BBukc7tsgWN5axVDJMoWPkXD1cv5RNa9elIcaYgoKW 53Rw== X-Forwarded-Encrypted: i=1; AJvYcCW1ndAbKfntn0+ydAtWDgBVwuvqSjE4mG40FrykmpJPnLcuVS3c7FucEE23h98heNEcFNFWHF9mD/EJv0M=@vger.kernel.org X-Gm-Message-State: AOJu0YzljXU0Omcb8JADnmek0aESAGNY6UeOXH/qFacDKu1tO5WITaXC CBvQEGKOf92IqviVRzutqeHbIptBAAE5jFiptN1icHTs6Tm/GgKcd81SM+OyzomE288= X-Gm-Gg: ASbGncszqiA+Cam6y6kFsiEZoEDW0IHnMC3ixXpKbmquz5K9XSWFmEVU9ygHiNBHqKi MC34VPRZQmkXHDLaypeOFf0SMOOGJ+8qTMJ+mmwnDAffpNKfrME8xHAq+FNhFZ/WdWe91swzk8p h+A61vBEIBMNZmdkGNs+UsnbMZawhfD5FzzjfXtW+JoyrtYyp7LiGZG7iJ8BHXe+rdPqhdxnmQi W1sRmcomqMsZFISuDAwiufmE6/10E/A3KZLoD1RdB5+ArjRCXx8ITjAfkbOHU7rkGDmSDeNmofV HyFWwsBtfNilZYIvCbWc8xxNqfDUZ+SjCtCHl7po0FmrOCUKAjapS6eveWAf5+wcE22sd7zsLEh CpvOkeWmS4CMVZv34PXBhzN5NfF1kAIfKLnqokjHygJ2lof/uLKVjqmsqWtGYQLHzrA== X-Google-Smtp-Source: AGHT+IEQtMmfXcpXrDYRw35RuK7bf++10bNgw0KJuXM1PCXb+Br9VU8Nk8Ms01AyRIuf+S7EyGrohQ== X-Received: by 2002:a05:6602:3d1:b0:87c:5e79:203 with SMTP id ca18e2360f4ac-8800f12d61fmr1072437639f.4.1753535414633; Sat, 26 Jul 2025 06:10:14 -0700 (PDT) Received: from zippy.localdomain (c-73-228-159-35.hsd1.mn.comcast.net. [73.228.159.35]) by smtp.gmail.com with ESMTPSA id ca18e2360f4ac-880f7a4ee9fsm49551439f.33.2025.07.26.06.10.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 26 Jul 2025 06:10:13 -0700 (PDT) From: Alex Elder To: lee@kernel.org, lgirdwood@gmail.com, broonie@kernel.org, alexandre.belloni@bootlin.com, robh@kernel.org, krzk+dt@kernel.org, conor+dt@kernel.org Cc: mat.jonczyk@o2.pl, dlan@gentoo.org, paul.walmsley@sifive.com, palmer@dabbelt.com, aou@eecs.berkeley.edu, alex@ghiti.fr, linux.amoon@gmail.com, troymitchell988@gmail.com, guodong@riscstar.com, linux-rtc@vger.kernel.org, devicetree@vger.kernel.org, linux-riscv@lists.infradead.org, spacemit@lists.linux.dev, linux-kernel@vger.kernel.org Subject: [PATCH v10 3/8] mfd: simple-mfd-i2c: add SpacemiT P1 support Date: Sat, 26 Jul 2025 08:09:57 -0500 Message-ID: <20250726131003.3137282-4-elder@riscstar.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20250726131003.3137282-1-elder@riscstar.com> References: <20250726131003.3137282-1-elder@riscstar.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" Enable support for the RTC and regulators found in the SpacemiT P1 PMIC. Support is implemented by the simple I2C MFD driver. The P1 PMIC is normally implemented with the SpacemiT K1 SoC. This PMIC provides 6 buck converters and 12 LDO regulators. It also implements a switch, watchdog timer, real-time clock, and more. Initially its RTC and regulators are supported. Signed-off-by: Alex Elder --- drivers/mfd/Kconfig | 11 +++++++++++ drivers/mfd/simple-mfd-i2c.c | 12 ++++++++++++ 2 files changed, 23 insertions(+) diff --git a/drivers/mfd/Kconfig b/drivers/mfd/Kconfig index 8f11b2df14704..3fe242ffcb31d 100644 --- a/drivers/mfd/Kconfig +++ b/drivers/mfd/Kconfig @@ -1238,6 +1238,17 @@ config MFD_QCOM_RPM Say M here if you want to include support for the Qualcomm RPM as a module. This will build a module called "qcom_rpm". =20 +config MFD_SPACEMIT_P1 + tristate "SpacemiT P1 PMIC" + depends on I2C + select MFD_SIMPLE_MFD_I2C + help + This option supports the I2C-based SpacemiT P1 PMIC, which + contains regulators, a power switch, GPIOs, an RTC, and more. + This option is selected when any of the supported sub-devices + is configured. The basic functionality is implemented by the + simple MFD I2C driver. + config MFD_SPMI_PMIC tristate "Qualcomm SPMI PMICs" depends on ARCH_QCOM || COMPILE_TEST diff --git a/drivers/mfd/simple-mfd-i2c.c b/drivers/mfd/simple-mfd-i2c.c index 3622f189c8342..34c69ef4a7e94 100644 --- a/drivers/mfd/simple-mfd-i2c.c +++ b/drivers/mfd/simple-mfd-i2c.c @@ -128,12 +128,24 @@ static const struct simple_mfd_data maxim_mon_max7770= 5 =3D { .mfd_cell_size =3D ARRAY_SIZE(max77705_sensor_cells), }; =20 +static const struct mfd_cell spacemit_p1_cells[] =3D { + { .name =3D "spacemit-p1-regulator", }, + { .name =3D "spacemit-p1-rtc", }, +}; + +static const struct simple_mfd_data spacemit_p1 =3D { + .mfd_cell =3D spacemit_p1_cells, + .mfd_cell_size =3D ARRAY_SIZE(spacemit_p1_cells), + .max_register =3D 0xaa, +}; + static const struct of_device_id simple_mfd_i2c_of_match[] =3D { { .compatible =3D "kontron,sl28cpld" }, { .compatible =3D "silergy,sy7636a", .data =3D &silergy_sy7636a}, { .compatible =3D "maxim,max5970", .data =3D &maxim_max5970}, { .compatible =3D "maxim,max5978", .data =3D &maxim_max5970}, { .compatible =3D "maxim,max77705-battery", .data =3D &maxim_mon_max77705= }, + { .compatible =3D "spacemit,p1", .data =3D &spacemit_p1, }, {} }; MODULE_DEVICE_TABLE(of, simple_mfd_i2c_of_match); --=20 2.48.1