|
@@ -206,33 +206,16 @@ static int write_opcode(struct arch_uprobe *auprobe, struct mm_struct *mm,
|
|
|
unsigned long vaddr, uprobe_opcode_t opcode)
|
|
|
{
|
|
|
struct page *old_page, *new_page;
|
|
|
- struct address_space *mapping;
|
|
|
void *vaddr_old, *vaddr_new;
|
|
|
struct vm_area_struct *vma;
|
|
|
- struct uprobe *uprobe;
|
|
|
int ret;
|
|
|
+
|
|
|
retry:
|
|
|
/* Read the page with vaddr into memory */
|
|
|
ret = get_user_pages(NULL, mm, vaddr, 1, 0, 0, &old_page, &vma);
|
|
|
if (ret <= 0)
|
|
|
return ret;
|
|
|
|
|
|
- ret = -EINVAL;
|
|
|
-
|
|
|
- /*
|
|
|
- * We are interested in text pages only. Our pages of interest
|
|
|
- * should be mapped for read and execute only. We desist from
|
|
|
- * adding probes in write mapped pages since the breakpoints
|
|
|
- * might end up in the file copy.
|
|
|
- */
|
|
|
- if (!valid_vma(vma, is_swbp_insn(&opcode)))
|
|
|
- goto put_out;
|
|
|
-
|
|
|
- uprobe = container_of(auprobe, struct uprobe, arch);
|
|
|
- mapping = uprobe->inode->i_mapping;
|
|
|
- if (mapping != vma->vm_file->f_mapping)
|
|
|
- goto put_out;
|
|
|
-
|
|
|
ret = -ENOMEM;
|
|
|
new_page = alloc_page_vma(GFP_HIGHUSER_MOVABLE, vma, vaddr);
|
|
|
if (!new_page)
|