static struct __initdata orion_addr_map_cfg addr_map_cfg = {
        .num_wins = 8,
        .remappable_wins = 4,
-       .bridge_virt_base = BRIDGE_VIRT_BASE,
+       .bridge_virt_base = (unsigned long) BRIDGE_VIRT_BASE,
 };
 
 static const struct __initdata orion_addr_map_info addr_map_info[] = {
 
  ****************************************************************************/
 static struct map_desc dove_io_desc[] __initdata = {
        {
-               .virtual        = DOVE_SB_REGS_VIRT_BASE,
+               .virtual        = (unsigned long) DOVE_SB_REGS_VIRT_BASE,
                .pfn            = __phys_to_pfn(DOVE_SB_REGS_PHYS_BASE),
                .length         = DOVE_SB_REGS_SIZE,
                .type           = MT_DEVICE,
        }, {
-               .virtual        = DOVE_NB_REGS_VIRT_BASE,
+               .virtual        = (unsigned long) DOVE_NB_REGS_VIRT_BASE,
                .pfn            = __phys_to_pfn(DOVE_NB_REGS_PHYS_BASE),
                .length         = DOVE_NB_REGS_SIZE,
                .type           = MT_DEVICE,
        }, {
-               .virtual        = DOVE_PCIE0_IO_VIRT_BASE,
+               .virtual        = (unsigned long) DOVE_PCIE0_IO_VIRT_BASE,
                .pfn            = __phys_to_pfn(DOVE_PCIE0_IO_PHYS_BASE),
                .length         = DOVE_PCIE0_IO_SIZE,
                .type           = MT_DEVICE,
        }, {
-               .virtual        = DOVE_PCIE1_IO_VIRT_BASE,
+               .virtual        = (unsigned long) DOVE_PCIE1_IO_VIRT_BASE,
                .pfn            = __phys_to_pfn(DOVE_PCIE1_IO_PHYS_BASE),
                .length         = DOVE_PCIE1_IO_SIZE,
                .type           = MT_DEVICE,
  ****************************************************************************/
 void __init dove_uart0_init(void)
 {
-       orion_uart0_init(DOVE_UART0_VIRT_BASE, DOVE_UART0_PHYS_BASE,
+       orion_uart0_init((unsigned long) DOVE_UART0_VIRT_BASE,
+                        DOVE_UART0_PHYS_BASE,
                         IRQ_DOVE_UART_0, tclk);
 }
 
  ****************************************************************************/
 void __init dove_uart1_init(void)
 {
-       orion_uart1_init(DOVE_UART1_VIRT_BASE, DOVE_UART1_PHYS_BASE,
+       orion_uart1_init((unsigned long) DOVE_UART1_VIRT_BASE,
+                        DOVE_UART1_PHYS_BASE,
                         IRQ_DOVE_UART_1, tclk);
 }
 
  ****************************************************************************/
 void __init dove_uart2_init(void)
 {
-       orion_uart2_init(DOVE_UART2_VIRT_BASE, DOVE_UART2_PHYS_BASE,
+       orion_uart2_init((unsigned long) DOVE_UART2_VIRT_BASE,
+                        DOVE_UART2_PHYS_BASE,
                         IRQ_DOVE_UART_2, tclk);
 }
 
  ****************************************************************************/
 void __init dove_uart3_init(void)
 {
-       orion_uart3_init(DOVE_UART3_VIRT_BASE, DOVE_UART3_PHYS_BASE,
+       orion_uart3_init((unsigned long) DOVE_UART3_VIRT_BASE,
+                        DOVE_UART3_PHYS_BASE,
                         IRQ_DOVE_UART_3, tclk);
 }
 
  ****************************************************************************/
 void __init dove_init_early(void)
 {
-       orion_time_set_base(TIMER_VIRT_BASE);
+       orion_time_set_base((unsigned long) TIMER_VIRT_BASE);
 }
 
 static int get_tclk(void)
 
 static void __init dove_timer_init(void)
 {
-       orion_time_init(BRIDGE_VIRT_BASE, BRIDGE_INT_TIMER1_CLR,
+       orion_time_init((unsigned long) BRIDGE_VIRT_BASE,
+                       BRIDGE_INT_TIMER1_CLR,
                        IRQ_DOVE_BRIDGE, get_tclk());
 }
 
 
  */
 
 #define DOVE_CESA_PHYS_BASE            0xc8000000
-#define DOVE_CESA_VIRT_BASE            0xfdb00000
+#define DOVE_CESA_VIRT_BASE            IOMEM(0xfdb00000)
 #define DOVE_CESA_SIZE                 SZ_1M
 
 #define DOVE_PCIE0_MEM_PHYS_BASE       0xe0000000
 #define DOVE_BOOTROM_SIZE              SZ_128M
 
 #define DOVE_SCRATCHPAD_PHYS_BASE      0xf0000000
-#define DOVE_SCRATCHPAD_VIRT_BASE      0xfdd00000
+#define DOVE_SCRATCHPAD_VIRT_BASE      IOMEM(0xfdd00000)
 #define DOVE_SCRATCHPAD_SIZE           SZ_1M
 
 #define DOVE_SB_REGS_PHYS_BASE         0xf1000000
-#define DOVE_SB_REGS_VIRT_BASE         0xfde00000
+#define DOVE_SB_REGS_VIRT_BASE         IOMEM(0xfde00000)
 #define DOVE_SB_REGS_SIZE              SZ_8M
 
 #define DOVE_NB_REGS_PHYS_BASE         0xf1800000
-#define DOVE_NB_REGS_VIRT_BASE         0xfe600000
+#define DOVE_NB_REGS_VIRT_BASE         IOMEM(0xfe600000)
 #define DOVE_NB_REGS_SIZE              SZ_8M
 
 #define DOVE_PCIE0_IO_PHYS_BASE                0xf2000000
-#define DOVE_PCIE0_IO_VIRT_BASE                0xfee00000
+#define DOVE_PCIE0_IO_VIRT_BASE                IOMEM(0xfee00000)
 #define DOVE_PCIE0_IO_BUS_BASE         0x00000000
 #define DOVE_PCIE0_IO_SIZE             SZ_1M
 
 #define DOVE_PCIE1_IO_PHYS_BASE                0xf2100000
-#define DOVE_PCIE1_IO_VIRT_BASE                0xfef00000
+#define DOVE_PCIE1_IO_VIRT_BASE                IOMEM(0xfef00000)
 #define DOVE_PCIE1_IO_BUS_BASE         0x00100000
 #define DOVE_PCIE1_IO_SIZE             SZ_1M
 
 
 {
        int i;
 
-       orion_irq_init(0, (void __iomem *)(IRQ_VIRT_BASE + IRQ_MASK_LOW_OFF));
-       orion_irq_init(32, (void __iomem *)(IRQ_VIRT_BASE + IRQ_MASK_HIGH_OFF));
+       orion_irq_init(0, IRQ_VIRT_BASE + IRQ_MASK_LOW_OFF);
+       orion_irq_init(32, IRQ_VIRT_BASE + IRQ_MASK_HIGH_OFF);
 
        /*
         * Initialize gpiolib for GPIOs 0-71.
         */
-       orion_gpio_init(NULL, 0, 32, (void __iomem *)DOVE_GPIO_LO_VIRT_BASE, 0,
+       orion_gpio_init(NULL, 0, 32, DOVE_GPIO_LO_VIRT_BASE, 0,
                        IRQ_DOVE_GPIO_START, gpio0_irqs);
 
-       orion_gpio_init(NULL, 32, 32, (void __iomem *)DOVE_GPIO_HI_VIRT_BASE, 0,
+       orion_gpio_init(NULL, 32, 32, DOVE_GPIO_HI_VIRT_BASE, 0,
                        IRQ_DOVE_GPIO_START + 32, gpio1_irqs);
 
-       orion_gpio_init(NULL, 64, 8, (void __iomem *)DOVE_GPIO2_VIRT_BASE, 0,
+       orion_gpio_init(NULL, 64, 8, DOVE_GPIO2_VIRT_BASE, 0,
                        IRQ_DOVE_GPIO_START + 64, gpio2_irqs);
 
        /*
 
        dove_mpp_dump_regs();
 
        /* Use platform code for pins 0-23 */
-       orion_mpp_conf(mpp_list, 0, MPP_MAX, DOVE_MPP_VIRT_BASE);
+       orion_mpp_conf(mpp_list, 0, MPP_MAX,
+                      (unsigned long) DOVE_MPP_VIRT_BASE);
 
        dove_mpp_conf_grp(mpp_grp_list);
        dove_mpp_cfg_au1(grp_au1_52_57);
 
        .map_irq        = dove_pcie_map_irq,
 };
 
-static void __init add_pcie_port(int index, unsigned long base)
+static void __init add_pcie_port(int index, void __iomem *base)
 {
        printk(KERN_INFO "Dove PCIe port %d: ", index);
 
-       if (orion_pcie_link_up((void __iomem *)base)) {
+       if (orion_pcie_link_up(base)) {
                struct pcie_port *pp = &pcie_port[num_pcie_ports++];
 
                printk(KERN_INFO "link up\n");
 
                pp->index = index;
                pp->root_bus_nr = -1;
-               pp->base = (void __iomem *)base;
+               pp->base = base;
                spin_lock_init(&pp->conf_lock);
                memset(pp->res, 0, sizeof(pp->res));
        } else {