diff options
| author | Dave Kleikamp <shaggy@linux.vnet.ibm.com> | 2009-02-02 13:40:55 -0600 | 
|---|---|---|
| committer | Dave Kleikamp <shaggy@linux.vnet.ibm.com> | 2009-02-02 13:40:55 -0600 | 
| commit | 8db0c5d5ef3ab99fe9e5151872b75f45c4282e3c (patch) | |
| tree | da9759151e00221c58cdd9f4de893c0b08753670 /arch/arm/common/clkdev.c | |
| parent | 1ad53a98c927a9b5b1b57288ac0edec562fbcf8d (diff) | |
| parent | 45c82b5a770be66845687a7d027c8b52946d59af (diff) | |
Merge branch 'master' of /home/shaggy/git/linus-clean/
Diffstat (limited to 'arch/arm/common/clkdev.c')
| -rw-r--r-- | arch/arm/common/clkdev.c | 25 | 
1 files changed, 19 insertions, 6 deletions
diff --git a/arch/arm/common/clkdev.c b/arch/arm/common/clkdev.c index 17a17b49a45b..1037bba18329 100644 --- a/arch/arm/common/clkdev.c +++ b/arch/arm/common/clkdev.c @@ -24,6 +24,15 @@  static LIST_HEAD(clocks);  static DEFINE_MUTEX(clocks_mutex); +/* + * Find the correct struct clk for the device and connection ID. + * We do slightly fuzzy matching here: + *  An entry with a NULL ID is assumed to be a wildcard. + *  If an entry has a device ID, it must match + *  If an entry has a connection ID, it must match + * Then we take the most specific entry - with the following + * order of precidence: dev+con > dev only > con only. + */  static struct clk *clk_find(const char *dev_id, const char *con_id)  {  	struct clk_lookup *p; @@ -31,13 +40,17 @@ static struct clk *clk_find(const char *dev_id, const char *con_id)  	int match, best = 0;  	list_for_each_entry(p, &clocks, node) { -		if ((p->dev_id && !dev_id) || (p->con_id && !con_id)) -			continue;  		match = 0; -		if (p->dev_id) -			match += 2 * (strcmp(p->dev_id, dev_id) == 0); -		if (p->con_id) -			match += 1 * (strcmp(p->con_id, con_id) == 0); +		if (p->dev_id) { +			if (!dev_id || strcmp(p->dev_id, dev_id)) +				continue; +			match += 2; +		} +		if (p->con_id) { +			if (!con_id || strcmp(p->con_id, con_id)) +				continue; +			match += 1; +		}  		if (match == 0)  			continue;  | 
