2  * Mapping for Ocotea user flash
 
   4  * Matt Porter <mporter@kernel.crashing.org>
 
   6  * Copyright 2002-2004 MontaVista Software Inc.
 
   8  * This program is free software; you can redistribute  it and/or modify it
 
   9  * under  the terms of  the GNU General  Public License as published by the
 
  10  * Free Software Foundation;  either version 2 of the  License, or (at your
 
  11  * option) any later version.
 
  14 #include <linux/module.h>
 
  15 #include <linux/types.h>
 
  16 #include <linux/kernel.h>
 
  17 #include <linux/init.h>
 
  18 #include <linux/mtd/mtd.h>
 
  19 #include <linux/mtd/map.h>
 
  20 #include <linux/mtd/partitions.h>
 
  22 #include <asm/ibm44x.h>
 
  23 #include <platforms/4xx/ocotea.h>
 
  25 static struct mtd_info *flash;
 
  27 static struct map_info ocotea_small_map = {
 
  28         .name =         "Ocotea small flash",
 
  29         .size =         OCOTEA_SMALL_FLASH_SIZE,
 
  33 static struct map_info ocotea_large_map = {
 
  34         .name =         "Ocotea large flash",
 
  35         .size =         OCOTEA_LARGE_FLASH_SIZE,
 
  39 static struct mtd_partition ocotea_small_partitions[] = {
 
  47 static struct mtd_partition ocotea_large_partitions[] = {
 
  60 int __init init_ocotea(void)
 
  64         unsigned long long small_flash_base, large_flash_base;
 
  66         fpga0_adr = ioremap64(OCOTEA_FPGA_ADDR, 16);
 
  70         fpga0_reg = readb((unsigned long)fpga0_adr);
 
  73         if (OCOTEA_BOOT_LARGE_FLASH(fpga0_reg)) {
 
  74                 small_flash_base = OCOTEA_SMALL_FLASH_HIGH;
 
  75                 large_flash_base = OCOTEA_LARGE_FLASH_LOW;
 
  78                 small_flash_base = OCOTEA_SMALL_FLASH_LOW;
 
  79                 large_flash_base = OCOTEA_LARGE_FLASH_HIGH;
 
  82         ocotea_small_map.phys = small_flash_base;
 
  83         ocotea_small_map.virt = ioremap64(small_flash_base,
 
  84                                          ocotea_small_map.size);
 
  86         if (!ocotea_small_map.virt) {
 
  87                 printk("Failed to ioremap flash\n");
 
  91         simple_map_init(&ocotea_small_map);
 
  93         flash = do_map_probe("map_rom", &ocotea_small_map);
 
  95                 flash->owner = THIS_MODULE;
 
  96                 add_mtd_partitions(flash, ocotea_small_partitions,
 
  97                                         ARRAY_SIZE(ocotea_small_partitions));
 
  99                 printk("map probe failed for flash\n");
 
 103         ocotea_large_map.phys = large_flash_base;
 
 104         ocotea_large_map.virt = ioremap64(large_flash_base,
 
 105                                          ocotea_large_map.size);
 
 107         if (!ocotea_large_map.virt) {
 
 108                 printk("Failed to ioremap flash\n");
 
 112         simple_map_init(&ocotea_large_map);
 
 114         flash = do_map_probe("cfi_probe", &ocotea_large_map);
 
 116                 flash->owner = THIS_MODULE;
 
 117                 add_mtd_partitions(flash, ocotea_large_partitions,
 
 118                                         ARRAY_SIZE(ocotea_large_partitions));
 
 120                 printk("map probe failed for flash\n");
 
 127 static void __exit cleanup_ocotea(void)
 
 130                 del_mtd_partitions(flash);
 
 134         if (ocotea_small_map.virt) {
 
 135                 iounmap((void *)ocotea_small_map.virt);
 
 136                 ocotea_small_map.virt = 0;
 
 139         if (ocotea_large_map.virt) {
 
 140                 iounmap((void *)ocotea_large_map.virt);
 
 141                 ocotea_large_map.virt = 0;
 
 145 module_init(init_ocotea);
 
 146 module_exit(cleanup_ocotea);
 
 148 MODULE_LICENSE("GPL");
 
 149 MODULE_AUTHOR("Matt Porter <mporter@kernel.crashing.org>");
 
 150 MODULE_DESCRIPTION("MTD map and partitions for IBM 440GX Ocotea boards");