mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-10 19:12:33 +08:00
d369d92fc7
Ethernet, switch, LEDs, buttons, USB, sysupgrade & LuCI were successfully tested on BCM4706. WARNING: Hack for BCM4710 adding BCM4710_PROTECTED_FILL_TLB() to the local_r4k_flush_cache_sigtramp() could not be ported. That function has been dropped in: commit adcc81f148d7 ("MIPS: math-emu: Write-protect delay slot emulation pages") commit 3315b6b336c8 ("MIPS: Delete unused flush_cache_sigtramp()") it's unsure if that chipset will still work reliably. Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
22 lines
901 B
Diff
22 lines
901 B
Diff
From: Wolfram Joost <dbox2@frokaschwei.de>
|
|
Subject: [PATCH] fork_cacheflush
|
|
|
|
On ASUS WL-500gP there are many unexpected "Segmentation fault"s that
|
|
seem to be caused by a kernel. They can be avoided by:
|
|
1) Disabling highpage
|
|
2) Using flush_cache_mm in flush_cache_dup_mm
|
|
|
|
For details see OpenWrt ticket #2035 https://dev.openwrt.org/ticket/2035
|
|
---
|
|
--- a/arch/mips/include/asm/cacheflush.h
|
|
+++ b/arch/mips/include/asm/cacheflush.h
|
|
@@ -46,7 +46,7 @@
|
|
extern void (*flush_cache_all)(void);
|
|
extern void (*__flush_cache_all)(void);
|
|
extern void (*flush_cache_mm)(struct mm_struct *mm);
|
|
-#define flush_cache_dup_mm(mm) do { (void) (mm); } while (0)
|
|
+#define flush_cache_dup_mm(mm) flush_cache_mm(mm)
|
|
extern void (*flush_cache_range)(struct vm_area_struct *vma,
|
|
unsigned long start, unsigned long end);
|
|
extern void (*flush_cache_page)(struct vm_area_struct *vma, unsigned long page, unsigned long pfn);
|