Linux Audio

Check our new training course

Loading...
v3.1
 
  1/*
  2 * linux/arch/arm/mach-omap1/io.c
  3 *
  4 * OMAP1 I/O mapping code
  5 *
  6 * This program is free software; you can redistribute it and/or modify
  7 * it under the terms of the GNU General Public License version 2 as
  8 * published by the Free Software Foundation.
  9 */
 10
 11#include <linux/module.h>
 12#include <linux/kernel.h>
 13#include <linux/init.h>
 14#include <linux/io.h>
 
 15
 16#include <asm/tlb.h>
 17#include <asm/mach/map.h>
 18#include <plat/mux.h>
 19#include <plat/tc.h>
 20
 21#include "clock.h"
 22
 23extern void omap_check_revision(void);
 24extern void omap_sram_init(void);
 
 25
 26/*
 27 * The machine specific code may provide the extra mapping besides the
 28 * default mapping provided here.
 29 */
 30static struct map_desc omap_io_desc[] __initdata = {
 
 31	{
 32		.virtual	= OMAP1_IO_VIRT,
 33		.pfn		= __phys_to_pfn(OMAP1_IO_PHYS),
 34		.length		= OMAP1_IO_SIZE,
 35		.type		= MT_DEVICE
 36	}
 37};
 38
 39#if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
 40static struct map_desc omap7xx_io_desc[] __initdata = {
 41	{
 42		.virtual	= OMAP7XX_DSP_BASE,
 43		.pfn		= __phys_to_pfn(OMAP7XX_DSP_START),
 44		.length		= OMAP7XX_DSP_SIZE,
 45		.type		= MT_DEVICE
 46	}, {
 47		.virtual	= OMAP7XX_DSPREG_BASE,
 48		.pfn		= __phys_to_pfn(OMAP7XX_DSPREG_START),
 49		.length		= OMAP7XX_DSPREG_SIZE,
 50		.type		= MT_DEVICE
 51	}
 52};
 53#endif
 54
 55#ifdef CONFIG_ARCH_OMAP15XX
 56static struct map_desc omap1510_io_desc[] __initdata = {
 57	{
 
 
 
 
 
 
 58		.virtual	= OMAP1510_DSP_BASE,
 59		.pfn		= __phys_to_pfn(OMAP1510_DSP_START),
 60		.length		= OMAP1510_DSP_SIZE,
 61		.type		= MT_DEVICE
 62	}, {
 63		.virtual	= OMAP1510_DSPREG_BASE,
 64		.pfn		= __phys_to_pfn(OMAP1510_DSPREG_START),
 65		.length		= OMAP1510_DSPREG_SIZE,
 66		.type		= MT_DEVICE
 67	}
 68};
 69#endif
 70
 71#if defined(CONFIG_ARCH_OMAP16XX)
 72static struct map_desc omap16xx_io_desc[] __initdata = {
 73	{
 
 
 
 
 
 
 74		.virtual	= OMAP16XX_DSP_BASE,
 75		.pfn		= __phys_to_pfn(OMAP16XX_DSP_START),
 76		.length		= OMAP16XX_DSP_SIZE,
 77		.type		= MT_DEVICE
 78	}, {
 79		.virtual	= OMAP16XX_DSPREG_BASE,
 80		.pfn		= __phys_to_pfn(OMAP16XX_DSPREG_START),
 81		.length		= OMAP16XX_DSPREG_SIZE,
 82		.type		= MT_DEVICE
 83	}
 84};
 85#endif
 86
 87/*
 88 * Maps common IO regions for omap1. This should only get called from
 89 * board specific init.
 90 */
 91void __init omap1_map_common_io(void)
 92{
 93	iotable_init(omap_io_desc, ARRAY_SIZE(omap_io_desc));
 94
 95	/* Normally devicemaps_init() would flush caches and tlb after
 96	 * mdesc->map_io(), but we must also do it here because of the CPU
 97	 * revision check below.
 98	 */
 99	local_flush_tlb_all();
100	flush_cache_all();
101
102	/* We want to check CPU revision early for cpu_is_omapxxxx() macros.
103	 * IO space mapping must be initialized before we can do that.
104	 */
105	omap_check_revision();
106
107#if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
108	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		iotable_init(omap1510_io_desc, ARRAY_SIZE(omap1510_io_desc));
115	}
116#endif
117#if defined(CONFIG_ARCH_OMAP16XX)
118	if (cpu_is_omap16xx()) {
119		iotable_init(omap16xx_io_desc, ARRAY_SIZE(omap16xx_io_desc));
120	}
121#endif
122
123	omap_sram_init();
 
 
 
