early_init_mmu();
 
-       probe_machine();
-
        setup_kdump_trampoline();
-
-#ifdef CONFIG_6xx
-       if (cpu_has_feature(CPU_FTR_CAN_DOZE) ||
-           cpu_has_feature(CPU_FTR_CAN_NAP))
-               ppc_md.power_save = ppc6xx_idle;
-#endif
-
-#ifdef CONFIG_E500
-       if (cpu_has_feature(CPU_FTR_CAN_DOZE) ||
-           cpu_has_feature(CPU_FTR_CAN_NAP))
-               ppc_md.power_save = e500_idle;
-#endif
-       if (ppc_md.progress)
-               ppc_md.progress("id mach(): done", 0x200);
 }
 
 /* Checks "l2cr=xxxx" command-line option */
 #define exc_lvl_early_init()
 #endif
 
+static void setup_power_save(void)
+{
+#ifdef CONFIG_6xx
+       if (cpu_has_feature(CPU_FTR_CAN_DOZE) ||
+           cpu_has_feature(CPU_FTR_CAN_NAP))
+               ppc_md.power_save = ppc6xx_idle;
+#endif
+
+#ifdef CONFIG_E500
+       if (cpu_has_feature(CPU_FTR_CAN_DOZE) ||
+           cpu_has_feature(CPU_FTR_CAN_NAP))
+               ppc_md.power_save = e500_idle;
+#endif
+}
+
 /* Warning, IO base is not yet inited */
 void __init setup_arch(char **cmdline_p)
 {
        unflatten_device_tree();
        check_for_initrd();
 
+       probe_machine();
+
+       setup_power_save();
+
        if (ppc_md.init_early)
                ppc_md.init_early();
 
 
 
 static int __init ep405_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "ep405"))
+       if (!of_machine_is_compatible("ep405"))
                return 0;
 
        return 1;
 
 
 static int __init ppc40x_probe(void)
 {
-       if (of_flat_dt_match(of_get_flat_dt_root(), board)) {
+       if (of_device_compatible_match(of_root, board)) {
                pci_set_flags(PCI_REASSIGN_ALL_RSRC);
                return 1;
        }
 
 
 static int __init virtex_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "xlnx,virtex"))
+       if (!of_machine_is_compatible("xlnx,virtex"))
                return 0;
 
        return 1;
 
 
 static int __init walnut_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "ibm,walnut"))
+       if (!of_machine_is_compatible("ibm,walnut"))
                return 0;
 
        pci_set_flags(PCI_REASSIGN_ALL_RSRC);
 
 
 static int __init ppc460ex_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       if (of_flat_dt_is_compatible(root, "amcc,canyonlands")) {
+       if (of_machine_is_compatible("amcc,canyonlands")) {
                pci_set_flags(PCI_REASSIGN_ALL_RSRC);
                return 1;
-               }
+       }
        return 0;
 }
 
 
  */
 static int __init ebony_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "ibm,ebony"))
+       if (!of_machine_is_compatible("ibm,ebony"))
                return 0;
 
        pci_set_flags(PCI_REASSIGN_ALL_RSRC);
 
  */
 static int __init iss4xx_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "ibm,iss-4xx"))
+       if (!of_machine_is_compatible("ibm,iss-4xx"))
                return 0;
 
        return 1;
 
 
 static int __init ppc44x_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
        int i = 0;
 
        for (i = 0; i < ARRAY_SIZE(board); i++) {
-               if (of_flat_dt_is_compatible(root, board[i])) {
+               if (of_machine_is_compatible(board[i])) {
                        pci_set_flags(PCI_REASSIGN_ALL_RSRC);
                        return 1;
                }
 
  */
 static int __init ppc47x_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "ibm,akebono"))
+       if (of_machine_is_compatible("ibm,akebono"))
                return 1;
 
-       if (of_flat_dt_is_compatible(root, "ibm,currituck")) {
+       if (of_machine_is_compatible("ibm,currituck")) {
                ppc_md.pci_irq_fixup = ppc47x_pci_irq_fixup;
                return 1;
        }
 
 
 static int __init sam440ep_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "acube,sam440ep"))
+       if (!of_machine_is_compatible("acube,sam440ep"))
                return 0;
 
        pci_set_flags(PCI_REASSIGN_ALL_RSRC);
 
 
 static int __init virtex_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "xlnx,virtex440"))
+       if (!of_machine_is_compatible("xlnx,virtex440"))
                return 0;
 
        return 1;
 
 
 static int __init warp_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "pika,warp"))
