Linux 2.6.25.3
[linux/fpc-iii.git] / arch / x86 / kernel / process_64.c
blob46c4c546b499806fc70aa2788393a9e989106949
1 /*
2 * Copyright (C) 1995 Linus Torvalds
4 * Pentium III FXSR, SSE support
5 * Gareth Hughes <gareth@valinux.com>, May 2000
7 * X86-64 port
8 * Andi Kleen.
10 * CPU hotplug support - ashok.raj@intel.com
14 * This file handles the architecture-dependent parts of process handling..
17 #include <stdarg.h>
19 #include <linux/cpu.h>
20 #include <linux/errno.h>
21 #include <linux/sched.h>
22 #include <linux/fs.h>
23 #include <linux/kernel.h>
24 #include <linux/mm.h>
25 #include <linux/elfcore.h>
26 #include <linux/smp.h>
27 #include <linux/slab.h>
28 #include <linux/user.h>
29 #include <linux/interrupt.h>
30 #include <linux/utsname.h>
31 #include <linux/delay.h>
32 #include <linux/module.h>
33 #include <linux/ptrace.h>
34 #include <linux/random.h>
35 #include <linux/notifier.h>
36 #include <linux/kprobes.h>
37 #include <linux/kdebug.h>
38 #include <linux/tick.h>
40 #include <asm/uaccess.h>
41 #include <asm/pgtable.h>
42 #include <asm/system.h>
43 #include <asm/io.h>
44 #include <asm/processor.h>
45 #include <asm/i387.h>
46 #include <asm/mmu_context.h>
47 #include <asm/pda.h>
48 #include <asm/prctl.h>
49 #include <asm/desc.h>
50 #include <asm/proto.h>
51 #include <asm/ia32.h>
52 #include <asm/idle.h>
54 asmlinkage extern void ret_from_fork(void);
56 unsigned long kernel_thread_flags = CLONE_VM | CLONE_UNTRACED;
58 unsigned long boot_option_idle_override = 0;
59 EXPORT_SYMBOL(boot_option_idle_override);
62 * Powermanagement idle function, if any..
64 void (*pm_idle)(void);
65 EXPORT_SYMBOL(pm_idle);
67 static ATOMIC_NOTIFIER_HEAD(idle_notifier);
69 void idle_notifier_register(struct notifier_block *n)
71 atomic_notifier_chain_register(&idle_notifier, n);
74 void enter_idle(void)
76 write_pda(isidle, 1);
77 atomic_notifier_call_chain(&idle_notifier, IDLE_START, NULL);
80 static void __exit_idle(void)
82 if (test_and_clear_bit_pda(0, isidle) == 0)
83 return;
84 atomic_notifier_call_chain(&idle_notifier, IDLE_END, NULL);
87 /* Called from interrupts to signify idle end */
88 void exit_idle(void)
90 /* idle loop has pid 0 */
91 if (current->pid)
92 return;
93 __exit_idle();
97 * We use this if we don't have any better
98 * idle routine..
100 void default_idle(void)
102 current_thread_info()->status &= ~TS_POLLING;
104 * TS_POLLING-cleared state must be visible before we
105 * test NEED_RESCHED:
107 smp_mb();
108 local_irq_disable();
109 if (!need_resched()) {
110 ktime_t t0, t1;
111 u64 t0n, t1n;
113 t0 = ktime_get();
114 t0n = ktime_to_ns(t0);
115 safe_halt(); /* enables interrupts racelessly */
116 local_irq_disable();
117 t1 = ktime_get();
118 t1n = ktime_to_ns(t1);
119 sched_clock_idle_wakeup_event(t1n - t0n);
121 local_irq_enable();
122 current_thread_info()->status |= TS_POLLING;
126 * On SMP it's slightly faster (but much more power-consuming!)
127 * to poll the ->need_resched flag instead of waiting for the
128 * cross-CPU IPI to arrive. Use this option with caution.
130 static void poll_idle(void)
132 local_irq_enable();
133 cpu_relax();
136 #ifdef CONFIG_HOTPLUG_CPU
137 DECLARE_PER_CPU(int, cpu_state);
139 #include <asm/nmi.h>
140 /* We halt the CPU with physical CPU hotplug */
141 static inline void play_dead(void)
143 idle_task_exit();
144 wbinvd();
145 mb();
146 /* Ack it */
147 __get_cpu_var(cpu_state) = CPU_DEAD;
149 local_irq_disable();
150 while (1)
151 halt();
153 #else
154 static inline void play_dead(void)
156 BUG();
158 #endif /* CONFIG_HOTPLUG_CPU */
161 * The idle thread. There's no useful work to be
162 * done, so just try to conserve power and have a
163 * low exit latency (ie sit in a loop waiting for
164 * somebody to say that they'd like to reschedule)
166 void cpu_idle(void)
168 current_thread_info()->status |= TS_POLLING;
169 /* endless idle loop with no priority at all */
170 while (1) {
171 tick_nohz_stop_sched_tick();
172 while (!need_resched()) {
173 void (*idle)(void);
175 rmb();
176 idle = pm_idle;
177 if (!idle)
178 idle = default_idle;
179 if (cpu_is_offline(smp_processor_id()))
180 play_dead();
182 * Idle routines should keep interrupts disabled
183 * from here on, until they go to idle.
184 * Otherwise, idle callbacks can misfire.
186 local_irq_disable();
187 enter_idle();
188 idle();
189 /* In many cases the interrupt that ended idle
190 has already called exit_idle. But some idle
191 loops can be woken up without interrupt. */
192 __exit_idle();
195 tick_nohz_restart_sched_tick();
196 preempt_enable_no_resched();
197 schedule();
198 preempt_disable();
202 static void do_nothing(void *unused)
207 * cpu_idle_wait - Used to ensure that all the CPUs discard old value of
208 * pm_idle and update to new pm_idle value. Required while changing pm_idle
209 * handler on SMP systems.
211 * Caller must have changed pm_idle to the new value before the call. Old
212 * pm_idle value will not be used by any CPU after the return of this function.
214 void cpu_idle_wait(void)
216 smp_mb();
217 /* kick all the CPUs so that they exit out of pm_idle */
218 smp_call_function(do_nothing, NULL, 0, 1);
220 EXPORT_SYMBOL_GPL(cpu_idle_wait);
223 * This uses new MONITOR/MWAIT instructions on P4 processors with PNI,
224 * which can obviate IPI to trigger checking of need_resched.
225 * We execute MONITOR against need_resched and enter optimized wait state
226 * through MWAIT. Whenever someone changes need_resched, we would be woken
227 * up from MWAIT (without an IPI).
229 * New with Core Duo processors, MWAIT can take some hints based on CPU
230 * capability.
232 void mwait_idle_with_hints(unsigned long ax, unsigned long cx)
234 if (!need_resched()) {
235 __monitor((void *)&current_thread_info()->flags, 0, 0);
236 smp_mb();
237 if (!need_resched())
238 __mwait(ax, cx);
242 /* Default MONITOR/MWAIT with no hints, used for default C1 state */
243 static void mwait_idle(void)
245 if (!need_resched()) {
246 __monitor((void *)&current_thread_info()->flags, 0, 0);
247 smp_mb();
248 if (!need_resched())
249 __sti_mwait(0, 0);
250 else
251 local_irq_enable();
252 } else {
253 local_irq_enable();
258 static int __cpuinit mwait_usable(const struct cpuinfo_x86 *c)
260 if (force_mwait)
261 return 1;
262 /* Any C1 states supported? */
263 return c->cpuid_level >= 5 && ((cpuid_edx(5) >> 4) & 0xf) > 0;
266 void __cpuinit select_idle_routine(const struct cpuinfo_x86 *c)
268 static int selected;
270 if (selected)
271 return;
272 #ifdef CONFIG_X86_SMP
273 if (pm_idle == poll_idle && smp_num_siblings > 1) {
274 printk(KERN_WARNING "WARNING: polling idle and HT enabled,"
275 " performance may degrade.\n");
277 #endif
278 if (cpu_has(c, X86_FEATURE_MWAIT) && mwait_usable(c)) {
280 * Skip, if setup has overridden idle.
281 * One CPU supports mwait => All CPUs supports mwait
283 if (!pm_idle) {
284 printk(KERN_INFO "using mwait in idle threads.\n");
285 pm_idle = mwait_idle;
288 selected = 1;
291 static int __init idle_setup(char *str)
293 if (!strcmp(str, "poll")) {
294 printk("using polling idle threads.\n");
295 pm_idle = poll_idle;
296 } else if (!strcmp(str, "mwait"))
297 force_mwait = 1;
298 else
299 return -1;
301 boot_option_idle_override = 1;
302 return 0;
304 early_param("idle", idle_setup);
306 /* Prints also some state that isn't saved in the pt_regs */
307 void __show_regs(struct pt_regs * regs)
309 unsigned long cr0 = 0L, cr2 = 0L, cr3 = 0L, cr4 = 0L, fs, gs, shadowgs;
310 unsigned long d0, d1, d2, d3, d6, d7;
311 unsigned int fsindex, gsindex;
312 unsigned int ds, cs, es;
314 printk("\n");
315 print_modules();
316 printk("Pid: %d, comm: %.20s %s %s %.*s\n",
317 current->pid, current->comm, print_tainted(),
318 init_utsname()->release,
319 (int)strcspn(init_utsname()->version, " "),
320 init_utsname()->version);
321 printk("RIP: %04lx:[<%016lx>] ", regs->cs & 0xffff, regs->ip);
322 printk_address(regs->ip, 1);
323 printk("RSP: %04lx:%016lx EFLAGS: %08lx\n", regs->ss, regs->sp,
324 regs->flags);
325 printk("RAX: %016lx RBX: %016lx RCX: %016lx\n",
326 regs->ax, regs->bx, regs->cx);
327 printk("RDX: %016lx RSI: %016lx RDI: %016lx\n",
328 regs->dx, regs->si, regs->di);
329 printk("RBP: %016lx R08: %016lx R09: %016lx\n",
330 regs->bp, regs->r8, regs->r9);
331 printk("R10: %016lx R11: %016lx R12: %016lx\n",
332 regs->r10, regs->r11, regs->r12);
333 printk("R13: %016lx R14: %016lx R15: %016lx\n",
334 regs->r13, regs->r14, regs->r15);
336 asm("movl %%ds,%0" : "=r" (ds));
337 asm("movl %%cs,%0" : "=r" (cs));
338 asm("movl %%es,%0" : "=r" (es));
339 asm("movl %%fs,%0" : "=r" (fsindex));
340 asm("movl %%gs,%0" : "=r" (gsindex));
342 rdmsrl(MSR_FS_BASE, fs);
343 rdmsrl(MSR_GS_BASE, gs);
344 rdmsrl(MSR_KERNEL_GS_BASE, shadowgs);
346 cr0 = read_cr0();
347 cr2 = read_cr2();
348 cr3 = read_cr3();
349 cr4 = read_cr4();
351 printk("FS: %016lx(%04x) GS:%016lx(%04x) knlGS:%016lx\n",
352 fs,fsindex,gs,gsindex,shadowgs);
353 printk("CS: %04x DS: %04x ES: %04x CR0: %016lx\n", cs, ds, es, cr0);
354 printk("CR2: %016lx CR3: %016lx CR4: %016lx\n", cr2, cr3, cr4);
356 get_debugreg(d0, 0);
357 get_debugreg(d1, 1);
358 get_debugreg(d2, 2);
359 printk("DR0: %016lx DR1: %016lx DR2: %016lx\n", d0, d1, d2);
360 get_debugreg(d3, 3);
361 get_debugreg(d6, 6);
362 get_debugreg(d7, 7);
363 printk("DR3: %016lx DR6: %016lx DR7: %016lx\n", d3, d6, d7);
366 void show_regs(struct pt_regs *regs)
368 printk("CPU %d:", smp_processor_id());
369 __show_regs(regs);
370 show_trace(NULL, regs, (void *)(regs + 1), regs->bp);
374 * Free current thread data structures etc..
376 void exit_thread(void)
378 struct task_struct *me = current;
379 struct thread_struct *t = &me->thread;
381 if (me->thread.io_bitmap_ptr) {
382 struct tss_struct *tss = &per_cpu(init_tss, get_cpu());
384 kfree(t->io_bitmap_ptr);
385 t->io_bitmap_ptr = NULL;
386 clear_thread_flag(TIF_IO_BITMAP);
388 * Careful, clear this in the TSS too:
390 memset(tss->io_bitmap, 0xff, t->io_bitmap_max);
391 t->io_bitmap_max = 0;
392 put_cpu();
396 void flush_thread(void)
398 struct task_struct *tsk = current;
400 if (test_tsk_thread_flag(tsk, TIF_ABI_PENDING)) {
401 clear_tsk_thread_flag(tsk, TIF_ABI_PENDING);
402 if (test_tsk_thread_flag(tsk, TIF_IA32)) {
403 clear_tsk_thread_flag(tsk, TIF_IA32);
404 } else {
405 set_tsk_thread_flag(tsk, TIF_IA32);
406 current_thread_info()->status |= TS_COMPAT;
409 clear_tsk_thread_flag(tsk, TIF_DEBUG);
411 tsk->thread.debugreg0 = 0;
412 tsk->thread.debugreg1 = 0;
413 tsk->thread.debugreg2 = 0;
414 tsk->thread.debugreg3 = 0;
415 tsk->thread.debugreg6 = 0;
416 tsk->thread.debugreg7 = 0;
417 memset(tsk->thread.tls_array, 0, sizeof(tsk->thread.tls_array));
419 * Forget coprocessor state..
421 clear_fpu(tsk);
422 clear_used_math();
425 void release_thread(struct task_struct *dead_task)
427 if (dead_task->mm) {
428 if (dead_task->mm->context.size) {
429 printk("WARNING: dead process %8s still has LDT? <%p/%d>\n",
430 dead_task->comm,
431 dead_task->mm->context.ldt,
432 dead_task->mm->context.size);
433 BUG();
438 static inline void set_32bit_tls(struct task_struct *t, int tls, u32 addr)
440 struct user_desc ud = {
441 .base_addr = addr,
442 .limit = 0xfffff,
443 .seg_32bit = 1,
444 .limit_in_pages = 1,
445 .useable = 1,
447 struct desc_struct *desc = t->thread.tls_array;
448 desc += tls;
449 fill_ldt(desc, &ud);
452 static inline u32 read_32bit_tls(struct task_struct *t, int tls)
454 return get_desc_base(&t->thread.tls_array[tls]);
458 * This gets called before we allocate a new thread and copy
459 * the current task into it.
461 void prepare_to_copy(struct task_struct *tsk)
463 unlazy_fpu(tsk);
466 int copy_thread(int nr, unsigned long clone_flags, unsigned long sp,
467 unsigned long unused,
468 struct task_struct * p, struct pt_regs * regs)
470 int err;
471 struct pt_regs * childregs;
472 struct task_struct *me = current;
474 childregs = ((struct pt_regs *)
475 (THREAD_SIZE + task_stack_page(p))) - 1;
476 *childregs = *regs;
478 childregs->ax = 0;
479 childregs->sp = sp;
480 if (sp == ~0UL)
481 childregs->sp = (unsigned long)childregs;
483 p->thread.sp = (unsigned long) childregs;
484 p->thread.sp0 = (unsigned long) (childregs+1);
485 p->thread.usersp = me->thread.usersp;
487 set_tsk_thread_flag(p, TIF_FORK);
489 p->thread.fs = me->thread.fs;
490 p->thread.gs = me->thread.gs;
492 asm("mov %%gs,%0" : "=m" (p->thread.gsindex));
493 asm("mov %%fs,%0" : "=m" (p->thread.fsindex));
494 asm("mov %%es,%0" : "=m" (p->thread.es));
495 asm("mov %%ds,%0" : "=m" (p->thread.ds));
497 if (unlikely(test_tsk_thread_flag(me, TIF_IO_BITMAP))) {
498 p->thread.io_bitmap_ptr = kmalloc(IO_BITMAP_BYTES, GFP_KERNEL);
499 if (!p->thread.io_bitmap_ptr) {
500 p->thread.io_bitmap_max = 0;
501 return -ENOMEM;
503 memcpy(p->thread.io_bitmap_ptr, me->thread.io_bitmap_ptr,
504 IO_BITMAP_BYTES);
505 set_tsk_thread_flag(p, TIF_IO_BITMAP);
509 * Set a new TLS for the child thread?
511 if (clone_flags & CLONE_SETTLS) {
512 #ifdef CONFIG_IA32_EMULATION
513 if (test_thread_flag(TIF_IA32))
514 err = do_set_thread_area(p, -1,
515 (struct user_desc __user *)childregs->si, 0);
516 else
517 #endif
518 err = do_arch_prctl(p, ARCH_SET_FS, childregs->r8);
519 if (err)
520 goto out;
522 err = 0;
523 out:
524 if (err && p->thread.io_bitmap_ptr) {
525 kfree(p->thread.io_bitmap_ptr);
526 p->thread.io_bitmap_max = 0;
528 return err;
532 * This special macro can be used to load a debugging register
534 #define loaddebug(thread, r) set_debugreg(thread->debugreg ## r, r)
536 static inline void __switch_to_xtra(struct task_struct *prev_p,
537 struct task_struct *next_p,
538 struct tss_struct *tss)
540 struct thread_struct *prev, *next;
541 unsigned long debugctl;
543 prev = &prev_p->thread,
544 next = &next_p->thread;
546 debugctl = prev->debugctlmsr;
547 if (next->ds_area_msr != prev->ds_area_msr) {
548 /* we clear debugctl to make sure DS
549 * is not in use when we change it */
550 debugctl = 0;
551 wrmsrl(MSR_IA32_DEBUGCTLMSR, 0);
552 wrmsrl(MSR_IA32_DS_AREA, next->ds_area_msr);
555 if (next->debugctlmsr != debugctl)
556 wrmsrl(MSR_IA32_DEBUGCTLMSR, next->debugctlmsr);
558 if (test_tsk_thread_flag(next_p, TIF_DEBUG)) {
559 loaddebug(next, 0);
560 loaddebug(next, 1);
561 loaddebug(next, 2);
562 loaddebug(next, 3);
563 /* no 4 and 5 */
564 loaddebug(next, 6);
565 loaddebug(next, 7);
568 if (test_tsk_thread_flag(next_p, TIF_IO_BITMAP)) {
570 * Copy the relevant range of the IO bitmap.
571 * Normally this is 128 bytes or less:
573 memcpy(tss->io_bitmap, next->io_bitmap_ptr,
574 max(prev->io_bitmap_max, next->io_bitmap_max));
575 } else if (test_tsk_thread_flag(prev_p, TIF_IO_BITMAP)) {
577 * Clear any possible leftover bits:
579 memset(tss->io_bitmap, 0xff, prev->io_bitmap_max);
582 #ifdef X86_BTS
583 if (test_tsk_thread_flag(prev_p, TIF_BTS_TRACE_TS))
584 ptrace_bts_take_timestamp(prev_p, BTS_TASK_DEPARTS);
586 if (test_tsk_thread_flag(next_p, TIF_BTS_TRACE_TS))
587 ptrace_bts_take_timestamp(next_p, BTS_TASK_ARRIVES);
588 #endif
592 * switch_to(x,y) should switch tasks from x to y.
594 * This could still be optimized:
595 * - fold all the options into a flag word and test it with a single test.
596 * - could test fs/gs bitsliced
598 * Kprobes not supported here. Set the probe on schedule instead.
600 struct task_struct *
601 __switch_to(struct task_struct *prev_p, struct task_struct *next_p)
603 struct thread_struct *prev = &prev_p->thread,
604 *next = &next_p->thread;
605 int cpu = smp_processor_id();
606 struct tss_struct *tss = &per_cpu(init_tss, cpu);
608 /* we're going to use this soon, after a few expensive things */
609 if (next_p->fpu_counter>5)
610 prefetch(&next->i387.fxsave);
613 * Reload esp0, LDT and the page table pointer:
615 load_sp0(tss, next);
618 * Switch DS and ES.
619 * This won't pick up thread selector changes, but I guess that is ok.
621 asm volatile("mov %%es,%0" : "=m" (prev->es));
622 if (unlikely(next->es | prev->es))
623 loadsegment(es, next->es);
625 asm volatile ("mov %%ds,%0" : "=m" (prev->ds));
626 if (unlikely(next->ds | prev->ds))
627 loadsegment(ds, next->ds);
629 load_TLS(next, cpu);
632 * Switch FS and GS.
635 unsigned fsindex;
636 asm volatile("movl %%fs,%0" : "=r" (fsindex));
637 /* segment register != 0 always requires a reload.
638 also reload when it has changed.
639 when prev process used 64bit base always reload
640 to avoid an information leak. */
641 if (unlikely(fsindex | next->fsindex | prev->fs)) {
642 loadsegment(fs, next->fsindex);
643 /* check if the user used a selector != 0
644 * if yes clear 64bit base, since overloaded base
645 * is always mapped to the Null selector
647 if (fsindex)
648 prev->fs = 0;
650 /* when next process has a 64bit base use it */
651 if (next->fs)
652 wrmsrl(MSR_FS_BASE, next->fs);
653 prev->fsindex = fsindex;
656 unsigned gsindex;
657 asm volatile("movl %%gs,%0" : "=r" (gsindex));
658 if (unlikely(gsindex | next->gsindex | prev->gs)) {
659 load_gs_index(next->gsindex);
660 if (gsindex)
661 prev->gs = 0;
663 if (next->gs)
664 wrmsrl(MSR_KERNEL_GS_BASE, next->gs);
665 prev->gsindex = gsindex;
668 /* Must be after DS reload */
669 unlazy_fpu(prev_p);
672 * Switch the PDA and FPU contexts.
674 prev->usersp = read_pda(oldrsp);
675 write_pda(oldrsp, next->usersp);
676 write_pda(pcurrent, next_p);
678 write_pda(kernelstack,
679 (unsigned long)task_stack_page(next_p) + THREAD_SIZE - PDA_STACKOFFSET);
680 #ifdef CONFIG_CC_STACKPROTECTOR
681 write_pda(stack_canary, next_p->stack_canary);
683 * Build time only check to make sure the stack_canary is at
684 * offset 40 in the pda; this is a gcc ABI requirement
686 BUILD_BUG_ON(offsetof(struct x8664_pda, stack_canary) != 40);
687 #endif
690 * Now maybe reload the debug registers and handle I/O bitmaps
692 if (unlikely(task_thread_info(next_p)->flags & _TIF_WORK_CTXSW_NEXT ||
693 task_thread_info(prev_p)->flags & _TIF_WORK_CTXSW_PREV))
694 __switch_to_xtra(prev_p, next_p, tss);
696 /* If the task has used fpu the last 5 timeslices, just do a full
697 * restore of the math state immediately to avoid the trap; the
698 * chances of needing FPU soon are obviously high now
700 if (next_p->fpu_counter>5)
701 math_state_restore();
702 return prev_p;
706 * sys_execve() executes a new program.
708 asmlinkage
709 long sys_execve(char __user *name, char __user * __user *argv,
710 char __user * __user *envp, struct pt_regs *regs)
712 long error;
713 char * filename;
715 filename = getname(name);
716 error = PTR_ERR(filename);
717 if (IS_ERR(filename))
718 return error;
719 error = do_execve(filename, argv, envp, regs);
720 putname(filename);
721 return error;
724 void set_personality_64bit(void)
726 /* inherit personality from parent */
728 /* Make sure to be in 64bit mode */
729 clear_thread_flag(TIF_IA32);
731 /* TBD: overwrites user setup. Should have two bits.
732 But 64bit processes have always behaved this way,
733 so it's not too bad. The main problem is just that
734 32bit childs are affected again. */
735 current->personality &= ~READ_IMPLIES_EXEC;
738 asmlinkage long sys_fork(struct pt_regs *regs)
740 return do_fork(SIGCHLD, regs->sp, regs, 0, NULL, NULL);
743 asmlinkage long
744 sys_clone(unsigned long clone_flags, unsigned long newsp,
745 void __user *parent_tid, void __user *child_tid, struct pt_regs *regs)
747 if (!newsp)
748 newsp = regs->sp;
749 return do_fork(clone_flags, newsp, regs, 0, parent_tid, child_tid);
753 * This is trivial, and on the face of it looks like it
754 * could equally well be done in user mode.
756 * Not so, for quite unobvious reasons - register pressure.
757 * In user mode vfork() cannot have a stack frame, and if
758 * done by calling the "clone()" system call directly, you
759 * do not have enough call-clobbered registers to hold all
760 * the information you need.
762 asmlinkage long sys_vfork(struct pt_regs *regs)
764 return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, regs->sp, regs, 0,
765 NULL, NULL);
768 unsigned long get_wchan(struct task_struct *p)
770 unsigned long stack;
771 u64 fp,ip;
772 int count = 0;
774 if (!p || p == current || p->state==TASK_RUNNING)
775 return 0;
776 stack = (unsigned long)task_stack_page(p);
777 if (p->thread.sp < stack || p->thread.sp > stack+THREAD_SIZE)
778 return 0;
779 fp = *(u64 *)(p->thread.sp);
780 do {
781 if (fp < (unsigned long)stack ||
782 fp > (unsigned long)stack+THREAD_SIZE)
783 return 0;
784 ip = *(u64 *)(fp+8);
785 if (!in_sched_functions(ip))
786 return ip;
787 fp = *(u64 *)fp;
788 } while (count++ < 16);
789 return 0;
792 long do_arch_prctl(struct task_struct *task, int code, unsigned long addr)
794 int ret = 0;
795 int doit = task == current;
796 int cpu;
798 switch (code) {
799 case ARCH_SET_GS:
800 if (addr >= TASK_SIZE_OF(task))
801 return -EPERM;
802 cpu = get_cpu();
803 /* handle small bases via the GDT because that's faster to
804 switch. */
805 if (addr <= 0xffffffff) {
806 set_32bit_tls(task, GS_TLS, addr);
807 if (doit) {
808 load_TLS(&task->thread, cpu);
809 load_gs_index(GS_TLS_SEL);
811 task->thread.gsindex = GS_TLS_SEL;
812 task->thread.gs = 0;
813 } else {
814 task->thread.gsindex = 0;
815 task->thread.gs = addr;
816 if (doit) {
817 load_gs_index(0);
818 ret = checking_wrmsrl(MSR_KERNEL_GS_BASE, addr);
821 put_cpu();
822 break;
823 case ARCH_SET_FS:
824 /* Not strictly needed for fs, but do it for symmetry
825 with gs */
826 if (addr >= TASK_SIZE_OF(task))
827 return -EPERM;
828 cpu = get_cpu();
829 /* handle small bases via the GDT because that's faster to
830 switch. */
831 if (addr <= 0xffffffff) {
832 set_32bit_tls(task, FS_TLS, addr);
833 if (doit) {
834 load_TLS(&task->thread, cpu);
835 asm volatile("movl %0,%%fs" :: "r"(FS_TLS_SEL));
837 task->thread.fsindex = FS_TLS_SEL;
838 task->thread.fs = 0;
839 } else {
840 task->thread.fsindex = 0;
841 task->thread.fs = addr;
842 if (doit) {
843 /* set the selector to 0 to not confuse
844 __switch_to */
845 asm volatile("movl %0,%%fs" :: "r" (0));
846 ret = checking_wrmsrl(MSR_FS_BASE, addr);
849 put_cpu();
850 break;
851 case ARCH_GET_FS: {
852 unsigned long base;
853 if (task->thread.fsindex == FS_TLS_SEL)
854 base = read_32bit_tls(task, FS_TLS);
855 else if (doit)
856 rdmsrl(MSR_FS_BASE, base);
857 else
858 base = task->thread.fs;
859 ret = put_user(base, (unsigned long __user *)addr);
860 break;
862 case ARCH_GET_GS: {
863 unsigned long base;
864 unsigned gsindex;
865 if (task->thread.gsindex == GS_TLS_SEL)
866 base = read_32bit_tls(task, GS_TLS);
867 else if (doit) {
868 asm("movl %%gs,%0" : "=r" (gsindex));
869 if (gsindex)
870 rdmsrl(MSR_KERNEL_GS_BASE, base);
871 else
872 base = task->thread.gs;
874 else
875 base = task->thread.gs;
876 ret = put_user(base, (unsigned long __user *)addr);
877 break;
880 default:
881 ret = -EINVAL;
882 break;
885 return ret;
888 long sys_arch_prctl(int code, unsigned long addr)
890 return do_arch_prctl(current, code, addr);
893 unsigned long arch_align_stack(unsigned long sp)
895 if (!(current->personality & ADDR_NO_RANDOMIZE) && randomize_va_space)
896 sp -= get_random_int() % 8192;
897 return sp & ~0xf;
900 unsigned long arch_randomize_brk(struct mm_struct *mm)
902 unsigned long range_end = mm->brk + 0x02000000;
903 return randomize_range(mm->brk, range_end, 0) ? : mm->brk;