process.c 10.8 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8 9 10 11 12
/*
 *  linux/arch/arm/kernel/process.c
 *
 *  Copyright (C) 1996-2000 Russell King - Converted to ARM.
 *  Original Copyright (C) 1995  Linus Torvalds
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#include <stdarg.h>

13
#include <linux/export.h>
L
Linus Torvalds 已提交
14
#include <linux/sched.h>
15
#include <linux/sched/debug.h>
16
#include <linux/sched/task.h>
17
#include <linux/sched/task_stack.h>
L
Linus Torvalds 已提交
18 19 20 21 22 23 24
#include <linux/kernel.h>
#include <linux/mm.h>
#include <linux/stddef.h>
#include <linux/unistd.h>
#include <linux/user.h>
#include <linux/interrupt.h>
#include <linux/init.h>
25
#include <linux/elfcore.h>
26
#include <linux/pm.h>
27
#include <linux/tick.h>
28
#include <linux/utsname.h>
29
#include <linux/uaccess.h>
30
#include <linux/random.h>
31
#include <linux/hw_breakpoint.h>
32
#include <linux/leds.h>
L
Linus Torvalds 已提交
33 34

#include <asm/processor.h>
35
#include <asm/thread_notify.h>
36
#include <asm/stacktrace.h>
37
#include <asm/system_misc.h>
38
#include <asm/mach/time.h>
39
#include <asm/tls.h>
40
#include <asm/vdso.h>
L
Linus Torvalds 已提交
41

42
#ifdef CONFIG_STACKPROTECTOR
43 44 45 46 47
#include <linux/stackprotector.h>
unsigned long __stack_chk_guard __read_mostly;
EXPORT_SYMBOL(__stack_chk_guard);
#endif

48
static const char *processor_modes[] __maybe_unused = {
49 50
  "USER_26", "FIQ_26" , "IRQ_26" , "SVC_26" , "UK4_26" , "UK5_26" , "UK6_26" , "UK7_26" ,
  "UK8_26" , "UK9_26" , "UK10_26", "UK11_26", "UK12_26", "UK13_26", "UK14_26", "UK15_26",
51 52
  "USER_32", "FIQ_32" , "IRQ_32" , "SVC_32" , "UK4_32" , "UK5_32" , "MON_32" , "ABT_32" ,
  "UK8_32" , "UK9_32" , "HYP_32", "UND_32" , "UK12_32", "UK13_32", "UK14_32", "SYS_32"
53 54
};

55
static const char *isa_modes[] __maybe_unused = {
56 57 58
  "ARM" , "Thumb" , "Jazelle", "ThumbEE"
};

L
Linus Torvalds 已提交
59
/*
N
Nicolas Pitre 已提交
60
 * This is our default idle handler.
L
Linus Torvalds 已提交
61
 */
N
Nicolas Pitre 已提交
62 63 64

void (*arm_pm_idle)(void);

65 66 67 68 69
/*
 * Called from the core idle loop.
 */

void arch_cpu_idle(void)
L
Linus Torvalds 已提交
70
{
N
Nicolas Pitre 已提交
71 72 73
	if (arm_pm_idle)
		arm_pm_idle();
	else
N
Nicolas Pitre 已提交
74
		cpu_do_idle();
75
	local_irq_enable();
L
Linus Torvalds 已提交
76 77
}

T
Thomas Gleixner 已提交
78
void arch_cpu_idle_prepare(void)
L
Linus Torvalds 已提交
79 80
{
	local_fiq_enable();
T
Thomas Gleixner 已提交
81
}
L
Linus Torvalds 已提交
82

T
Thomas Gleixner 已提交
83 84 85 86 87
void arch_cpu_idle_enter(void)
{
	ledtrig_cpu(CPU_LED_IDLE_START);
#ifdef CONFIG_PL310_ERRATA_769419
	wmb();
88
#endif
T
Thomas Gleixner 已提交
89
}
90

T
Thomas Gleixner 已提交
91 92 93 94 95
void arch_cpu_idle_exit(void)
{
	ledtrig_cpu(CPU_LED_IDLE_END);
}