+       if (!of_machine_is_compatible("pika,warp"))
                return 0;
 
        /* For __dma_alloc_coherent */
 
  */
 static int __init mpc5121_ads_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,mpc5121ads");
+       return of_machine_is_compatible("fsl,mpc5121ads");
 }
 
 define_machine(mpc5121_ads) {
 
  */
 static int __init mpc512x_generic_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 define_machine(mpc512x_generic) {
 
 
 static int __init pdm360ng_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "ifm,pdm360ng");
+       return of_machine_is_compatible("ifm,pdm360ng");
 }
 
 define_machine(pdm360ng) {
 
 
 static int __init efika_probe(void)
 {
-       const char *model = of_get_flat_dt_prop(of_get_flat_dt_root(),
-                                               "model", NULL);
+       const char *model = of_get_property(of_root, "model", NULL);
 
        if (model == NULL)
                return 0;
 
  */
 static int __init lite5200_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 define_machine(lite5200) {
 
  */
 static int __init media5200_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 define_machine(media5200_platform) {
 
  */
 static int __init mpc5200_simple_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 define_machine(mpc5200_simple_platform) {
 
  */
 static int __init ep8248e_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "fsl,ep8248e");
+       return of_machine_is_compatible("fsl,ep8248e");
 }
 
 define_machine(ep8248e)
 
  */
 static int __init km82xx_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "keymile,km82xx");
+       return of_machine_is_compatible("keymile,km82xx");
 }
 
 define_machine(km82xx)
 
  */
 static int __init mpc8272_ads_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "fsl,mpc8272ads");
+       return of_machine_is_compatible("fsl,mpc8272ads");
 }
 
 define_machine(mpc8272_ads)
 
  */
 static int __init pq2fads_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "fsl,pq2fads");
+       return of_machine_is_compatible("fsl,pq2fads");
 }
 
 static const struct of_device_id of_bus_ids[] __initconst = {
 
  */
 static int __init asp834x_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "analogue-and-micro,asp8347e");
+       return of_machine_is_compatible("analogue-and-micro,asp8347e");
 }
 
 define_machine(asp834x) {
 
  */
 static int __init mpc83xx_km_probe(void)
 {
-       unsigned long node = of_get_flat_dt_root();
        int i = 0;
 
        while (board[i]) {
-               if (of_flat_dt_is_compatible(node, board[i]))
+               if (of_machine_is_compatible(board[i]))
                        break;
                i++;
        }
 
  */
 static int __init mpc830x_rdb_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 machine_device_initcall(mpc830x_rdb, mpc83xx_declare_of_platform_devices);
 
  */
 static int __init mpc831x_rdb_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 machine_device_initcall(mpc831x_rdb, mpc83xx_declare_of_platform_devices);
 
  */
 static int __init mpc832x_sys_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "MPC832xMDS");
+       return of_machine_is_compatible("MPC832xMDS");
 }
 
 define_machine(mpc832x_mds) {
 
  */
 static int __init mpc832x_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "MPC832xRDB");
+       return of_machine_is_compatible("MPC832xRDB");
 }
 
 define_machine(mpc832x_rdb) {
 
  */
 static int __init mpc834x_itx_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "MPC834xMITX");
+       return of_machine_is_compatible("MPC834xMITX");
 }
 
 define_machine(mpc834x_itx) {
 
  */
 static int __init mpc834x_mds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "MPC834xMDS");
+       return of_machine_is_compatible("MPC834xMDS");
 }
 
 define_machine(mpc834x_mds) {
 
  */
 static int __init mpc836x_mds_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "MPC836xMDS");
+       return of_machine_is_compatible("MPC836xMDS");
 }
 
 define_machine(mpc836x_mds) {
 
  */
 static int __init mpc836x_rdk_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,mpc8360rdk");
+       return of_machine_is_compatible("fsl,mpc8360rdk");
 }
 
 define_machine(mpc836x_rdk) {
 
  */
 static int __init mpc837x_mds_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "fsl,mpc837xmds");
+       return of_machine_is_compatible("fsl,mpc837xmds");
 }
 
 define_machine(mpc837x_mds) {
 
  */
 static int __init mpc837x_rdb_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 define_machine(mpc837x_rdb) {
 
  */
 static int __init sbc834x_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "SBC834xE");
+       return of_machine_is_compatible("SBC834xE");
 }
 
 define_machine(sbc834x) {
 
 
 static int __init bsc9132_qds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,bsc9132qds");
+       return of_machine_is_compatible("fsl,bsc9132qds");
 }
 
 define_machine(bsc9132_qds) {
 
 
 static int __init bsc9131_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,bsc9131rdb");
+       return of_machine_is_compatible("fsl,bsc9131rdb");
 }
 
 define_machine(bsc9131_rdb) {
 
  */
 static int __init c293_pcie_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,C293PCIE"))
+       if (of_machine_is_compatible("fsl,C293PCIE"))
                return 1;
        return 0;
 }
 
  */
 static int __init corenet_generic_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
        char hv_compat[24];
        int i;
 #ifdef CONFIG_SMP
        extern struct smp_ops_t smp_85xx_ops;
 #endif
 
