X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=arch%2Fmips%2Fmm%2Fc-sb1.c;h=ad41b2b4600405848d9b061886d0f090ba25ac3f;hb=6a77f38946aaee1cd85eeec6cf4229b204c15071;hp=5bae2b0e916654cf07724cde9d0ff304782cf0de;hpb=87fc8d1bb10cd459024a742c6a10961fefcef18f;p=linux-2.6.git diff --git a/arch/mips/mm/c-sb1.c b/arch/mips/mm/c-sb1.c index 5bae2b0e9..ad41b2b46 100644 --- a/arch/mips/mm/c-sb1.c +++ b/arch/mips/mm/c-sb1.c @@ -20,10 +20,13 @@ */ #include #include -#include + +#include #include #include #include +#include +#include #include extern void sb1_dma_init(void); @@ -32,17 +35,17 @@ extern void sb1_dma_init(void); static unsigned long icache_size; static unsigned long dcache_size; -static unsigned long icache_line_size; -static unsigned long dcache_line_size; +static unsigned short icache_line_size; +static unsigned short dcache_line_size; static unsigned int icache_index_mask; static unsigned int dcache_index_mask; -static unsigned long icache_assoc; -static unsigned long dcache_assoc; +static unsigned short icache_assoc; +static unsigned short dcache_assoc; -static unsigned int icache_sets; -static unsigned int dcache_sets; +static unsigned short icache_sets; +static unsigned short dcache_sets; static unsigned int icache_range_cutoff; static unsigned int dcache_range_cutoff; @@ -449,6 +452,11 @@ static unsigned int decode_cache_line_size(unsigned int config_field) * 9:7 Dcache Associativity */ +static char *way_string[] = { + "direct mapped", "2-way", "3-way", "4-way", + "5-way", "6-way", "7-way", "8-way", +}; + static __init void probe_cache_sizes(void) { u32 config1; @@ -473,6 +481,13 @@ static __init void probe_cache_sizes(void) */ icache_range_cutoff = icache_sets * icache_line_size; dcache_range_cutoff = (dcache_sets / 2) * icache_line_size; + + printk("Primary instruction cache %ldkB, %s, linesize %d bytes.\n", + icache_size >> 10, way_string[icache_assoc - 1], + icache_line_size); + printk("Primary data cache %ldkB, %s, linesize %d bytes.\n", + dcache_size >> 10, way_string[dcache_assoc - 1], + dcache_line_size); } /* @@ -488,7 +503,7 @@ void ld_mmu_sb1(void) /* Special cache error handler for SB1 */ memcpy((void *)(CAC_BASE + 0x100), &except_vec2_sb1, 0x80); memcpy((void *)(UNCAC_BASE + 0x100), &except_vec2_sb1, 0x80); - memcpy((void *)KSEG1ADDR(&handle_vec2_sb1), &handle_vec2_sb1, 0x80); + memcpy((void *)CKSEG1ADDR(&handle_vec2_sb1), &handle_vec2_sb1, 0x80); probe_cache_sizes(); @@ -526,15 +541,14 @@ void ld_mmu_sb1(void) * before subsequent instruction fetch. */ __asm__ __volatile__( + ".set push \n" " .set noat \n" " .set noreorder \n" - " .set mips3\n\t \n" - " la $1, 1f \n" - " mtc0 $1, $14 \n" + " .set mips3 \n" + " " STR(PTR_LA) " $1, 1f \n" + " " STR(MTC0) " $1, $14 \n" " eret \n" - "1: .set mips0\n\t \n" - " .set at \n" - " .set reorder" + "1: .set pop" : : : "memory");