blob: c00491594b46d8b4adf2e75621090187bf778b5b [file] [log] [blame]
Robin Getz96f10502009-09-24 14:11:24 +00001/*
2 * Copyright 2004-2008 Analog Devices Inc.
3 *
4 * Licensed under the GPL-2 or later.
5 */
Bryan Wu1394f032007-05-06 14:50:22 -07006#ifndef _BFIN_PTRACE_H
7#define _BFIN_PTRACE_H
8
David Howells2ba36452012-10-09 09:46:39 +01009#include <uapi/asm/ptrace.h>
Bryan Wu1394f032007-05-06 14:50:22 -070010
11#ifndef __ASSEMBLY__
12
Bryan Wu1394f032007-05-06 14:50:22 -070013/* user_mode returns true if only one bit is set in IPEND, other than the
14 master interrupt enable. */
15#define user_mode(regs) (!(((regs)->ipend & ~0x10) & (((regs)->ipend & ~0x10) - 1)))
Bryan Wu1394f032007-05-06 14:50:22 -070016
Mike Frysingere8f263d2010-01-26 07:33:53 +000017#define arch_has_single_step() (1)
Mike Frysingere8f263d2010-01-26 07:33:53 +000018/* common code demands this function */
19#define ptrace_disable(child) user_disable_single_step(child)
Al Viro1ca97bb2012-11-18 12:50:10 -050020#define current_user_stack_pointer() rdusp()
Mike Frysingere8f263d2010-01-26 07:33:53 +000021
Sonic Zhang99a5b282010-09-06 10:16:04 +000022extern int is_user_addr_valid(struct task_struct *child,
23 unsigned long start, unsigned long len);
24
Mike Frysingere8f263d2010-01-26 07:33:53 +000025/*
26 * Get the address of the live pt_regs for the specified task.
27 * These are saved onto the top kernel stack when the process
28 * is not running.
29 *
30 * Note: if a user thread is execve'd from kernel space, the
31 * kernel stack will not be empty on entry to the kernel, so
32 * ptracing these tasks will fail.
33 */
34#define task_pt_regs(task) \
35 (struct pt_regs *) \
36 ((unsigned long)task_stack_page(task) + \
37 (THREAD_SIZE - sizeof(struct pt_regs)))
38
Mike Frysinger82258c62011-05-26 16:25:42 -070039#include <asm-generic/ptrace.h>
40
Bryan Wu1394f032007-05-06 14:50:22 -070041#endif /* __ASSEMBLY__ */
Bryan Wu1394f032007-05-06 14:50:22 -070042#endif /* _BFIN_PTRACE_H */