2  * $Id: redwood.c,v 1.11 2005/11/07 11:14:28 gleixner Exp $
 
   4  * drivers/mtd/maps/redwood.c
 
   6  * FLASH map for the IBM Redwood 4/5/6 boards.
 
   8  * Author: MontaVista Software, Inc. <source@mvista.com>
 
  10  * 2001-2003 (c) MontaVista, Software, Inc. This file is licensed under
 
  11  * the terms of the GNU General Public License version 2. This program
 
  12  * is licensed "as is" without any warranty of any kind, whether express
 
  16 #include <linux/module.h>
 
  17 #include <linux/types.h>
 
  18 #include <linux/kernel.h>
 
  19 #include <linux/init.h>
 
  21 #include <linux/mtd/mtd.h>
 
  22 #include <linux/mtd/map.h>
 
  23 #include <linux/mtd/partitions.h>
 
  27 #if !defined (CONFIG_REDWOOD_6)
 
  29 #define WINDOW_ADDR 0xffc00000
 
  30 #define WINDOW_SIZE 0x00400000
 
  33 #define RW_PART0_SZ     0x10000
 
  34 #define RW_PART1_OF     RW_PART0_SZ
 
  35 #define RW_PART1_SZ     0x200000 - 0x10000
 
  36 #define RW_PART2_OF     0x200000
 
  37 #define RW_PART2_SZ     0x10000
 
  38 #define RW_PART3_OF     0x210000
 
  39 #define RW_PART3_SZ     0x200000 - (0x10000 + 0x20000)
 
  40 #define RW_PART4_OF     0x3e0000
 
  41 #define RW_PART4_SZ     0x20000
 
  43 static struct mtd_partition redwood_flash_partitions[] = {
 
  45                 .name = "Redwood OpenBIOS Vital Product Data",
 
  46                 .offset = RW_PART0_OF,
 
  48                 .mask_flags = MTD_WRITEABLE     /* force read-only */
 
  51                 .name = "Redwood kernel",
 
  52                 .offset = RW_PART1_OF,
 
  56                 .name = "Redwood OpenBIOS non-volatile storage",
 
  57                 .offset = RW_PART2_OF,
 
  59                 .mask_flags = MTD_WRITEABLE     /* force read-only */
 
  62                 .name = "Redwood filesystem",
 
  63                 .offset = RW_PART3_OF,
 
  67                 .name = "Redwood OpenBIOS",
 
  68                 .offset = RW_PART4_OF,
 
  70                 .mask_flags = MTD_WRITEABLE     /* force read-only */
 
  74 #else /* CONFIG_REDWOOD_6 */
 
  75 /* FIXME: the window is bigger - armin */
 
  76 #define WINDOW_ADDR 0xff800000
 
  77 #define WINDOW_SIZE 0x00800000
 
  80 #define RW_PART0_SZ     0x400000        /* 4 MiB data */
 
  81 #define RW_PART1_OF     RW_PART0_OF + RW_PART0_SZ
 
  82 #define RW_PART1_SZ     0x10000         /* 64K VPD */
 
  83 #define RW_PART2_OF     RW_PART1_OF + RW_PART1_SZ
 
  84 #define RW_PART2_SZ     0x400000 - (0x10000 + 0x20000)
 
  85 #define RW_PART3_OF     RW_PART2_OF + RW_PART2_SZ
 
  86 #define RW_PART3_SZ     0x20000
 
  88 static struct mtd_partition redwood_flash_partitions[] = {
 
  90                 .name = "Redwood filesystem",
 
  91                 .offset = RW_PART0_OF,
 
  95                 .name = "Redwood OpenBIOS Vital Product Data",
 
  96                 .offset = RW_PART1_OF,
 
  98                 .mask_flags = MTD_WRITEABLE     /* force read-only */
 
 101                 .name = "Redwood kernel",
 
 102                 .offset = RW_PART2_OF,
 
 106                 .name = "Redwood OpenBIOS",
 
 107                 .offset = RW_PART3_OF,
 
 109                 .mask_flags = MTD_WRITEABLE     /* force read-only */
 
 113 #endif /* CONFIG_REDWOOD_6 */
 
 115 struct map_info redwood_flash_map = {
 
 116         .name = "IBM Redwood",
 
 123 #define NUM_REDWOOD_FLASH_PARTITIONS ARRAY_SIZE(redwood_flash_partitions)
 
 125 static struct mtd_info *redwood_mtd;
 
 127 int __init init_redwood_flash(void)
 
 129         printk(KERN_NOTICE "redwood: flash mapping: %x at %x\n",
 
 130                         WINDOW_SIZE, WINDOW_ADDR);
 
 132         redwood_flash_map.virt = ioremap(WINDOW_ADDR, WINDOW_SIZE);
 
 134         if (!redwood_flash_map.virt) {
 
 135                 printk("init_redwood_flash: failed to ioremap\n");
 
 138         simple_map_init(&redwood_flash_map);
 
 140         redwood_mtd = do_map_probe("cfi_probe",&redwood_flash_map);
 
 143                 redwood_mtd->owner = THIS_MODULE;
 
 144                 return add_mtd_partitions(redwood_mtd,
 
 145                                 redwood_flash_partitions,
 
 146                                 NUM_REDWOOD_FLASH_PARTITIONS);
 
 152 static void __exit cleanup_redwood_flash(void)
 
 155                 del_mtd_partitions(redwood_mtd);
 
 156                 /* moved iounmap after map_destroy - armin */
 
 157                 map_destroy(redwood_mtd);
 
 158                 iounmap((void *)redwood_flash_map.virt);
 
 162 module_init(init_redwood_flash);
 
 163 module_exit(cleanup_redwood_flash);
 
 165 MODULE_LICENSE("GPL");
 
 166 MODULE_AUTHOR("MontaVista Software <source@mvista.com>");
 
 167 MODULE_DESCRIPTION("MTD map driver for the IBM Redwood reference boards");