diff options
author | David S. Miller <davem@sunset.davemloft.net> | 2006-06-22 22:53:24 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2006-06-24 02:15:32 -0400 |
commit | cecc4e9222c4e2bca59834750e493eea6be97613 (patch) | |
tree | 9fd177ac904e4ef091c0322ae9f105210d42916d /arch/sparc64/kernel/time.c | |
parent | 9c10a58ed634d98114c5717e2da761d8a63f2cd4 (diff) |
[SPARC64]: Convert central bus layer to in-kernel PROM device tree.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc64/kernel/time.c')
-rw-r--r-- | arch/sparc64/kernel/time.c | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/arch/sparc64/kernel/time.c b/arch/sparc64/kernel/time.c index d072b8632ccd..348b82035561 100644 --- a/arch/sparc64/kernel/time.c +++ b/arch/sparc64/kernel/time.c | |||
@@ -796,26 +796,26 @@ static void __init clock_assign_clk_reg(struct linux_prom_registers *clk_reg, | |||
796 | 796 | ||
797 | static int __init clock_probe_central(void) | 797 | static int __init clock_probe_central(void) |
798 | { | 798 | { |
799 | struct linux_prom_registers clk_reg[2]; | 799 | struct linux_prom_registers clk_reg[2], *pr; |
800 | char model[64]; | 800 | struct device_node *dp; |
801 | int node; | 801 | char *model; |
802 | 802 | ||
803 | if (!central_bus) | 803 | if (!central_bus) |
804 | return 0; | 804 | return 0; |
805 | 805 | ||
806 | /* Get Central FHC's prom node. */ | 806 | /* Get Central FHC's prom node. */ |
807 | node = central_bus->child->prom_node; | 807 | dp = central_bus->child->prom_node; |
808 | 808 | ||
809 | /* Then get the first child device below it. */ | 809 | /* Then get the first child device below it. */ |
810 | node = prom_getchild(node); | 810 | dp = dp->child; |
811 | 811 | ||
812 | while (node) { | 812 | while (dp) { |
813 | prom_getstring(node, "model", model, sizeof(model)); | 813 | model = of_get_property(dp, "model", NULL); |
814 | if (!clock_model_matches(model)) | 814 | if (!model || !clock_model_matches(model)) |
815 | goto next_sibling; | 815 | goto next_sibling; |
816 | 816 | ||
817 | prom_getproperty(node, "reg", (char *)clk_reg, | 817 | pr = of_get_property(dp, "reg", NULL); |
818 | sizeof(clk_reg)); | 818 | memcpy(clk_reg, pr, sizeof(clk_reg)); |
819 | 819 | ||
820 | apply_fhc_ranges(central_bus->child, clk_reg, 1); | 820 | apply_fhc_ranges(central_bus->child, clk_reg, 1); |
821 | apply_central_ranges(central_bus, clk_reg, 1); | 821 | apply_central_ranges(central_bus, clk_reg, 1); |
@@ -824,7 +824,7 @@ static int __init clock_probe_central(void) | |||
824 | return 1; | 824 | return 1; |
825 | 825 | ||
826 | next_sibling: | 826 | next_sibling: |
827 | node = prom_getsibling(node); | 827 | dp = dp->sibling; |
828 | } | 828 | } |
829 | 829 | ||
830 | return 0; | 830 | return 0; |