2 * Copyright (C) 2016 Socionext Inc.
3 * Author: Masahiro Yamada <yamada.masahiro@socionext.com>
5 * SPDX-License-Identifier: GPL-2.0+
8 #ifndef __CLK_UNIPHIER_H__
9 #define __CLK_UNIPHIER_H__
11 #include <linux/kernel.h>
13 #define UNIPHIER_CLK_MAX_NR_MUXS 8
15 struct uniphier_clk_gate_data
{
21 struct uniphier_clk_mux_data
{
25 unsigned int masks
[UNIPHIER_CLK_MAX_NR_MUXS
];
26 unsigned int vals
[UNIPHIER_CLK_MAX_NR_MUXS
];
27 unsigned long rates
[UNIPHIER_CLK_MAX_NR_MUXS
];
30 struct uniphier_clk_data
{
31 const struct uniphier_clk_gate_data
*gate
;
32 const struct uniphier_clk_mux_data
*mux
;
35 #define UNIPHIER_CLK_ID_END (unsigned int)(-1)
37 #define UNIPHIER_CLK_END \
38 { .id = UNIPHIER_CLK_ID_END }
40 #define UNIPHIER_CLK_GATE(_id, _reg, _bit) \
47 #define UNIPHIER_CLK_FIXED_RATE(_id, _rate) \
53 extern const struct uniphier_clk_data uniphier_mio_clk_data
;
55 #endif /* __CLK_UNIPHIER_H__ */