X-Git-Url: https://git.archive.openwrt.org/?a=blobdiff_plain;f=target%2Flinux%2Fgeneric%2Fpatches-3.18%2F309-mips_fuse_workaround.patch;fp=target%2Flinux%2Fgeneric%2Fpatches-3.18%2F309-mips_fuse_workaround.patch;h=934b1198f4128234bf52a2799c746558f8d1d5d2;hb=3c6fb99e0074356ee59dd2b1e1dddc4f9c573d52;hp=0000000000000000000000000000000000000000;hpb=338f10decd8d0433f6832eb80c1248c7a59a7173;p=openwrt.git diff --git a/target/linux/generic/patches-3.18/309-mips_fuse_workaround.patch b/target/linux/generic/patches-3.18/309-mips_fuse_workaround.patch new file mode 100644 index 0000000000..934b1198f4 --- /dev/null +++ b/target/linux/generic/patches-3.18/309-mips_fuse_workaround.patch @@ -0,0 +1,32 @@ +--- a/arch/mips/mm/cache.c ++++ b/arch/mips/mm/cache.c +@@ -38,6 +38,7 @@ void (*__flush_cache_vunmap)(void); + + void (*__flush_kernel_vmap_range)(unsigned long vaddr, int size); + EXPORT_SYMBOL_GPL(__flush_kernel_vmap_range); ++EXPORT_SYMBOL(__flush_cache_all); + void (*__invalidate_kernel_vmap_range)(unsigned long vaddr, int size); + + /* MIPS specific cache operations */ +--- a/fs/fuse/dev.c ++++ b/fs/fuse/dev.c +@@ -20,6 +20,9 @@ + #include + #include + #include ++#ifdef CONFIG_MIPS ++#include ++#endif + + MODULE_ALIAS_MISCDEV(FUSE_MINOR); + MODULE_ALIAS("devname:fuse"); +@@ -749,6 +752,9 @@ static int fuse_copy_fill(struct fuse_co + static int fuse_copy_do(struct fuse_copy_state *cs, void **val, unsigned *size) + { + unsigned ncpy = min(*size, cs->len); ++#ifdef CONFIG_MIPS ++ __flush_cache_all(); ++#endif + if (val) { + void *pgaddr = kmap_atomic(cs->pg); + void *buf = pgaddr + cs->offset;