Skip to content

Commit

Permalink
soc: arm: npcx: fix clock reference of APB4/FIU1 buses
Browse files Browse the repository at this point in the history
This CL fixes the clock reference of APB4/FIU1 buses by introducing new
Kconfig options.

Signed-off-by: Mulin Chao <mlchao@nuvoton.com>
  • Loading branch information
MulinChao authored and fabiobaltieri committed Nov 16, 2023
1 parent 483dd8a commit 76b0aab
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 18 deletions.
12 changes: 12 additions & 0 deletions drivers/clock_control/Kconfig.npcx
Original file line number Diff line number Diff line change
Expand Up @@ -18,3 +18,15 @@ config CLOCK_CONTROL_NPCX_EXTERNAL_SRC
is generated by the on-chip Crystal Oscillator (XTOSC).
This includes an on-chip oscillator, to which an external crystal
and the related passive components are connected.

config CLOCK_CONTROL_NPCX_SUPP_APB4
bool "Indicates that the clock controller supports APB4 bus"
default y if !SOC_SERIES_NPCX7
help
Selected if NPCX series supports APB4 bus.

config CLOCK_CONTROL_NPCX_SUPP_FIU1
bool "Indicates that the clock controller supports FIU1 bus"
default y if SOC_SERIES_NPCX4
help
Selected if NPCX series supports FIU1 bus.
16 changes: 16 additions & 0 deletions soc/arm/nuvoton_npcx/common/soc_clock.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,14 @@ struct npcx_clk_cfg {
#define APB2DIV_VAL (DT_PROP(DT_NODELABEL(pcc), apb2_prescaler) - 1)
/* APB3 clock divider */
#define APB3DIV_VAL (DT_PROP(DT_NODELABEL(pcc), apb3_prescaler) - 1)
/* APB4 clock divider if supported */
#if DT_NODE_HAS_PROP(DT_NODELABEL(pcc), apb4_prescaler)
#if defined(CONFIG_CLOCK_CONTROL_NPCX_SUPP_APB4) /* Supported in NPCX9 and later series */
#define APB4DIV_VAL (DT_PROP(DT_NODELABEL(pcc), apb4_prescaler) - 1)
#else
#error "APB4 clock divider is not supported but defined in pcc node!"
#endif /* CONFIG_CLOCK_CONTROL_NPCX_SUPP_APB4 */
#endif

/* Construct a uint8_t array from 'pwdwn-ctl-val' prop for PWDWN_CTL initialization. */
#define NPCX_PWDWN_CTL_ITEMS_INIT(node, prop, idx) DT_PROP_BY_IDX(node, prop, idx),
Expand Down Expand Up @@ -89,6 +97,14 @@ struct npcx_clk_cfg {
#define FIUDIV_VAL 0 /* FIU_CLK = CORE_CLK */
#endif

#if defined(CONFIG_CLOCK_CONTROL_NPCX_SUPP_FIU1)
#if (CORE_CLK > (MAX_OFMCLK / 2))
#define FIU1DIV_VAL 1 /* FIU1_CLK = CORE_CLK/2 */
#else
#define FIU1DIV_VAL 0 /* FIU1_CLK = CORE_CLK */
#endif
#endif /* CONFIG_CLOCK_CONTROL_NPCX_SUPP_FIU1 */

/* Get APB clock freq */
#define NPCX_APB_CLOCK(no) (APBSRC_CLK / (APB##no##DIV_VAL + 1))

Expand Down
12 changes: 0 additions & 12 deletions soc/arm/nuvoton_npcx/npcx4/soc.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,16 +58,4 @@
#include <soc_pins.h>
#include <soc_power.h>

/* NPCX4 Clock definitions */
#if DT_NODE_HAS_PROP(DT_NODELABEL(pcc), apb4_prescaler)
/* APB4 clock divider if supported */
#define APB4DIV_VAL (DT_PROP(DT_NODELABEL(pcc), apb4_prescaler) - 1)
#endif

#if (CORE_CLK > (MAX_OFMCLK / 2))
#define FIU1DIV_VAL 1 /* If CORE_CLK > MAX_OFMCLK / 2, FIU1_CLK = CORE_CLK/2 */
#else
#define FIU1DIV_VAL 0 /* Else, FIU1_CLK = CORE_CLK */
#endif

#endif /* _NUVOTON_NPCX_SOC_H_ */
6 changes: 0 additions & 6 deletions soc/arm/nuvoton_npcx/npcx9/soc.h
Original file line number Diff line number Diff line change
Expand Up @@ -56,10 +56,4 @@
#include <soc_pins.h>
#include <soc_power.h>

/* NPCX9 Clock definitions */
#if DT_NODE_HAS_PROP(DT_NODELABEL(pcc), apb4_prescaler)
/* APB4 clock divider if supported */
#define APB4DIV_VAL (DT_PROP(DT_NODELABEL(pcc), apb4_prescaler) - 1)
#endif

#endif /* _NUVOTON_NPCX_SOC_H_ */

0 comments on commit 76b0aab

Please sign in to comment.