| /* |
| * Copyright (c) 2014 Marvell Technology Group Ltd. |
| * |
| * Alexandre Belloni <alexandre.belloni@free-electrons.com> |
| * Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> |
| * |
| * This program is free software; you can redistribute it and/or modify it |
| * under the terms and conditions of the GNU General Public License, |
| * version 2, as published by the Free Software Foundation. |
| * |
| * This program is distributed in the hope it will be useful, but WITHOUT |
| * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
| * more details. |
| * |
| * You should have received a copy of the GNU General Public License along with |
| * this program. If not, see <http://www.gnu.org/licenses/>. |
| */ |
| #ifndef __BERLIN2_DIV_H |
| #define __BERLIN2_DIV_H |
| |
| struct clk_hw; |
| |
| #define BERLIN2_DIV_HAS_GATE BIT(0) |
| #define BERLIN2_DIV_HAS_MUX BIT(1) |
| |
| #define BERLIN2_PLL_SELECT(_off, _sh) \ |
| .pll_select_offs = _off, \ |
| .pll_select_shift = _sh |
| |
| #define BERLIN2_PLL_SWITCH(_off, _sh) \ |
| .pll_switch_offs = _off, \ |
| .pll_switch_shift = _sh |
| |
| #define BERLIN2_DIV_SELECT(_off, _sh) \ |
| .div_select_offs = _off, \ |
| .div_select_shift = _sh |
| |
| #define BERLIN2_DIV_SWITCH(_off, _sh) \ |
| .div_switch_offs = _off, \ |
| .div_switch_shift = _sh |
| |
| #define BERLIN2_DIV_D3SWITCH(_off, _sh) \ |
| .div3_switch_offs = _off, \ |
| .div3_switch_shift = _sh |
| |
| #define BERLIN2_DIV_GATE(_off, _sh) \ |
| .gate_offs = _off, \ |
| .gate_shift = _sh |
| |
| #define BERLIN2_SINGLE_DIV(_off) \ |
| BERLIN2_DIV_GATE(_off, 0), \ |
| BERLIN2_PLL_SELECT(_off, 1), \ |
| BERLIN2_PLL_SWITCH(_off, 4), \ |
| BERLIN2_DIV_SWITCH(_off, 5), \ |
| BERLIN2_DIV_D3SWITCH(_off, 6), \ |
| BERLIN2_DIV_SELECT(_off, 7) |
| |
| struct berlin2_div_map { |
| u16 pll_select_offs; |
| u16 pll_switch_offs; |
| u16 div_select_offs; |
| u16 div_switch_offs; |
| u16 div3_switch_offs; |
| u16 gate_offs; |
| u8 pll_select_shift; |
| u8 pll_switch_shift; |
| u8 div_select_shift; |
| u8 div_switch_shift; |
| u8 div3_switch_shift; |
| u8 gate_shift; |
| }; |
| |
| struct berlin2_div_data { |
| const char *name; |
| const u8 *parent_ids; |
| int num_parents; |
| unsigned long flags; |
| struct berlin2_div_map map; |
| u8 div_flags; |
| }; |
| |
| struct clk_hw * |
| berlin2_div_register(const struct berlin2_div_map *map, |
| void __iomem *base, const char *name, u8 div_flags, |
| const char **parent_names, int num_parents, |
| unsigned long flags, spinlock_t *lock); |
| |
| #endif /* __BERLIN2_DIV_H */ |