root/arch/sh/boards/mach-lboxre2/setup.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. lboxre2_devices_setup

   1 // SPDX-License-Identifier: GPL-2.0
   2 /*
   3  * linux/arch/sh/boards/lbox/setup.c
   4  *
   5  * Copyright (C) 2007 Nobuhiro Iwamatsu
   6  *
   7  * NTT COMWARE L-BOX RE2 Support
   8  */
   9 
  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>
  17 
  18 static struct resource cf_ide_resources[] = {
  19         [0] = {
  20                 .start  = 0x1f0,
  21                 .end    = 0x1f0 + 8 ,
  22                 .flags  = IORESOURCE_IO,
  23         },
  24         [1] = {
  25                 .start  = 0x1f0 + 0x206,
  26                 .end    = 0x1f0 +8 + 0x206 + 8,
  27                 .flags  = IORESOURCE_IO,
  28         },
  29         [2] = {
  30                 .start  = IRQ_CF0,
  31                 .flags  = IORESOURCE_IRQ,
  32         },
  33 };
  34 
  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,
  40 };
  41 
  42 static struct platform_device *lboxre2_devices[] __initdata = {
  43        &cf_ide_device,
  44 };
  45 
  46 static int __init lboxre2_devices_setup(void)
  47 {
  48         u32 cf0_io_base;        /* Boot CF base address */
  49         pgprot_t prot;
  50         unsigned long paddrbase, psize;
  51 
  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;
  60         }
  61 
  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 ;
  66 
  67         return platform_add_devices(lboxre2_devices,
  68                         ARRAY_SIZE(lboxre2_devices));
  69 
  70 }
  71 device_initcall(lboxre2_devices_setup);
  72 
  73 /*
  74  * The Machine Vector
  75  */
  76 static struct sh_machine_vector mv_lboxre2 __initmv = {
  77         .mv_name                = "L-BOX RE2",
  78         .mv_init_irq            = init_lboxre2_IRQ,
  79 };

/* [<][>][^][v][top][bottom][index][help] */