-       if (of_flat_dt_match(root, boards))
+       if (of_device_compatible_match(of_root, boards))
                return 1;
 
        /* Check if we're running under the Freescale hypervisor */
        for (i = 0; boards[i]; i++) {
                snprintf(hv_compat, sizeof(hv_compat), "%s-hv", boards[i]);
-               if (of_flat_dt_is_compatible(root, hv_compat)) {
+               if (of_machine_is_compatible(hv_compat)) {
                        ppc_md.init_IRQ = ehv_pic_init;
 
                        ppc_md.get_irq = ehv_pic_get_irq;
 
  */
 static int __init ge_imp3a_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "ge,IMP3A");
+       return of_machine_is_compatible("ge,IMP3A");
 }
 
 machine_arch_initcall(ge_imp3a, mpc85xx_common_publish_devices);
 
  */
 static int __init ksi8560_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "emerson,KSI8560");
+       return of_machine_is_compatible("emerson,KSI8560");
 }
 
 define_machine(ksi8560) {
 
  */
 static int __init mpc8536_ds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,mpc8536ds");
+       return of_machine_is_compatible("fsl,mpc8536ds");
 }
 
 define_machine(mpc8536_ds) {
 
  */
 static int __init mpc85xx_ads_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "MPC85xxADS");
+       return of_machine_is_compatible("MPC85xxADS");
 }
 
 define_machine(mpc85xx_ads) {
 
  */
 static int __init mpc85xx_cds_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "MPC85xxCDS");
+       return of_machine_is_compatible("MPC85xxCDS");
 }
 
 machine_arch_initcall(mpc85xx_cds, mpc85xx_common_publish_devices);
 
  */
 static int __init mpc8544_ds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return !!of_flat_dt_is_compatible(root, "MPC8544DS");
+       return !!of_machine_is_compatible("MPC8544DS");
 }
 
 machine_arch_initcall(mpc8544_ds, mpc85xx_common_publish_devices);
  */
 static int __init mpc8572_ds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return !!of_flat_dt_is_compatible(root, "fsl,MPC8572DS");
+       return !!of_machine_is_compatible("fsl,MPC8572DS");
 }
 
 /*
  */
 static int __init p2020_ds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return !!of_flat_dt_is_compatible(root, "fsl,P2020DS");
+       return !!of_machine_is_compatible("fsl,P2020DS");
 }
 
 define_machine(mpc8544_ds) {
 
 
 static int __init mpc85xx_mds_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "MPC85xxMDS");
+       return of_machine_is_compatible("MPC85xxMDS");
 }
 
 define_machine(mpc8568_mds) {
 
 static int __init mpc8569_mds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,MPC8569EMDS");
+       return of_machine_is_compatible("fsl,MPC8569EMDS");
 }
 
 define_machine(mpc8569_mds) {
 
 static int __init p1021_mds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1021MDS");
+       return of_machine_is_compatible("fsl,P1021MDS");
 
 }
 
 
  */
 static int __init p2020_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,P2020RDB"))
+       if (of_machine_is_compatible("fsl,P2020RDB"))
                return 1;
        return 0;
 }
 
 static int __init p1020_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,P1020RDB"))
+       if (of_machine_is_compatible("fsl,P1020RDB"))
                return 1;
        return 0;
 }
 
 static int __init p1020_rdb_pc_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1020RDB-PC");
+       return of_machine_is_compatible("fsl,P1020RDB-PC");
 }
 
 static int __init p1020_rdb_pd_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1020RDB-PD");
+       return of_machine_is_compatible("fsl,P1020RDB-PD");
 }
 
 static int __init p1021_rdb_pc_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,P1021RDB-PC"))
+       if (of_machine_is_compatible("fsl,P1021RDB-PC"))
                return 1;
        return 0;
 }
 
 static int __init p2020_rdb_pc_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,P2020RDB-PC"))
+       if (of_machine_is_compatible("fsl,P2020RDB-PC"))
                return 1;
        return 0;
 }
 
 static int __init p1025_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1025RDB");
