|
@@ -282,19 +282,14 @@ int __weak set_swbp(struct arch_uprobe *auprobe, struct mm_struct *mm,
|
|
|
void __weak arch_uprobe_copy_ixol(struct page *page, unsigned long vaddr,
|
|
|
void *src, unsigned long len)
|
|
|
{
|
|
|
- void *kaddr;
|
|
|
+ unsigned long kaddr, kstart;
|
|
|
|
|
|
/* Initialize the slot */
|
|
|
- kaddr = kmap_atomic(page);
|
|
|
- memcpy(kaddr + (vaddr & ~PAGE_MASK), src, len);
|
|
|
- kunmap_atomic(kaddr);
|
|
|
-
|
|
|
- /*
|
|
|
- * The MIPS version of flush_icache_range will operate safely on
|
|
|
- * user space addresses and more importantly, it doesn't require a
|
|
|
- * VMA argument.
|
|
|
- */
|
|
|
- flush_icache_range(vaddr, vaddr + len);
|
|
|
+ kaddr = (unsigned long)kmap_atomic(page);
|
|
|
+ kstart = kaddr + (vaddr & ~PAGE_MASK);
|
|
|
+ memcpy((void *)kstart, src, len);
|
|
|
+ flush_icache_range(kstart, kstart + len);
|
|
|
+ kunmap_atomic((void *)kaddr);
|
|
|
}
|
|
|
|
|
|
/**
|