io.c 4.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13
/*
 * linux/arch/arm/mach-omap1/io.c
 *
 * OMAP1 I/O mapping code
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
14
#include <linux/io.h>
15

16
#include <asm/tlb.h>
17
#include <asm/mach/map.h>
18 19
#include <plat/mux.h>
#include <plat/tc.h>
20

21 22
#include "clock.h"

23
extern void omap_check_revision(void);
24
extern void omap_sram_init(void);
25 26 27 28 29 30

/*
 * The machine specific code may provide the extra mapping besides the
 * default mapping provided here.
 */
static struct map_desc omap_io_desc[] __initdata = {
31
	{
T
Tony Lindgren 已提交
32 33 34
		.virtual	= OMAP1_IO_VIRT,
		.pfn		= __phys_to_pfn(OMAP1_IO_PHYS),
		.length		= OMAP1_IO_SIZE,
35 36
		.type		= MT_DEVICE
	}
37 38
};

39
#if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
40
static struct map_desc omap7xx_io_desc[] __initdata = {
41
	{
42 43 44
		.virtual	= OMAP7XX_DSP_BASE,
		.pfn		= __phys_to_pfn(OMAP7XX_DSP_START),
		.length		= OMAP7XX_DSP_SIZE,
45 46
		.type		= MT_DEVICE
	}, {
47 48 49
		.virtual	= OMAP7XX_DSPREG_BASE,
		.pfn		= __phys_to_pfn(OMAP7XX_DSPREG_START),
		.length		= OMAP7XX_DSPREG_SIZE,
50 51
		.type		= MT_DEVICE
	}
52 53 54
};
#endif

55
#ifdef CONFIG_ARCH_OMAP15XX
56
static struct map_desc omap1510_io_desc[] __initdata = {
57 58 59 60 61 62 63 64 65 66 67
	{
		.virtual	= OMAP1510_DSP_BASE,
		.pfn		= __phys_to_pfn(OMAP1510_DSP_START),
		.length		= OMAP1510_DSP_SIZE,
		.type		= MT_DEVICE
	}, {
		.virtual	= OMAP1510_DSPREG_BASE,
		.pfn		= __phys_to_pfn(OMAP1510_DSPREG_START),
		.length		= OMAP1510_DSPREG_SIZE,
		.type		= MT_DEVICE
	}
68 69 70 71
};
#endif

#if defined(CONFIG_ARCH_OMAP16XX)
72
static struct map_desc omap16xx_io_desc[] __initdata = {
73 74 75 76 77 78 79 80 81 82 83
	{
		.virtual	= OMAP16XX_DSP_BASE,
		.pfn		= __phys_to_pfn(OMAP16XX_DSP_START),
		.length		= OMAP16XX_DSP_SIZE,
		.type		= MT_DEVICE
	}, {
		.virtual	= OMAP16XX_DSPREG_BASE,
		.pfn		= __phys_to_pfn(OMAP16XX_DSPREG_START),
		.length		= OMAP16XX_DSPREG_SIZE,
		.type		= MT_DEVICE
	}
84 85 86
};
#endif

87 88 89 90 91
/*
 * Maps common IO regions for omap1. This should only get called from
 * board specific init.
 */
void __init omap1_map_common_io(void)
92 93
{
	iotable_init(omap_io_desc, ARRAY_SIZE(omap_io_desc));
94 95 96 97 98 99 100 101 102 103 104

	/* Normally devicemaps_init() would flush caches and tlb after
	 * mdesc->map_io(), but we must also do it here because of the CPU
	 * revision check below.
	 */
	local_flush_tlb_all();
	flush_cache_all();

	/* We want to check CPU revision early for cpu_is_omapxxxx() macros.
	 * IO space mapping must be initialized before we can do that.
	 */
105 106
	omap_check_revision();

107 108
#if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
	if (cpu_is_omap7xx()) {
109
		iotable_init(omap7xx_io_desc, ARRAY_SIZE(omap7xx_io_desc));
110 111
	}
#endif
112
#ifdef CONFIG_ARCH_OMAP15XX
113
	if (cpu_is_omap15xx()) {
114 115 116 117
		iotable_init(omap1510_io_desc, ARRAY_SIZE(omap1510_io_desc));
	}
#endif
#if defined(CONFIG_ARCH_OMAP16XX)
118 119
	if (cpu_is_omap16xx()) {
		iotable_init(omap16xx_io_desc, ARRAY_SIZE(omap16xx_io_desc));
120 121 122
	}
#endif

123
	omap_sram_init();
124
	omap_init_consistent_dma_size();
125
}
126

127 128 129 130
/*
 * Common low-level hardware init for omap1. This should only get called from
 * board specific init.
 */
R
Russell King 已提交
131
void __init omap1_init_common_hw(void)
132
{
133 134 135 136 137 138 139 140
	/* REVISIT: Refer to OMAP5910 Errata, Advisory SYS_1: "Timeout Abort
	 * on a Posted Write in the TIPB Bridge".
	 */
	omap_writew(0x0, MPU_PUBLIC_TIPB_CNTL);
	omap_writew(0x0, MPU_PRIVATE_TIPB_CNTL);

	/* Must init clocks early to assure that timer interrupt works
	 */
141
	omap1_clk_init();
142

143
	omap1_mux_init();
144
}
145

146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184
/*
 * NOTE: Please use ioremap + __raw_read/write where possible instead of these
 */

u8 omap_readb(u32 pa)
{
	return __raw_readb(OMAP1_IO_ADDRESS(pa));
}
EXPORT_SYMBOL(omap_readb);

u16 omap_readw(u32 pa)
{
	return __raw_readw(OMAP1_IO_ADDRESS(pa));
}
EXPORT_SYMBOL(omap_readw);

u32 omap_readl(u32 pa)
{
	return __raw_readl(OMAP1_IO_ADDRESS(pa));
}
EXPORT_SYMBOL(omap_readl);

void omap_writeb(u8 v, u32 pa)
{
	__raw_writeb(v, OMAP1_IO_ADDRESS(pa));
}
EXPORT_SYMBOL(omap_writeb);

void omap_writew(u16 v, u32 pa)
{
	__raw_writew(v, OMAP1_IO_ADDRESS(pa));
}
EXPORT_SYMBOL(omap_writew);

void omap_writel(u32 v, u32 pa)
{
	__raw_writel(v, OMAP1_IO_ADDRESS(pa));
}
EXPORT_SYMBOL(omap_writel);