Commit 26156397 authored by Jie Zhang's avatar Jie Zhang Committed by Bryan Wu

Blackfin arch: Allow ptrace access the fixed code.

Signed-off-by: default avatarJie Zhang <jie.zhang@analog.com>
Signed-off-by: default avatarBryan Wu <bryan.wu@analog.com>
parent 8a26ac70
...@@ -44,6 +44,7 @@ ...@@ -44,6 +44,7 @@
#include <asm/processor.h> #include <asm/processor.h>
#include <asm/asm-offsets.h> #include <asm/asm-offsets.h>
#include <asm/dma.h> #include <asm/dma.h>
#include <asm/fixed_code.h>
#define MAX_SHARED_LIBS 3 #define MAX_SHARED_LIBS 3
#define TEXT_OFFSET 0 #define TEXT_OFFSET 0
...@@ -169,6 +170,9 @@ static inline int is_user_addr_valid(struct task_struct *child, ...@@ -169,6 +170,9 @@ static inline int is_user_addr_valid(struct task_struct *child,
&& start + len <= (unsigned long)sraml->addr + sraml->length) && start + len <= (unsigned long)sraml->addr + sraml->length)
return 0; return 0;
if (start >= FIXED_CODE_START && start + len <= FIXED_CODE_END)
return 0;
return -EIO; return -EIO;
} }
...@@ -215,9 +219,13 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data) ...@@ -215,9 +219,13 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data)
copied = sizeof(tmp); copied = sizeof(tmp);
} else } else
#endif #endif
copied = if (addr + add >= FIXED_CODE_START
access_process_vm(child, addr + add, &tmp, && addr + add + sizeof(tmp) <= FIXED_CODE_END) {
sizeof(tmp), 0); memcpy(&tmp, (const void *)(addr + add), sizeof(tmp));
copied = sizeof(tmp);
} else
copied = access_process_vm(child, addr + add, &tmp,
sizeof(tmp), 0);
pr_debug("ptrace: copied size %d [0x%08lx]\n", copied, tmp); pr_debug("ptrace: copied size %d [0x%08lx]\n", copied, tmp);
if (copied != sizeof(tmp)) if (copied != sizeof(tmp))
break; break;
...@@ -281,9 +289,13 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data) ...@@ -281,9 +289,13 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data)
copied = sizeof(data); copied = sizeof(data);
} else } else
#endif #endif
copied = if (addr + add >= FIXED_CODE_START
access_process_vm(child, addr + add, &data, && addr + add + sizeof(data) <= FIXED_CODE_END) {
sizeof(data), 1); memcpy((void *)(addr + add), &data, sizeof(data));
copied = sizeof(data);
} else
copied = access_process_vm(child, addr + add, &data,
sizeof(data), 1);
pr_debug("ptrace: copied size %d\n", copied); pr_debug("ptrace: copied size %d\n", copied);
if (copied != sizeof(data)) if (copied != sizeof(data))
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment