/* * Copyright (C) 2016 Socionext Inc. * Author: Masahiro Yamada * * SPDX-License-Identifier: GPL-2.0+ */ #ifndef __CLK_UNIPHIER_H__ #define __CLK_UNIPHIER_H__ #include #define UNIPHIER_CLK_MAX_NR_MUXS 8 struct uniphier_clk_gate_data { unsigned int id; unsigned int reg; unsigned int bit; }; struct uniphier_clk_mux_data { unsigned int id; unsigned int nr_muxs; unsigned int reg; unsigned int masks[UNIPHIER_CLK_MAX_NR_MUXS]; unsigned int vals[UNIPHIER_CLK_MAX_NR_MUXS]; unsigned long rates[UNIPHIER_CLK_MAX_NR_MUXS]; }; struct uniphier_clk_data { const struct uniphier_clk_gate_data *gate; const struct uniphier_clk_mux_data *mux; }; #define UNIPHIER_CLK_ID_END (unsigned int)(-1) #define UNIPHIER_CLK_END \ { .id = UNIPHIER_CLK_ID_END } #define UNIPHIER_CLK_GATE(_id, _reg, _bit) \ { \ .id = (_id), \ .reg = (_reg), \ .bit = (_bit), \ } #define UNIPHIER_CLK_FIXED_RATE(_id, _rate) \ { \ .id = (_id), \ .rates = {(_reg),}, \ } extern const struct uniphier_clk_data uniphier_pxs2_sys_clk_data; extern const struct uniphier_clk_data uniphier_ld20_sys_clk_data; extern const struct uniphier_clk_data uniphier_mio_clk_data; #endif /* __CLK_UNIPHIER_H__ */