R
Russell King 已提交
96
void __show_regs(struct pt_regs *regs)
L
Linus Torvalds 已提交
97
{
98 99
	unsigned long flags;
	char buf[64];
100
#ifndef CONFIG_CPU_V7M
101
	unsigned int domain, fs;
102 103 104 105 106 107
#ifdef CONFIG_CPU_SW_DOMAIN_PAN
	/*
	 * Get the domain register for the parent context. In user
	 * mode, we don't save the DACR, so lets use what it should
	 * be. For other modes, we place it after the pt_regs struct.
	 */
108
	if (user_mode(regs)) {
109
		domain = DACR_UACCESS_ENABLE;
110 111
		fs = get_fs();
	} else {
112
		domain = to_svc_pt_regs(regs)->dacr;
113 114
		fs = to_svc_pt_regs(regs)->addr_limit;
	}
115 116
#else
	domain = get_domain();
117
	fs = get_fs();
118 119
#endif
#endif
L
Linus Torvalds 已提交
120

121 122
	show_regs_print_info(KERN_DEFAULT);

123 124
	printk("PC is at %pS\n", (void *)instruction_pointer(regs));
	printk("LR is at %pS\n", (void *)regs->ARM_lr);
125 126 127 128
	printk("pc : [<%08lx>]    lr : [<%08lx>]    psr: %08lx\n",
	       regs->ARM_pc, regs->ARM_lr, regs->ARM_cpsr);
	printk("sp : %08lx  ip : %08lx  fp : %08lx\n",
	       regs->ARM_sp, regs->ARM_ip, regs->ARM_fp);
L
Linus Torvalds 已提交
129 130 131 132 133 134 135 136 137
	printk("r10: %08lx  r9 : %08lx  r8 : %08lx\n",
		regs->ARM_r10, regs->ARM_r9,
		regs->ARM_r8);
	printk("r7 : %08lx  r6 : %08lx  r5 : %08lx  r4 : %08lx\n",
		regs->ARM_r7, regs->ARM_r6,
		regs->ARM_r5, regs->ARM_r4);
	printk("r3 : %08lx  r2 : %08lx  r1 : %08lx  r0 : %08lx\n",
		regs->ARM_r3, regs->ARM_r2,
		regs->ARM_r1, regs->ARM_r0);
138 139 140 141 142 143 144 145

	flags = regs->ARM_cpsr;
	buf[0] = flags & PSR_N_BIT ? 'N' : 'n';
	buf[1] = flags & PSR_Z_BIT ? 'Z' : 'z';
	buf[2] = flags & PSR_C_BIT ? 'C' : 'c';
	buf[3] = flags & PSR_V_BIT ? 'V' : 'v';
	buf[4] = '\0';

146
#ifndef CONFIG_CPU_V7M
147 148 149 150 151 152
	{
		const char *segment;

		if ((domain & domain_mask(DOMAIN_USER)) ==
		    domain_val(DOMAIN_USER, DOMAIN_NOACCESS))
			segment = "none";
153
		else if (fs == get_ds())
154 155 156 157 158 159 160 161 162 163
			segment = "kernel";
		else
			segment = "user";

		printk("Flags: %s  IRQs o%s  FIQs o%s  Mode %s  ISA %s  Segment %s\n",
			buf, interrupts_enabled(regs) ? "n" : "ff",
			fast_interrupts_enabled(regs) ? "n" : "ff",
			processor_modes[processor_mode(regs)],
			isa_modes[isa_mode(regs)], segment);
	}
164 165 166 167
#else
	printk("xPSR: %08lx\n", regs->ARM_cpsr);
#endif

168
#ifdef CONFIG_CPU_CP15
L
Linus Torvalds 已提交
169
	{
170
		unsigned int ctrl;
171 172

		buf[0] = '\0';
173
#ifdef CONFIG_CPU_CP15_MMU
174
		{
175
			unsigned int transbase;
176
			asm("mrc p15, 0, %0, c2, c0\n\t"
177
			    : "=r" (transbase));
178
			snprintf(buf, sizeof(buf), "  Table: %08x  DAC: %08x",
179
				transbase, domain);
180
		}
181
#endif
182 183 184 185
		asm("mrc p15, 0, %0, c1, c0\n" : "=r" (ctrl));

		printk("Control: %08x%s\n", ctrl, buf);
	}
186
#endif
L
Linus Torvalds 已提交
187 188
}

R
Russell King 已提交
189 190 191
void show_regs(struct pt_regs * regs)
{
	__show_regs(regs);
192
	dump_stack();
R
Russell King 已提交
193 194
}

195 196 197 198
ATOMIC_NOTIFIER_HEAD(thread_notify_head);

EXPORT_SYMBOL_GPL(thread_notify_head);

L
Linus Torvalds 已提交
199 200 201
/*
 * Free current thread data structures etc..
 */
202
void exit_thread(struct task_struct *tsk)
L
Linus Torvalds 已提交
203
{
204
	thread_notify(THREAD_NOTIFY_EXIT, task_thread_info(tsk));
L
Linus Torvalds 已提交
205 206 207 208 209 210 211
}

