Linux 6.13-rc4
[linux.git] / arch / sh / boards / mach-lboxre2 / setup.c
blob20d01b430f2a811ce1f7ea7c9c94fbbfefa98f9b
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * linux/arch/sh/boards/lbox/setup.c
5 * Copyright (C) 2007 Nobuhiro Iwamatsu
7 * NTT COMWARE L-BOX RE2 Support
8 */
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>
16 #include <asm/io.h>
18 static struct resource cf_ide_resources[] = {
19 [0] = {
20 .start = 0x1f0,
21 .end = 0x1f0 + 8 ,
22 .flags = IORESOURCE_IO,
24 [1] = {
25 .start = 0x1f0 + 0x206,
26 .end = 0x1f0 +8 + 0x206 + 8,
27 .flags = IORESOURCE_IO,
29 [2] = {
30 .start = IRQ_CF0,
31 .flags = IORESOURCE_IRQ,
35 static struct platform_device cf_ide_device = {
36 .name = "pata_platform",
37 .id = -1,
38 .num_resources = ARRAY_SIZE(cf_ide_resources),
39 .resource = cf_ide_resources,
42 static struct platform_device *lboxre2_devices[] __initdata = {
43 &cf_ide_device,
46 static int __init lboxre2_devices_setup(void)
48 u32 cf0_io_base; /* Boot CF base address */
49 pgprot_t prot;
50 unsigned long paddrbase, psize;
52 /* open I/O area window */
53 paddrbase = virt_to_phys((void*)PA_AREA5_IO);
54 psize = PAGE_SIZE;
55 prot = PAGE_KERNEL_PCC(1, _PAGE_PCC_IO16);
56 cf0_io_base = (u32)ioremap_prot(paddrbase, psize, pgprot_val(prot));
57 if (!cf0_io_base) {
58 printk(KERN_ERR "%s : can't open CF I/O window!\n" , __func__ );
59 return -ENOMEM;
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);
74 * The Machine Vector
76 static struct sh_machine_vector mv_lboxre2 __initmv = {
77 .mv_name = "L-BOX RE2",
78 .mv_init_irq = init_lboxre2_IRQ,