tag | line | file | source code |
tsk | 24 | fs/nfs/mmap.c | extern int share_page(struct vm_area_struct * area, struct task_struct * tsk, |
tsk | 28 | fs/nfs/mmap.c | extern unsigned long put_page(struct task_struct * tsk,unsigned long page, |
tsk | 92 | include/linux/mm.h | extern unsigned long put_dirty_page(struct task_struct * tsk,unsigned long page, |
tsk | 94 | include/linux/mm.h | extern void free_page_tables(struct task_struct * tsk); |
tsk | 95 | include/linux/mm.h | extern void clear_page_tables(struct task_struct * tsk); |
tsk | 103 | include/linux/mm.h | struct task_struct *tsk, unsigned long user_esp); |
tsk | 105 | include/linux/mm.h | struct task_struct *tsk, unsigned long user_esp); |
tsk | 304 | include/linux/sched.h | extern void notify_parent(struct task_struct * tsk); |
tsk | 343 | include/linux/sched.h | #define switch_to(tsk) \ |
tsk | 355 | include/linux/sched.h | :"m" (*(((char *)&tsk->tss.tr)-4)), \ |
tsk | 356 | include/linux/sched.h | "c" (tsk) \ |
tsk | 69 | kernel/exit.c | void notify_parent(struct task_struct * tsk) |
tsk | 71 | kernel/exit.c | if (tsk->p_pptr == task[1]) |
tsk | 72 | kernel/exit.c | tsk->exit_signal = SIGCHLD; |
tsk | 73 | kernel/exit.c | send_sig(tsk->exit_signal, tsk->p_pptr, 1); |
tsk | 74 | kernel/exit.c | wake_up_interruptible(&tsk->p_pptr->wait_chldexit); |
tsk | 92 | kernel/fork.c | int dup_mmap(struct task_struct * tsk) |
tsk | 96 | kernel/fork.c | tsk->mmap = NULL; |
tsk | 97 | kernel/fork.c | p = &tsk->mmap; |
tsk | 103 | kernel/fork.c | tmp->vm_task = tsk; |
tsk | 86 | kernel/ptrace.c | static unsigned long get_long(struct task_struct * tsk, |
tsk | 92 | kernel/ptrace.c | page = *PAGE_DIR_OFFSET(tsk->tss.cr3,addr); |
tsk | 99 | kernel/ptrace.c | do_no_page(0,addr,tsk,0); |
tsk | 113 | kernel/ptrace.c | static void put_long(struct task_struct * tsk, unsigned long addr, |
tsk | 119 | kernel/ptrace.c | page = *PAGE_DIR_OFFSET(tsk->tss.cr3,addr); |
tsk | 127 | kernel/ptrace.c | do_no_page(PAGE_RW,addr,tsk,0); |
tsk | 131 | kernel/ptrace.c | do_wp_page(PAGE_RW | PAGE_PRESENT,addr,tsk,0); |
tsk | 145 | kernel/ptrace.c | static int read_long(struct task_struct * tsk, unsigned long addr, |
tsk | 153 | kernel/ptrace.c | low = get_long(tsk,addr & ~(sizeof(long)-1)); |
tsk | 154 | kernel/ptrace.c | high = get_long(tsk,(addr+sizeof(long)) & ~(sizeof(long)-1)); |
tsk | 171 | kernel/ptrace.c | *result = get_long(tsk,addr); |
tsk | 179 | kernel/ptrace.c | static int write_long(struct task_struct * tsk, unsigned long addr, |
tsk | 187 | kernel/ptrace.c | low = get_long(tsk,addr & ~(sizeof(long)-1)); |
tsk | 188 | kernel/ptrace.c | high = get_long(tsk,(addr+sizeof(long)) & ~(sizeof(long)-1)); |
tsk | 212 | kernel/ptrace.c | put_long(tsk,addr & ~(sizeof(long)-1),low); |
tsk | 213 | kernel/ptrace.c | put_long(tsk,(addr+sizeof(long)) & ~(sizeof(long)-1),high); |
tsk | 215 | kernel/ptrace.c | put_long(tsk,addr,data); |
tsk | 152 | kernel/sys.c | static void mark_screen_rdonly(struct task_struct * tsk) |
tsk | 157 | kernel/sys.c | if ((tmp = tsk->tss.cr3) != 0) { |
tsk | 116 | mm/memory.c | void clear_page_tables(struct task_struct * tsk) |
tsk | 122 | mm/memory.c | if (!tsk) |
tsk | 124 | mm/memory.c | if (tsk == task[0]) |
tsk | 126 | mm/memory.c | pg_dir = tsk->tss.cr3; |
tsk | 136 | mm/memory.c | oom(tsk); |
tsk | 142 | mm/memory.c | tsk->tss.cr3 = (unsigned long) new_pg; |
tsk | 154 | mm/memory.c | void free_page_tables(struct task_struct * tsk) |
tsk | 160 | mm/memory.c | if (!tsk) |
tsk | 162 | mm/memory.c | if (tsk == task[0]) { |
tsk | 166 | mm/memory.c | pg_dir = tsk->tss.cr3; |
tsk | 171 | mm/memory.c | tsk->tss.cr3 = (unsigned long) swapper_pg_dir; |
tsk | 172 | mm/memory.c | if (tsk == current) |
tsk | 173 | mm/memory.c | __asm__ __volatile__("movl %0,%%cr3": :"a" (tsk->tss.cr3)); |
tsk | 191 | mm/memory.c | int clone_page_tables(struct task_struct * tsk) |
tsk | 197 | mm/memory.c | tsk->tss.cr3 = pg_dir; |
tsk | 206 | mm/memory.c | int copy_page_tables(struct task_struct * tsk) |
tsk | 215 | mm/memory.c | tsk->tss.cr3 = new_pg_dir; |
tsk | 237 | mm/memory.c | free_page_tables(tsk); |
tsk | 467 | mm/memory.c | unsigned long put_page(struct task_struct * tsk,unsigned long page, |
tsk | 478 | mm/memory.c | page_table = PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 483 | mm/memory.c | oom(tsk); |
tsk | 504 | mm/memory.c | unsigned long put_dirty_page(struct task_struct * tsk, unsigned long page, unsigned long address) |
tsk | 512 | mm/memory.c | page_table = PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 549 | mm/memory.c | struct task_struct * tsk, unsigned long user_esp) |
tsk | 555 | mm/memory.c | pde = PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 570 | mm/memory.c | tsk->min_flt++; |
tsk | 576 | mm/memory.c | ++tsk->rss; |
tsk | 584 | mm/memory.c | oom(tsk); |
tsk | 597 | mm/memory.c | send_sig(SIGKILL, tsk, 1); |
tsk | 602 | mm/memory.c | send_sig(SIGKILL, tsk, 1); |
tsk | 614 | mm/memory.c | struct task_struct * tsk, unsigned long user_esp) |
tsk | 619 | mm/memory.c | pg_table = PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 631 | mm/memory.c | if (user_esp && tsk == current) { |
tsk | 632 | mm/memory.c | send_sig(SIGSEGV, tsk, 1); |
tsk | 641 | mm/memory.c | __do_wp_page(error_code, address, tsk, user_esp); |
tsk | 672 | mm/memory.c | static inline void get_empty_page(struct task_struct * tsk, unsigned long address) |
tsk | 677 | mm/memory.c | oom(tsk); |
tsk | 680 | mm/memory.c | if (!put_page(tsk,tmp,address,PAGE_PRIVATE)) |
tsk | 698 | mm/memory.c | static int try_to_share(unsigned long address, struct task_struct * tsk, |
tsk | 707 | mm/memory.c | to_page = (unsigned long)PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 757 | mm/memory.c | int share_page(struct vm_area_struct * area, struct task_struct * tsk, |
tsk | 768 | mm/memory.c | if (tsk == *p) |
tsk | 787 | mm/memory.c | if (try_to_share(address,tsk,*p,error_code,newpage)) |
tsk | 796 | mm/memory.c | static inline unsigned long get_empty_pgtable(struct task_struct * tsk,unsigned long address) |
tsk | 801 | mm/memory.c | p = PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 809 | mm/memory.c | p = PAGE_DIR_OFFSET(tsk->tss.cr3,address); |
tsk | 828 | mm/memory.c | struct task_struct *tsk, unsigned long user_esp) |
tsk | 834 | mm/memory.c | page = get_empty_pgtable(tsk,address); |
tsk | 842 | mm/memory.c | ++tsk->rss; |
tsk | 844 | mm/memory.c | ++tsk->maj_flt; |
tsk | 849 | mm/memory.c | for (mpnt = tsk->mmap ; mpnt ; mpnt = mpnt->vm_next) { |
tsk | 859 | mm/memory.c | ++tsk->min_flt; |
tsk | 860 | mm/memory.c | get_empty_page(tsk,address); |
tsk | 861 | mm/memory.c | if (tsk != current) |
tsk | 863 | mm/memory.c | if (address >= tsk->end_data && address < tsk->brk) |
tsk | 868 | mm/memory.c | send_sig(SIGSEGV,tsk,1); |