void flush_thread(void)
{
	struct thread_info *thread = current_thread_info();
	struct task_struct *tsk = current;

212 213
	flush_ptrace_hw_breakpoint(tsk);

L
Linus Torvalds 已提交
214 215
	memset(thread->used_cp, 0, sizeof(thread->used_cp));
	memset(&tsk->thread.debug, 0, sizeof(struct debug_info));
216 217
	memset(&thread->fpstate, 0, sizeof(union fp_state));

218 219
	flush_tls();

220
	thread_notify(THREAD_NOTIFY_FLUSH, thread);
L
Linus Torvalds 已提交
221 222 223 224 225 226 227 228 229
}

void release_thread(struct task_struct *dead_task)
{
}

asmlinkage void ret_from_fork(void) __asm__("ret_from_fork");

int
A
Alexey Dobriyan 已提交
230
copy_thread(unsigned long clone_flags, unsigned long stack_start,
231
	    unsigned long stk_sz, struct task_struct *p)
L
Linus Torvalds 已提交
232
{
A
Al Viro 已提交
233 234
	struct thread_info *thread = task_thread_info(p);
	struct pt_regs *childregs = task_pt_regs(p);
L
Linus Torvalds 已提交
235 236

	memset(&thread->cpu_context, 0, sizeof(struct cpu_context_save));
237

238
#ifdef CONFIG_CPU_USE_DOMAINS
239 240 241 242 243 244 245
	/*
	 * Copy the initial value of the domain access control register
	 * from the current thread: thread->addr_limit will have been
	 * copied from the current thread via setup_thread_stack() in
	 * kernel/fork.c
	 */
	thread->cpu_domain = get_domain();
246
#endif
247

A
Al Viro 已提交
248 249
	if (likely(!(p->flags & PF_KTHREAD))) {
		*childregs = *current_pt_regs();
250
		childregs->ARM_r0 = 0;
A
Al Viro 已提交
251 252
		if (stack_start)
			childregs->ARM_sp = stack_start;
253
	} else {
254
		memset(childregs, 0, sizeof(struct pt_regs));
255 256 257 258
		thread->cpu_context.r4 = stk_sz;
		thread->cpu_context.r5 = stack_start;
		childregs->ARM_cpsr = SVC_MODE;
	}
259
	thread->cpu_context.pc = (unsigned long)ret_from_fork;
L
Linus Torvalds 已提交
260 261
	thread->cpu_context.sp = (unsigned long)childregs;

262 263
	clear_ptrace_hw_breakpoint(p);

L
Linus Torvalds 已提交
264
	if (clone_flags & CLONE_SETTLS)
265 266
		thread->tp_value[0] = childregs->ARM_r3;
	thread->tp_value[1] = get_tpuser();
L
Linus Torvalds 已提交
267

268 269
	thread_notify(THREAD_NOTIFY_COPY, thread);

L
Linus Torvalds 已提交
270 271 272
	return 0;
}

273 274 275 276 277 278 279 280 281
/*
 * Fill in the task's elfregs structure for a core dump.
 */
int dump_task_regs(struct task_struct *t, elf_gregset_t *elfregs)
{
	elf_core_copy_regs(elfregs, task_pt_regs(t));
	return 1;
}

L
Linus Torvalds 已提交
282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298
/*
 * fill in the fpe structure for a core dump...
 */
int dump_fpu (struct pt_regs *regs, struct user_fp *fp)
{
	struct thread_info *thread = current_thread_info();
	int used_math = thread->used_cp[1] | thread->used_cp[2];

	if (used_math)
		memcpy(fp, &thread->fpstate.soft, sizeof (*fp));

	return used_math != 0;
}
EXPORT_SYMBOL(dump_fpu);

unsigned long get_wchan(struct task_struct *p)
{
299
	struct stackframe frame;
300
	unsigned long stack_page;
L
Linus Torvalds 已提交
301 302 303 304
	int count = 0;
	if (!p || p == current || p->state == TASK_RUNNING)
		return 0;

305 306 307 308
	frame.fp = thread_saved_fp(p);
	frame.sp = thread_saved_sp(p);
	frame.lr = 0;			/* recovered from the stack */
	frame.pc = thread_saved_pc(p);
309
	stack_page = (unsigned long)task_stack_page(p);
L
Linus Torvalds 已提交
310
	do {
311 312 313
		if (frame.sp < stack_page ||
		    frame.sp >= stack_page + THREAD_SIZE ||
		    unwind_frame(&frame) < 0)
L
Linus Torvalds 已提交
314
			return 0;
315 316
		if (!in_sched_functions(frame.pc))
			return frame.pc;
L
Linus Torvalds 已提交
317 318 319
	} while (count ++ < 16);
	return 0;
}
320 321 322

