dd9bf78040
Move iop33x and iop32x PCI to fixed i/o mapping and remove io.h. This changes the PCI bus addresses from the cpu address to 0 based. It appears that there is translation h/w for this, but its untested. Not sure what to do with io_offset. I think it should always be 0. AFAICT, PCI setup is skipped if the ATU is already setup. Signed-off-by: Rob Herring <rob.herring@calxeda.com> Reviewed-by: Arnd Bergmann <arnd@arndb.de>
35 lines
950 B
C
35 lines
950 B
C
/*
|
|
* arch/arm/plat-iop/setup.c
|
|
*
|
|
* Author: Nicolas Pitre <nico@fluxnic.net>
|
|
* Copyright (C) 2001 MontaVista Software, Inc.
|
|
* Copyright (C) 2004 Intel Corporation.
|
|
*
|
|
* 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/mm.h>
|
|
#include <linux/init.h>
|
|
#include <asm/mach/map.h>
|
|
#include <asm/hardware/iop3xx.h>
|
|
|
|
/*
|
|
* Standard IO mapping for all IOP3xx based systems. Note that
|
|
* the IOP3xx OCCDR must be mapped uncached and unbuffered.
|
|
*/
|
|
static struct map_desc iop3xx_std_desc[] __initdata = {
|
|
{ /* mem mapped registers */
|
|
.virtual = IOP3XX_PERIPHERAL_VIRT_BASE,
|
|
.pfn = __phys_to_pfn(IOP3XX_PERIPHERAL_PHYS_BASE),
|
|
.length = IOP3XX_PERIPHERAL_SIZE,
|
|
.type = MT_UNCACHED,
|
|
},
|
|
};
|
|
|
|
void __init iop3xx_map_io(void)
|
|
{
|
|
iotable_init(iop3xx_std_desc, ARRAY_SIZE(iop3xx_std_desc));
|
|
}
|