]> git.sur5r.net Git - u-boot/blob - drivers/clk/uniphier/clk-uniphier.h
770a3225e1a3bdddbad1a0319ef0e50e10f43047
[u-boot] / drivers / clk / uniphier / clk-uniphier.h
1 /*
2  * Copyright (C) 2016 Socionext Inc.
3  *   Author: Masahiro Yamada <yamada.masahiro@socionext.com>
4  *
5  * SPDX-License-Identifier:     GPL-2.0+
6  */
7
8 #ifndef __CLK_UNIPHIER_H__
9 #define __CLK_UNIPHIER_H__
10
11 #include <linux/kernel.h>
12
13 #define UNIPHIER_CLK_MAX_NR_MUXS        8
14
15 struct uniphier_clk_gate_data {
16         unsigned int id;
17         unsigned int reg;
18         unsigned int bit;
19 };
20
21 struct uniphier_clk_mux_data {
22         unsigned int id;
23         unsigned int nr_muxs;
24         unsigned int reg;
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];
28 };
29
30 struct uniphier_clk_data {
31         const struct uniphier_clk_gate_data *gate;
32         const struct uniphier_clk_mux_data *mux;
33 };
34
35 #define UNIPHIER_CLK_ID_END             (unsigned int)(-1)
36
37 #define UNIPHIER_CLK_END                                \
38         { .id = UNIPHIER_CLK_ID_END }
39
40 #define UNIPHIER_CLK_GATE(_id, _reg, _bit)              \
41         {                                               \
42                 .id = (_id),                            \
43                 .reg = (_reg),                          \
44                 .bit = (_bit),                          \
45         }
46
47 #define UNIPHIER_CLK_FIXED_RATE(_id, _rate)             \
48         {                                               \
49                 .id = (_id),                            \
50                 .rates = {(_reg),},                     \
51         }
52
53 extern const struct uniphier_clk_data uniphier_pxs2_sys_clk_data;
54 extern const struct uniphier_clk_data uniphier_ld20_sys_clk_data;
55 extern const struct uniphier_clk_data uniphier_mio_clk_data;
56
57 #endif /* __CLK_UNIPHIER_H__ */