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
b1999b0e
Commit
b1999b0e
authored
Jun 21, 2004
by
David Woodhouse
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add support for MPC8560 CPU and WindRiver PowerQUICC III SBC8560
Signed-off-by:
Kumar Gala
<
kumar.gala@freescale.com
>
parent
9a85e04e
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
685 additions
and
2 deletions
+685
-2
arch/ppc/platforms/85xx/Kconfig
arch/ppc/platforms/85xx/Kconfig
+12
-1
arch/ppc/platforms/85xx/Makefile
arch/ppc/platforms/85xx/Makefile
+2
-0
arch/ppc/platforms/85xx/mpc8560.c
arch/ppc/platforms/85xx/mpc8560.c
+74
-0
arch/ppc/platforms/85xx/sbc8560.c
arch/ppc/platforms/85xx/sbc8560.c
+269
-0
arch/ppc/platforms/85xx/sbc8560.h
arch/ppc/platforms/85xx/sbc8560.h
+48
-0
arch/ppc/platforms/85xx/sbc85xx.c
arch/ppc/platforms/85xx/sbc85xx.c
+215
-0
arch/ppc/platforms/85xx/sbc85xx.h
arch/ppc/platforms/85xx/sbc85xx.h
+57
-0
arch/ppc/syslib/ppc85xx_setup.c
arch/ppc/syslib/ppc85xx_setup.c
+2
-0
arch/ppc/syslib/ppc85xx_setup.h
arch/ppc/syslib/ppc85xx_setup.h
+3
-1
include/asm-ppc/mpc85xx.h
include/asm-ppc/mpc85xx.h
+3
-0
No files found.
arch/ppc/platforms/85xx/Kconfig
View file @
b1999b0e
...
...
@@ -21,6 +21,12 @@ config MPC8540_ADS
help
This option enables support for the MPC 8540 ADS evaluation board.
config SBC8560
bool "WindRiver PowerQUICC III SBC8560"
help
This option enables support for the WindRiver PowerQUICC III
SBC8560 board.
endchoice
# It's often necessary to know the specific 85xx processor type.
...
...
@@ -31,6 +37,11 @@ config MPC8540
depends on MPC8540_ADS
default y
config MPC8560
bool
depends on SBC8560
default y
config FSL_OCP
bool
depends on 85xx
...
...
@@ -38,7 +49,7 @@ config FSL_OCP
config PPC_GEN550
bool
depends on MPC8540
depends on MPC8540
|| SBC8560
default y
endmenu
arch/ppc/platforms/85xx/Makefile
View file @
b1999b0e
...
...
@@ -3,5 +3,7 @@
#
obj-$(CONFIG_MPC8540_ADS)
+=
mpc85xx_ads_common.o mpc8540_ads.o
obj-$(CONFIG_SBC8560)
+=
sbc85xx.o sbc8560.o
obj-$(CONFIG_MPC8540)
+=
mpc8540.o
obj-$(CONFIG_MPC8560)
+=
mpc8560.o
arch/ppc/platforms/85xx/mpc8560.c
0 → 100644
View file @
b1999b0e
/*
* arch/ppc/platforms/85xx/mpc8560.c
*
* MPC8560 I/O descriptions
*
* Maintainer: Kumar Gala <kumar.gala@freescale.com>
*
* Copyright 2004 Freescale Semiconductor Inc.
*
* 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/init.h>
#include <linux/module.h>
#include <asm/mpc85xx.h>
#include <asm/ocp.h>
/* These should be defined in platform code */
extern
struct
ocp_gfar_data
mpc85xx_tsec1_def
;
extern
struct
ocp_gfar_data
mpc85xx_tsec2_def
;
extern
struct
ocp_mpc_i2c_data
mpc85xx_i2c1_def
;
/* We use offsets for paddr since we do not know at compile time
* what CCSRBAR is, platform code should fix this up in
* setup_arch
*
* Only the first IRQ is given even if a device has
* multiple lines associated with ita
*/
struct
ocp_def
core_ocp
[]
=
{
{
.
vendor
=
OCP_VENDOR_FREESCALE
,
.
function
=
OCP_FUNC_IIC
,
.
index
=
0
,
.
paddr
=
MPC85xx_IIC1_OFFSET
,
.
irq
=
MPC85xx_IRQ_IIC1
,
.
pm
=
OCP_CPM_NA
,
.
additions
=
&
mpc85xx_i2c1_def
,
},
{
.
vendor
=
OCP_VENDOR_FREESCALE
,
.
function
=
OCP_FUNC_GFAR
,
.
index
=
0
,
.
paddr
=
MPC85xx_ENET1_OFFSET
,
.
irq
=
MPC85xx_IRQ_TSEC1_TX
,
.
pm
=
OCP_CPM_NA
,
.
additions
=
&
mpc85xx_tsec1_def
,
},
{
.
vendor
=
OCP_VENDOR_FREESCALE
,
.
function
=
OCP_FUNC_GFAR
,
.
index
=
1
,
.
paddr
=
MPC85xx_ENET2_OFFSET
,
.
irq
=
MPC85xx_IRQ_TSEC2_TX
,
.
pm
=
OCP_CPM_NA
,
.
additions
=
&
mpc85xx_tsec2_def
,
},
{
.
vendor
=
OCP_VENDOR_FREESCALE
,
.
function
=
OCP_FUNC_DMA
,
.
index
=
0
,
.
paddr
=
MPC85xx_DMA_OFFSET
,
.
irq
=
MPC85xx_IRQ_DMA0
,
.
pm
=
OCP_CPM_NA
,
},
{
.
vendor
=
OCP_VENDOR_FREESCALE
,
.
function
=
OCP_FUNC_PERFMON
,
.
index
=
0
,
.
paddr
=
MPC85xx_PERFMON_OFFSET
,
.
irq
=
MPC85xx_IRQ_PERFMON
,
.
pm
=
OCP_CPM_NA
,
},
{
.
vendor
=
OCP_VENDOR_INVALID
}
};
arch/ppc/platforms/85xx/sbc8560.c
0 → 100644
View file @
b1999b0e
/*
* arch/ppc/platforms/85xx/sbc8560.c
*
* Wind River SBC8560 board specific routines
*
* Maintainer: Kumar Gala <kumar.gala@freescale.com>
*
* Copyright 2004 Freescale Semiconductor Inc.
*
* 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/config.h>
#include <linux/stddef.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/errno.h>
#include <linux/reboot.h>
#include <linux/pci.h>
#include <linux/kdev_t.h>
#include <linux/major.h>
#include <linux/console.h>
#include <linux/delay.h>
#include <linux/irq.h>
#include <linux/seq_file.h>
#include <linux/root_dev.h>
#include <linux/serial.h>
#include <linux/tty.h>
/* for linux/serial_core.h */
#include <linux/serial_core.h>
#include <linux/module.h>
#include <asm/system.h>
#include <asm/pgtable.h>
#include <asm/page.h>
#include <asm/atomic.h>
#include <asm/time.h>
#include <asm/io.h>
#include <asm/machdep.h>
#include <asm/prom.h>
#include <asm/open_pic.h>
#include <asm/bootinfo.h>
#include <asm/pci-bridge.h>
#include <asm/mpc85xx.h>
#include <asm/irq.h>
#include <asm/immap_85xx.h>
#include <asm/kgdb.h>
#include <asm/ocp.h>
#include <mm/mmu_decl.h>
#include <syslib/ppc85xx_common.h>
#include <syslib/ppc85xx_setup.h>
struct
ocp_gfar_data
mpc85xx_tsec1_def
=
{
.
interruptTransmit
=
MPC85xx_IRQ_TSEC1_TX
,
.
interruptError
=
MPC85xx_IRQ_TSEC1_ERROR
,
.
interruptReceive
=
MPC85xx_IRQ_TSEC1_RX
,
.
interruptPHY
=
MPC85xx_IRQ_EXT6
,
.
flags
=
(
GFAR_HAS_GIGABIT
|
GFAR_HAS_MULTI_INTR
|
GFAR_HAS_PHY_INTR
),
.
phyid
=
25
,
.
phyregidx
=
0
,
};
struct
ocp_gfar_data
mpc85xx_tsec2_def
=
{
.
interruptTransmit
=
MPC85xx_IRQ_TSEC2_TX
,
.
interruptError
=
MPC85xx_IRQ_TSEC2_ERROR
,
.
interruptReceive
=
MPC85xx_IRQ_TSEC2_RX
,
.
interruptPHY
=
MPC85xx_IRQ_EXT7
,
.
flags
=
(
GFAR_HAS_GIGABIT
|
GFAR_HAS_MULTI_INTR
|
GFAR_HAS_PHY_INTR
),
.
phyid
=
26
,
.
phyregidx
=
0
,
};
struct
ocp_gfar_data
mpc85xx_fec_def
=
{
.
interruptTransmit
=
MPC85xx_IRQ_FEC
,
.
interruptError
=
MPC85xx_IRQ_FEC
,
.
interruptReceive
=
MPC85xx_IRQ_FEC
,
.
interruptPHY
=
MPC85xx_IRQ_EXT5
,
.
flags
=
0
,
.
phyid
=
1
,
.
phyregidx
=
0
,
};
struct
ocp_fs_i2c_data
mpc85xx_i2c1_def
=
{
.
flags
=
FS_I2C_SEPARATE_DFSRR
,
};
#ifdef CONFIG_SERIAL_8250
static
void
__init
sbc8560_early_serial_map
(
void
)
{
struct
uart_port
uart_req
;
/* Setup serial port access */
memset
(
&
uart_req
,
0
,
sizeof
(
uart_req
));
uart_req
.
irq
=
MPC85xx_IRQ_EXT9
;
uart_req
.
flags
=
STD_COM_FLAGS
;
uart_req
.
uartclk
=
BASE_BAUD
*
16
;
uart_req
.
iotype
=
SERIAL_IO_MEM
;
uart_req
.
mapbase
=
UARTA_ADDR
;
uart_req
.
membase
=
ioremap
(
uart_req
.
mapbase
,
MPC85xx_UART0_SIZE
);
#if defined(CONFIG_SERIAL_TEXT_DEBUG) || defined(CONFIG_KGDB)
gen550_init
(
0
,
&
uart_req
);
#endif
if
(
early_serial_setup
(
&
uart_req
)
!=
0
)
printk
(
"Early serial init of port 0 failed
\n
"
);
/* Assume early_serial_setup() doesn't modify uart_req */
uart_req
.
line
=
1
;
uart_req
.
mapbase
=
UARTB_ADDR
;
uart_req
.
membase
=
ioremap
(
uart_req
.
mapbase
,
MPC85xx_UART1_SIZE
);
uart_req
.
irq
=
MPC85xx_IRQ_EXT10
;
#if defined(CONFIG_SERIAL_TEXT_DEBUG) || defined(CONFIG_KGDB)
gen550_init
(
1
,
&
uart_req
);
#endif
if
(
early_serial_setup
(
&
uart_req
)
!=
0
)
printk
(
"Early serial init of port 1 failed
\n
"
);
}
#endif
/* ************************************************************************
*
* Setup the architecture
*
*/
static
void
__init
sbc8560_setup_arch
(
void
)
{
struct
ocp_def
*
def
;
struct
ocp_gfar_data
*
einfo
;
bd_t
*
binfo
=
(
bd_t
*
)
__res
;
unsigned
int
freq
;
/* get the core frequency */
freq
=
binfo
->
bi_intfreq
;
if
(
ppc_md
.
progress
)
ppc_md
.
progress
(
"sbc8560_setup_arch()"
,
0
);
/* Set loops_per_jiffy to a half-way reasonable value,
for use until calibrate_delay gets called. */
loops_per_jiffy
=
freq
/
HZ
;
#ifdef CONFIG_PCI
/* setup PCI host bridges */
mpc85xx_setup_hose
();
#endif
#ifdef CONFIG_DUMMY_CONSOLE
conswitchp
=
&
dummy_con
;
#endif
#ifdef CONFIG_SERIAL_8250
sbc8560_early_serial_map
();
#endif
#ifdef CONFIG_SERIAL_TEXT_DEBUG
/* Invalidate the entry we stole earlier the serial ports
* should be properly mapped */
invalidate_tlbcam_entry
(
NUM_TLBCAMS
-
1
);
#endif
/* Set up MAC addresses for the Ethernet devices */
def
=
ocp_get_one_device
(
OCP_VENDOR_FREESCALE
,
OCP_FUNC_GFAR
,
0
);
if
(
def
)
{
einfo
=
(
struct
ocp_gfar_data
*
)
def
->
additions
;
memcpy
(
einfo
->
mac_addr
,
binfo
->
bi_enetaddr
,
6
);
}
def
=
ocp_get_one_device
(
OCP_VENDOR_FREESCALE
,
OCP_FUNC_GFAR
,
1
);
if
(
def
)
{
einfo
=
(
struct
ocp_gfar_data
*
)
def
->
additions
;
memcpy
(
einfo
->
mac_addr
,
binfo
->
bi_enet1addr
,
6
);
}
def
=
ocp_get_one_device
(
OCP_VENDOR_FREESCALE
,
OCP_FUNC_GFAR
,
2
);
if
(
def
)
{
einfo
=
(
struct
ocp_gfar_data
*
)
def
->
additions
;
memcpy
(
einfo
->
mac_addr
,
binfo
->
bi_enet2addr
,
6
);
}
#ifdef CONFIG_BLK_DEV_INITRD
if
(
initrd_start
)
ROOT_DEV
=
Root_RAM0
;
else
#endif
#ifdef CONFIG_ROOT_NFS
ROOT_DEV
=
Root_NFS
;
#else
ROOT_DEV
=
Root_HDA1
;
#endif
ocp_for_each_device
(
mpc85xx_update_paddr_ocp
,
&
(
binfo
->
bi_immr_base
));
}
/* ************************************************************************ */
void
__init
platform_init
(
unsigned
long
r3
,
unsigned
long
r4
,
unsigned
long
r5
,
unsigned
long
r6
,
unsigned
long
r7
)
{
/* parse_bootinfo must always be called first */
parse_bootinfo
(
find_bootinfo
());
/*
* If we were passed in a board information, copy it into the
* residual data area.
*/
if
(
r3
)
{
memcpy
((
void
*
)
__res
,
(
void
*
)
(
r3
+
KERNELBASE
),
sizeof
(
bd_t
));
}
#ifdef CONFIG_SERIAL_TEXT_DEBUG
/* Use the last TLB entry to map CCSRBAR to allow access to DUART regs */
settlbcam
(
NUM_TLBCAMS
-
1
,
UARTA_ADDR
,
UARTA_ADDR
,
0x1000
,
_PAGE_IO
,
0
);
#endif
#if defined(CONFIG_BLK_DEV_INITRD)
/*
* If the init RAM disk has been configured in, and there's a valid
* starting address for it, set it up.
*/
if
(
r4
)
{
initrd_start
=
r4
+
KERNELBASE
;
initrd_end
=
r5
+
KERNELBASE
;
}
#endif
/* CONFIG_BLK_DEV_INITRD */
/* Copy the kernel command line arguments to a safe place. */
if
(
r6
)
{
*
(
char
*
)
(
r7
+
KERNELBASE
)
=
0
;
strcpy
(
cmd_line
,
(
char
*
)
(
r6
+
KERNELBASE
));
}
/* setup the PowerPC module struct */
ppc_md
.
setup_arch
=
sbc8560_setup_arch
;
ppc_md
.
show_cpuinfo
=
sbc8560_show_cpuinfo
;
ppc_md
.
init_IRQ
=
sbc8560_init_IRQ
;
ppc_md
.
get_irq
=
openpic_get_irq
;
ppc_md
.
restart
=
mpc85xx_restart
;
ppc_md
.
power_off
=
mpc85xx_power_off
;
ppc_md
.
halt
=
mpc85xx_halt
;
ppc_md
.
find_end_of_memory
=
mpc85xx_find_end_of_memory
;
ppc_md
.
time_init
=
NULL
;
ppc_md
.
set_rtc_time
=
NULL
;
ppc_md
.
get_rtc_time
=
NULL
;
ppc_md
.
calibrate_decr
=
mpc85xx_calibrate_decr
;
#if defined(CONFIG_SERIAL_8250) && defined(CONFIG_SERIAL_TEXT_DEBUG)
ppc_md
.
progress
=
gen550_progress
;
#endif
/* CONFIG_SERIAL_8250 && CONFIG_SERIAL_TEXT_DEBUG */
if
(
ppc_md
.
progress
)
ppc_md
.
progress
(
"sbc8560_init(): exit"
,
0
);
return
;
}
arch/ppc/platforms/85xx/sbc8560.h
0 → 100644
View file @
b1999b0e
/*
* arch/ppc/platforms/85xx/sbc8560.h
*
* Wind River SBC8560 board definitions
*
* Copyright 2003 Motorola Inc.
*
* 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.
*
*/
#ifndef __MACH_SBC8560_H__
#define __MACH_SBC8560_H__
#include <linux/config.h>
#include <linux/serial.h>
#include <platforms/85xx/sbc85xx.h>
#ifdef CONFIG_SERIAL_MANY_PORTS
#define RS_TABLE_SIZE 64
#else
#define RS_TABLE_SIZE 2
#endif
/* Rate for the 1.8432 Mhz clock for the onboard serial chip */
#define BASE_BAUD ( 1843200 / 16 )
#ifdef CONFIG_SERIAL_DETECT_IRQ
#define STD_COM_FLAGS (ASYNC_BOOT_AUTOCONF|ASYNC_SKIP_TEST|ASYNC_AUTO_IRQ)
#else
#define STD_COM_FLAGS (ASYNC_BOOT_AUTOCONF|ASYNC_SKIP_TEST)
#endif
#define STD_SERIAL_PORT_DFNS \
{ 0, BASE_BAUD, UARTA_ADDR, MPC85xx_IRQ_EXT9, STD_COM_FLAGS,
/* ttyS0 */
\
iomem_base: (u8 *)UARTA_ADDR, \
io_type: SERIAL_IO_MEM }, \
{ 0, BASE_BAUD, UARTB_ADDR, MPC85xx_IRQ_EXT10, STD_COM_FLAGS,
/* ttyS1 */
\
iomem_base: (u8 *)UARTB_ADDR, \
io_type: SERIAL_IO_MEM },
#define SERIAL_PORT_DFNS \
STD_SERIAL_PORT_DFNS
#endif
/* __MACH_SBC8560_H__ */
arch/ppc/platforms/85xx/sbc85xx.c
0 → 100644
View file @
b1999b0e
/*
* arch/ppc/platform/85xx/sbc85xx.c
*
* WindRiver PowerQUICC III SBC85xx board common routines
*
* Copyright 2002, 2003 Motorola Inc.
* Copyright 2004 Red Hat, Inc.
*
* 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/config.h>
#include <linux/stddef.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/errno.h>
#include <linux/reboot.h>
#include <linux/pci.h>
#include <linux/kdev_t.h>
#include <linux/major.h>
#include <linux/console.h>
#include <linux/delay.h>
#include <linux/irq.h>
#include <linux/seq_file.h>
#include <linux/serial.h>
#include <linux/module.h>
#include <asm/system.h>
#include <asm/pgtable.h>
#include <asm/page.h>
#include <asm/atomic.h>
#include <asm/time.h>
#include <asm/io.h>
#include <asm/machdep.h>
#include <asm/prom.h>
#include <asm/open_pic.h>
#include <asm/bootinfo.h>
#include <asm/pci-bridge.h>
#include <asm/mpc85xx.h>
#include <asm/irq.h>
#include <asm/immap_85xx.h>
#include <asm/ocp.h>
#include <mm/mmu_decl.h>
#include <platforms/85xx/sbc85xx.h>
unsigned
char
__res
[
sizeof
(
bd_t
)];
#ifndef CONFIG_PCI
unsigned
long
isa_io_base
=
0
;
unsigned
long
isa_mem_base
=
0
;
unsigned
long
pci_dram_offset
=
0
;
#endif
extern
unsigned
long
total_memory
;
/* in mm/init */
/* Internal interrupts are all Level Sensitive, and Positive Polarity */
static
u_char
sbc8560_openpic_initsenses
[]
__initdata
=
{
(
IRQ_POLARITY_POSITIVE
),
/* Internal 0: L2 Cache */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 1: ECM */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 2: DDR DRAM */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 3: LBIU */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 4: DMA 0 */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 5: DMA 1 */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 6: DMA 2 */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 7: DMA 3 */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 8: PCI/PCI-X */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 9: RIO Inbound Port Write Error */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 10: RIO Doorbell Inbound */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 11: RIO Outbound Message */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 12: RIO Inbound Message */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 13: TSEC 0 Transmit */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 14: TSEC 0 Receive */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 15: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 16: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 17: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 18: TSEC 0 Receive/Transmit Error */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 19: TSEC 1 Transmit */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 20: TSEC 1 Receive */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 21: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 22: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 23: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 24: TSEC 1 Receive/Transmit Error */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 25: Fast Ethernet */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 26: DUART */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 27: I2C */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 28: Performance Monitor */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 29: Unused */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 30: CPM */
(
IRQ_POLARITY_POSITIVE
),
/* Internal 31: Unused */
0x0
,
/* External 0: */
0x0
,
/* External 1: */
#if defined(CONFIG_PCI)
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_NEGATIVE
),
/* External 2: PCI slot 0 */
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_NEGATIVE
),
/* External 3: PCI slot 1 */
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_NEGATIVE
),
/* External 4: PCI slot 2 */
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_NEGATIVE
),
/* External 5: PCI slot 3 */
#else
0x0
,
/* External 2: */
0x0
,
/* External 3: */
0x0
,
/* External 4: */
0x0
,
/* External 5: */
#endif
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_NEGATIVE
),
/* External 6: PHY */
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_NEGATIVE
),
/* External 7: PHY */
0x0
,
/* External 8: */
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_POSITIVE
),
/* External 9: PHY */
(
IRQ_SENSE_LEVEL
|
IRQ_POLARITY_POSITIVE
),
/* External 10: PHY */
0x0
,
/* External 11: */
};
/* ************************************************************************ */
int
sbc8560_show_cpuinfo
(
struct
seq_file
*
m
)
{
uint
pvid
,
svid
,
phid1
;
uint
memsize
=
total_memory
;
bd_t
*
binfo
=
(
bd_t
*
)
__res
;
unsigned
int
freq
;
/* get the core frequency */
freq
=
binfo
->
bi_intfreq
;
pvid
=
mfspr
(
PVR
);
svid
=
mfspr
(
SVR
);
seq_printf
(
m
,
"Vendor
\t\t
: Wind River
\n
"
);
switch
(
svid
&
0xffff0000
)
{
case
SVR_8540
:
seq_printf
(
m
,
"Machine
\t\t
: hhmmm, this board isn't made yet!
\n
"
);
break
;
case
SVR_8560
:
seq_printf
(
m
,
"Machine
\t\t
: SBC8560
\n
"
);
break
;
default:
seq_printf
(
m
,
"Machine
\t\t
: unknown
\n
"
);
break
;
}
seq_printf
(
m
,
"bus freq
\t
: %u.%.6u MHz
\n
"
,
freq
/
1000000
,
freq
%
1000000
);
seq_printf
(
m
,
"PVR
\t\t
: 0x%x
\n
"
,
pvid
);
seq_printf
(
m
,
"SVR
\t\t
: 0x%x
\n
"
,
svid
);
/* Display cpu Pll setting */
phid1
=
mfspr
(
HID1
);
seq_printf
(
m
,
"PLL setting
\t
: 0x%x
\n
"
,
((
phid1
>>
24
)
&
0x3f
));
/* Display the amount of memory */
seq_printf
(
m
,
"Memory
\t\t
: %d MB
\n
"
,
memsize
/
(
1024
*
1024
));
return
0
;
}
void
__init
sbc8560_init_IRQ
(
void
)
{
bd_t
*
binfo
=
(
bd_t
*
)
__res
;
/* Determine the Physical Address of the OpenPIC regs */
phys_addr_t
OpenPIC_PAddr
=
binfo
->
bi_immr_base
+
MPC85xx_OPENPIC_OFFSET
;
OpenPIC_Addr
=
ioremap
(
OpenPIC_PAddr
,
MPC85xx_OPENPIC_SIZE
);
OpenPIC_InitSenses
=
sbc8560_openpic_initsenses
;
OpenPIC_NumInitSenses
=
sizeof
(
sbc8560_openpic_initsenses
);
/* Skip reserved space and internal sources */
openpic_set_sources
(
0
,
32
,
OpenPIC_Addr
+
0x10200
);
/* Map PIC IRQs 0-11 */
openpic_set_sources
(
32
,
12
,
OpenPIC_Addr
+
0x10000
);
/* we let openpic interrupts starting from an offset, to
* leave space for cascading interrupts underneath.
*/
openpic_init
(
MPC85xx_OPENPIC_IRQ_OFFSET
);
return
;
}
/*
* interrupt routing
*/
#ifdef CONFIG_PCI
int
mpc85xx_map_irq
(
struct
pci_dev
*
dev
,
unsigned
char
idsel
,
unsigned
char
pin
)
{
static
char
pci_irq_table
[][
4
]
=
/*
* PCI IDSEL/INTPIN->INTLINE
* A B C D
*/
{
{
PIRQA
,
PIRQB
,
PIRQC
,
PIRQD
},
{
PIRQD
,
PIRQA
,
PIRQB
,
PIRQC
},
{
PIRQC
,
PIRQD
,
PIRQA
,
PIRQB
},
{
PIRQB
,
PIRQC
,
PIRQD
,
PIRQA
},
};
const
long
min_idsel
=
12
,
max_idsel
=
15
,
irqs_per_slot
=
4
;
return
PCI_IRQ_TABLE_LOOKUP
;
}
int
mpc85xx_exclude_device
(
u_char
bus
,
u_char
devfn
)
{
if
(
bus
==
0
&&
PCI_SLOT
(
devfn
)
==
0
)
return
PCIBIOS_DEVICE_NOT_FOUND
;
else
return
PCIBIOS_SUCCESSFUL
;
}
#endif
/* CONFIG_PCI */
arch/ppc/platforms/85xx/sbc85xx.h
0 → 100644
View file @
b1999b0e
/*
* arch/ppc/platforms/85xx/sbc85xx.h
*
* WindRiver PowerQUICC III SBC85xx common board definitions
*
* Copyright 2003 Motorola Inc.
* Copyright 2004 Red Hat, Inc.
*
* 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.
*
*/
#ifndef __PLATFORMS_85XX_SBC85XX_H__
#define __PLATFORMS_85XX_SBC85XX_H__
#include <linux/config.h>
#include <linux/init.h>
#include <linux/seq_file.h>
#include <asm/ppcboot.h>
struct
pci_dev
;
#define BOARD_CCSRBAR ((uint)0xff700000)
#define CCSRBAR_SIZE ((uint)1024*1024)
#define BCSR_ADDR ((uint)0xfc000000)
#define BCSR_SIZE ((uint)(16 * 1024 * 1024))
#define UARTA_ADDR (BCSR_ADDR + 0x00700000)
#define UARTB_ADDR (BCSR_ADDR + 0x00800000)
#define RTC_DEVICE_ADDR (BCSR_ADDR + 0x00900000)
#define EEPROM_ADDR (BCSR_ADDR + 0x00b00000)
extern
int
sbc8560_show_cpuinfo
(
struct
seq_file
*
m
);
extern
void
sbc8560_init_IRQ
(
void
)
__init
;
/* PCI interrupt controller */
#define PIRQA MPC85xx_IRQ_EXT1
#define PIRQB MPC85xx_IRQ_EXT2
#define PIRQC MPC85xx_IRQ_EXT3
#define PIRQD MPC85xx_IRQ_EXT4
#define MPC85XX_PCI1_LOWER_IO 0x00000000
#define MPC85XX_PCI1_UPPER_IO 0x00ffffff
#define MPC85XX_PCI1_LOWER_MEM 0x80000000
#define MPC85XX_PCI1_UPPER_MEM 0x9fffffff
#define MPC85XX_PCI1_IO_BASE 0xe2000000
#define MPC85XX_PCI1_MEM_OFFSET 0x00000000
#define MPC85XX_PCI1_IO_SIZE 0x01000000
#endif
/* __PLATFORMS_85XX_SBC85XX_H__ */
arch/ppc/syslib/ppc85xx_setup.c
View file @
b1999b0e
...
...
@@ -30,6 +30,8 @@
#include <asm/ocp.h>
#include <asm/kgdb.h>
#include <syslib/ppc85xx_setup.h>
/* Return the amount of memory */
unsigned
long
__init
mpc85xx_find_end_of_memory
(
void
)
...
...
arch/ppc/syslib/ppc85xx_setup.h
View file @
b1999b0e
...
...
@@ -53,7 +53,9 @@ extern void mpc85xx_setup_hose(void) __init;
#define RS_TABLE_SIZE 2
#endif
#define BASE_BAUD 0
#ifndef BASE_BAUD
#define BASE_BAUD 115200
#endif
#define STD_UART_OP(num) \
{ 0, BASE_BAUD, num, MPC85xx_IRQ_DUART, \
...
...
include/asm-ppc/mpc85xx.h
View file @
b1999b0e
...
...
@@ -25,6 +25,9 @@
#ifdef CONFIG_MPC8540_ADS
#include <platforms/85xx/mpc8540_ads.h>
#endif
#ifdef CONFIG_SBC8560
#include <platforms/85xx/sbc8560.h>
#endif
#define _IO_BASE isa_io_base
#define _ISA_MEM_BASE isa_mem_base
...
...
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