1 /* SPDX-License-Identifier: GPL-2.0+ */
3 * Copyright (C) 2016 Atmel Corporation
10 #include <linux/bitops.h>
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)
22 struct clk_master_layout {
28 extern const struct clk_master_layout at91rm9200_master_layout;
29 extern const struct clk_master_layout at91sam9x5_master_layout;
31 struct clk_master_characteristics {
32 struct clk_range output;
37 struct clk_pll_characteristics {
38 struct clk_range input;
40 const struct clk_range *output;
46 struct clk_pll_layout {
58 struct clk_programmable_layout {
66 struct clk_pcr_layout {
74 struct clk_usbck_layout {
81 * Clock setup description
82 * @cid: clock id corresponding to clock subsystem
83 * @pid: parent clock id corresponding to clock subsystem
87 struct pmc_clk_setup {
94 extern const struct clk_programmable_layout at91rm9200_programmable_layout;
95 extern const struct clk_programmable_layout at91sam9g45_programmable_layout;
96 extern const struct clk_programmable_layout at91sam9x5_programmable_layout;
98 extern const struct clk_ops at91_clk_ops;
100 struct clk *at91_clk_main_rc(void __iomem *reg, const char *name,
101 const char *parent_name);
102 struct clk *at91_clk_main_osc(void __iomem *reg, const char *name,
103 const char *parent_name, bool bypass);
104 struct clk *at91_clk_rm9200_main(void __iomem *reg, const char *name,
105 const char *parent_name);
106 struct clk *at91_clk_sam9x5_main(void __iomem *reg, const char *name,
107 const char * const *parent_names, int num_parents,
108 const u32 *mux_table, int type);
110 sam9x60_clk_register_usb(void __iomem *base, const char *name,
111 const char * const *parent_names, u8 num_parents,
112 const struct clk_usbck_layout *usbck_layout,
113 const u32 *clk_mux_table, const u32 *mux_table, u8 id);
115 sam9x60_clk_register_div_pll(void __iomem *base, const char *name,
116 const char *parent_name, u8 id,
117 const struct clk_pll_characteristics *characteristics,
118 const struct clk_pll_layout *layout, bool critical);
120 sam9x60_clk_register_frac_pll(void __iomem *base, const char *name,
121 const char *parent_name, u8 id,
122 const struct clk_pll_characteristics *characteristics,
123 const struct clk_pll_layout *layout, bool critical);
125 at91_clk_register_master_pres(void __iomem *base, const char *name,
126 const char * const *parent_names, int num_parents,
127 const struct clk_master_layout *layout,
128 const struct clk_master_characteristics *characteristics,
129 const u32 *mux_table);
131 at91_clk_register_master_div(void __iomem *base,
132 const char *name, const char *parent_name,
133 const struct clk_master_layout *layout,
134 const struct clk_master_characteristics *characteristics);
136 at91_clk_sama7g5_register_master(void __iomem *base, const char *name,
137 const char * const *parent_names, int num_parents,
138 const u32 *mux_table, const u32 *clk_mux_table,
139 bool critical, u8 id);
141 at91_clk_register_utmi(void __iomem *base, struct udevice *dev,
142 const char *name, const char *parent_name);
144 at91_clk_sama7g5_register_utmi(void __iomem *base, const char *name,
145 const char *parent_name);
147 at91_clk_register_programmable(void __iomem *base, const char *name,
148 const char * const *parent_names, u8 num_parents, u8 id,
149 const struct clk_programmable_layout *layout,
150 const u32 *clk_mux_table, const u32 *mux_table);
152 at91_clk_register_system(void __iomem *base, const char *name,
153 const char *parent_name, u8 id);
155 at91_clk_register_peripheral(void __iomem *base, const char *name,
156 const char *parent_name, u32 id);
158 at91_clk_register_sam9x5_peripheral(void __iomem *base,
159 const struct clk_pcr_layout *layout,
160 const char *name, const char *parent_name,
161 u32 id, const struct clk_range *range);
163 at91_clk_register_generic(void __iomem *base,
164 const struct clk_pcr_layout *layout, const char *name,
165 const char * const *parent_names,
166 const u32 *clk_mux_table, const u32 *mux_table,
167 u8 num_parents, u8 id, const struct clk_range *range);
169 int at91_clk_mux_val_to_index(const u32 *table, u32 num_parents, u32 val);
170 int at91_clk_mux_index_to_val(const u32 *table, u32 num_parents, u32 index);
172 void pmc_read(void __iomem *base, unsigned int off, unsigned int *val);
173 void pmc_write(void __iomem *base, unsigned int off, unsigned int val);
174 void pmc_update_bits(void __iomem *base, unsigned int off, unsigned int mask,
177 int at91_clk_setup(const struct pmc_clk_setup *setup, int size);