+       return of_machine_is_compatible("fsl,P1025RDB");
 }
 
 static int __init p1020_mbg_pc_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1020MBG-PC");
+       return of_machine_is_compatible("fsl,P1020MBG-PC");
 }
 
 static int __init p1020_utm_pc_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1020UTM-PC");
+       return of_machine_is_compatible("fsl,P1020UTM-PC");
 }
 
 static int __init p1024_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1024RDB");
+       return of_machine_is_compatible("fsl,P1024RDB");
 }
 
 define_machine(p2020_rdb) {
 
  */
 static int __init mvme2500_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "artesyn,MVME2500");
+       return of_machine_is_compatible("artesyn,MVME2500");
 }
 
 define_machine(mvme2500) {
 
  */
 static int __init p1010_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,P1010RDB"))
+       if (of_machine_is_compatible("fsl,P1010RDB"))
                return 1;
-       if (of_flat_dt_is_compatible(root, "fsl,P1010RDB-PB"))
+       if (of_machine_is_compatible("fsl,P1010RDB-PB"))
                return 1;
        return 0;
 }
 
  */
 static int __init p1022_ds_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,p1022ds");
+       return of_machine_is_compatible("fsl,p1022ds");
 }
 
 define_machine(p1022_ds) {
 
  */
 static int __init p1022_rdk_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,p1022rdk");
+       return of_machine_is_compatible("fsl,p1022rdk");
 }
 
 define_machine(p1022_rdk) {
 
 
 static int __init p1023_rdb_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,P1023RDB");
+       return of_machine_is_compatible("fsl,P1023RDB");
 
 }
 
 
  */
 static int __init ppa8548_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "ppa8548");
+       return of_machine_is_compatible("ppa8548");
 }
 
 define_machine(ppa8548) {
 
  */
 static int __init qemu_e500_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return !!of_flat_dt_is_compatible(root, "fsl,qemu-e500");
+       return !!of_machine_is_compatible("fsl,qemu-e500");
 }
 
 machine_arch_initcall(qemu_e500, mpc85xx_common_publish_devices);
 
  */
 static int __init sbc8548_probe(void)
 {
-        unsigned long root = of_get_flat_dt_root();
-
-        return of_flat_dt_is_compatible(root, "SBC8548");
+       return of_machine_is_compatible("SBC8548");
 }
 
 define_machine(sbc8548) {
 
  */
 static int __init socrates_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "abb,socrates"))
+       if (of_machine_is_compatible("abb,socrates"))
                return 1;
 
        return 0;
 
  */
 static int __init stx_gp3_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "stx,gp3-8560");
+       return of_machine_is_compatible("stx,gp3-8560");
 }
 
 define_machine(stx_gp3) {
 
  */
 static int __init tqm85xx_probe(void)
 {
-       return of_flat_dt_match(of_get_flat_dt_root(), board);
+       return of_device_compatible_match(of_root, board);
 }
 
 define_machine(tqm85xx) {
 
 
 static int __init twr_p1025_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "fsl,TWR-P1025");
+       return of_machine_is_compatible("fsl,TWR-P1025");
 }
 
 define_machine(twr_p1025) {
 
  */
 static int __init xes_mpc8572_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "xes,MPC8572");
+       return of_machine_is_compatible("xes,MPC8572");
 }
 
 static int __init xes_mpc8548_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "xes,MPC8548");
+       return of_machine_is_compatible("xes,MPC8548");
 }
 
 static int __init xes_mpc8540_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "xes,MPC8540");
+       return of_machine_is_compatible("xes,MPC8540");
 }
 
 define_machine(xes_mpc8572) {
 
  */
 static int __init gef_ppc9a_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "gef,ppc9a"))
+       if (of_machine_is_compatible("gef,ppc9a"))
                return 1;
 
        return 0;
 
  */
 static int __init gef_sbc310_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "gef,sbc310"))
+       if (of_machine_is_compatible("gef,sbc310"))
                return 1;
 
        return 0;
 
  */
 static int __init gef_sbc610_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "gef,sbc610"))
+       if (of_machine_is_compatible("gef,sbc610"))
                return 1;
 
        return 0;
 
  */
 static int __init mpc86xx_hpcd_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,MPC8610HPCD"))
+       if (of_machine_is_compatible("fsl,MPC8610HPCD"))
                return 1;       /* Looks good */
 
        return 0;
 
  */
 static int __init mpc86xx_hpcn_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "fsl,mpc8641hpcn"))
+       if (of_machine_is_compatible("fsl,mpc8641hpcn"))
                return 1;       /* Looks good */
 
        /* Be nice and don't give silent boot death.  Delete this in 2.6.27 */
