diff options
author | Konstantin Khlebnikov <khlebnikov@yandex-team.ru> | 2015-04-08 12:59:20 -0400 |
---|---|---|
committer | Grant Likely <grant.likely@linaro.org> | 2015-06-04 01:39:52 -0400 |
commit | c8fff7bc5bba6bd59cad40441c189c4efe7190f6 (patch) | |
tree | 20680226822a5f94e7bc5b15ce8b6802b562224a | |
parent | ba155e2d21f6bf05de86a78dbe5bfd8757604a65 (diff) |
of: return NUMA_NO_NODE from fallback of_node_to_nid()
Node 0 might be offline as well as any other numa node,
in this case kernel cannot handle memory allocation and crashes.
Signed-off-by: Konstantin Khlebnikov <khlebnikov@yandex-team.ru>
Fixes: 0c3f061c195c ("of: implement of_node_to_nid as a weak function")
Signed-off-by: Grant Likely <grant.likely@linaro.org>
-rw-r--r-- | drivers/of/base.c | 2 | ||||
-rw-r--r-- | include/linux/of.h | 5 |
2 files changed, 5 insertions, 2 deletions
diff --git a/drivers/of/base.c b/drivers/of/base.c index 99764db0875a..8e39b38ca206 100644 --- a/drivers/of/base.c +++ b/drivers/of/base.c | |||
@@ -89,7 +89,7 @@ EXPORT_SYMBOL(of_n_size_cells); | |||
89 | #ifdef CONFIG_NUMA | 89 | #ifdef CONFIG_NUMA |
90 | int __weak of_node_to_nid(struct device_node *np) | 90 | int __weak of_node_to_nid(struct device_node *np) |
91 | { | 91 | { |
92 | return numa_node_id(); | 92 | return NUMA_NO_NODE; |
93 | } | 93 | } |
94 | #endif | 94 | #endif |
95 | 95 | ||
diff --git a/include/linux/of.h b/include/linux/of.h index ddeaae6d2083..ab071742c0c4 100644 --- a/include/linux/of.h +++ b/include/linux/of.h | |||
@@ -667,7 +667,10 @@ static inline void of_property_clear_flag(struct property *p, unsigned long flag | |||
667 | #if defined(CONFIG_OF) && defined(CONFIG_NUMA) | 667 | #if defined(CONFIG_OF) && defined(CONFIG_NUMA) |
668 | extern int of_node_to_nid(struct device_node *np); | 668 | extern int of_node_to_nid(struct device_node *np); |
669 | #else | 669 | #else |
670 | static inline int of_node_to_nid(struct device_node *device) { return 0; } | 670 | static inline int of_node_to_nid(struct device_node *device) |
671 | { | ||
672 | return NUMA_NO_NODE; | ||
673 | } | ||
671 | #endif | 674 | #endif |
672 | 675 | ||
673 | static inline struct device_node *of_find_matching_node( | 676 | static inline struct device_node *of_find_matching_node( |