xref: /freebsd/sys/arm64/qoriq/clk/qoriq_clkgen.h (revision be82b3a0bf72ed3b5f01ac9fcd8dcd3802e3c742)
1b8cb0864SMarcin Wojtas /*-
24d846d26SWarner Losh  * SPDX-License-Identifier: BSD-2-Clause
3b8cb0864SMarcin Wojtas  *
4b8cb0864SMarcin Wojtas  * Copyright (c) 2020 Alstom Group.
5b8cb0864SMarcin Wojtas  * Copyright (c) 2020 Semihalf.
6b8cb0864SMarcin Wojtas  *
7b8cb0864SMarcin Wojtas  * Redistribution and use in source and binary forms, with or without
8b8cb0864SMarcin Wojtas  * modification, are permitted provided that the following conditions
9b8cb0864SMarcin Wojtas  * are met:
10b8cb0864SMarcin Wojtas  * 1. Redistributions of source code must retain the above copyright
11b8cb0864SMarcin Wojtas  *    notice, this list of conditions and the following disclaimer.
12b8cb0864SMarcin Wojtas  * 2. Redistributions in binary form must reproduce the above copyright
13b8cb0864SMarcin Wojtas  *    notice, this list of conditions and the following disclaimer in the
14b8cb0864SMarcin Wojtas  *    documentation and/or other materials provided with the distribution.
15b8cb0864SMarcin Wojtas  *
16b8cb0864SMarcin Wojtas  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17b8cb0864SMarcin Wojtas  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18b8cb0864SMarcin Wojtas  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19b8cb0864SMarcin Wojtas  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20b8cb0864SMarcin Wojtas  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21b8cb0864SMarcin Wojtas  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22b8cb0864SMarcin Wojtas  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23b8cb0864SMarcin Wojtas  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24b8cb0864SMarcin Wojtas  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25b8cb0864SMarcin Wojtas  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26b8cb0864SMarcin Wojtas  * SUCH DAMAGE.
27b8cb0864SMarcin Wojtas  *
28b8cb0864SMarcin Wojtas  */
29b8cb0864SMarcin Wojtas 
30b8cb0864SMarcin Wojtas #ifndef	_QORIQ_CLKGEN_H_
31b8cb0864SMarcin Wojtas #define	_QORIQ_CLKGEN_H_
32b8cb0864SMarcin Wojtas 
33*be82b3a0SEmmanuel Vadot #include <dev/clk/clk.h>
34*be82b3a0SEmmanuel Vadot #include <dev/clk/clk_mux.h>
35b8cb0864SMarcin Wojtas 
36b8cb0864SMarcin Wojtas #include <arm64/qoriq/clk/qoriq_clk_pll.h>
37b8cb0864SMarcin Wojtas 
38b8cb0864SMarcin Wojtas #define	QORIQ_CLK_NAME_MAX_LEN	32
39b8cb0864SMarcin Wojtas 
40b8cb0864SMarcin Wojtas #define	QORIQ_LITTLE_ENDIAN	0x01
41b8cb0864SMarcin Wojtas 
42b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_SYSCLK	0
43b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_CMUX		1
44b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_HWACCEL	2
45b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_FMAN		3
46b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_PLATFORM_PLL	4
47b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_CORECLK	5
48b8cb0864SMarcin Wojtas #define	QORIQ_TYPE_INTERNAL	6
49b8cb0864SMarcin Wojtas 
50b8cb0864SMarcin Wojtas #define	PLL_DIV1	0
51b8cb0864SMarcin Wojtas #define	PLL_DIV2	1
52b8cb0864SMarcin Wojtas #define	PLL_DIV3	2
53b8cb0864SMarcin Wojtas #define	PLL_DIV4	3
54b8cb0864SMarcin Wojtas #define	PLL_DIV5	4
55b8cb0864SMarcin Wojtas #define	PLL_DIV6	5
56b8cb0864SMarcin Wojtas #define	PLL_DIV7	6
57b8cb0864SMarcin Wojtas #define	PLL_DIV8	7
58b8cb0864SMarcin Wojtas #define	PLL_DIV9	8
59b8cb0864SMarcin Wojtas #define	PLL_DIV10	9
60b8cb0864SMarcin Wojtas #define	PLL_DIV11	10
61b8cb0864SMarcin Wojtas #define	PLL_DIV12	11
62b8cb0864SMarcin Wojtas #define	PLL_DIV13	12
63b8cb0864SMarcin Wojtas #define	PLL_DIV14	13
64b8cb0864SMarcin Wojtas #define	PLL_DIV15	14
65b8cb0864SMarcin Wojtas #define	PLL_DIV16	15
66b8cb0864SMarcin Wojtas 
67b8cb0864SMarcin Wojtas #define	QORIQ_CLK_ID(_type, _index)	((_type << 8) + _index)
68b8cb0864SMarcin Wojtas 
69b8cb0864SMarcin Wojtas #define	QORIQ_SYSCLK_NAME	"clockgen_sysclk"
70b8cb0864SMarcin Wojtas #define	QORIQ_CORECLK_NAME	"clockgen_coreclk"
71b8cb0864SMarcin Wojtas 
72b8cb0864SMarcin Wojtas typedef int (*qoriq_init_func_t)(device_t);
73b8cb0864SMarcin Wojtas 
74b8cb0864SMarcin Wojtas struct qoriq_clkgen_softc {
75b8cb0864SMarcin Wojtas 	device_t			dev;
76b8cb0864SMarcin Wojtas 	struct resource			*res;
77b8cb0864SMarcin Wojtas 	struct clkdom			*clkdom;
78b8cb0864SMarcin Wojtas 	struct mtx			mtx;
79b8cb0864SMarcin Wojtas 	struct qoriq_clk_pll_def	*pltfrm_pll_def;
80b8cb0864SMarcin Wojtas 	struct qoriq_clk_pll_def	**cga_pll;
81b8cb0864SMarcin Wojtas 	int				cga_pll_num;
82b8cb0864SMarcin Wojtas 	struct clk_mux_def		**mux;
83b8cb0864SMarcin Wojtas 	int				mux_num;
84b8cb0864SMarcin Wojtas 	qoriq_init_func_t		init_func;
85b8cb0864SMarcin Wojtas 	uint32_t			flags;
86b8cb0864SMarcin Wojtas 	bool				has_coreclk;
87b8cb0864SMarcin Wojtas };
88b8cb0864SMarcin Wojtas 
89b8cb0864SMarcin Wojtas MALLOC_DECLARE(M_QORIQ_CLKGEN);
90b8cb0864SMarcin Wojtas DECLARE_CLASS(qoriq_clkgen_driver);
91b8cb0864SMarcin Wojtas 
92b8cb0864SMarcin Wojtas int qoriq_clkgen_attach(device_t);
93b8cb0864SMarcin Wojtas 
94b8cb0864SMarcin Wojtas #endif	/* _QORIQ_CLKGEN_H_ */
95