Linux clock framework development
 help / color / mirror / Atom feed
From: "Xuyang Dong" <dongxuyang@eswincomputing.com>
To: "Brian Masney" <bmasney@redhat.com>, sashiko-bot@kernel.org
Cc: mturquette@baylibre.com, sboyd@kernel.org, robh@kernel.org,
	krzk+dt@kernel.org, conor+dt@kernel.org,
	linux-clk@vger.kernel.org, devicetree@vger.kernel.org,
	linux-kernel@vger.kernel.org, p.zabel@pengutronix.de,
	huangyifeng@eswincomputing.com, benoit.monin@bootlin.com,
	ningyu@eswincomputing.com, linmin@eswincomputing.com,
	pinkesh.vaghela@einfochips.com
Subject: Re: Re: [PATCH v4 2/3] clk: eswin: Add eic7700 HSP clock driver
Date: Thu, 14 May 2026 10:30:11 +0800 (GMT+08:00)	[thread overview]
Message-ID: <849a595.6278.19e2451f3d0.Coremail.dongxuyang@eswincomputing.com> (raw)
In-Reply-To: <agNLDkz0L67lL0_f@redhat.com>

> 
> On Tue, May 12, 2026 at 10:07:47AM +0800, Xuyang Dong wrote:
> > Add driver for the ESWIN EIC7700 high-speed peripherals system
> > clock controller and register an auxiliary device for system
> > reset controller which is named as "hsp-reset".
> > 
> > Signed-off-by: Xuyang Dong <dongxuyang@eswincomputing.com>
> > ---
> >  drivers/clk/eswin/Kconfig           |  12 +
> >  drivers/clk/eswin/Makefile          |   1 +
> >  drivers/clk/eswin/clk-eic7700-hsp.c | 338 ++++++++++++++++++++++++++++
> >  3 files changed, 351 insertions(+)
> >  create mode 100644 drivers/clk/eswin/clk-eic7700-hsp.c
> > 
> > diff --git a/drivers/clk/eswin/Kconfig b/drivers/clk/eswin/Kconfig
> > index 0406ec499ec9..e6cc2a407bac 100644
> > --- a/drivers/clk/eswin/Kconfig
> > +++ b/drivers/clk/eswin/Kconfig
> > @@ -13,3 +13,15 @@ config COMMON_CLK_EIC7700
> >  	  SoC. The clock controller generates and supplies clocks to various
> >  	  peripherals within the SoC.
> >  	  Say yes here to support the clock controller on the EIC7700 SoC.
> > +
> > +config COMMON_CLK_EIC7700_HSP
> > +	tristate "EIC7700 HSP Clock Driver"
> > +	depends on ARCH_ESWIN || COMPILE_TEST
> > +	select AUXILIARY_BUS
> > +	select COMMON_CLK_EIC7700
> > +	select RESET_EIC7700_HSP if RESET_CONTROLLER
> > +	help
> > +	  This driver provides support for clock controller on ESWIN EIC7700
> > +	  HSP. The clock controller generates and supplies clocks to high
> > +	  speed peripherals within the SoC.
> > +	  Say yes here to support the clock controller on the EIC7700 HSP.
> > diff --git a/drivers/clk/eswin/Makefile b/drivers/clk/eswin/Makefile
> > index 4a7c2af82164..21a09a3396df 100644
> > --- a/drivers/clk/eswin/Makefile
> > +++ b/drivers/clk/eswin/Makefile
> > @@ -6,3 +6,4 @@
> >  obj-$(CONFIG_COMMON_CLK_ESWIN)		+= clk.o
> >  
> >  obj-$(CONFIG_COMMON_CLK_EIC7700)	+= clk-eic7700.o
> > +obj-$(CONFIG_COMMON_CLK_EIC7700_HSP)	+= clk-eic7700-hsp.o
> > diff --git a/drivers/clk/eswin/clk-eic7700-hsp.c b/drivers/clk/eswin/clk-eic7700-hsp.c
> > new file mode 100644
> > index 000000000000..0d5bd5b705dc
> > --- /dev/null
> > +++ b/drivers/clk/eswin/clk-eic7700-hsp.c
> > @@ -0,0 +1,338 @@
> > +// SPDX-License-Identifier: GPL-2.0
> > +/*
> > + * Copyright 2026, Beijing ESWIN Computing Technology Co., Ltd..
> > + * All rights reserved.
> > + *
> > + * ESWIN EIC7700 HSP Clock Driver
> > + *
> > + * Authors: Xuyang Dong <dongxuyang@eswincomputing.com>
> > + */
> > +
> > +#include <linux/auxiliary_bus.h>
> > +#include <linux/clk-provider.h>
> > +#include <linux/platform_device.h>
> > +#include <linux/regmap.h>
> > +
> > +#include <dt-bindings/clock/eswin,eic7700-hspcrg.h>
> > +
> > +#include "common.h"
> > +
> > +#define EIC7700_HSP_SATA_REG		0x300
> > +#define EIC7700_HSP_MSHC0_REG		0x510
> > +#define EIC7700_HSP_MSHC1_REG		0x610
> > +#define EIC7700_HSP_MSHC2_REG		0x710
> > +#define EIC7700_HSP_USB0_REG		0x800
> > +#define EIC7700_HSP_USB0_REF_REG	0x83c
> > +#define EIC7700_HSP_USB1_REG		0x900
> > +#define EIC7700_HSP_USB1_REF_REG	0x93c
> > +
> > +#define USB_REF_XTAL24M			0x2a
> > +#define EIC7700_HSP_NR_CLKS		(EIC7700_HSP_CLK_GATE_SATA + 1)
> > +
> > +struct eic7700_hsp_clk_gate {
> > +	struct clk_hw hw;
> > +	unsigned int id;
> > +	struct regmap *regmap;
> > +	unsigned int reg;
> > +	unsigned int ref_reg;
> > +	const char *name;
> > +	const struct clk_parent_data *parent_data;
> > +	unsigned long flags;
> > +	unsigned int offset;
> > +	unsigned int ref_offset;
> > +	u8 bit_idx;
> > +};
> > +
> > +static const struct regmap_config eic7700_hsp_regmap_config = {
> > +	.reg_bits = 32,
> > +	.val_bits = 32,
> > +	.max_register = 0x1ffc,
> > +	.reg_stride = 4,
> > +	.fast_io = true,
> > +	.use_raw_spinlock = true,
> > +};
> > +
> > +static inline struct eic7700_hsp_clk_gate *to_gate_clk(struct clk_hw *hw)
> > +{
> > +	return container_of(hw, struct eic7700_hsp_clk_gate, hw);
> > +}
> > +
> > +#define EIC7700_HSP_GATE(_id, _name, _pdata, _flags, _offset, _idx,	\
> > +			 _ref_offset)					\
> > +	{								\
> > +		.id		= _id,					\
> > +		.name		= _name,				\
> > +		.parent_data	= _pdata,				\
> > +		.flags		= _flags,				\
> > +		.offset		= _offset,				\
> > +		.ref_offset	= _ref_offset,				\
> > +		.bit_idx	= _idx,					\
> > +	}
> > +
> > +static void hsp_clk_gate_endisable(struct clk_hw *hw, bool enable)
> > +{
> > +	struct eic7700_hsp_clk_gate *gate = to_gate_clk(hw);
> > +
> > +	if (enable) {
> > +		/*
> > +		 * Hardware bug: The USB reference clock must be 24MHz.
> > +		 * The default register value after reset is invalid.
> > +		 * Workaround: Rewrite the correct value before enabling
> > +		 * the USB gate clock.
> > +		 */
> > +		regmap_update_bits(gate->regmap, gate->ref_reg, 0x3f,
> > +				   USB_REF_XTAL24M);
> > +	}
> > +	regmap_assign_bits(gate->regmap, gate->reg, BIT(gate->bit_idx), enable);
> > +}
> > +
> > +static int hsp_clk_gate_enable(struct clk_hw *hw)
> > +{
> > +	hsp_clk_gate_endisable(hw, true);
> > +
> > +	return 0;
> > +}
> > +
> > +static void hsp_clk_gate_disable(struct clk_hw *hw)
> > +{
> > +	hsp_clk_gate_endisable(hw, false);
> > +}
> > +
> > +static int hsp_clk_gate_is_enabled(struct clk_hw *hw)
> > +{
> > +	struct eic7700_hsp_clk_gate *gate = to_gate_clk(hw);
> > +	unsigned int val;
> > +
> > +	regmap_read(gate->regmap, gate->reg, &val);
> > +
> > +	return !!(val & BIT(gate->bit_idx));
> 
> If the regmap_read() fails, then val will be uninitialized.

Hi Brian and Sashiko,

I will update the following code to address this in next version.

+	int ret;
+
+	ret = regmap_read(gate->regmap, gate->reg, &val);
+	if (ret != 0)
+		return ret;

Does this change look acceptable to you?

Best regards,
Xuyang Dong

> 
> With that fixed:
> 
> Reviewed-by: Brian Masney <bmasney@redhat.com>

  reply	other threads:[~2026-05-14  2:30 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-05-12  2:04 [PATCH v4 0/3] Add driver support for ESWIN EIC7700 HSP clock and reset generator dongxuyang
2026-05-12  2:05 ` [PATCH v4 1/3] dt-bindings: clock: Add ESWIN eic7700 " dongxuyang
2026-05-12 15:48   ` Brian Masney
2026-05-12 16:40     ` Conor Dooley
2026-05-12 17:27       ` Brian Masney
2026-05-12  2:07 ` [PATCH v4 2/3] clk: eswin: Add eic7700 HSP clock driver Xuyang Dong
2026-05-12 15:45   ` Brian Masney
2026-05-14  2:30     ` Xuyang Dong [this message]
2026-05-14 10:53       ` Brian Masney
2026-05-12  2:08 ` [PATCH v4 3/3] reset: eswin: Add eic7700 HSP reset driver dongxuyang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=849a595.6278.19e2451f3d0.Coremail.dongxuyang@eswincomputing.com \
    --to=dongxuyang@eswincomputing.com \
    --cc=benoit.monin@bootlin.com \
    --cc=bmasney@redhat.com \
    --cc=conor+dt@kernel.org \
    --cc=devicetree@vger.kernel.org \
    --cc=huangyifeng@eswincomputing.com \
    --cc=krzk+dt@kernel.org \
    --cc=linmin@eswincomputing.com \
    --cc=linux-clk@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mturquette@baylibre.com \
    --cc=ningyu@eswincomputing.com \
    --cc=p.zabel@pengutronix.de \
    --cc=pinkesh.vaghela@einfochips.com \
    --cc=robh@kernel.org \
    --cc=sashiko-bot@kernel.org \
    --cc=sboyd@kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox