blob: a0728c33e5d9e60de43b6f867b1efcfd61c1561f [file] [log] [blame]
Tony Lindgren1dbae812005-11-10 14:26:51 +00001/*
2 * linux/arch/arm/mach-omap2/io.c
3 *
4 * OMAP2 I/O mapping code
5 *
6 * Copyright (C) 2005 Nokia Corporation
7 * Author: Juha Yrjölä <juha.yrjola@nokia.com>
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License version 2 as
11 * published by the Free Software Foundation.
12 */
13
Tony Lindgren1dbae812005-11-10 14:26:51 +000014#include <linux/module.h>
15#include <linux/kernel.h>
16#include <linux/init.h>
17
Tony Lindgren120db2c2006-04-02 17:46:27 +010018#include <asm/tlb.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000019#include <asm/io.h>
Tony Lindgren120db2c2006-04-02 17:46:27 +010020
21#include <asm/mach/map.h>
22
Tony Lindgren1dbae812005-11-10 14:26:51 +000023#include <asm/arch/mux.h>
Tony Lindgren120db2c2006-04-02 17:46:27 +010024#include <asm/arch/omapfb.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000025
26extern void omap_sram_init(void);
27extern int omap2_clk_init(void);
28extern void omap2_check_revision(void);
Juha Yrjola4bbbc1a2006-06-26 16:16:16 -070029extern void gpmc_init(void);
Tony Lindgren1dbae812005-11-10 14:26:51 +000030
31/*
32 * The machine specific code may provide the extra mapping besides the
33 * default mapping provided here.
34 */
35static struct map_desc omap2_io_desc[] __initdata = {
36 {
37 .virtual = L3_24XX_VIRT,
38 .pfn = __phys_to_pfn(L3_24XX_PHYS),
39 .length = L3_24XX_SIZE,
40 .type = MT_DEVICE
41 },
42 {
43 .virtual = L4_24XX_VIRT,
44 .pfn = __phys_to_pfn(L4_24XX_PHYS),
45 .length = L4_24XX_SIZE,
46 .type = MT_DEVICE
47 }
48};
49
Tony Lindgren120db2c2006-04-02 17:46:27 +010050void __init omap2_map_common_io(void)
Tony Lindgren1dbae812005-11-10 14:26:51 +000051{
52 iotable_init(omap2_io_desc, ARRAY_SIZE(omap2_io_desc));
Tony Lindgren120db2c2006-04-02 17:46:27 +010053
54 /* Normally devicemaps_init() would flush caches and tlb after
55 * mdesc->map_io(), but we must also do it here because of the CPU
56 * revision check below.
57 */
58 local_flush_tlb_all();
59 flush_cache_all();
60
Tony Lindgren1dbae812005-11-10 14:26:51 +000061 omap2_check_revision();
62 omap_sram_init();
Tony Lindgren120db2c2006-04-02 17:46:27 +010063 omapfb_reserve_mem();
64}
65
66void __init omap2_init_common_hw(void)
67{
Tony Lindgren1dbae812005-11-10 14:26:51 +000068 omap2_mux_init();
69 omap2_clk_init();
Juha Yrjola4bbbc1a2006-06-26 16:16:16 -070070 gpmc_init();
Tony Lindgren1dbae812005-11-10 14:26:51 +000071}