1 // SPDX-License-Identifier: GPL-2.0
3 * H8/300 divide clock driver
5 * Copyright 2015 Yoshinori Sato <ysato@users.sourceforge.jp>
8 #include <linux/clk-provider.h>
11 #include <linux/of_address.h>
13 static DEFINE_SPINLOCK(clklock
);
15 static void __init
h8300_div_clk_setup(struct device_node
*node
)
17 unsigned int num_parents
;
19 const char *clk_name
= node
->name
;
20 const char *parent_name
;
21 void __iomem
*divcr
= NULL
;
25 num_parents
= of_clk_get_parent_count(node
);
27 pr_err("%s: no parent found\n", clk_name
);
31 divcr
= of_iomap(node
, 0);
33 pr_err("%s: failed to map divide register\n", clk_name
);
36 offset
= (unsigned long)divcr
& 3;
37 offset
= (3 - offset
) * 8;
38 divcr
= (void __iomem
*)((unsigned long)divcr
& ~3);
40 parent_name
= of_clk_get_parent_name(node
, 0);
41 of_property_read_u32(node
, "renesas,width", &width
);
42 hw
= clk_hw_register_divider(NULL
, clk_name
, parent_name
,
43 CLK_SET_RATE_GATE
, divcr
, offset
, width
,
44 CLK_DIVIDER_POWER_OF_TWO
, &clklock
);
46 of_clk_add_hw_provider(node
, of_clk_hw_simple_get
, hw
);
49 pr_err("%s: failed to register %s div clock (%ld)\n",
50 __func__
, clk_name
, PTR_ERR(hw
));
56 CLK_OF_DECLARE(h8300_div_clk
, "renesas,h8300-div-clock", h8300_div_clk_setup
);