124}
 
125
126/*
127 * Common low-level hardware init for omap1. This should only get called from
128 * board specific init.
129 */
130void __init omap1_init_common_hw(void)
131{
 
 
132	/* REVISIT: Refer to OMAP5910 Errata, Advisory SYS_1: "Timeout Abort
133	 * on a Posted Write in the TIPB Bridge".
134	 */
135	omap_writew(0x0, MPU_PUBLIC_TIPB_CNTL);
136	omap_writew(0x0, MPU_PRIVATE_TIPB_CNTL);
 
137
138	/* Must init clocks early to assure that timer interrupt works
139	 */
140	omap1_clk_init();
141
142	omap1_mux_init();
143}
144
145/*
146 * NOTE: Please use ioremap + __raw_read/write where possible instead of these
147 */
148
149u8 omap_readb(u32 pa)
150{
151	return __raw_readb(OMAP1_IO_ADDRESS(pa));
152}
153EXPORT_SYMBOL(omap_readb);
154
155u16 omap_readw(u32 pa)
156{
157	return __raw_readw(OMAP1_IO_ADDRESS(pa));
158}
159EXPORT_SYMBOL(omap_readw);
160
161u32 omap_readl(u32 pa)
162{
163	return __raw_readl(OMAP1_IO_ADDRESS(pa));
164}
165EXPORT_SYMBOL(omap_readl);
166
167void omap_writeb(u8 v, u32 pa)
168{
169	__raw_writeb(v, OMAP1_IO_ADDRESS(pa));
170}
171EXPORT_SYMBOL(omap_writeb);
172
173void omap_writew(u16 v, u32 pa)
174{
175	__raw_writew(v, OMAP1_IO_ADDRESS(pa));
176}
177EXPORT_SYMBOL(omap_writew);
178
179void omap_writel(u32 v, u32 pa)
180{
181	__raw_writel(v, OMAP1_IO_ADDRESS(pa));
182}
183EXPORT_SYMBOL(omap_writel);
v6.2
  1// SPDX-License-Identifier: GPL-2.0-only
  2/*
  3 * linux/arch/arm/mach-omap1/io.c
  4 *
  5 * OMAP1 I/O mapping code
 
 
 
 
  6 */
  7
  8#include <linux/module.h>
  9#include <linux/kernel.h>
 10#include <linux/init.h>
 11#include <linux/io.h>
 12#include <linux/omap-dma.h>
 13
 14#include <asm/tlb.h>
 15#include <asm/mach/map.h>
 
 
 
 
 16
 17#include "tc.h"
 18#include "iomap.h"
 19#include "common.h"
 20
 21/*
 22 * The machine specific code may provide the extra mapping besides the
 23 * default mapping provided here.
 24 */
 25#if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
 26static struct map_desc omap7xx_io_desc[] __initdata = {
 27	{
 28		.virtual	= OMAP1_IO_VIRT,
 29		.pfn		= __phys_to_pfn(OMAP1_IO_PHYS),
 30		.length		= OMAP1_IO_SIZE,
 31		.type		= MT_DEVICE
 32	},
 
 
 
 
 33	{
 34		.virtual	= OMAP7XX_DSP_BASE,
 35		.pfn		= __phys_to_pfn(OMAP7XX_DSP_START),
 36		.length		= OMAP7XX_DSP_SIZE,
 37		.type		= MT_DEVICE
 38	}, {
 39		.virtual	= OMAP7XX_DSPREG_BASE,
 40		.pfn		= __phys_to_pfn(OMAP7XX_DSPREG_START),
 41		.length		= OMAP7XX_DSPREG_SIZE,
 42		.type		= MT_DEVICE
 43	}
 44};
 45#endif
 46
 47#ifdef CONFIG_ARCH_OMAP15XX
 48static struct map_desc omap1510_io_desc[] __initdata = {
 49	{
 50		.virtual	= OMAP1_IO_VIRT,
 51		.pfn		= __phys_to_pfn(OMAP1_IO_PHYS),
 52		.length		= OMAP1_IO_SIZE,
 53		.type		= MT_DEVICE
 54	},
 55	{
 56		.virtual	= OMAP1510_DSP_BASE,
 57		.pfn		= __phys_to_pfn(OMAP1510_DSP_START),
 58		.length		= OMAP1510_DSP_SIZE,
 59		.type		= MT_DEVICE
 60	}, {
 61		.virtual	= OMAP1510_DSPREG_BASE,
 62		.pfn		= __phys_to_pfn(OMAP1510_DSPREG_START),
 63		.length		= OMAP1510_DSPREG_SIZE,
 64		.type		= MT_DEVICE
 65	}
 66};
 67#endif
 68
 69#if defined(CONFIG_ARCH_OMAP16XX)
 70static struct map_desc omap16xx_io_desc[] __initdata = {
 71	{
 72		.virtual	= OMAP1_IO_VIRT,
 73		.pfn		= __phys_to_pfn(OMAP1_IO_PHYS),
 74		.length		= OMAP1_IO_SIZE,
 75		.type		= MT_DEVICE
 76	},
 77	{
 78		.virtual	= OMAP16XX_DSP_BASE,
 79		.pfn		= __phys_to_pfn(OMAP16XX_DSP_START),
 80		.length		= OMAP16XX_DSP_SIZE,
 81		.type		= MT_DEVICE
 82	}, {
 83		.virtual	= OMAP16XX_DSPREG_BASE,
 84		.pfn		= __phys_to_pfn(OMAP16XX_DSPREG_START),
 85		.length		= OMAP16XX_DSPREG_SIZE,
 86		.type		= MT_DEVICE
 87	}
 88};
 89#endif
 90
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 91#if defined (CONFIG_ARCH_OMAP730) || defined (CONFIG_ARCH_OMAP850)
 92void __init omap7xx_map_io(void)
 93{
 94	iotable_init(omap7xx_io_desc, ARRAY_SIZE(omap7xx_io_desc));
 95}
 96#endif
 97
 98#ifdef CONFIG_ARCH_OMAP15XX
 99void __init omap15xx_map_io(void)