unsigned long arch_randomize_brk(struct mm_struct *mm)
{
323
	return randomize_page(mm->brk, 0x02000000);
324
}
325

326
#ifdef CONFIG_MMU
327
#ifdef CONFIG_KUSER_HELPERS
328 329
/*
 * The vectors page is always readable from user space for the
330 331
 * atomic helpers. Insert it into the gate_vma so that it is visible
 * through ptrace and /proc/<pid>/mem.
332
 */
333 334 335 336 337
static struct vm_area_struct gate_vma = {
	.vm_start	= 0xffff0000,
	.vm_end		= 0xffff0000 + PAGE_SIZE,
	.vm_flags	= VM_READ | VM_EXEC | VM_MAYREAD | VM_MAYEXEC,
};
338

339
static int __init gate_vma_init(void)
340
{
341
	gate_vma.vm_page_prot = PAGE_READONLY_EXEC;
342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358
	return 0;
}
arch_initcall(gate_vma_init);

struct vm_area_struct *get_gate_vma(struct mm_struct *mm)
{
	return &gate_vma;
}

int in_gate_area(struct mm_struct *mm, unsigned long addr)
{
	return (addr >= gate_vma.vm_start) && (addr < gate_vma.vm_end);
}

int in_gate_area_no_mm(unsigned long addr)
{
	return in_gate_area(NULL, addr);
359
}
360
#define is_gate_vma(vma)	((vma) == &gate_vma)
361 362 363
#else
#define is_gate_vma(vma)	0
#endif
364 365 366

const char *arch_vma_name(struct vm_area_struct *vma)
{
367
	return is_gate_vma(vma) ? "[vectors]" : NULL;
368 369
}

370
/* If possible, provide a placement hint at a random offset from the
371
 * stack for the sigpage and vdso pages.
372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400
 */
static unsigned long sigpage_addr(const struct mm_struct *mm,
				  unsigned int npages)
{
	unsigned long offset;
	unsigned long first;
	unsigned long last;
	unsigned long addr;
	unsigned int slots;

	first = PAGE_ALIGN(mm->start_stack);

	last = TASK_SIZE - (npages << PAGE_SHIFT);

	/* No room after stack? */
	if (first > last)
		return 0;

	/* Just enough room? */
	if (first == last)
		return first;

	slots = ((last - first) >> PAGE_SHIFT) + 1;

	offset = get_random_int() % slots;

	addr = first + (offset << PAGE_SHIFT);

	return addr;
401 402
}

403
static struct page *signal_page;
404 405
extern struct page *get_signal_page(void);

406 407 408 409 410 411 412
static int sigpage_mremap(const struct vm_special_mapping *sm,
		struct vm_area_struct *new_vma)
{
	current->mm->context.sigpage = new_vma->vm_start;
	return 0;
}

413 414 415
static const struct vm_special_mapping sigpage_mapping = {
	.name = "[sigpage]",
	.pages = &signal_page,
416
	.mremap = sigpage_mremap,
417 418
};

419 420 421
int arch_setup_additional_pages(struct linux_binprm *bprm, int uses_interp)
{
	struct mm_struct *mm = current->mm;
422
	struct vm_area_struct *vma;
423
	unsigned long npages;
424
	unsigned long addr;
425
	unsigned long hint;
426
	int ret = 0;
427

428 429 430
	if (!signal_page)
		signal_page = get_signal_page();
	if (!signal_page)
431 432
		return -ENOMEM;

433 434 435
	npages = 1; /* for sigpage */
	npages += vdso_total_pages;

436 437
	if (down_write_killable(&mm->mmap_sem))
		return -EINTR;
438 439
	hint = sigpage_addr(mm, npages);
	addr = get_unmapped_area(NULL, hint, npages << PAGE_SHIFT, 0, 0);
440 441 442 443 444
	if (IS_ERR_VALUE(addr)) {
		ret = addr;
		goto up_fail;
	}

445
	vma = _install_special_mapping(mm, addr, PAGE_SIZE,
446
		VM_READ | VM_EXEC | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC,
447 448 449 450 451 452
		&sigpage_mapping);

	if (IS_ERR(vma)) {
		ret = PTR_ERR(vma);
		goto up_fail;
	}
453

454
	mm->context.sigpage = addr;
455

456 457 458 459 460 461
	/* Unlike the sigpage, failure to install the vdso is unlikely
	 * to be fatal to the process, so no error check needed
	 * here.
	 */
	arm_install_vdso(mm, addr + PAGE_SIZE);

462 463 464
 up_fail:
	up_write(&mm->mmap_sem);
	return ret;
465
}
466
#endif