Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
| 2 | /* |
| 3 | * Copyright (C) 2020 Microchip Technology Inc. |
| 4 | * Padmarao Begari <padmarao.begari@microchip.com> |
| 5 | */ |
| 6 | #ifndef __MICROCHIP_MPFS_CLK_H |
| 7 | #define __MICROCHIP_MPFS_CLK_H |
| 8 | |
| 9 | #include <linux/clk-provider.h> |
Conor Dooley | 54713d6 | 2024-10-23 11:17:52 +0100 | [diff] [blame] | 10 | #include <regmap.h> |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 11 | /** |
| 12 | * mpfs_clk_register_cfgs() - register configuration clocks |
| 13 | * |
| 14 | * @base: base address of the mpfs system register. |
Conor Dooley | 4a182e0 | 2022-10-25 08:58:45 +0100 | [diff] [blame] | 15 | * @parent: a pointer to parent clock. |
Heinrich Schuchardt | 47b4c02 | 2022-01-19 18:05:50 +0100 | [diff] [blame] | 16 | * Return: zero on success, or a negative error code. |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 17 | */ |
Conor Dooley | 54713d6 | 2024-10-23 11:17:52 +0100 | [diff] [blame] | 18 | int mpfs_clk_register_cfgs(struct clk *parent, struct regmap *regmap); |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 19 | /** |
Conor Dooley | d4bbef0 | 2022-10-25 08:58:46 +0100 | [diff] [blame] | 20 | * mpfs_clk_register_msspll() - register the mss pll |
| 21 | * |
| 22 | * @base: base address of the mpfs system register. |
| 23 | * @parent: a pointer to parent clock. |
| 24 | * Return: zero on success, or a negative error code. |
| 25 | */ |
| 26 | int mpfs_clk_register_msspll(void __iomem *base, struct clk *parent); |
| 27 | /** |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 28 | * mpfs_clk_register_periphs() - register peripheral clocks |
| 29 | * |
| 30 | * @base: base address of the mpfs system register. |
Conor Dooley | 73a1d60 | 2022-10-25 08:58:47 +0100 | [diff] [blame] | 31 | * @dev: udevice representing the clock controller. |
Heinrich Schuchardt | 47b4c02 | 2022-01-19 18:05:50 +0100 | [diff] [blame] | 32 | * Return: zero on success, or a negative error code. |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 33 | */ |
Conor Dooley | 54713d6 | 2024-10-23 11:17:52 +0100 | [diff] [blame] | 34 | int mpfs_clk_register_periphs(struct udevice *dev, struct regmap *regmap); |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 35 | /** |
| 36 | * divider_get_val() - get the clock divider value |
| 37 | * |
| 38 | * @rate: requested clock rate. |
| 39 | * @parent_rate: parent clock rate. |
| 40 | * @table: a pointer to clock divider table. |
| 41 | * @width: width of the divider bit field. |
| 42 | * @flags: common clock framework flags. |
Heinrich Schuchardt | 47b4c02 | 2022-01-19 18:05:50 +0100 | [diff] [blame] | 43 | * Return: divider value on success, or a negative error code. |
Padmarao Begari | 0c4ae80 | 2021-01-15 08:20:38 +0530 | [diff] [blame] | 44 | */ |
| 45 | int divider_get_val(unsigned long rate, unsigned long parent_rate, |
| 46 | const struct clk_div_table *table, |
| 47 | u8 width, unsigned long flags); |
| 48 | |
| 49 | #endif /* __MICROCHIP_MPFS_CLK_H */ |