100{
101	iotable_init(omap1510_io_desc, ARRAY_SIZE(omap1510_io_desc));
102}
 
 
 
 
103#endif
104
105#if defined(CONFIG_ARCH_OMAP16XX)
106void __init omap16xx_map_io(void)
107{
108	iotable_init(omap16xx_io_desc, ARRAY_SIZE(omap16xx_io_desc));
109}
110#endif
111
112/*
113 * Common low-level hardware init for omap1.
 
114 */
115void __init omap1_init_early(void)
116{
117	omap_check_revision();
118
119	/* REVISIT: Refer to OMAP5910 Errata, Advisory SYS_1: "Timeout Abort
120	 * on a Posted Write in the TIPB Bridge".
121	 */
122	omap_writew(0x0, MPU_PUBLIC_TIPB_CNTL);
123	omap_writew(0x0, MPU_PRIVATE_TIPB_CNTL);
124}
125
126void __init omap1_init_late(void)
127{
128	omap_serial_wakeup_init();
 
 
129}
130
131/*
132 * NOTE: Please use ioremap + __raw_read/write where possible instead of these
133 */
134
135u8 omap_readb(u32 pa)
136{
137	return __raw_readb(OMAP1_IO_ADDRESS(pa));
138}
139EXPORT_SYMBOL(omap_readb);
140
141u16 omap_readw(u32 pa)
142{
143	return __raw_readw(OMAP1_IO_ADDRESS(pa));
144}
145EXPORT_SYMBOL(omap_readw);
146
147u32 omap_readl(u32 pa)
148{
149	return __raw_readl(OMAP1_IO_ADDRESS(pa));
150}
151EXPORT_SYMBOL(omap_readl);
152
153void omap_writeb(u8 v, u32 pa)
154{
155	__raw_writeb(v, OMAP1_IO_ADDRESS(pa));
156}
157EXPORT_SYMBOL(omap_writeb);
158
159void omap_writew(u16 v, u32 pa)
160{
161	__raw_writew(v, OMAP1_IO_ADDRESS(pa));
162}
163EXPORT_SYMBOL(omap_writew);
164
165void omap_writel(u32 v, u32 pa)
166{
167	__raw_writel(v, OMAP1_IO_ADDRESS(pa));
168}
169EXPORT_SYMBOL(omap_writel);