-       if (of_flat_dt_is_compatible(root, "mpc86xx")) {
+       if (of_machine_is_compatible("mpc86xx")) {
                pr_warning("WARNING: your dts/dtb is old. You must update before the next kernel release\n");
                return 1;
        }
 
  */
 static int __init sbc8641_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "wind,sbc8641"))
+       if (of_machine_is_compatible("wind,sbc8641"))
                return 1;       /* Looks good */
 
        return 0;
 
 
 static int __init adder875_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "analogue-and-micro,adder875");
+       return of_machine_is_compatible("analogue-and-micro,adder875");
 }
 
 static const struct of_device_id of_bus_ids[] __initconst = {
 
 
 static int __init ep88xc_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "fsl,ep88xc");
+       return of_machine_is_compatible("fsl,ep88xc");
 }
 
 static const struct of_device_id of_bus_ids[] __initconst = {
 
 
 static int __init mpc86xads_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "fsl,mpc866ads");
+       return of_machine_is_compatible("fsl,mpc866ads");
 }
 
 static const struct of_device_id of_bus_ids[] __initconst = {
 
 
 static int __init mpc885ads_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-       return of_flat_dt_is_compatible(root, "fsl,mpc885ads");
+       return of_machine_is_compatible("fsl,mpc885ads");
 }
 
 static const struct of_device_id of_bus_ids[] __initconst = {
 
 
 static int __init tqm8xx_probe(void)
 {
-       unsigned long node = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(node, "tqc,tqm8xx");
+       return of_machine_is_compatible("tqc,tqm8xx");
 }
 
 static const struct of_device_id of_bus_ids[] __initconst = {
 
 
 static int __init amigaone_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (of_flat_dt_is_compatible(root, "eyetech,amigaone")) {
+       if (of_machine_is_compatible("eyetech,amigaone")) {
                /*
                 * Coherent memory access cause complete system lockup! Thus
                 * disable this CPU feature, even if the CPU needs it.
 
  */
 static int __init c2k_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "GEFanuc,C2K"))
+       if (!of_machine_is_compatible("GEFanuc,C2K"))
                return 0;
 
        printk(KERN_INFO "Detected a GEFanuc C2K board\n");
 
 
 static int __init gamecube_probe(void)
 {
-       unsigned long dt_root;
-
-       dt_root = of_get_flat_dt_root();
-       if (!of_flat_dt_is_compatible(dt_root, "nintendo,gamecube"))
+       if (!of_machine_is_compatible("nintendo,gamecube"))
                return 0;
 
        pm_power_off = gamecube_power_off;
 
  */
 static int __init holly_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "ibm,holly"))
+       if (!of_machine_is_compatible("ibm,holly"))
                return 0;
        return 1;
 }
 
 
 static int __init linkstation_probe(void)
 {
-       unsigned long root;
-
-       root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "linkstation"))
+       if (!of_machine_is_compatible("linkstation"))
                return 0;
 
        pm_power_off = linkstation_power_off;
 
  */
 static int __init mpc7448_hpc2_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "mpc74xx"))
+       if (!of_machine_is_compatible("mpc74xx"))
                return 0;
        return 1;
 }
 
  */
 static int __init mvme5100_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "MVME5100");
+       return of_machine_is_compatible("MVME5100");
 }
 
 static int __init probe_of_platform_devices(void)
 
 
 static int __init storcenter_probe(void)
 {
-       unsigned long root = of_get_flat_dt_root();
-
-       return of_flat_dt_is_compatible(root, "iomega,storcenter");
+       return of_machine_is_compatible("iomega,storcenter");
 }
 
 define_machine(storcenter){
 
 
 static int __init wii_probe(void)
 {
-       unsigned long dt_root;
-
-       dt_root = of_get_flat_dt_root();
-       if (!of_flat_dt_is_compatible(dt_root, "nintendo,wii"))
+       if (!of_machine_is_compatible("nintendo,wii"))
                return 0;
 
        pm_power_off = wii_power_off;
 
  */
 static int __init pmac_probe(void)
 {
-#ifdef CONFIG_PPC32
-       unsigned long root = of_get_flat_dt_root();
-
-       if (!of_flat_dt_is_compatible(root, "Power Macintosh") &&
-           !of_flat_dt_is_compatible(root, "MacRISC"))
-               return 0;
-#else
        if (!of_machine_is_compatible("Power Macintosh") &&
            !of_machine_is_compatible("MacRISC"))
                return 0;
-#endif
 
 #ifdef CONFIG_PPC32
        /* isa_io_base gets set in pmac_pci_init */