83 строки
2.3 KiB
C
83 строки
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Structures used by ASPEED clock drivers
|
|
*
|
|
* Copyright 2019 IBM Corp.
|
|
*/
|
|
|
|
#include <linux/clk-provider.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/reset-controller.h>
|
|
#include <linux/spinlock.h>
|
|
|
|
struct clk_div_table;
|
|
struct regmap;
|
|
|
|
/**
|
|
* struct aspeed_gate_data - Aspeed gated clocks
|
|
* @clock_idx: bit used to gate this clock in the clock register
|
|
* @reset_idx: bit used to reset this IP in the reset register. -1 if no
|
|
* reset is required when enabling the clock
|
|
* @name: the clock name
|
|
* @parent_name: the name of the parent clock
|
|
* @flags: standard clock framework flags
|
|
*/
|
|
struct aspeed_gate_data {
|
|
u8 clock_idx;
|
|
s8 reset_idx;
|
|
const char *name;
|
|
const char *parent_name;
|
|
unsigned long flags;
|
|
};
|
|
|
|
/**
|
|
* struct aspeed_clk_gate - Aspeed specific clk_gate structure
|
|
* @hw: handle between common and hardware-specific interfaces
|
|
* @reg: register controlling gate
|
|
* @clock_idx: bit used to gate this clock in the clock register
|
|
* @reset_idx: bit used to reset this IP in the reset register. -1 if no
|
|
* reset is required when enabling the clock
|
|
* @flags: hardware-specific flags
|
|
* @lock: register lock
|
|
*
|
|
* Some of the clocks in the Aspeed SoC must be put in reset before enabling.
|
|
* This modified version of clk_gate allows an optional reset bit to be
|
|
* specified.
|
|
*/
|
|
struct aspeed_clk_gate {
|
|
struct clk_hw hw;
|
|
struct regmap *map;
|
|
u8 clock_idx;
|
|
s8 reset_idx;
|
|
u8 flags;
|
|
spinlock_t *lock;
|
|
};
|
|
|
|
#define to_aspeed_clk_gate(_hw) container_of(_hw, struct aspeed_clk_gate, hw)
|
|
|
|
/**
|
|
* struct aspeed_reset - Aspeed reset controller
|
|
* @map: regmap to access the containing system controller
|
|
* @rcdev: reset controller device
|
|
*/
|
|
struct aspeed_reset {
|
|
struct regmap *map;
|
|
struct reset_controller_dev rcdev;
|
|
};
|
|
|
|
#define to_aspeed_reset(p) container_of((p), struct aspeed_reset, rcdev)
|
|
|
|
/**
|
|
* struct aspeed_clk_soc_data - Aspeed SoC specific divisor information
|
|
* @div_table: Common divider lookup table
|
|
* @eclk_div_table: Divider lookup table for ECLK
|
|
* @mac_div_table: Divider lookup table for MAC (Ethernet) clocks
|
|
* @calc_pll: Callback to maculate common PLL settings
|
|
*/
|
|
struct aspeed_clk_soc_data {
|
|
const struct clk_div_table *div_table;
|
|
const struct clk_div_table *eclk_div_table;
|
|
const struct clk_div_table *mac_div_table;
|
|
struct clk_hw *(*calc_pll)(const char *name, u32 val);
|
|
};
|