1 // SPDX-License-Identifier: GPL-2.0
3 * linux/arch/sh/boards/lbox/setup.c
5 * Copyright (C) 2007 Nobuhiro Iwamatsu
7 * NTT COMWARE L-BOX RE2 Support
10 #include <linux/init.h>
11 #include <linux/platform_device.h>
12 #include <linux/ata_platform.h>
13 #include <asm/machvec.h>
14 #include <asm/addrspace.h>
15 #include <mach/lboxre2.h>
18 static struct resource cf_ide_resources
[] = {
22 .flags
= IORESOURCE_IO
,
25 .start
= 0x1f0 + 0x206,
26 .end
= 0x1f0 +8 + 0x206 + 8,
27 .flags
= IORESOURCE_IO
,
31 .flags
= IORESOURCE_IRQ
,
35 static struct platform_device cf_ide_device
= {
36 .name
= "pata_platform",
38 .num_resources
= ARRAY_SIZE(cf_ide_resources
),
39 .resource
= cf_ide_resources
,
42 static struct platform_device
*lboxre2_devices
[] __initdata
= {
46 static int __init
lboxre2_devices_setup(void)
48 u32 cf0_io_base
; /* Boot CF base address */
50 unsigned long paddrbase
, psize
;
52 /* open I/O area window */
53 paddrbase
= virt_to_phys((void*)PA_AREA5_IO
);
55 prot
= PAGE_KERNEL_PCC(1, _PAGE_PCC_IO16
);
56 cf0_io_base
= (u32
)ioremap_prot(paddrbase
, psize
, pgprot_val(prot
));
58 printk(KERN_ERR
"%s : can't open CF I/O window!\n" , __func__
);
62 cf_ide_resources
[0].start
+= cf0_io_base
;
63 cf_ide_resources
[0].end
+= cf0_io_base
;
64 cf_ide_resources
[1].start
+= cf0_io_base
;
65 cf_ide_resources
[1].end
+= cf0_io_base
;
67 return platform_add_devices(lboxre2_devices
,
68 ARRAY_SIZE(lboxre2_devices
));
71 device_initcall(lboxre2_devices_setup
);
76 static struct sh_machine_vector mv_lboxre2 __initmv
= {
77 .mv_name
= "L-BOX RE2",
78 .mv_init_irq
= init_lboxre2_IRQ
,