2007-10-10 09:55:26 -06:00
|
|
|
/*
|
2009-09-24 08:11:24 -06:00
|
|
|
* Copyright 2004-2009 Analog Devices Inc.
|
blackfin architecture
This adds support for the Analog Devices Blackfin processor architecture, and
currently supports the BF533, BF532, BF531, BF537, BF536, BF534, and BF561
(Dual Core) devices, with a variety of development platforms including those
avaliable from Analog Devices (BF533-EZKit, BF533-STAMP, BF537-STAMP,
BF561-EZKIT), and Bluetechnix! Tinyboards.
The Blackfin architecture was jointly developed by Intel and Analog Devices
Inc. (ADI) as the Micro Signal Architecture (MSA) core and introduced it in
December of 2000. Since then ADI has put this core into its Blackfin
processor family of devices. The Blackfin core has the advantages of a clean,
orthogonal,RISC-like microprocessor instruction set. It combines a dual-MAC
(Multiply/Accumulate), state-of-the-art signal processing engine and
single-instruction, multiple-data (SIMD) multimedia capabilities into a single
instruction-set architecture.
The Blackfin architecture, including the instruction set, is described by the
ADSP-BF53x/BF56x Blackfin Processor Programming Reference
http://blackfin.uclinux.org/gf/download/frsrelease/29/2549/Blackfin_PRM.pdf
The Blackfin processor is already supported by major releases of gcc, and
there are binary and source rpms/tarballs for many architectures at:
http://blackfin.uclinux.org/gf/project/toolchain/frs There is complete
documentation, including "getting started" guides available at:
http://docs.blackfin.uclinux.org/ which provides links to the sources and
patches you will need in order to set up a cross-compiling environment for
bfin-linux-uclibc
This patch, as well as the other patches (toolchain, distribution,
uClibc) are actively supported by Analog Devices Inc, at:
http://blackfin.uclinux.org/
We have tested this on LTP, and our test plan (including pass/fails) can
be found at:
http://docs.blackfin.uclinux.org/doku.php?id=testing_the_linux_kernel
[m.kozlowski@tuxland.pl: balance parenthesis in blackfin header files]
Signed-off-by: Bryan Wu <bryan.wu@analog.com>
Signed-off-by: Mariusz Kozlowski <m.kozlowski@tuxland.pl>
Signed-off-by: Aubrey Li <aubrey.li@analog.com>
Signed-off-by: Jie Zhang <jie.zhang@analog.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-05-06 15:50:22 -06:00
|
|
|
*
|
2009-09-24 08:11:24 -06:00
|
|
|
* Licensed under the GPL-2 or later.
|
2007-10-10 09:55:26 -06:00
|
|
|
*/
|
blackfin architecture
This adds support for the Analog Devices Blackfin processor architecture, and
currently supports the BF533, BF532, BF531, BF537, BF536, BF534, and BF561
(Dual Core) devices, with a variety of development platforms including those
avaliable from Analog Devices (BF533-EZKit, BF533-STAMP, BF537-STAMP,
BF561-EZKIT), and Bluetechnix! Tinyboards.
The Blackfin architecture was jointly developed by Intel and Analog Devices
Inc. (ADI) as the Micro Signal Architecture (MSA) core and introduced it in
December of 2000. Since then ADI has put this core into its Blackfin
processor family of devices. The Blackfin core has the advantages of a clean,
orthogonal,RISC-like microprocessor instruction set. It combines a dual-MAC
(Multiply/Accumulate), state-of-the-art signal processing engine and
single-instruction, multiple-data (SIMD) multimedia capabilities into a single
instruction-set architecture.
The Blackfin architecture, including the instruction set, is described by the
ADSP-BF53x/BF56x Blackfin Processor Programming Reference
http://blackfin.uclinux.org/gf/download/frsrelease/29/2549/Blackfin_PRM.pdf
The Blackfin processor is already supported by major releases of gcc, and
there are binary and source rpms/tarballs for many architectures at:
http://blackfin.uclinux.org/gf/project/toolchain/frs There is complete
documentation, including "getting started" guides available at:
http://docs.blackfin.uclinux.org/ which provides links to the sources and
patches you will need in order to set up a cross-compiling environment for
bfin-linux-uclibc
This patch, as well as the other patches (toolchain, distribution,
uClibc) are actively supported by Analog Devices Inc, at:
http://blackfin.uclinux.org/
We have tested this on LTP, and our test plan (including pass/fails) can
be found at:
http://docs.blackfin.uclinux.org/doku.php?id=testing_the_linux_kernel
[m.kozlowski@tuxland.pl: balance parenthesis in blackfin header files]
Signed-off-by: Bryan Wu <bryan.wu@analog.com>
Signed-off-by: Mariusz Kozlowski <m.kozlowski@tuxland.pl>
Signed-off-by: Aubrey Li <aubrey.li@analog.com>
Signed-off-by: Jie Zhang <jie.zhang@analog.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-05-06 15:50:22 -06:00
|
|
|
|
|
|
|
#ifndef _CPLB_H
|
|
|
|
#define _CPLB_H
|
|
|
|
|
2008-08-26 20:51:02 -06:00
|
|
|
#include <mach/anomaly.h>
|
blackfin architecture
This adds support for the Analog Devices Blackfin processor architecture, and
currently supports the BF533, BF532, BF531, BF537, BF536, BF534, and BF561
(Dual Core) devices, with a variety of development platforms including those
avaliable from Analog Devices (BF533-EZKit, BF533-STAMP, BF537-STAMP,
BF561-EZKIT), and Bluetechnix! Tinyboards.
The Blackfin architecture was jointly developed by Intel and Analog Devices
Inc. (ADI) as the Micro Signal Architecture (MSA) core and introduced it in
December of 2000. Since then ADI has put this core into its Blackfin
processor family of devices. The Blackfin core has the advantages of a clean,
orthogonal,RISC-like microprocessor instruction set. It combines a dual-MAC
(Multiply/Accumulate), state-of-the-art signal processing engine and
single-instruction, multiple-data (SIMD) multimedia capabilities into a single
instruction-set architecture.
The Blackfin architecture, including the instruction set, is described by the
ADSP-BF53x/BF56x Blackfin Processor Programming Reference
http://blackfin.uclinux.org/gf/download/frsrelease/29/2549/Blackfin_PRM.pdf
The Blackfin processor is already supported by major releases of gcc, and
there are binary and source rpms/tarballs for many architectures at:
http://blackfin.uclinux.org/gf/project/toolchain/frs There is complete
documentation, including "getting started" guides available at:
http://docs.blackfin.uclinux.org/ which provides links to the sources and
patches you will need in order to set up a cross-compiling environment for
bfin-linux-uclibc
This patch, as well as the other patches (toolchain, distribution,
uClibc) are actively supported by Analog Devices Inc, at:
http://blackfin.uclinux.org/
We have tested this on LTP, and our test plan (including pass/fails) can
be found at:
http://docs.blackfin.uclinux.org/doku.php?id=testing_the_linux_kernel
[m.kozlowski@tuxland.pl: balance parenthesis in blackfin header files]
Signed-off-by: Bryan Wu <bryan.wu@analog.com>
Signed-off-by: Mariusz Kozlowski <m.kozlowski@tuxland.pl>
Signed-off-by: Aubrey Li <aubrey.li@analog.com>
Signed-off-by: Jie Zhang <jie.zhang@analog.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-05-06 15:50:22 -06:00
|
|
|
|
2007-10-10 09:55:26 -06:00
|
|
|
#define SDRAM_IGENERIC (CPLB_L1_CHBL | CPLB_USER_RD | CPLB_VALID | CPLB_PORTPRIO)
|
|
|
|
#define SDRAM_IKERNEL (SDRAM_IGENERIC | CPLB_LOCK)
|
|
|
|
#define L1_IMEMORY ( CPLB_USER_RD | CPLB_VALID | CPLB_LOCK)
|
|
|
|
#define SDRAM_INON_CHBL ( CPLB_USER_RD | CPLB_VALID)
|
|
|
|
|
|
|
|
#if ANOMALY_05000158
|
|
|
|
#define ANOMALY_05000158_WORKAROUND 0x200
|
|
|
|
#else
|
|
|
|
#define ANOMALY_05000158_WORKAROUND 0x0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define CPLB_COMMON (CPLB_DIRTY | CPLB_SUPV_WR | CPLB_USER_WR | CPLB_USER_RD | CPLB_VALID | ANOMALY_05000158_WORKAROUND)
|
|
|
|
|
2009-06-16 03:48:33 -06:00
|
|
|
#ifdef CONFIG_BFIN_EXTMEM_WRITEBACK
|
2007-10-10 09:55:26 -06:00
|
|
|
#define SDRAM_DGENERIC (CPLB_L1_CHBL | CPLB_COMMON)
|
2009-06-16 03:48:33 -06:00
|
|
|
#elif defined(CONFIG_BFIN_EXTMEM_WRITETHROUGH)
|
2007-10-10 09:55:26 -06:00
|
|
|
#define SDRAM_DGENERIC (CPLB_L1_CHBL | CPLB_WT | CPLB_L1_AOW | CPLB_COMMON)
|
2009-06-16 03:48:33 -06:00
|
|
|
#else
|
|
|
|
#define SDRAM_DGENERIC (CPLB_COMMON)
|
2007-10-10 09:55:26 -06:00
|
|
|
#endif
|
|
|
|
|
2009-05-06 22:09:15 -06:00
|
|
|
#define SDRAM_DNON_CHBL (CPLB_COMMON)
|
|
|
|
#define SDRAM_EBIU (CPLB_COMMON)
|
|
|
|
#define SDRAM_OOPS (CPLB_VALID | ANOMALY_05000158_WORKAROUND | CPLB_LOCK | CPLB_DIRTY)
|
|
|
|
|
2007-10-10 09:55:26 -06:00
|
|
|
#define L1_DMEMORY (CPLB_LOCK | CPLB_COMMON)
|
2008-11-18 02:48:22 -07:00
|
|
|
|
|
|
|
#ifdef CONFIG_SMP
|
2009-05-06 22:09:15 -06:00
|
|
|
#define L2_ATTR (INITIAL_T | I_CPLB | D_CPLB)
|
2009-06-16 03:48:33 -06:00
|
|
|
#define L2_IMEMORY (CPLB_COMMON | PAGE_SIZE_1MB)
|
|
|
|
#define L2_DMEMORY (CPLB_LOCK | CPLB_COMMON | PAGE_SIZE_1MB)
|
2008-11-18 02:48:22 -07:00
|
|
|
|
|
|
|
#else
|
2009-05-06 22:09:15 -06:00
|
|
|
#define L2_ATTR (INITIAL_T | SWITCH_T | I_CPLB | D_CPLB)
|
2009-06-16 03:48:33 -06:00
|
|
|
# if defined(CONFIG_BFIN_L2_ICACHEABLE)
|
|
|
|
# define L2_IMEMORY (CPLB_L1_CHBL | CPLB_USER_RD | CPLB_VALID | PAGE_SIZE_1MB)
|
|
|
|
# else
|
|
|
|
# define L2_IMEMORY ( CPLB_USER_RD | CPLB_VALID | PAGE_SIZE_1MB)
|
|
|
|
# endif
|
2009-05-06 22:09:15 -06:00
|
|
|
|
2009-06-16 03:48:33 -06:00
|
|
|
# if defined(CONFIG_BFIN_L2_WRITEBACK)
|
|
|
|
# define L2_DMEMORY (CPLB_L1_CHBL | CPLB_COMMON | PAGE_SIZE_1MB)
|
|
|
|
# elif defined(CONFIG_BFIN_L2_WRITETHROUGH)
|
|
|
|
# define L2_DMEMORY (CPLB_L1_CHBL | CPLB_WT | CPLB_L1_AOW | CPLB_COMMON | PAGE_SIZE_1MB)
|
2009-05-06 22:09:15 -06:00
|
|
|
# else
|
2009-06-16 03:48:33 -06:00
|
|
|
# define L2_DMEMORY (CPLB_COMMON | PAGE_SIZE_1MB)
|
2009-05-06 22:09:15 -06:00
|
|
|
# endif
|
2008-11-18 02:48:22 -07:00
|
|
|
#endif /* CONFIG_SMP */
|
|
|
|
|
2007-10-10 09:55:26 -06:00
|
|
|
#define SIZE_1K 0x00000400 /* 1K */
|
|
|
|
#define SIZE_4K 0x00001000 /* 4K */
|
|
|
|
#define SIZE_1M 0x00100000 /* 1M */
|
|
|
|
#define SIZE_4M 0x00400000 /* 4M */
|
2012-05-16 04:03:47 -06:00
|
|
|
#define SIZE_16K 0x00004000 /* 16K */
|
|
|
|
#define SIZE_64K 0x00010000 /* 64K */
|
|
|
|
#define SIZE_16M 0x01000000 /* 16M */
|
|
|
|
#define SIZE_64M 0x04000000 /* 64M */
|
2007-10-10 09:55:26 -06:00
|
|
|
|
2008-01-27 03:39:16 -07:00
|
|
|
#define MAX_CPLBS 16
|
2007-08-27 01:29:35 -06:00
|
|
|
|
blackfin architecture
This adds support for the Analog Devices Blackfin processor architecture, and
currently supports the BF533, BF532, BF531, BF537, BF536, BF534, and BF561
(Dual Core) devices, with a variety of development platforms including those
avaliable from Analog Devices (BF533-EZKit, BF533-STAMP, BF537-STAMP,
BF561-EZKIT), and Bluetechnix! Tinyboards.
The Blackfin architecture was jointly developed by Intel and Analog Devices
Inc. (ADI) as the Micro Signal Architecture (MSA) core and introduced it in
December of 2000. Since then ADI has put this core into its Blackfin
processor family of devices. The Blackfin core has the advantages of a clean,
orthogonal,RISC-like microprocessor instruction set. It combines a dual-MAC
(Multiply/Accumulate), state-of-the-art signal processing engine and
single-instruction, multiple-data (SIMD) multimedia capabilities into a single
instruction-set architecture.
The Blackfin architecture, including the instruction set, is described by the
ADSP-BF53x/BF56x Blackfin Processor Programming Reference
http://blackfin.uclinux.org/gf/download/frsrelease/29/2549/Blackfin_PRM.pdf
The Blackfin processor is already supported by major releases of gcc, and
there are binary and source rpms/tarballs for many architectures at:
http://blackfin.uclinux.org/gf/project/toolchain/frs There is complete
documentation, including "getting started" guides available at:
http://docs.blackfin.uclinux.org/ which provides links to the sources and
patches you will need in order to set up a cross-compiling environment for
bfin-linux-uclibc
This patch, as well as the other patches (toolchain, distribution,
uClibc) are actively supported by Analog Devices Inc, at:
http://blackfin.uclinux.org/
We have tested this on LTP, and our test plan (including pass/fails) can
be found at:
http://docs.blackfin.uclinux.org/doku.php?id=testing_the_linux_kernel
[m.kozlowski@tuxland.pl: balance parenthesis in blackfin header files]
Signed-off-by: Bryan Wu <bryan.wu@analog.com>
Signed-off-by: Mariusz Kozlowski <m.kozlowski@tuxland.pl>
Signed-off-by: Aubrey Li <aubrey.li@analog.com>
Signed-off-by: Jie Zhang <jie.zhang@analog.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-05-06 15:50:22 -06:00
|
|
|
#define CPLB_ENABLE_ICACHE_P 0
|
|
|
|
#define CPLB_ENABLE_DCACHE_P 1
|
|
|
|
#define CPLB_ENABLE_DCACHE2_P 2
|
|
|
|
#define CPLB_ENABLE_CPLBS_P 3 /* Deprecated! */
|
|
|
|
#define CPLB_ENABLE_ICPLBS_P 4
|
|
|
|
#define CPLB_ENABLE_DCPLBS_P 5
|
|
|
|
|
|
|
|
#define CPLB_ENABLE_ICACHE (1<<CPLB_ENABLE_ICACHE_P)
|
|
|
|
#define CPLB_ENABLE_DCACHE (1<<CPLB_ENABLE_DCACHE_P)
|
|
|
|
#define CPLB_ENABLE_DCACHE2 (1<<CPLB_ENABLE_DCACHE2_P)
|
|
|
|
#define CPLB_ENABLE_CPLBS (1<<CPLB_ENABLE_CPLBS_P)
|
|
|
|
#define CPLB_ENABLE_ICPLBS (1<<CPLB_ENABLE_ICPLBS_P)
|
|
|
|
#define CPLB_ENABLE_DCPLBS (1<<CPLB_ENABLE_DCPLBS_P)
|
|
|
|
#define CPLB_ENABLE_ANY_CPLBS CPLB_ENABLE_CPLBS | \
|
|
|
|
CPLB_ENABLE_ICPLBS | \
|
|
|
|
CPLB_ENABLE_DCPLBS
|
|
|
|
|
|
|
|
#define CPLB_RELOADED 0x0000
|
|
|
|
#define CPLB_NO_UNLOCKED 0x0001
|
|
|
|
#define CPLB_NO_ADDR_MATCH 0x0002
|
|
|
|
#define CPLB_PROT_VIOL 0x0003
|
|
|
|
#define CPLB_UNKNOWN_ERR 0x0004
|
|
|
|
|
|
|
|
#define CPLB_DEF_CACHE CPLB_L1_CHBL | CPLB_WT
|
|
|
|
#define CPLB_CACHE_ENABLED CPLB_L1_CHBL | CPLB_DIRTY
|
|
|
|
|
|
|
|
#define CPLB_I_PAGE_MGMT CPLB_LOCK | CPLB_VALID
|
|
|
|
#define CPLB_D_PAGE_MGMT CPLB_LOCK | CPLB_ALL_ACCESS | CPLB_VALID
|
|
|
|
#define CPLB_DNOCACHE CPLB_ALL_ACCESS | CPLB_VALID
|
|
|
|
#define CPLB_DDOCACHE CPLB_DNOCACHE | CPLB_DEF_CACHE
|
|
|
|
#define CPLB_INOCACHE CPLB_USER_RD | CPLB_VALID
|
|
|
|
#define CPLB_IDOCACHE CPLB_INOCACHE | CPLB_L1_CHBL
|
|
|
|
|
2009-01-07 08:14:38 -07:00
|
|
|
#define FAULT_RW (1 << 16)
|
|
|
|
#define FAULT_USERSUPV (1 << 17)
|
|
|
|
#define FAULT_CPLBBITS 0x0000ffff
|
|
|
|
|
2009-08-06 19:20:58 -06:00
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
|
|
|
static inline void _disable_cplb(u32 mmr, u32 mask)
|
|
|
|
{
|
|
|
|
u32 ctrl = bfin_read32(mmr) & ~mask;
|
|
|
|
/* CSYNC to ensure load store ordering */
|
|
|
|
__builtin_bfin_csync();
|
|
|
|
bfin_write32(mmr, ctrl);
|
|
|
|
__builtin_bfin_ssync();
|
|
|
|
}
|
|
|
|
static inline void disable_cplb(u32 mmr, u32 mask)
|
|
|
|
{
|
|
|
|
u32 ctrl = bfin_read32(mmr) & ~mask;
|
|
|
|
CSYNC();
|
|
|
|
bfin_write32(mmr, ctrl);
|
|
|
|
SSYNC();
|
|
|
|
}
|
|
|
|
#define _disable_dcplb() _disable_cplb(DMEM_CONTROL, ENDCPLB)
|
|
|
|
#define disable_dcplb() disable_cplb(DMEM_CONTROL, ENDCPLB)
|
|
|
|
#define _disable_icplb() _disable_cplb(IMEM_CONTROL, ENICPLB)
|
|
|
|
#define disable_icplb() disable_cplb(IMEM_CONTROL, ENICPLB)
|
|
|
|
|
|
|
|
static inline void _enable_cplb(u32 mmr, u32 mask)
|
|
|
|
{
|
|
|
|
u32 ctrl = bfin_read32(mmr) | mask;
|
|
|
|
/* CSYNC to ensure load store ordering */
|
|
|
|
__builtin_bfin_csync();
|
|
|
|
bfin_write32(mmr, ctrl);
|
|
|
|
__builtin_bfin_ssync();
|
|
|
|
}
|
|
|
|
static inline void enable_cplb(u32 mmr, u32 mask)
|
|
|
|
{
|
|
|
|
u32 ctrl = bfin_read32(mmr) | mask;
|
|
|
|
CSYNC();
|
|
|
|
bfin_write32(mmr, ctrl);
|
|
|
|
SSYNC();
|
|
|
|
}
|
|
|
|
#define _enable_dcplb() _enable_cplb(DMEM_CONTROL, ENDCPLB)
|
|
|
|
#define enable_dcplb() enable_cplb(DMEM_CONTROL, ENDCPLB)
|
|
|
|
#define _enable_icplb() _enable_cplb(IMEM_CONTROL, ENICPLB)
|
|
|
|
#define enable_icplb() enable_cplb(IMEM_CONTROL, ENICPLB)
|
|
|
|
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
|
|
|
|
#endif /* _CPLB_H */
|