aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWolfram Sang <wsa+renesas@sang-engineering.com>2015-03-12 12:17:58 -0400
committerWolfram Sang <wsa@the-dreams.de>2015-03-18 08:36:46 -0400
commit351d224f64afc1b3b359a1738b7d4600c7e64061 (patch)
tree3cdb8debf2d255b55f0bddc54bafa721551faa89
parentb20d386485e25934aef8aa24cbc8c2f51a2cb9cf (diff)
of: base: add function to get highest id of an alias stem
I2C supports adding adapters using either a dynamic or fixed id. The latter is provided by aliases in the DT case. To prevent id collisions of those two types, install this function which gives us the highest fixed id, so we can then let the dynamically created ones come after this highest number. Signed-off-by: Wolfram Sang <wsa+renesas@sang-engineering.com> Acked-by: Rob Herring <robh@kernel.org> Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
-rw-r--r--drivers/of/base.c26
-rw-r--r--include/linux/of.h6
2 files changed, 32 insertions, 0 deletions
diff --git a/drivers/of/base.c b/drivers/of/base.c
index 0a8aeb8523fe..63cba04aacf6 100644
--- a/drivers/of/base.c
+++ b/drivers/of/base.c
@@ -1958,6 +1958,32 @@ int of_alias_get_id(struct device_node *np, const char *stem)
1958} 1958}
1959EXPORT_SYMBOL_GPL(of_alias_get_id); 1959EXPORT_SYMBOL_GPL(of_alias_get_id);
1960 1960
1961/**
1962 * of_alias_get_highest_id - Get highest alias id for the given stem
1963 * @stem: Alias stem to be examined
1964 *
1965 * The function travels the lookup table to get the highest alias id for the
1966 * given alias stem. It returns the alias id if found.
1967 */
1968int of_alias_get_highest_id(const char *stem)
1969{
1970 struct alias_prop *app;
1971 int id = -ENODEV;
1972
1973 mutex_lock(&of_mutex);
1974 list_for_each_entry(app, &aliases_lookup, link) {
1975 if (strcmp(app->stem, stem) != 0)
1976 continue;
1977
1978 if (app->id > id)
1979 id = app->id;
1980 }
1981 mutex_unlock(&of_mutex);
1982
1983 return id;
1984}
1985EXPORT_SYMBOL_GPL(of_alias_get_highest_id);
1986
1961const __be32 *of_prop_next_u32(struct property *prop, const __be32 *cur, 1987const __be32 *of_prop_next_u32(struct property *prop, const __be32 *cur,
1962 u32 *pu) 1988 u32 *pu)
1963{ 1989{
diff --git a/include/linux/of.h b/include/linux/of.h
index dfde07e77a63..9bfcc18ceab3 100644
--- a/include/linux/of.h
+++ b/include/linux/of.h
@@ -332,6 +332,7 @@ extern int of_count_phandle_with_args(const struct device_node *np,
332 332
333extern void of_alias_scan(void * (*dt_alloc)(u64 size, u64 align)); 333extern void of_alias_scan(void * (*dt_alloc)(u64 size, u64 align));
334extern int of_alias_get_id(struct device_node *np, const char *stem); 334extern int of_alias_get_id(struct device_node *np, const char *stem);
335extern int of_alias_get_highest_id(const char *stem);
335 336
336extern int of_machine_is_compatible(const char *compat); 337extern int of_machine_is_compatible(const char *compat);
337 338
@@ -594,6 +595,11 @@ static inline int of_alias_get_id(struct device_node *np, const char *stem)
594 return -ENOSYS; 595 return -ENOSYS;
595} 596}
596 597
598static inline int of_alias_get_highest_id(const char *stem)
599{
600 return -ENOSYS;
601}
602
597static inline int of_machine_is_compatible(const char *compat) 603static inline int of_machine_is_compatible(const char *compat)
598{ 604{
599 return 0; 605 return 0;