Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
714d25d2
Commit
714d25d2
authored
Jan 07, 2005
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://bk.arm.linux.org.uk/linux-2.6-rmk
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
aa7b5720
683c51ac
Changes
26
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
26 changed files
with
1336 additions
and
113 deletions
+1336
-113
arch/arm/configs/iq80332_defconfig
arch/arm/configs/iq80332_defconfig
+864
-0
arch/arm/mach-iop3xx/Kconfig
arch/arm/mach-iop3xx/Kconfig
+15
-2
arch/arm/mach-iop3xx/Makefile
arch/arm/mach-iop3xx/Makefile
+2
-0
arch/arm/mach-iop3xx/iop321-pci.c
arch/arm/mach-iop3xx/iop321-pci.c
+0
-8
arch/arm/mach-iop3xx/iop321-setup.c
arch/arm/mach-iop3xx/iop321-setup.c
+59
-2
arch/arm/mach-iop3xx/iop331-setup.c
arch/arm/mach-iop3xx/iop331-setup.c
+84
-8
arch/arm/mach-iop3xx/iq31244-pci.c
arch/arm/mach-iop3xx/iq31244-pci.c
+10
-12
arch/arm/mach-iop3xx/iq80321-pci.c
arch/arm/mach-iop3xx/iq80321-pci.c
+9
-24
arch/arm/mach-iop3xx/iq80332-mm.c
arch/arm/mach-iop3xx/iq80332-mm.c
+36
-0
arch/arm/mach-iop3xx/iq80332-pci.c
arch/arm/mach-iop3xx/iq80332-pci.c
+128
-0
arch/arm/mach-ixp4xx/common.c
arch/arm/mach-ixp4xx/common.c
+37
-0
arch/arm/mach-ixp4xx/coyote-setup.c
arch/arm/mach-ixp4xx/coyote-setup.c
+2
-1
arch/arm/mach-ixp4xx/ixdp425-setup.c
arch/arm/mach-ixp4xx/ixdp425-setup.c
+3
-1
arch/arm/mach-ixp4xx/prpmc1100-setup.c
arch/arm/mach-ixp4xx/prpmc1100-setup.c
+3
-1
arch/arm/mm/proc-xscale.S
arch/arm/mm/proc-xscale.S
+2
-2
include/asm-arm/arch-iop3xx/entry-macro.S
include/asm-arm/arch-iop3xx/entry-macro.S
+3
-8
include/asm-arm/arch-iop3xx/hardware.h
include/asm-arm/arch-iop3xx/hardware.h
+1
-0
include/asm-arm/arch-iop3xx/iop321.h
include/asm-arm/arch-iop3xx/iop321.h
+19
-9
include/asm-arm/arch-iop3xx/iop331-irqs.h
include/asm-arm/arch-iop3xx/iop331-irqs.h
+23
-0
include/asm-arm/arch-iop3xx/iq31244.h
include/asm-arm/arch-iop3xx/iq31244.h
+0
-12
include/asm-arm/arch-iop3xx/iq80321.h
include/asm-arm/arch-iop3xx/iq80321.h
+0
-11
include/asm-arm/arch-iop3xx/iq80332.h
include/asm-arm/arch-iop3xx/iq80332.h
+23
-0
include/asm-arm/arch-iop3xx/timex.h
include/asm-arm/arch-iop3xx/timex.h
+1
-1
include/asm-arm/arch-iop3xx/uncompress.h
include/asm-arm/arch-iop3xx/uncompress.h
+5
-3
include/asm-arm/arch-ixp4xx/irqs.h
include/asm-arm/arch-ixp4xx/irqs.h
+6
-8
include/asm-arm/arch-ixp4xx/platform.h
include/asm-arm/arch-ixp4xx/platform.h
+1
-0
No files found.
arch/arm/configs/iq80332_defconfig
0 → 100644
View file @
714d25d2
This diff is collapsed.
Click to expand it.
arch/arm/mach-iop3xx/Kconfig
View file @
714d25d2
...
...
@@ -25,6 +25,13 @@ config ARCH_IQ80331
Say Y here if you want to run your kernel on the Intel IQ80331
evaluation kit for the IOP331 chipset.
config MACH_IQ80332
bool "Enable support for IQ80332"
select ARCH_IOP331
help
Say Y here if you want to run your kernel on the Intel IQ80332
evaluation kit for the IOP332 chipset
config ARCH_EP80219
bool "Enable support for EP80219"
select ARCH_IOP321
...
...
@@ -41,10 +48,16 @@ config ARCH_IOP331
bool
default ARCH_IQ80331
help
The IQ80331 uses the IOP331 variant.
The IQ80331
, IQ80332, and IQ80333
uses the IOP331 variant.
comment "IOP3xx Chipset Features"
endmenu
config IOP331_STEPD
bool "Chip stepping D of the IOP80331 processor or IOP80333"
depends on (ARCH_IOP331)
help
Say Y here if you have StepD of the IOP80331 or IOP8033
based platforms.
endmenu
endif
arch/arm/mach-iop3xx/Makefile
View file @
714d25d2
...
...
@@ -19,3 +19,5 @@ obj-$(CONFIG_ARCH_IQ80321) += iq80321-mm.o iq80321-pci.o
obj-$(CONFIG_ARCH_IQ31244)
+=
iq31244-mm.o iq31244-pci.o
obj-$(CONFIG_ARCH_IQ80331)
+=
iq80331-mm.o iq80331-pci.o
obj-$(CONFIG_MACH_IQ80332)
+=
iq80332-mm.o iq80332-pci.o
arch/arm/mach-iop3xx/iop321-pci.c
View file @
714d25d2
...
...
@@ -197,14 +197,6 @@ struct pci_bus *iop321_scan_bus(int nr, struct pci_sys_data *sys)
void
iop321_init
(
void
)
{
#if CONFIG_ARCH_EP80219
*
IOP321_ATUCR
=
0x2
;
*
IOP321_OIOWTVR
=
0x90000000
;
*
IOP321_IABAR0
=
0x00000004
;
*
IOP321_IABAR2
=
0xa000000c
;
*
IOP321_IALR2
=
0xe0000000
;
#endif
DBG
(
"PCI: Intel 80321 PCI init code.
\n
"
);
DBG
(
"
\t
ATU: IOP321_ATUCMD=0x%04x
\n
"
,
*
IOP321_ATUCMD
);
DBG
(
"
\t
ATU: IOP321_OMWTVR0=0x%04x, IOP321_OIOWTVR=0x%04x
\n
"
,
...
...
arch/arm/mach-iop3xx/iop321-setup.c
View file @
714d25d2
...
...
@@ -3,6 +3,7 @@
*
* Author: Nicolas Pitre <nico@cam.org>
* 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
...
...
@@ -40,10 +41,10 @@ static struct map_desc iop321_std_desc[] __initdata = {
/* virtual physical length type */
/* mem mapped registers */
{
IOP321_VIRT_MEM_BASE
,
IOP321_PHY_MEM_BASE
,
0x00002000
,
MT_DEVICE
},
{
IOP321_VIRT_MEM_BASE
,
IOP321_PHY
S
_MEM_BASE
,
0x00002000
,
MT_DEVICE
},
/* PCI IO space */
{
0xfe000000
,
0x90000000
,
0x00020000
,
MT_DEVICE
}
{
IOP321_PCI_LOWER_IO_VA
,
IOP321_PCI_LOWER_IO_PA
,
IOP321_PCI_IO_WINDOW_SIZE
,
MT_DEVICE
}
};
#ifdef CONFIG_ARCH_IQ80321
...
...
@@ -71,6 +72,60 @@ static struct uart_port iop321_serial_ports[] = {
}
};
static
struct
resource
iop32x_i2c_0_resources
[]
=
{
[
0
]
=
{
.
start
=
0xfffff680
,
.
end
=
0xfffff698
,
.
flags
=
IORESOURCE_MEM
,
},
[
1
]
=
{
.
start
=
IRQ_IOP321_I2C_0
,
.
end
=
IRQ_IOP321_I2C_0
,
.
flags
=
IORESOURCE_IRQ
}
};
static
struct
resource
iop32x_i2c_1_resources
[]
=
{
[
0
]
=
{
.
start
=
0xfffff6a0
,
.
end
=
0xfffff6b8
,
.
flags
=
IORESOURCE_MEM
,
},
[
1
]
=
{
.
start
=
IRQ_IOP321_I2C_1
,
.
end
=
IRQ_IOP321_I2C_1
,
.
flags
=
IORESOURCE_IRQ
}
};
static
struct
platform_device
iop32x_i2c_0_controller
=
{
.
name
=
"IOP3xx-I2C"
,
.
id
=
0
,
.
num_resources
=
2
,
.
resource
=
iop32x_i2c_0_resources
};
static
struct
platform_device
iop32x_i2c_1_controller
=
{
.
name
=
"IOP3xx-I2C"
,
.
id
=
1
,
.
num_resources
=
2
,
.
resource
=
iop32x_i2c_1_resources
};
static
struct
platform_device
*
iop32x_devices
[]
__initdata
=
{
&
iop32x_i2c_0_controller
,
&
iop32x_i2c_1_controller
};
void
__init
iop32x_init
(
void
)
{
if
(
iop_is_321
())
{
platform_add_devices
(
iop32x_devices
,
ARRAY_SIZE
(
iop32x_devices
));
}
}
void
__init
iop321_map_io
(
void
)
{
iotable_init
(
iop321_std_desc
,
ARRAY_SIZE
(
iop321_std_desc
));
...
...
@@ -97,6 +152,7 @@ MACHINE_START(IQ80321, "Intel IQ80321")
INITIRQ
(
iop321_init_irq
)
.
timer
=
&
iop321_timer
,
BOOT_PARAMS
(
0xa0000100
)
INIT_MACHINE
(
iop32x_init
)
MACHINE_END
#elif defined(CONFIG_ARCH_IQ31244)
MACHINE_START
(
IQ31244
,
"Intel IQ31244"
)
...
...
@@ -106,6 +162,7 @@ MACHINE_START(IQ31244, "Intel IQ31244")
INITIRQ
(
iop321_init_irq
)
.
timer
=
&
iop321_timer
,
BOOT_PARAMS
(
0xa0000100
)
INIT_MACHINE
(
iop32x_init
)
MACHINE_END
#else
#error No machine descriptor defined for this IOP3XX implementation
...
...
arch/arm/mach-iop3xx/iop331-setup.c
View file @
714d25d2
...
...
@@ -12,6 +12,7 @@
#include <linux/mm.h>
#include <linux/init.h>
#include <linux/config.h>
#include <linux/init.h>
#include <linux/major.h>
#include <linux/fs.h>
#include <linux/device.h>
...
...
@@ -42,13 +43,13 @@ static struct map_desc iop331_std_desc[] __initdata = {
{
IOP331_VIRT_MEM_BASE
,
IOP331_PHYS_MEM_BASE
,
0x00002000
,
MT_DEVICE
},
/* PCI IO space */
{
0xfe000000
,
0x90000000
,
0x00020000
,
MT_DEVICE
}
{
IOP331_PCI_LOWER_IO_VA
,
IOP331_PCI_LOWER_IO_PA
,
IOP331_PCI_IO_WINDOW_SIZE
,
MT_DEVICE
}
};
static
struct
uart_port
iop331_serial_ports
[]
=
{
{
.
membase
=
(
char
*
)(
I
Q80
331_UART0_VIRT
),
.
mapbase
=
(
I
Q80
331_UART0_PHYS
),
.
membase
=
(
char
*
)(
I
OP
331_UART0_VIRT
),
.
mapbase
=
(
I
OP
331_UART0_PHYS
),
.
irq
=
IRQ_IOP331_UART0
,
.
flags
=
UPF_SKIP_TEST
,
.
iotype
=
UPIO_MEM
,
...
...
@@ -58,8 +59,8 @@ static struct uart_port iop331_serial_ports[] = {
.
type
=
PORT_XSCALE
,
.
fifosize
=
32
}
,
{
.
membase
=
(
char
*
)(
I
Q80
331_UART1_VIRT
),
.
mapbase
=
(
I
Q80
331_UART1_PHYS
),
.
membase
=
(
char
*
)(
I
OP
331_UART1_VIRT
),
.
mapbase
=
(
I
OP
331_UART1_PHYS
),
.
irq
=
IRQ_IOP331_UART1
,
.
flags
=
UPF_SKIP_TEST
,
.
iotype
=
UPIO_MEM
,
...
...
@@ -71,6 +72,60 @@ static struct uart_port iop331_serial_ports[] = {
}
};
static
struct
resource
iop33x_i2c_0_resources
[]
=
{
[
0
]
=
{
.
start
=
0xfffff680
,
.
end
=
0xfffff698
,
.
flags
=
IORESOURCE_MEM
,
},
[
1
]
=
{
.
start
=
IRQ_IOP331_I2C_0
,
.
end
=
IRQ_IOP331_I2C_0
,
.
flags
=
IORESOURCE_IRQ
}
};
static
struct
resource
iop33x_i2c_1_resources
[]
=
{
[
0
]
=
{
.
start
=
0xfffff6a0
,
.
end
=
0xfffff6b8
,
.
flags
=
IORESOURCE_MEM
,
},
[
1
]
=
{
.
start
=
IRQ_IOP331_I2C_1
,
.
end
=
IRQ_IOP331_I2C_1
,
.
flags
=
IORESOURCE_IRQ
}
};
static
struct
platform_device
iop33x_i2c_0_controller
=
{
.
name
=
"IOP3xx-I2C"
,
.
id
=
0
,
.
num_resources
=
2
,
.
resource
=
iop33x_i2c_0_resources
};
static
struct
platform_device
iop33x_i2c_1_controller
=
{
.
name
=
"IOP3xx-I2C"
,
.
id
=
1
,
.
num_resources
=
2
,
.
resource
=
iop33x_i2c_1_resources
};
static
struct
platform_device
*
iop33x_devices
[]
__initdata
=
{
&
iop33x_i2c_0_controller
,
&
iop33x_i2c_1_controller
};
void
__init
iop33x_init
(
void
)
{
if
(
iop_is_331
())
{
platform_add_devices
(
iop33x_devices
,
ARRAY_SIZE
(
iop33x_devices
));
}
}
void
__init
iop331_map_io
(
void
)
{
iotable_init
(
iop331_std_desc
,
ARRAY_SIZE
(
iop331_std_desc
));
...
...
@@ -78,22 +133,43 @@ void __init iop331_map_io(void)
early_serial_setup
(
&
iop331_serial_ports
[
1
]);
}
#ifdef CONFIG_ARCH_I
Q80
331
#ifdef CONFIG_ARCH_I
OP
331
extern
void
iop331_init_irq
(
void
);
extern
struct
sys_timer
iop331_timer
;
#endif
#ifdef CONFIG_ARCH_IQ80331
extern
void
iq80331_map_io
(
void
);
#endif
#ifdef CONFIG_MACH_IQ80332
extern
void
iq80332_map_io
(
void
);
#endif
#if defined(CONFIG_ARCH_IQ80331)
MACHINE_START
(
IQ80331
,
"Intel IQ80331"
)
MAINTAINER
(
"Intel Corp."
)
BOOT_MEM
(
PHYS_OFFSET
,
0xfefff000
,
0xfffff000
)
// virtual, physical
//BOOT_MEM(PHYS_OFFSET, I
Q80331_UART0_VIRT, IQ80
331_UART0_PHYS)
//BOOT_MEM(PHYS_OFFSET, I
OP331_UART0_VIRT, IOP
331_UART0_PHYS)
MAPIO
(
iq80331_map_io
)
INITIRQ
(
iop331_init_irq
)
.
timer
=
&
iop331_timer
,
BOOT_PARAMS
(
0x0100
)
INIT_MACHINE
(
iop33x_init
)
MACHINE_END
#elif defined(CONFIG_MACH_IQ80332)
MACHINE_START
(
IQ80332
,
"Intel IQ80332"
)
MAINTAINER
(
"Intel Corp."
)
BOOT_MEM
(
PHYS_OFFSET
,
0xfefff000
,
0xfffff000
)
// virtual, physical
//BOOT_MEM(PHYS_OFFSET, IOP331_UART0_VIRT, IOP331_UART0_PHYS)
MAPIO
(
iq80332_map_io
)
INITIRQ
(
iop331_init_irq
)
.
timer
=
&
iop331_timer
,
BOOT_PARAMS
(
0x0100
)
INIT_MACHINE
(
iop33x_init
)
MACHINE_END
#else
#error No machine descriptor defined for this IOP3XX implementation
#endif
...
...
arch/arm/mach-iop3xx/iq31244-pci.c
View file @
714d25d2
...
...
@@ -5,6 +5,7 @@
*
* Author: Rory Bolt <rorybolt@pacbell.net>
* Copyright (C) 2002 Rory Bolt
* Copyright (C) 2004 Intel Corp.
*
* 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
...
...
@@ -77,28 +78,28 @@ static int iq31244_setup(int nr, struct pci_sys_data *sys)
memset
(
res
,
0
,
sizeof
(
struct
resource
)
*
2
);
res
[
0
].
start
=
I
Q31244_PCI_IO_BASE
+
0x6e000000
;
res
[
0
].
end
=
I
Q31244_PCI_IO_BASE
+
IQ31244_PCI_IO_SIZE
-
1
+
IQ31244
_PCI_IO_OFFSET
;
res
[
0
].
start
=
I
OP321_PCI_LOWER_IO_BA
+
IOP321_PCI_IO_OFFSET
;
res
[
0
].
end
=
I
OP321_PCI_UPPER_IO_BA
+
IOP321
_PCI_IO_OFFSET
;
res
[
0
].
name
=
"IQ31244 PCI I/O Space"
;
res
[
0
].
flags
=
IORESOURCE_IO
;
res
[
1
].
start
=
I
Q31244_PCI_MEM_BASE
;
res
[
1
].
end
=
I
Q31244_PCI_MEM_BASE
+
IQ31244_PCI_MEM_SIZE
;
res
[
1
].
start
=
I
OP321_PCI_LOWER_MEM_BA
+
IOP321_PCI_MEM_OFFSET
;
res
[
1
].
end
=
I
OP321_PCI_UPPER_MEM_BA
+
IOP321_PCI_MEM_OFFSET
;
res
[
1
].
name
=
"IQ31244 PCI Memory Space"
;
res
[
1
].
flags
=
IORESOURCE_MEM
;
request_resource
(
&
ioport_resource
,
&
res
[
0
]);
request_resource
(
&
iomem_resource
,
&
res
[
1
]);
sys
->
mem_offset
=
IOP321_PCI_MEM_OFFSET
;
sys
->
io_offset
=
IOP321_PCI_IO_OFFSET
;
sys
->
resource
[
0
]
=
&
res
[
0
];
sys
->
resource
[
1
]
=
&
res
[
1
];
sys
->
resource
[
2
]
=
NULL
;
sys
->
io_offset
=
IQ31244_PCI_IO_OFFSET
;
sys
->
mem_offset
=
IQ80321_PCI_MEM_BASE
-
(
*
IOP321_IABAR1
&
PCI_BASE_ADDRESS_MEM_MASK
);
iop3xx_pcibios_min_io
=
I
Q31244_PCI_IO_BASE
;
iop3xx_pcibios_min_mem
=
I
Q31244_PCI_MEM_BASE
;
iop3xx_pcibios_min_io
=
I
OP321_PCI_LOWER_IO_VA
;
iop3xx_pcibios_min_mem
=
I
OP321_PCI_LOWER_MEM_VA
;
return
1
;
}
...
...
@@ -106,9 +107,6 @@ static int iq31244_setup(int nr, struct pci_sys_data *sys)
static
void
iq31244_preinit
(
void
)
{
iop321_init
();
/* setting up the second translation window */
*
IOP321_OMWTVR1
=
IQ31244_PCI_MEM_BASE
+
0x04000000
;
*
IOP321_OUMWTVR1
=
0x0
;
}
static
struct
hw_pci
iq31244_pci
__initdata
=
{
...
...
arch/arm/mach-iop3xx/iq80321-pci.c
View file @
714d25d2
...
...
@@ -5,6 +5,7 @@
*
* Author: Rory Bolt <rorybolt@pacbell.net>
* Copyright (C) 2002 Rory Bolt
* Copyright (C) 2004 Intel Corp.
*
* 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
...
...
@@ -71,44 +72,28 @@ static int iq80321_setup(int nr, struct pci_sys_data *sys)
memset
(
res
,
0
,
sizeof
(
struct
resource
)
*
2
);
res
[
0
].
start
=
I
Q80321_PCI_IO_BASE
+
IQ80
321_PCI_IO_OFFSET
;
res
[
0
].
end
=
I
Q80321_PCI_IO_BASE
+
IQ80321_PCI_IO_SIZE
-
1
+
IQ80
321_PCI_IO_OFFSET
;
res
[
0
].
start
=
I
OP321_PCI_LOWER_IO_BA
+
IOP
321_PCI_IO_OFFSET
;
res
[
0
].
end
=
I
OP321_PCI_UPPER_IO_BA
+
IOP
321_PCI_IO_OFFSET
;
res
[
0
].
name
=
"IQ80321 PCI I/O Space"
;
res
[
0
].
flags
=
IORESOURCE_IO
;
res
[
1
].
start
=
I
Q80321_PCI_MEM_BASE
;
res
[
1
].
end
=
I
Q80321_PCI_MEM_BASE
+
IQ80321_PCI_MEM_SIZE
;
res
[
1
].
start
=
I
OP321_PCI_LOWER_MEM_BA
+
IOP321_PCI_MEM_OFFSET
;
res
[
1
].
end
=
I
OP321_PCI_UPPER_MEM_BA
+
IOP321_PCI_MEM_OFFSET
;
res
[
1
].
name
=
"IQ80321 PCI Memory Space"
;
res
[
1
].
flags
=
IORESOURCE_MEM
;
request_resource
(
&
ioport_resource
,
&
res
[
0
]);
request_resource
(
&
iomem_resource
,
&
res
[
1
]);
/*
* Since the IQ80321 is a slave card on a PCI backplane,
* it uses BAR1 to reserve a portion of PCI memory space for
* use with the private devices on the secondary bus
* (GigE and PCI-X slot). We read BAR1 and configure
* our outbound translation windows to target that
* address range and assign all devices in that
* address range. W/O this, certain BIOSes will fail
* to boot as the IQ80321 claims addresses that are
* in use by other devices.
*
* Note that the same cannot be done with I/O space,
* so hopefully the host will stick to the lower 64K for
* PCI I/O and leave us alone.
*/
sys
->
mem_offset
=
IQ80321_PCI_MEM_BASE
-
(
*
IOP321_IABAR1
&
PCI_BASE_ADDRESS_MEM_MASK
);
sys
->
mem_offset
=
IOP321_PCI_MEM_OFFSET
;
sys
->
io_offset
=
IOP321_PCI_IO_OFFSET
;
sys
->
resource
[
0
]
=
&
res
[
0
];
sys
->
resource
[
1
]
=
&
res
[
1
];
sys
->
resource
[
2
]
=
NULL
;
sys
->
io_offset
=
IQ80321_PCI_IO_OFFSET
;
iop3xx_pcibios_min_io
=
I
Q80321_PCI_IO_BASE
;
iop3xx_pcibios_min_mem
=
I
Q80321_PCI_MEM_BASE
;
iop3xx_pcibios_min_io
=
I
OP321_PCI_LOWER_IO_VA
;
iop3xx_pcibios_min_mem
=
I
OP321_PCI_LOWER_MEM_VA
;
return
1
;
}
...
...
arch/arm/mach-iop3xx/iq80332-mm.c
0 → 100644
View file @
714d25d2
/*
* linux/arch/arm/mach-iop3xx/mm.c
*
* Low level memory initialization for iq80332 platform
*
* Author: Dave Jiang <dave.jiang@intel.com>
* Copyright (C) 2004 Intel Corp.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2 of the License, or (at your
* option) any later version.
*
*/
#include <linux/mm.h>
#include <linux/init.h>
#include <asm/io.h>
#include <asm/pgtable.h>
#include <asm/page.h>
#include <asm/mach/map.h>
#include <asm/mach-types.h>
/*
* IQ80332 specific IO mappings
*
* We use RedBoot's setup for the onboard devices.
*/
void
__init
iq80332_map_io
(
void
)
{
iop331_map_io
();
}
arch/arm/mach-iop3xx/iq80332-pci.c
0 → 100644
View file @
714d25d2
/*
* arch/arm/mach-iop3xx/iq80332-pci.c
*
* PCI support for the Intel IQ80332 reference board
*
* Author: Dave Jiang <dave.jiang@intel.com>
* Copyright (C) 2004 Intel Corp.
*
* 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/kernel.h>
#include <linux/pci.h>
#include <linux/init.h>
#include <asm/hardware.h>
#include <asm/irq.h>
#include <asm/mach/pci.h>
#include <asm/mach-types.h>
/*
* The following macro is used to lookup irqs in a standard table
* format for those systems that do not already have PCI
* interrupts properly routed. We assume 1 <= pin <= 4
*/
#define PCI_IRQ_TABLE_LOOKUP(minid,maxid) \
({ int _ctl_ = -1; \
unsigned int _idsel = idsel - minid; \
if (_idsel <= maxid) \
_ctl_ = pci_irq_table[_idsel][pin-1]; \
_ctl_; })
#define INTA IRQ_IQ80332_INTA
#define INTB IRQ_IQ80332_INTB
#define INTC IRQ_IQ80332_INTC
#define INTD IRQ_IQ80332_INTD
//#define INTE IRQ_IQ80332_I82544
static
inline
int
__init
iq80332_map_irq
(
struct
pci_dev
*
dev
,
u8
idsel
,
u8
pin
)
{
static
int
pci_irq_table
[][
8
]
=
{
/*
* PCI IDSEL/INTPIN->INTLINE
* A B C D
*/
{
-
1
,
-
1
,
-
1
,
-
1
},
{
-
1
,
-
1
,
-
1
,
-
1
},
{
-
1
,
-
1
,
-
1
,
-
1
},
{
INTA
,
INTB
,
INTC
,
INTD
},
/* PCI-X Slot */
{
-
1
,
-
1
,
-
1
,
-
1
},
{
INTC
,
INTC
,
INTC
,
INTC
},
/* GigE */
{
-
1
,
-
1
,
-
1
,
-
1
},
{
-
1
,
-
1
,
-
1
,
-
1
},
};
BUG_ON
(
pin
<
1
||
pin
>
4
);
return
PCI_IRQ_TABLE_LOOKUP
(
1
,
7
);
}
static
int
iq80332_setup
(
int
nr
,
struct
pci_sys_data
*
sys
)
{
struct
resource
*
res
;
if
(
nr
!=
0
)
return
0
;
res
=
kmalloc
(
sizeof
(
struct
resource
)
*
2
,
GFP_KERNEL
);
if
(
!
res
)
panic
(
"PCI: unable to alloc resources"
);
memset
(
res
,
0
,
sizeof
(
struct
resource
)
*
2
);
res
[
0
].
start
=
IOP331_PCI_LOWER_IO_BA
+
IOP331_PCI_IO_OFFSET
;
res
[
0
].
end
=
IOP331_PCI_UPPER_IO_BA
+
IOP331_PCI_IO_OFFSET
;
res
[
0
].
name
=
"IQ80332 PCI I/O Space"
;
res
[
0
].
flags
=
IORESOURCE_IO
;
res
[
1
].
start
=
IOP331_PCI_LOWER_MEM_BA
+
IOP331_PCI_MEM_OFFSET
;
res
[
1
].
end
=
IOP331_PCI_UPPER_MEM_BA
+
IOP331_PCI_MEM_OFFSET
;
res
[
1
].
name
=
"IQ80332 PCI Memory Space"
;
res
[
1
].
flags
=
IORESOURCE_MEM
;
request_resource
(
&
ioport_resource
,
&
res
[
0
]);
request_resource
(
&
iomem_resource
,
&
res
[
1
]);
sys
->
mem_offset
=
IOP331_PCI_MEM_OFFSET
;
sys
->
io_offset
=
IOP331_PCI_IO_OFFSET
;
sys
->
resource
[
0
]
=
&
res
[
0
];
sys
->
resource
[
1
]
=
&
res
[
1
];
sys
->
resource
[
2
]
=
NULL
;
iop3xx_pcibios_min_io
=
IOP331_PCI_LOWER_IO_VA
;
iop3xx_pcibios_min_mem
=
IOP331_PCI_LOWER_MEM_VA
;
return
1
;
}
static
void
iq80332_preinit
(
void
)
{
iop331_init
();
}
static
struct
hw_pci
iq80332_pci
__initdata
=
{
.
swizzle
=
pci_std_swizzle
,
.
nr_controllers
=
1
,
.
setup
=
iq80332_setup
,
.
scan
=
iop331_scan_bus
,
.
preinit
=
iq80332_preinit
,
.
map_irq
=
iq80332_map_irq
};
static
int
__init
iq80332_pci_init
(
void
)
{
if
(
machine_is_iq80332
())
pci_common_init
(
&
iq80332_pci
);
return
0
;
}
subsys_initcall
(
iq80332_pci_init
);
arch/arm/mach-ixp4xx/common.c
View file @
714d25d2
...
...
@@ -279,3 +279,40 @@ struct sys_timer ixp4xx_timer = {
.
init
=
ixp4xx_timer_init
,
.
offset
=
ixp4xx_gettimeoffset
,
};
static
struct
resource
ixp46x_i2c_resources
[]
=
{
[
0
]
=
{
.
start
=
0xc8011000
,
.
end
=
0xc801101c
,
.
flags
=
IORESOURCE_MEM
,
},
[
1
]
=
{
.
start
=
IRQ_IXP4XX_I2C
,
.
end
=
IRQ_IXP4XX_I2C
,
.
flags
=
IORESOURCE_IRQ
}
};
/*
* I2C controller. The IXP46x uses the same block as the IOP3xx, so
* we just use the same device name.
*/
static
struct
platform_device
ixp46x_i2c_controller
=
{
.
name
=
"IOP3xx-I2C"
,
.
id
=
0
,
.
num_resources
=
2
,
.
resource
=
&
ixp46x_i2c_resources
};
static
struct
platform_device
*
ixp46x_devices
[]
__initdata
=
{
&
ixp46x_i2c_controller
};
void
__init
ixp4xx_sys_init
(
void
)
{
if
(
cpu_is_ixp46x
())
{
platform_add_devices
(
ixp46x_devices
,
ARRAY_SIZE
(
ixp46x_devices
));
}
}
arch/arm/mach-ixp4xx/coyote-setup.c
View file @
714d25d2
...
...
@@ -89,7 +89,8 @@ static void __init coyote_init(void)
*
IXP4XX_EXP_CS0
|=
IXP4XX_FLASH_WRITABLE
;
*
IXP4XX_EXP_CS1
=
*
IXP4XX_EXP_CS0
;
platform_add_devices
(
&
coyote_devices
,
ARRAY_SIZE
(
coyote_devices
));
ixp4xx_sys_init
();
platform_add_devices
(
coyote_devices
,
ARRAY_SIZE
(
coyote_devices
));
}
#ifdef CONFIG_ARCH_ADI_COYOTE
...
...
arch/arm/mach-ixp4xx/ixdp425-setup.c
View file @
714d25d2
...
...
@@ -108,6 +108,8 @@ static struct platform_device *ixdp425_devices[] __initdata = {
static
void
__init
ixdp425_init
(
void
)
{
ixp4xx_sys_init
();
/*
* IXP465 has 32MB window
*/
...
...
@@ -115,7 +117,7 @@ static void __init ixdp425_init(void)
ixdp425_flash_resource
.
end
+=
IXDP425_FLASH_SIZE
;
}
platform_add_devices
(
&
ixdp425_devices
,
ARRAY_SIZE
(
ixdp425_devices
));
platform_add_devices
(
ixdp425_devices
,
ARRAY_SIZE
(
ixdp425_devices
));
}
MACHINE_START
(
IXDP425
,
"Intel IXDP425 Development Platform"
)
...
...
arch/arm/mach-ixp4xx/prpmc1100-setup.c
View file @
714d25d2
...
...
@@ -79,7 +79,9 @@ static struct platform_device *prpmc1100_devices[] __initdata = {
static
void
__init
prpmc1100_init
(
void
)
{
platform_add_devices
(
&
prpmc1100_devices
,
ARRAY_SIZE
(
prpmc1100_devices
));
ixp4xx_sys_init
();
platform_add_devices
(
prpmc1100_devices
,
ARRAY_SIZE
(
prpmc1100_devices
));
}
MACHINE_START
(
PRPMC1100
,
"Motorola PrPMC1100"
)
...
...
arch/arm/mm/proc-xscale.S
View file @
714d25d2
...
...
@@ -754,8 +754,8 @@ __8032x_proc_info:
.
type
__8033x_proc_info
,#
object
__8033x_proc_info
:
.
long
0x690540
9
0
.
long
0xffffff
b
0
.
long
0x690540
1
0
.
long
0xffffff
3
0
.
long
PMD_TYPE_SECT
|
\
PMD_SECT_BUFFERABLE
|
\
PMD_SECT_CACHEABLE
|
\
...
...
include/asm-arm/arch-iop3xx/entry-macro.S
View file @
714d25d2
...
...
@@ -43,16 +43,11 @@
cmp
\
irqstat
,
#
0
beq
1001
f
clz
\
irqnr
,
\
irqstat
/*
*
mov
\
base
,
#
31
*
subs
\
irqnr
,
\
base
,
\
irqnr
*/
rsbs
\
irqnr
,
\
irqnr
,#
31
@
recommend
by
RMK
add
\
irqnr
,
\
irqnr
,#
IRQ_IOP331_XINT8
b
1001
f
1002
:
clz
\
irqnr
,
\
irqstat
mov
\
base
,
#
31
subs
\
irqnr
,
\
base
,
\
irqnr
rsbs
\
irqnr
,
\
irqnr
,#
31
@
recommend
by
RMK
add
\
irqnr
,
\
irqnr
,#
IRQ_IOP331_DMA0_EOT
1001
:
.
endm
...
...
include/asm-arm/arch-iop3xx/hardware.h
View file @
714d25d2
...
...
@@ -52,5 +52,6 @@ extern unsigned int processor_id;
#include "iq80321.h"
#include "iq31244.h"
#include "iq80331.h"
#include "iq80332.h"
#endif
/* _ASM_ARCH_HARDWARE_H */
include/asm-arm/arch-iop3xx/iop321.h
View file @
714d25d2
...
...
@@ -5,6 +5,7 @@
*
* Author: Rory Bolt <rorybolt@pacbell.net>
* Copyright (C) 2002 Rory Bolt
* Copyright (C) 2004 Intel Corp.
*
* 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
...
...
@@ -30,21 +31,30 @@
/*
* IOP321 I/O and Mem space regions for PCI autoconfiguration
*/
#define IOP321_PCI_LOWER_IO 0x90000000
#define IOP321_PCI_UPPER_IO 0x9000ffff
#define IOP321_PCI_LOWER_MEM 0x80000000
#define IOP321_PCI_UPPER_MEM 0x83ffffff
#define IOP321_PCI_WINDOW_SIZE 64 * 0x100000
#define IOP321_PCI_IO_WINDOW_SIZE 0x10000
#define IOP321_PCI_LOWER_IO_PA 0x90000000
#define IOP321_PCI_LOWER_IO_VA 0xfe000000
#define IOP321_PCI_LOWER_IO_BA (*IOP321_OIOWTVR)
#define IOP321_PCI_UPPER_IO_PA (IOP321_PCI_LOWER_IO_PA + IOP321_PCI_IO_WINDOW_SIZE - 1)
#define IOP321_PCI_UPPER_IO_VA (IOP321_PCI_LOWER_IO_VA + IOP321_PCI_IO_WINDOW_SIZE - 1)
#define IOP321_PCI_UPPER_IO_BA (IOP321_PCI_LOWER_IO_BA + IOP321_PCI_IO_WINDOW_SIZE - 1)
#define IOP321_PCI_IO_OFFSET (IOP321_PCI_LOWER_IO_VA - IOP321_PCI_LOWER_IO_BA)
#define IOP321_PCI_MEM_WINDOW_SIZE (~*IOP321_IALR1 + 1)
#define IOP321_PCI_LOWER_MEM_PA 0x80000000
#define IOP321_PCI_LOWER_MEM_VA 0x80000000
#define IOP321_PCI_LOWER_MEM_BA (*IOP321_OMWTVR0)
#define IOP321_PCI_UPPER_MEM_PA (IOP321_PCI_LOWER_MEM_PA + IOP321_PCI_MEM_WINDOW_SIZE - 1)
#define IOP321_PCI_UPPER_MEM_VA (IOP321_PCI_LOWER_MEM_VA + IOP321_PCI_MEM_WINDOW_SIZE - 1)
#define IOP321_PCI_UPPER_MEM_BA (IOP321_PCI_LOWER_MEM_BA + IOP321_PCI_MEM_WINDOW_SIZE - 1)
#define IOP321_PCI_MEM_OFFSET (IOP321_PCI_LOWER_MEM_VA - IOP321_PCI_LOWER_MEM_BA)
/*
* IOP321 chipset registers
*/
#define IOP321_VIRT_MEM_BASE 0xfeffe000
/* chip virtual mem address*/
//#define IOP321_VIRT_MEM_BASE 0xfff00000 /* chip virtual mem address*/
#define IOP321_PHY_MEM_BASE 0xffffe000
/* chip physical memory address */
#define IOP321_PHYS_MEM_BASE 0xffffe000
/* chip physical memory address */
#define IOP321_REG_ADDR(reg) (IOP321_VIRT_MEM_BASE | (reg))
/* Reserved 0x00000000 through 0x000000FF */
...
...
include/asm-arm/arch-iop3xx/iop331-irqs.h
View file @
714d25d2
...
...
@@ -91,6 +91,7 @@
#define NR_IRQS NR_IOP331_IRQS
#if defined(CONFIG_ARCH_IQ80331)
/*
* Interrupts available on the IQ80331 board
*/
...
...
@@ -110,4 +111,26 @@
#define IRQ_IQ80331_INTC IRQ_IOP331_XINT2
#define IRQ_IQ80331_INTD IRQ_IOP331_XINT3
#elif defined(CONFIG_MACH_IQ80332)
/*
* Interrupts available on the IQ80332 board
*/
/*
* On board devices
*/
#define IRQ_IQ80332_I82544 IRQ_IOP331_XINT0
#define IRQ_IQ80332_UART0 IRQ_IOP331_UART0
#define IRQ_IQ80332_UART1 IRQ_IOP331_UART1
/*
* PCI interrupts
*/
#define IRQ_IQ80332_INTA IRQ_IOP331_XINT0
#define IRQ_IQ80332_INTB IRQ_IOP331_XINT1
#define IRQ_IQ80332_INTC IRQ_IOP331_XINT2
#define IRQ_IQ80332_INTD IRQ_IOP331_XINT3
#endif
#endif // _IOP331_IRQ_H_
include/asm-arm/arch-iop3xx/iq31244.h
View file @
714d25d2
...
...
@@ -7,8 +7,6 @@
#ifndef _IQ31244_H_
#define _IQ31244_H_
#define IQ31244_RAMBASE 0xa0000000
#define IQ31244_FLASHBASE 0xf0000000
/* Flash */
#define IQ31244_FLASHSIZE 0x00800000
#define IQ31244_FLASHWIDTH 2
...
...
@@ -19,16 +17,6 @@
#define IQ31244_ROTARY_SW 0xfe8d0000
/* Rotary Switch */
#define IQ31244_BATT_STAT 0xfe8f0000
/* Battery Status */
/*
* IQ31244 PCI I/O and Mem space regions
*/
#define IQ31244_PCI_IO_BASE 0x90000000
#define IQ31244_PCI_IO_SIZE 0x00010000
#define IQ31244_PCI_MEM_BASE 0x80000000
//#define IQ31244_PCI_MEM_SIZE 0x04000000
#define IQ31244_PCI_MEM_SIZE 0x08000000
#define IQ31244_PCI_IO_OFFSET 0x6e000000
#ifndef __ASSEMBLY__
extern
void
iq31244_map_io
(
void
);
#endif
...
...
include/asm-arm/arch-iop3xx/iq80321.h
View file @
714d25d2
...
...
@@ -7,8 +7,6 @@
#ifndef _IQ80321_H_
#define _IQ80321_H_
#define IQ80321_RAMBASE 0xa0000000
#define IQ80321_FLASHBASE 0xf0000000
/* Flash */
#define IQ80321_FLASHSIZE 0x00800000
#define IQ80321_FLASHWIDTH 1
...
...
@@ -19,15 +17,6 @@
#define IQ80321_ROTARY_SW 0xfe8d0000
/* Rotary Switch */
#define IQ80321_BATT_STAT 0xfe8f0000
/* Battery Status */
/*
* IQ80321 PCI I/O and Mem space regions
*/
#define IQ80321_PCI_IO_BASE 0x90000000
#define IQ80321_PCI_IO_SIZE 0x00010000
#define IQ80321_PCI_MEM_BASE 0x80000000
#define IQ80321_PCI_MEM_SIZE 0x04000000
#define IQ80321_PCI_IO_OFFSET 0x6e000000
#ifndef __ASSEMBLY__
extern
void
iq80321_map_io
(
void
);
#endif
...
...
include/asm-arm/arch-iop3xx/iq80332.h
0 → 100644
View file @
714d25d2
/*
* linux/include/asm/arch-iop3xx/iq80332.h
*
* Intel IQ80332 evaluation board registers
*/
#ifndef _IQ80332_H_
#define _IQ80332_H_
#define IQ80332_FLASHBASE 0xc0000000
/* Flash */
#define IQ80332_FLASHSIZE 0x00800000
#define IQ80332_FLASHWIDTH 1
#define IQ80332_7SEG_1 0xce840000
/* 7-Segment MSB */
#define IQ80332_7SEG_0 0xce850000
/* 7-Segment LSB (WO) */
#define IQ80332_ROTARY_SW 0xce8d0000
/* Rotary Switch */
#define IQ80332_BATT_STAT 0xce8f0000
/* Battery Status */
#ifndef __ASSEMBLY__
extern
void
iq80332_map_io
(
void
);
#endif
#endif // _IQ80332_H_
include/asm-arm/arch-iop3xx/timex.h
View file @
714d25d2
...
...
@@ -10,7 +10,7 @@
#define CLOCK_TICK_RATE IOP321_TICK_RATE
#elif defined(CONFIG_ARCH_IQ80331)
#elif defined(CONFIG_ARCH_IQ80331)
|| defined(CONFIG_MACH_IQ80332)
#define CLOCK_TICK_RATE IOP331_TICK_RATE
...
...
include/asm-arm/arch-iop3xx/uncompress.h
View file @
714d25d2
...
...
@@ -9,8 +9,10 @@
#ifdef CONFIG_ARCH_IOP321
#define UTYPE unsigned char *
#el
se
#el
if defined(CONFIG_ARCH_IOP331)
#define UTYPE u32 *
#else
#error "Missing IOP3xx arch type def"
#endif
static
volatile
UTYPE
uart_base
;
...
...
@@ -42,8 +44,8 @@ static __inline__ void __arch_decomp_setup(unsigned long arch_id)
uart_base
=
(
volatile
UTYPE
)
IQ80321_UART
;
else
if
(
machine_is_iq31244
())
uart_base
=
(
volatile
UTYPE
)
IQ31244_UART
;
else
if
(
machine_is_iq80331
())
uart_base
=
(
volatile
UTYPE
)
I
Q80
331_UART0_PHYS
;
else
if
(
machine_is_iq80331
()
||
machine_is_iq80332
()
)
uart_base
=
(
volatile
UTYPE
)
I
OP
331_UART0_PHYS
;
else
uart_base
=
(
volatile
UTYPE
)
0xfe800000
;
}
...
...
include/asm-arm/arch-ixp4xx/irqs.h
View file @
714d25d2
...
...
@@ -48,14 +48,6 @@
#define IRQ_IXP4XX_GPIO12 29
#define IRQ_IXP4XX_SW_INT1 30
#define IRQ_IXP4XX_SW_INT2 31
#ifndef CONFIG_CPU_IXP46X
#define NR_IRQS 32
#else
/*
* IXP465 adds new sources
*/
#define IRQ_IXP4XX_USB_HOST 32
#define IRQ_IXP4XX_I2C 33
#define IRQ_IXP4XX_SSP 34
...
...
@@ -67,6 +59,12 @@
#define IRQ_IXP4XX_MCU_ECC 61
#define IRQ_IXP4XX_EXP_PE 62
/*
* Only first 32 sources are valid if running on IXP42x systems
*/
#ifndef CONFIG_CPU_IXP46X
#define NR_IRQS 32
#else
#define NR_IRQS 64
#endif
...
...
include/asm-arm/arch-ixp4xx/platform.h
View file @
714d25d2
...
...
@@ -60,6 +60,7 @@ struct sys_timer;
*/
extern
void
ixp4xx_map_io
(
void
);
extern
void
ixp4xx_init_irq
(
void
);
extern
void
ixp4xx_sys_init
(
void
);
extern
struct
sys_timer
ixp4xx_timer
;
extern
void
ixp4xx_pci_preinit
(
void
);
struct
pci_sys_data
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment