return rc;
 
        for_each_node_by_type(np, "display") {
-               if (of_get_property(np, "linux,opened", NULL)) {
+               if (of_property_read_bool(np, "linux,opened")) {
                        printk("trying %pOF ...\n", np);
                        rc = btext_initialize(np);
                        printk("result: %d\n", rc);
 
                return -1;
 
        /* if rtas uses this device, don't try to use it as well */
-       if (of_get_property(np, "used-by-rtas", NULL) != NULL)
+       if (of_property_read_bool(np, "used-by-rtas"))
                return -1;
 
        /* Get the address */
 
        }
 
        /* Check if primary bridge */
-       if (of_get_property(np, "primary", NULL))
+       if (of_property_read_bool(np, "primary"))
                primary = 1;
 
        /* Get bus range if any */
        struct pci_controller *hose = NULL;
        void __iomem *reg = NULL;
        const int *bus_range;
-       int big_pim = 0, msi = 0, primary = 0;
+       int big_pim, msi, primary;
 
        /* Fetch config space registers address */
        if (of_address_to_resource(np, 0, &rsrc_cfg)) {
        }
 
        /* Check if it supports large PIMs (440GX) */
-       if (of_get_property(np, "large-inbound-windows", NULL))
-               big_pim = 1;
+       big_pim = of_property_read_bool(np, "large-inbound-windows");
 
        /* Check if we should enable MSIs inbound hole */
-       if (of_get_property(np, "enable-msi-hole", NULL))
-               msi = 1;
+       msi = of_property_read_bool(np, "enable-msi-hole");
 
        /* Check if primary bridge */
-       if (of_get_property(np, "primary", NULL))
-               primary = 1;
+       primary = of_property_read_bool(np, "primary");
 
        /* Get bus range if any */
        bus_range = of_get_property(np, "bus-range", NULL);
        struct resource dma_window;
        struct pci_controller *hose = NULL;
        const int *bus_range;
-       int primary = 0, busses;
+       int primary, busses;
        void __iomem *mbase = NULL, *cfg_data = NULL;
        const u32 *pval;
        u32 val;
 
        /* Check if primary bridge */
-       if (of_get_property(port->node, "primary", NULL))
-               primary = 1;
+       primary = of_property_read_bool(port->node, "primary");
 
        /* Get bus range if any */
        bus_range = of_get_property(port->node, "bus-range", NULL);
 
         * on a gpt0, so check has-wdt property before mapping.
         */
        for_each_matching_node(np, mpc52xx_gpt_ids) {
-               if (of_get_property(np, "fsl,has-wdt", NULL) ||
-                   of_get_property(np, "has-wdt", NULL)) {
+               if (of_property_read_bool(np, "fsl,has-wdt") ||
+                   of_property_read_bool(np, "has-wdt")) {
                        mpc52xx_wdt = of_iomap(np, 0);
                        of_node_put(np);
                        break;
 
        mutex_unlock(&mpc52xx_gpt_list_mutex);
 
        /* check if this device could be a watchdog */
-       if (of_get_property(ofdev->dev.of_node, "fsl,has-wdt", NULL) ||
-           of_get_property(ofdev->dev.of_node, "has-wdt", NULL)) {
+       if (of_property_read_bool(ofdev->dev.of_node, "fsl,has-wdt") ||
+           of_property_read_bool(ofdev->dev.of_node, "has-wdt")) {
                const u32 *on_boot_wdt;
 
                gpt->wdt_mode = MPC52xx_GPT_CAN_WDT;
 
        BUG_ON(openpic_addr == 0);
 
        /* Check for a big endian MPIC */
-       if (of_get_property(np, "big-endian", NULL) != NULL)
+       if (of_property_read_bool(np, "big-endian"))
                flags |= MPIC_BIG_ENDIAN;
 
        /* XXX Maple specific bits */
 
        iommu_off = 1;
 #else
        iommu_off = of_chosen &&
-                       of_get_property(of_chosen, "linux,iommu-off", NULL);
+                       of_property_read_bool(of_chosen, "linux,iommu-off");
 #endif
        if (iommu_off)
                return;
 
                        int cpu_count = 1;
 
                        /* Nap mode not supported on SMP */
-                       if (of_get_property(np, "flush-on-lock", NULL) ||
+                       if (of_property_read_bool(np, "flush-on-lock") ||
                            (cpu_count > 1)) {
                                powersave_nap = 0;
                                of_node_put(np);
 
 
        pmac_call_feature(PMAC_FTR_ENABLE_MPIC, np, 0, 0);
 
-       if (of_get_property(np, "big-endian", NULL))
+       if (of_property_read_bool(np, "big-endian"))
                flags |= MPIC_BIG_ENDIAN;
 
        /* Primary Big Endian means HT interrupts. This is quite dodgy
 #ifdef CONFIG_PPC32
        if (!pmac_newworld)
                of_irq_workarounds |= OF_IMAP_OLDWORLD_MAC;
-       if (of_get_property(of_chosen, "linux,bootx", NULL) != NULL)
+       if (of_property_read_bool(of_chosen, "linux,bootx"))
                of_irq_workarounds |= OF_IMAP_NO_PHANDLE;
 
        /* If we don't have phandles on a newworld, then try to locate a
 
                        of_get_property(np, "d-cache-size", NULL);
                seq_printf(m, "L2 cache\t:");
                has_l2cache = 1;
-               if (of_get_property(np, "cache-unified", NULL) && dc) {
+               if (of_property_read_bool(np, "cache-unified") && dc) {
                        seq_printf(m, " %dK unified", *dc / 1024);
                } else {
                        if (ic)
 
                struct device_node *cpus =
                        of_find_node_by_path("/cpus");
                if (cpus &&
-                   of_get_property(cpus, "platform-cpu-timebase", NULL)) {
+                   of_property_read_bool(cpus, "platform-cpu-timebase")) {
                        pmac_tb_freeze = smp_core99_pfunc_tb_freeze;
                        printk(KERN_INFO "Processor timebase sync using"
                               " platform function\n");
 
        }
 
        if (family == PFO) {
-               if (of_get_property(of_node, "interrupt-controller", NULL)) {
+               if (of_property_read_bool(of_node, "interrupt-controller")) {
                        pr_debug("%s: Skipping the interrupt controller %pOFn.\n",
                                        __func__, of_node);
                        return NULL;
 
        const u32 *p;
 
        for (par = of_node_get(node); par;) {
-               if (of_get_property(par, "dcr-controller", NULL))
+               if (of_property_read_bool(par, "dcr-controller"))
                        break;
                p = of_get_property(par, "dcr-parent", NULL);
                tmp = par;
 
 {
        struct device_node *np, *np2;
        struct ehv_pic *ehv_pic;
-       int coreint_flag = 1;
 
        np = of_find_compatible_node(NULL, NULL, "epapr,hv-pic");
        if (!np) {
                return;
        }
 
-       if (!of_find_property(np, "has-external-proxy", NULL))
-               coreint_flag = 0;
-
        ehv_pic = kzalloc(sizeof(struct ehv_pic), GFP_KERNEL);
        if (!ehv_pic) {
                of_node_put(np);
 
        ehv_pic->hc_irq = ehv_pic_irq_chip;
        ehv_pic->hc_irq.irq_set_affinity = ehv_pic_set_affinity;
-       ehv_pic->coreint_flag = coreint_flag;
+       ehv_pic->coreint_flag = of_property_read_bool(np, "has-external-proxy");
 
        global_ehv_pic = ehv_pic;
        irq_set_default_host(global_ehv_pic->irqhost);
 
        };
 
        for_each_node_by_name(np, "global-utilities") {
-               if ((of_get_property(np, "fsl,has-rstcr", NULL))) {
+               if (of_property_read_bool(np, "fsl,has-rstcr")) {
                        rstcr = of_iomap(np, 0) + 0xb0;
                        if (!rstcr) {
                                printk (KERN_ERR "Error: reset control "
 
        }
 
        /* Read extra device-tree properties into the flags variable */
-       if (of_get_property(node, "big-endian", NULL))
+       if (of_property_read_bool(node, "big-endian"))
                flags |= MPIC_BIG_ENDIAN;
-       if (of_get_property(node, "pic-no-reset", NULL))
+       if (of_property_read_bool(node, "pic-no-reset"))
                flags |= MPIC_NO_RESET;
-       if (of_get_property(node, "single-cpu-affinity", NULL))
+       if (of_property_read_bool(node, "single-cpu-affinity"))
                flags |= MPIC_SINGLE_DEST_CPU;
        if (of_device_is_compatible(node, "fsl,mpic")) {
                flags |= MPIC_FSL | MPIC_LARGE_VECTORS;
 
                 * driver itself to phylib and use a non-misleading
                 * name for the workaround flag - it's not actually to
                 * do with the model of PHY in use */
-               if (of_get_property(phy, "txc-rxc-delay-disable", NULL))
+               if (of_property_read_bool(phy, "txc-rxc-delay-disable"))
                        tsi_eth_data.phy_type = TSI108_PHY_BCM54XX;
                of_node_put(phy);
 
 
        }
 
        /* Do we support single escalation */
-       if (of_get_property(np, "single-escalation-support", NULL) != NULL)
-               xive_has_single_esc = true;
+       xive_has_single_esc = of_property_read_bool(np, "single-escalation-support");
 
-       if (of_get_property(np, "vp-save-restore", NULL))
-               xive_has_save_restore = true;
+       xive_has_save_restore = of_property_read_bool(np, "vp-save-restore");
 
        /* Configure Thread Management areas for KVM */
        for_each_possible_cpu(cpu)