65 lines
		
	
	
	
		
			1.4 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			65 lines
		
	
	
	
		
			1.4 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
|   | #ifndef __ASM_MIPS_CLOCK_H
 | ||
|  | #define __ASM_MIPS_CLOCK_H
 | ||
|  | 
 | ||
|  | #include <linux/kref.h>
 | ||
|  | #include <linux/list.h>
 | ||
|  | #include <linux/seq_file.h>
 | ||
|  | #include <linux/clk.h>
 | ||
|  | 
 | ||
|  | extern void (*cpu_wait) (void); | ||
|  | 
 | ||
|  | struct clk; | ||
|  | 
 | ||
|  | struct clk_ops { | ||
|  | 	void (*init) (struct clk *clk); | ||
|  | 	void (*enable) (struct clk *clk); | ||
|  | 	void (*disable) (struct clk *clk); | ||
|  | 	void (*recalc) (struct clk *clk); | ||
|  | 	int (*set_rate) (struct clk *clk, unsigned long rate, int algo_id); | ||
|  | 	long (*round_rate) (struct clk *clk, unsigned long rate); | ||
|  | }; | ||
|  | 
 | ||
|  | struct clk { | ||
|  | 	struct list_head node; | ||
|  | 	const char *name; | ||
|  | 	int id; | ||
|  | 	struct module *owner; | ||
|  | 
 | ||
|  | 	struct clk *parent; | ||
|  | 	struct clk_ops *ops; | ||
|  | 
 | ||
|  | 	struct kref kref; | ||
|  | 
 | ||
|  | 	unsigned long rate; | ||
|  | 	unsigned long flags; | ||
|  | }; | ||
|  | 
 | ||
|  | #define CLK_ALWAYS_ENABLED	(1 << 0)
 | ||
|  | #define CLK_RATE_PROPAGATES	(1 << 1)
 | ||
|  | 
 | ||
|  | /* Should be defined by processor-specific code */ | ||
|  | void arch_init_clk_ops(struct clk_ops **, int type); | ||
|  | 
 | ||
|  | int clk_init(void); | ||
|  | 
 | ||
|  | int __clk_enable(struct clk *); | ||
|  | void __clk_disable(struct clk *); | ||
|  | 
 | ||
|  | void clk_recalc_rate(struct clk *); | ||
|  | 
 | ||
|  | int clk_register(struct clk *); | ||
|  | void clk_unregister(struct clk *); | ||
|  | 
 | ||
|  | /* the exported API, in addition to clk_set_rate */ | ||
|  | /**
 | ||
|  |  * clk_set_rate_ex - set the clock rate for a clock source, with additional parameter | ||
|  |  * @clk: clock source | ||
|  |  * @rate: desired clock rate in Hz | ||
|  |  * @algo_id: algorithm id to be passed down to ops->set_rate | ||
|  |  * | ||
|  |  * Returns success (0) or negative errno. | ||
|  |  */ | ||
|  | int clk_set_rate_ex(struct clk *clk, unsigned long rate, int algo_id); | ||
|  | 
 | ||
|  | #endif				/* __ASM_MIPS_CLOCK_H */
 |