diff options
| author | David Gibson <david@gibson.dropbear.id.au> | 2005-11-09 19:50:16 -0500 |
|---|---|---|
| committer | Paul Mackerras <paulus@samba.org> | 2005-11-09 21:09:22 -0500 |
| commit | 26ef5c09576496dfd08d2b36ec1d08a6f917a0eb (patch) | |
| tree | 6a0bc875966eb00dc04dc2fdf7deeac96262698b /arch | |
| parent | e130bedb7ce718a8eb6b56a3806b96281f618111 (diff) | |
[PATCH] powerpc: Merge cacheflush.h and cache.h
The ppc32 and ppc64 versions of cacheflush.h were almost identical.
The two versions of cache.h are fairly similar, except for a bunch of
register definitions in the ppc32 version which probably belong better
elsewhere. This patch, therefore, merges both headers. Notable
points:
- there are several functions in cacheflush.h which exist only
on ppc32 or only on ppc64. These are handled by #ifdef for now, but
these should probably be consolidated, along with the actual code
behind them later.
- Confusingly, both ppc32 and ppc64 have a
flush_dcache_range(), but they're subtly different: it uses dcbf on
ppc32 and dcbst on ppc64, ppc64 has a flush_inval_dcache_range() which
uses dcbf. These too should be merged and consolidated later.
- Also flush_dcache_range() was defined in cacheflush.h on
ppc64, and in cache.h on ppc32. In the merged version it's in
cacheflush.h
- On ppc32 flush_icache_range() is a normal function from
misc.S. On ppc64, it was wrapper, testing a feature bit before
calling __flush_icache_range() which does the actual flush. This
patch takes the ppc64 approach, which amounts to no change on ppc32,
since CPU_FTR_COHERENT_ICACHE will never be set there, but does mean
renaming flush_icache_range() to __flush_icache_range() in
arch/ppc/kernel/misc.S and arch/powerpc/kernel/misc_32.S
- The PReP register info from asm-ppc/cache.h has moved to
arch/ppc/platforms/prep_setup.c
- The 8xx register info from asm-ppc/cache.h has moved to a
new asm-powerpc/reg_8xx.h, included from reg.h
- flush_dcache_all() was defined on ppc32 (only), but was
never called (although it was exported). Thus this patch removes it
from cacheflush.h and from ARCH=powerpc (misc_32.S) entirely. It's
left in ARCH=ppc for now, with the prototype moved to ppc_ksyms.c.
Built for Walnut (ARCH=ppc), 32-bit multiplatform (pmac, CHRP and PReP
ARCH=ppc, pmac and CHRP ARCH=powerpc). Built and booted on POWER5
LPAR (ARCH=powerpc and ARCH=ppc64).
Built for 32-bit powermac (ARCH=ppc and ARCH=powerpc). Built and
booted on POWER5 LPAR (ARCH=powerpc and ARCH=ppc64). Built and booted
on G5 (ARCH=powerpc)
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch')
| -rw-r--r-- | arch/powerpc/kernel/misc_32.S | 23 | ||||
| -rw-r--r-- | arch/ppc/kernel/misc.S | 4 | ||||
| -rw-r--r-- | arch/ppc/kernel/ppc_ksyms.c | 1 | ||||
| -rw-r--r-- | arch/ppc/platforms/prep_setup.c | 9 |
4 files changed, 13 insertions, 24 deletions
diff --git a/arch/powerpc/kernel/misc_32.S b/arch/powerpc/kernel/misc_32.S index 3bedb532aed9..f6d84a75ed26 100644 --- a/arch/powerpc/kernel/misc_32.S +++ b/arch/powerpc/kernel/misc_32.S | |||
| @@ -519,7 +519,7 @@ END_FTR_SECTION_IFCLR(CPU_FTR_SPLIT_ID_CACHE) | |||
| 519 | * | 519 | * |
| 520 | * flush_icache_range(unsigned long start, unsigned long stop) | 520 | * flush_icache_range(unsigned long start, unsigned long stop) |
| 521 | */ | 521 | */ |
| 522 | _GLOBAL(flush_icache_range) | 522 | _GLOBAL(__flush_icache_range) |
| 523 | BEGIN_FTR_SECTION | 523 | BEGIN_FTR_SECTION |
| 524 | blr /* for 601, do nothing */ | 524 | blr /* for 601, do nothing */ |
| 525 | END_FTR_SECTION_IFCLR(CPU_FTR_SPLIT_ID_CACHE) | 525 | END_FTR_SECTION_IFCLR(CPU_FTR_SPLIT_ID_CACHE) |
| @@ -607,27 +607,6 @@ _GLOBAL(invalidate_dcache_range) | |||
| 607 | sync /* wait for dcbi's to get to ram */ | 607 | sync /* wait for dcbi's to get to ram */ |
| 608 | blr | 608 | blr |
| 609 | 609 | ||
| 610 | #ifdef CONFIG_NOT_COHERENT_CACHE | ||
| 611 | /* | ||
| 612 | * 40x cores have 8K or 16K dcache and 32 byte line size. | ||
| 613 | * 44x has a 32K dcache and 32 byte line size. | ||
| 614 | * 8xx has 1, 2, 4, 8K variants. | ||
| 615 | * For now, cover the worst case of the 44x. | ||
| 616 | * Must be called with external interrupts disabled. | ||
| 617 | */ | ||
| 618 | #define CACHE_NWAYS 64 | ||
| 619 | #define CACHE_NLINES 16 | ||
| 620 | |||
| 621 | _GLOBAL(flush_dcache_all) | ||
| 622 | li r4, (2 * CACHE_NWAYS * CACHE_NLINES) | ||
| 623 | mtctr r4 | ||
| 624 | lis r5, KERNELBASE@h | ||
| 625 | 1: lwz r3, 0(r5) /* Load one word from every line */ | ||
| 626 | addi r5, r5, L1_CACHE_BYTES | ||
| 627 | bdnz 1b | ||
| 628 | blr | ||
| 629 | #endif /* CONFIG_NOT_COHERENT_CACHE */ | ||
| 630 | |||
| 631 | /* | 610 | /* |
| 632 | * Flush a particular page from the data cache to RAM. | 611 | * Flush a particular page from the data cache to RAM. |
| 633 | * Note: this is necessary because the instruction cache does *not* | 612 | * Note: this is necessary because the instruction cache does *not* |
diff --git a/arch/ppc/kernel/misc.S b/arch/ppc/kernel/misc.S index ae6af29938a1..5e61124581d0 100644 --- a/arch/ppc/kernel/misc.S +++ b/arch/ppc/kernel/misc.S | |||
| @@ -497,9 +497,9 @@ END_FTR_SECTION_IFCLR(CPU_FTR_SPLIT_ID_CACHE) | |||
| 497 | * and invalidate the corresponding instruction cache blocks. | 497 | * and invalidate the corresponding instruction cache blocks. |
| 498 | * This is a no-op on the 601. | 498 | * This is a no-op on the 601. |
| 499 | * | 499 | * |
| 500 | * flush_icache_range(unsigned long start, unsigned long stop) | 500 | * __flush_icache_range(unsigned long start, unsigned long stop) |
| 501 | */ | 501 | */ |
| 502 | _GLOBAL(flush_icache_range) | 502 | _GLOBAL(__flush_icache_range) |
| 503 | BEGIN_FTR_SECTION | 503 | BEGIN_FTR_SECTION |
| 504 | blr /* for 601, do nothing */ | 504 | blr /* for 601, do nothing */ |
| 505 | END_FTR_SECTION_IFCLR(CPU_FTR_SPLIT_ID_CACHE) | 505 | END_FTR_SECTION_IFCLR(CPU_FTR_SPLIT_ID_CACHE) |
diff --git a/arch/ppc/kernel/ppc_ksyms.c b/arch/ppc/kernel/ppc_ksyms.c index 6550de73a855..307077f14936 100644 --- a/arch/ppc/kernel/ppc_ksyms.c +++ b/arch/ppc/kernel/ppc_ksyms.c | |||
| @@ -175,6 +175,7 @@ EXPORT_SYMBOL(pci_bus_to_phys); | |||
| 175 | #endif /* CONFIG_PCI */ | 175 | #endif /* CONFIG_PCI */ |
| 176 | 176 | ||
| 177 | #ifdef CONFIG_NOT_COHERENT_CACHE | 177 | #ifdef CONFIG_NOT_COHERENT_CACHE |
| 178 | extern void flush_dcache_all(void); | ||
| 178 | EXPORT_SYMBOL(flush_dcache_all); | 179 | EXPORT_SYMBOL(flush_dcache_all); |
| 179 | #endif | 180 | #endif |
| 180 | 181 | ||
diff --git a/arch/ppc/platforms/prep_setup.c b/arch/ppc/platforms/prep_setup.c index 067d7d53b81e..4415748071dc 100644 --- a/arch/ppc/platforms/prep_setup.c +++ b/arch/ppc/platforms/prep_setup.c | |||
| @@ -61,6 +61,15 @@ | |||
| 61 | #include <asm/pci-bridge.h> | 61 | #include <asm/pci-bridge.h> |
| 62 | #include <asm/todc.h> | 62 | #include <asm/todc.h> |
| 63 | 63 | ||
| 64 | /* prep registers for L2 */ | ||
| 65 | #define CACHECRBA 0x80000823 /* Cache configuration register address */ | ||
| 66 | #define L2CACHE_MASK 0x03 /* Mask for 2 L2 Cache bits */ | ||
| 67 | #define L2CACHE_512KB 0x00 /* 512KB */ | ||
| 68 | #define L2CACHE_256KB 0x01 /* 256KB */ | ||
| 69 | #define L2CACHE_1MB 0x02 /* 1MB */ | ||
| 70 | #define L2CACHE_NONE 0x03 /* NONE */ | ||
| 71 | #define L2CACHE_PARITY 0x08 /* Mask for L2 Cache Parity Protected bit */ | ||
| 72 | |||
| 64 | TODC_ALLOC(); | 73 | TODC_ALLOC(); |
| 65 | 74 | ||
| 66 | unsigned char ucSystemType; | 75 | unsigned char ucSystemType; |
