blob: f6d1a3f747a9b58b3f33ce0ee25c3bf889985c0b [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Jeff Dikeba180fd2007-10-16 01:27:00 -07002 * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 * Licensed under the GPL
4 */
5
6#ifndef __UM_PROCESSOR_GENERIC_H
7#define __UM_PROCESSOR_GENERIC_H
8
9struct pt_regs;
10
11struct task_struct;
12
Al Viro37185b32012-10-08 03:27:32 +010013#include <asm/ptrace.h>
14#include <registers.h>
15#include <sysdep/archsetjmp.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070016
Richard Weinberger607647a2011-05-24 17:13:03 -070017#include <linux/prefetch.h>
18
Linus Torvalds1da177e2005-04-16 15:20:36 -070019struct mm_struct;
20
21struct thread_struct {
Linus Torvalds1da177e2005-04-16 15:20:36 -070022 struct pt_regs regs;
Richard Weinbergerf72c22e2013-09-23 17:38:02 +020023 struct pt_regs *segv_regs;
Linus Torvalds1da177e2005-04-16 15:20:36 -070024 int singlestep_syscall;
25 void *fault_addr;
Jeff Dikefab95c52007-10-16 01:27:05 -070026 jmp_buf *fault_catcher;
Linus Torvalds1da177e2005-04-16 15:20:36 -070027 struct task_struct *prev_sched;
Linus Torvalds1da177e2005-04-16 15:20:36 -070028 struct arch_thread arch;
Jeff Dike77bf4402007-10-16 01:26:58 -070029 jmp_buf switch_buf;
Linus Torvalds1da177e2005-04-16 15:20:36 -070030 struct {
31 int op;
32 union {
33 struct {
34 int pid;
35 } fork, exec;
36 struct {
37 int (*proc)(void *);
38 void *arg;
39 } thread;
40 struct {
41 void (*proc)(void *);
42 void *arg;
43 } cb;
44 } u;
45 } request;
46};
47
48#define INIT_THREAD \
49{ \
Jeff Dikeba180fd2007-10-16 01:27:00 -070050 .regs = EMPTY_REGS, \
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 .fault_addr = NULL, \
52 .prev_sched = NULL, \
Linus Torvalds1da177e2005-04-16 15:20:36 -070053 .arch = INIT_ARCH_THREAD, \
54 .request = { 0 } \
55}
56
Jeff Dike77bf4402007-10-16 01:26:58 -070057static inline void release_thread(struct task_struct *task)
58{
59}
60
Linus Torvalds1da177e2005-04-16 15:20:36 -070061static inline void mm_copy_segments(struct mm_struct *from_mm,
62 struct mm_struct *new_mm)
63{
64}
65
66#define init_stack (init_thread_union.stack)
67
68/*
69 * User space process size: 3GB (default).
70 */
Jeff Dike536788f2008-02-08 04:22:07 -080071extern unsigned long task_size;
72
73#define TASK_SIZE (task_size)
Linus Torvalds1da177e2005-04-16 15:20:36 -070074
David Howells922a70d2008-02-08 04:19:26 -080075#undef STACK_TOP
76#undef STACK_TOP_MAX
77
78extern unsigned long stacksizelim;
79
80#define STACK_ROOM (stacksizelim)
81#define STACK_TOP (TASK_SIZE - 2 * PAGE_SIZE)
82#define STACK_TOP_MAX STACK_TOP
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084/* This decides where the kernel will search for a free chunk of vm
85 * space during mmap's.
86 */
87#define TASK_UNMAPPED_BASE (0x40000000)
88
89extern void start_thread(struct pt_regs *regs, unsigned long entry,
90 unsigned long stack);
91
92struct cpuinfo_um {
93 unsigned long loops_per_jiffy;
94 int ipi_pipe[2];
95};
96
97extern struct cpuinfo_um boot_cpu_data;
98
Linus Torvalds1da177e2005-04-16 15:20:36 -070099#define cpu_data (&boot_cpu_data)
100#define current_cpu_data boot_cpu_data
Allan Gravesfad1c452005-10-04 14:53:52 -0400101
Jeff Dike77bf4402007-10-16 01:26:58 -0700102#define KSTK_REG(tsk, reg) get_thread_reg(reg, &tsk->thread.switch_buf)
Jeff Dikec1127462008-02-04 22:30:36 -0800103extern unsigned long get_wchan(struct task_struct *p);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104
105#endif