2006-09-27 11:50:59 +02:00
|
|
|
/*
|
2007-02-05 11:42:07 +01:00
|
|
|
* linux/arch/arm/mach-at91/clock.h
|
2006-09-27 11:50:59 +02:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define CLK_TYPE_PRIMARY 0x1
|
|
|
|
#define CLK_TYPE_PLL 0x2
|
|
|
|
#define CLK_TYPE_PROGRAMMABLE 0x4
|
|
|
|
#define CLK_TYPE_PERIPHERAL 0x8
|
2006-12-01 11:27:31 +01:00
|
|
|
#define CLK_TYPE_SYSTEM 0x10
|
2006-09-27 11:50:59 +02:00
|
|
|
|
|
|
|
|
|
|
|
struct clk {
|
|
|
|
struct list_head node;
|
|
|
|
const char *name; /* unique clock name */
|
|
|
|
const char *function; /* function of the clock */
|
|
|
|
struct device *dev; /* device associated with function */
|
|
|
|
unsigned long rate_hz;
|
|
|
|
struct clk *parent;
|
|
|
|
u32 pmc_mask;
|
|
|
|
void (*mode)(struct clk *, int);
|
2009-12-15 21:57:27 +01:00
|
|
|
unsigned id:3; /* PCK0..4, or 32k/main/a/b */
|
2006-09-27 11:50:59 +02:00
|
|
|
unsigned type; /* clock type */
|
|
|
|
u16 users;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
extern int __init clk_register(struct clk *clk);
|