blob: 33c7a66e84b5218ecff26811478f0ae71cbc849c [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Wenyou Yang8c772bd2016-07-20 17:55:12 +08002/*
3 * Copyright (C) 2016 Atmel Corporation
4 * Wenyou.Yang <wenyou.yang@atmel.com>
Wenyou Yang8c772bd2016-07-20 17:55:12 +08005 */
6
7#ifndef __AT91_PMC_H__
8#define __AT91_PMC_H__
9
Claudiu Beznea8fdb4252020-09-07 17:46:38 +030010#include <linux/bitops.h>
11#include <linux/io.h>
12
13/* Keep a range of 256 available clocks for every clock type. */
14#define AT91_TO_CLK_ID(_t, _i) (((_t) << 8) | ((_i) & 0xff))
15#define AT91_CLK_ID_TO_DID(_i) ((_i) & 0xff)
Wenyou Yang6b66b922017-09-05 18:30:07 +080016
Claudiu Beznea923ac872020-09-07 17:46:42 +030017struct clk_range {
18 unsigned long min;
19 unsigned long max;
20};
21
Claudiu Beznea1f9023a2020-09-07 17:46:43 +030022struct clk_master_layout {
23 u32 offset;
24 u32 mask;
25 u8 pres_shift;
26};
27
28extern const struct clk_master_layout at91rm9200_master_layout;
29extern const struct clk_master_layout at91sam9x5_master_layout;
30
31struct clk_master_characteristics {
32 struct clk_range output;
33 u32 divisors[4];
34 u8 have_div3_pres;
35};
36
Claudiu Beznea923ac872020-09-07 17:46:42 +030037struct clk_pll_characteristics {
38 struct clk_range input;
39 int num_output;
40 const struct clk_range *output;
41 u16 *icpll;
42 u8 *out;
43 u8 upll : 1;
44};
45
46struct clk_pll_layout {
47 u32 pllr_mask;
48 u32 mul_mask;
49 u32 frac_mask;
50 u32 div_mask;
51 u32 endiv_mask;
52 u8 mul_shift;
53 u8 frac_shift;
54 u8 div_shift;
55 u8 endiv_shift;
56};
57
Claudiu Beznea5d408872020-09-07 17:46:41 +030058struct clk *at91_clk_main_rc(void __iomem *reg, const char *name,
59 const char *parent_name);
60struct clk *at91_clk_main_osc(void __iomem *reg, const char *name,
61 const char *parent_name, bool bypass);
62struct clk *at91_clk_rm9200_main(void __iomem *reg, const char *name,
63 const char *parent_name);
64struct clk *at91_clk_sam9x5_main(void __iomem *reg, const char *name,
65 const char * const *parent_names, int num_parents,
66 const u32 *mux_table, int type);
Claudiu Beznea923ac872020-09-07 17:46:42 +030067struct clk *
68sam9x60_clk_register_div_pll(void __iomem *base, const char *name,
69 const char *parent_name, u8 id,
70 const struct clk_pll_characteristics *characteristics,
71 const struct clk_pll_layout *layout, bool critical);
72struct clk *
73sam9x60_clk_register_frac_pll(void __iomem *base, const char *name,
74 const char *parent_name, u8 id,
75 const struct clk_pll_characteristics *characteristics,
76 const struct clk_pll_layout *layout, bool critical);
Claudiu Beznea1f9023a2020-09-07 17:46:43 +030077struct clk *
78at91_clk_register_master(void __iomem *base, const char *name,
79 const char * const *parent_names, int num_parents,
80 const struct clk_master_layout *layout,
81 const struct clk_master_characteristics *characteristics,
82 const u32 *mux_table);
Claudiu Beznea5d408872020-09-07 17:46:41 +030083
Claudiu Beznea8fdb4252020-09-07 17:46:38 +030084int at91_clk_mux_val_to_index(const u32 *table, u32 num_parents, u32 val);
85int at91_clk_mux_index_to_val(const u32 *table, u32 num_parents, u32 index);
86
87void pmc_read(void __iomem *base, unsigned int off, unsigned int *val);
88void pmc_write(void __iomem *base, unsigned int off, unsigned int val);
89void pmc_update_bits(void __iomem *base, unsigned int off, unsigned int mask,
90 unsigned int bits);
Claudiu Beznea3f203a12020-09-07 17:46:39 +030091
Wenyou Yang8c772bd2016-07-20 17:55:12 +080092#endif