Avoid SMP cacheflushes. This is a minor optimization of startup but
will also avoid smp_call_function from doing stupid things when called from a CPU that is not yet marked online. Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
This commit is contained in:
parent
bdf21b18b4
commit
1d40cfcd34
@ -1150,6 +1150,7 @@ static inline void signal32_init(void)
|
|||||||
|
|
||||||
extern void cpu_cache_init(void);
|
extern void cpu_cache_init(void);
|
||||||
extern void tlb_init(void);
|
extern void tlb_init(void);
|
||||||
|
extern void flush_tlb_handlers(void);
|
||||||
|
|
||||||
void __init per_cpu_trap_init(void)
|
void __init per_cpu_trap_init(void)
|
||||||
{
|
{
|
||||||
@ -1348,4 +1349,5 @@ void __init trap_init(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range(ebase, ebase + 0x400);
|
flush_icache_range(ebase, ebase + 0x400);
|
||||||
|
flush_tlb_handlers();
|
||||||
}
|
}
|
||||||
|
@ -1270,9 +1270,8 @@ void __init ld_mmu_r4xx0(void)
|
|||||||
_dma_cache_inv = r4k_dma_cache_inv;
|
_dma_cache_inv = r4k_dma_cache_inv;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
__flush_cache_all();
|
|
||||||
coherency_setup();
|
|
||||||
|
|
||||||
build_clear_page();
|
build_clear_page();
|
||||||
build_copy_page();
|
build_copy_page();
|
||||||
|
local_r4k___flush_cache_all(NULL);
|
||||||
|
coherency_setup();
|
||||||
}
|
}
|
||||||
|
@ -492,4 +492,5 @@ void __init ld_mmu_tx39(void)
|
|||||||
|
|
||||||
build_clear_page();
|
build_clear_page();
|
||||||
build_copy_page();
|
build_copy_page();
|
||||||
|
tx39h_flush_icache_all();
|
||||||
}
|
}
|
||||||
|
@ -404,9 +404,6 @@ dest = label();
|
|||||||
|
|
||||||
build_jr_ra();
|
build_jr_ra();
|
||||||
|
|
||||||
flush_icache_range((unsigned long)&clear_page_array,
|
|
||||||
(unsigned long) epc);
|
|
||||||
|
|
||||||
BUG_ON(epc > clear_page_array + ARRAY_SIZE(clear_page_array));
|
BUG_ON(epc > clear_page_array + ARRAY_SIZE(clear_page_array));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -482,8 +479,5 @@ dest = label();
|
|||||||
|
|
||||||
build_jr_ra();
|
build_jr_ra();
|
||||||
|
|
||||||
flush_icache_range((unsigned long)©_page_array,
|
|
||||||
(unsigned long) epc);
|
|
||||||
|
|
||||||
BUG_ON(epc > copy_page_array + ARRAY_SIZE(copy_page_array));
|
BUG_ON(epc > copy_page_array + ARRAY_SIZE(copy_page_array));
|
||||||
}
|
}
|
||||||
|
@ -743,7 +743,6 @@ static void __init build_r3000_tlb_refill_handler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
memcpy((void *)CAC_BASE, tlb_handler, 0x80);
|
memcpy((void *)CAC_BASE, tlb_handler, 0x80);
|
||||||
flush_icache_range(CAC_BASE, CAC_BASE + 0x80);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1258,7 +1257,6 @@ static void __init build_r4000_tlb_refill_handler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
memcpy((void *)CAC_BASE, final_handler, 0x100);
|
memcpy((void *)CAC_BASE, final_handler, 0x100);
|
||||||
flush_icache_range(CAC_BASE, CAC_BASE + 0x100);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1519,9 +1517,6 @@ static void __init build_r3000_tlb_load_handler(void)
|
|||||||
printk("%08x\n", handle_tlbl[i]);
|
printk("%08x\n", handle_tlbl[i]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range((unsigned long)handle_tlbl,
|
|
||||||
(unsigned long)handle_tlbl + FASTPATH_SIZE * sizeof(u32));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init build_r3000_tlb_store_handler(void)
|
static void __init build_r3000_tlb_store_handler(void)
|
||||||
@ -1559,9 +1554,6 @@ static void __init build_r3000_tlb_store_handler(void)
|
|||||||
printk("%08x\n", handle_tlbs[i]);
|
printk("%08x\n", handle_tlbs[i]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range((unsigned long)handle_tlbs,
|
|
||||||
(unsigned long)handle_tlbs + FASTPATH_SIZE * sizeof(u32));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init build_r3000_tlb_modify_handler(void)
|
static void __init build_r3000_tlb_modify_handler(void)
|
||||||
@ -1599,9 +1591,6 @@ static void __init build_r3000_tlb_modify_handler(void)
|
|||||||
printk("%08x\n", handle_tlbm[i]);
|
printk("%08x\n", handle_tlbm[i]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range((unsigned long)handle_tlbm,
|
|
||||||
(unsigned long)handle_tlbm + FASTPATH_SIZE * sizeof(u32));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1691,9 +1680,6 @@ static void __init build_r4000_tlb_load_handler(void)
|
|||||||
printk("%08x\n", handle_tlbl[i]);
|
printk("%08x\n", handle_tlbl[i]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range((unsigned long)handle_tlbl,
|
|
||||||
(unsigned long)handle_tlbl + FASTPATH_SIZE * sizeof(u32));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init build_r4000_tlb_store_handler(void)
|
static void __init build_r4000_tlb_store_handler(void)
|
||||||
@ -1730,9 +1716,6 @@ static void __init build_r4000_tlb_store_handler(void)
|
|||||||
printk("%08x\n", handle_tlbs[i]);
|
printk("%08x\n", handle_tlbs[i]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range((unsigned long)handle_tlbs,
|
|
||||||
(unsigned long)handle_tlbs + FASTPATH_SIZE * sizeof(u32));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init build_r4000_tlb_modify_handler(void)
|
static void __init build_r4000_tlb_modify_handler(void)
|
||||||
@ -1770,9 +1753,6 @@ static void __init build_r4000_tlb_modify_handler(void)
|
|||||||
printk("%08x\n", handle_tlbm[i]);
|
printk("%08x\n", handle_tlbm[i]);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
flush_icache_range((unsigned long)handle_tlbm,
|
|
||||||
(unsigned long)handle_tlbm + FASTPATH_SIZE * sizeof(u32));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void __init build_tlb_refill_handler(void)
|
void __init build_tlb_refill_handler(void)
|
||||||
@ -1820,3 +1800,13 @@ void __init build_tlb_refill_handler(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __init flush_tlb_handlers(void)
|
||||||
|
{
|
||||||
|
flush_icache_range((unsigned long)handle_tlbl,
|
||||||
|
(unsigned long)handle_tlbl + sizeof(handle_tlbl));
|
||||||
|
flush_icache_range((unsigned long)handle_tlbs,
|
||||||
|
(unsigned long)handle_tlbs + sizeof(handle_tlbs));
|
||||||
|
flush_icache_range((unsigned long)handle_tlbm,
|
||||||
|
(unsigned long)handle_tlbm + sizeof(handle_tlbm));
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user