1 /* 2 * Framebuffer device registration for TI OMAP platforms 3 * 4 * Copyright (C) 2006 Nokia Corporation 5 * Author: Imre Deak <imre.deak@nokia.com> 6 * 7 * This program is free software; you can redistribute it and/or modify it 8 * under the terms of the GNU General Public License as published by the 9 * Free Software Foundation; either version 2 of the License, or (at your 10 * option) any later version. 11 * 12 * This program is distributed in the hope that it will be useful, but 13 * WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 15 * General Public License for more details. 16 * 17 * You should have received a copy of the GNU General Public License along 18 * with this program; if not, write to the Free Software Foundation, Inc., 19 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 20 */ 21 22 #include <linux/module.h> 23 #include <linux/kernel.h> 24 #include <linux/mm.h> 25 #include <linux/init.h> 26 #include <linux/platform_device.h> 27 #include <linux/memblock.h> 28 #include <linux/io.h> 29 #include <linux/omapfb.h> 30 #include <linux/dma-mapping.h> 31 32 #include <asm/mach/map.h> 33 34 #include "soc.h" 35 36 #ifdef CONFIG_OMAP2_VRFB 37 38 /* 39 * The first memory resource is the register region for VRFB, 40 * the rest are VRFB virtual memory areas for each VRFB context. 41 */ 42 43 static const struct resource omap2_vrfb_resources[] = { 44 DEFINE_RES_MEM_NAMED(0x68008000u, 0x40, "vrfb-regs"), 45 DEFINE_RES_MEM_NAMED(0x70000000u, 0x4000000, "vrfb-area-0"), 46 DEFINE_RES_MEM_NAMED(0x74000000u, 0x4000000, "vrfb-area-1"), 47 DEFINE_RES_MEM_NAMED(0x78000000u, 0x4000000, "vrfb-area-2"), 48 DEFINE_RES_MEM_NAMED(0x7c000000u, 0x4000000, "vrfb-area-3"), 49 }; 50 51 static const struct resource omap3_vrfb_resources[] = { 52 DEFINE_RES_MEM_NAMED(0x6C000180u, 0xc0, "vrfb-regs"), 53 DEFINE_RES_MEM_NAMED(0x70000000u, 0x4000000, "vrfb-area-0"), 54 DEFINE_RES_MEM_NAMED(0x74000000u, 0x4000000, "vrfb-area-1"), 55 DEFINE_RES_MEM_NAMED(0x78000000u, 0x4000000, "vrfb-area-2"), 56 DEFINE_RES_MEM_NAMED(0x7c000000u, 0x4000000, "vrfb-area-3"), 57 DEFINE_RES_MEM_NAMED(0xe0000000u, 0x4000000, "vrfb-area-4"), 58 DEFINE_RES_MEM_NAMED(0xe4000000u, 0x4000000, "vrfb-area-5"), 59 DEFINE_RES_MEM_NAMED(0xe8000000u, 0x4000000, "vrfb-area-6"), 60 DEFINE_RES_MEM_NAMED(0xec000000u, 0x4000000, "vrfb-area-7"), 61 DEFINE_RES_MEM_NAMED(0xf0000000u, 0x4000000, "vrfb-area-8"), 62 DEFINE_RES_MEM_NAMED(0xf4000000u, 0x4000000, "vrfb-area-9"), 63 DEFINE_RES_MEM_NAMED(0xf8000000u, 0x4000000, "vrfb-area-10"), 64 DEFINE_RES_MEM_NAMED(0xfc000000u, 0x4000000, "vrfb-area-11"), 65 }; 66 67 static int __init omap_init_vrfb(void) 68 { 69 struct platform_device *pdev; 70 const struct resource *res; 71 unsigned int num_res; 72 73 if (cpu_is_omap24xx()) { 74 res = omap2_vrfb_resources; 75 num_res = ARRAY_SIZE(omap2_vrfb_resources); 76 } else if (cpu_is_omap34xx()) { 77 res = omap3_vrfb_resources; 78 num_res = ARRAY_SIZE(omap3_vrfb_resources); 79 } else { 80 return 0; 81 } 82 83 pdev = platform_device_register_resndata(NULL, "omapvrfb", -1, 84 res, num_res, NULL, 0); 85 86 return PTR_RET(pdev); 87 } 88 89 omap_arch_initcall(omap_init_vrfb); 90 #endif 91 92 #if defined(CONFIG_FB_OMAP2) || defined(CONFIG_FB_OMAP2_MODULE) 93 94 static u64 omap_fb_dma_mask = ~(u32)0; 95 static struct omapfb_platform_data omapfb_config; 96 97 static struct platform_device omap_fb_device = { 98 .name = "omapfb", 99 .id = -1, 100 .dev = { 101 .dma_mask = &omap_fb_dma_mask, 102 .coherent_dma_mask = DMA_BIT_MASK(32), 103 .platform_data = &omapfb_config, 104 }, 105 .num_resources = 0, 106 }; 107 108 static int __init omap_init_fb(void) 109 { 110 return platform_device_register(&omap_fb_device); 111 } 112 113 omap_arch_initcall(omap_init_fb); 114 115 #endif 116