| Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 1 | /* | 
| Andrew Victor | 9d04126 | 2007-02-05 11:42:07 +0100 | [diff] [blame] | 2 | * linux/arch/arm/mach-at91/clock.h | 
| Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 3 | * | 
|  | 4 | * This program is free software; you can redistribute it and/or modify | 
|  | 5 | * it under the terms of the GNU General Public License version 2 as | 
|  | 6 | * published by the Free Software Foundation. | 
|  | 7 | */ | 
|  | 8 |  | 
| Jean-Christophe PLAGNIOL-VILLARD | bd60299 | 2011-02-02 07:27:07 +0100 | [diff] [blame] | 9 | #include <linux/clkdev.h> | 
|  | 10 |  | 
| Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 11 | #define CLK_TYPE_PRIMARY	0x1 | 
|  | 12 | #define CLK_TYPE_PLL		0x2 | 
|  | 13 | #define CLK_TYPE_PROGRAMMABLE	0x4 | 
|  | 14 | #define CLK_TYPE_PERIPHERAL	0x8 | 
| Andrew Victor | d481f86 | 2006-12-01 11:27:31 +0100 | [diff] [blame] | 15 | #define CLK_TYPE_SYSTEM		0x10 | 
| Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 16 |  | 
|  | 17 |  | 
|  | 18 | struct clk { | 
|  | 19 | struct list_head node; | 
|  | 20 | const char	*name;		/* unique clock name */ | 
| Jean-Christophe PLAGNIOL-VILLARD | bd60299 | 2011-02-02 07:27:07 +0100 | [diff] [blame] | 21 | struct clk_lookup cl; | 
| Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 22 | unsigned long	rate_hz; | 
|  | 23 | struct clk	*parent; | 
|  | 24 | u32		pmc_mask; | 
|  | 25 | void		(*mode)(struct clk *, int); | 
| Andrew Victor | 5e38efa | 2009-12-15 21:57:27 +0100 | [diff] [blame] | 26 | unsigned	id:3;		/* PCK0..4, or 32k/main/a/b */ | 
| Andrew Victor | 2eeaaa2 | 2006-09-27 10:50:59 +0100 | [diff] [blame] | 27 | unsigned	type;		/* clock type */ | 
|  | 28 | u16		users; | 
|  | 29 | }; | 
|  | 30 |  | 
|  | 31 |  | 
|  | 32 | extern int __init clk_register(struct clk *clk); | 
| Jean-Christophe PLAGNIOL-VILLARD | bd60299 | 2011-02-02 07:27:07 +0100 | [diff] [blame] | 33 | extern struct clk mck; | 
|  | 34 | extern struct clk utmi_clk; | 
|  | 35 |  | 
|  | 36 | #define CLKDEV_CON_ID(_id, _clk)			\ | 
|  | 37 | {						\ | 
|  | 38 | .con_id = _id,				\ | 
|  | 39 | .clk = _clk,				\ | 
|  | 40 | } | 
|  | 41 |  | 
|  | 42 | #define CLKDEV_CON_DEV_ID(_con_id, _dev_id, _clk)	\ | 
|  | 43 | {						\ | 
|  | 44 | .con_id = _con_id,			\ | 
|  | 45 | .dev_id = _dev_id,			\ | 
|  | 46 | .clk = _clk,				\ | 
|  | 47 | } |