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>
next prev parent reply other threads:[~2026-05-14 2:30 UTC|newest]
Thread overview: 9+ 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-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