1 / 28

Process

Process. 宋祥葳. Outline. Processes, Lightweight Processes Process and Thread Process Descriptor Process State Process ID Process Data Structure Process relationship Process Resource Limit. What is a Process?. The concept An instance of a program in execution

neci
Télécharger la présentation

Process

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Process 宋祥葳

  2. Outline • Processes, Lightweight Processes • Process and Thread • Process Descriptor • Process State • Process ID • Process Data Structure • Process relationship • Process Resource Limit

  3. What is a Process? • The concept • An instance of a program in execution • The basic unit of execution in an operating system • The purpose • Act as an entity to which system resources are allocated • The collection of data structures that describe how far the execution of the program has progressed

  4. Process Concept Command Interpreter User Applications WindowSystem Middleware Operating System Process Process Process Process Instruction Execution & Interrupt Processing I/O Devices Memory

  5. Anatomy of a Process Process State Running, Waiting, Halting, Ready state Process Number Process ID used to identify Process Program Counter Indicate the address of the next instruction to be executed for this processes CPURegister Save the state information when an interrupt occurs Memory Limit Include the page, segment table and the base, limit registers value List of Open Files Process Control Block (PCB)

  6. Linux Process Descriptor structsched_rt_entity { structlist_headrun_list; unsigned long timeout; unsigned inttime_slice; intnr_cpus_allowed; …… }; Include/linux/Sched.h :1074~1378

  7. The Linux Process Descriptor Linux 2.6.28 Process Structure 1074 structtask_struct { 1075 volatile long state; /* -1 unrunnable, 0 runnable, >0 stopped */ 1076 void *stack; 1078 unsigned intflags; /* per process flags */1092 structsched_entityse; 1093 structsched_rt_entityrt; 1126 structlist_headtasks;1128 structmm_struct *mm, *active_mm;1150 structtask_struct*real_parent; /* real parent process (when being debugged) */ 1151 structtask_struct*parent; /* parent process */1214 /* CPU-specific state of this task */ 1215 structthread_structthread; 1216 /* filesystem information */ 1217 structfs_struct*fs; 1218/* open file information */ structfiles_struct*files; …… /include/linux/sched.h1074~1378

  8. Process descriptors handling • Linux packs two different data structures in a single per-process memory area. • The length of this memory is 8192 bytes (2 page frames) Esp is the CPU stack pointer, which is used to address the stack’s top location

  9. Introducing Threads • A thread (or lightweight process) is a basic unit of CPU utilization; it consists of: • Program counter • Register set • Stack space • A thread shares with other threads belong to the same process its: • Code section • Data section • Operating-system resource • A traditional process is equal to a task with one thread Process Process Thread 1 Thread 1 Thread 2 Thread 3 Thread 4

  10. Introducing Threads Process’s address space • Process Control Block (PCB) contains process-specific information • Owner, PID, heap pointer, priority, active thread, and pointers to thread information • Thread Control Block (TCB) contain thread-specific information • Stack pointer, PC, thread state, register TCB for Thread1 …… PC Heap SP state register Stack- Thread2 TCB for Thread2 Stack- Thread1 PC Initialized data SP Code state register

  11. The Thread Structure arch\x86\include\asm\Thread_info.h

  12. Process State

  13. Linux Processes State /include/linux/sched.h:173~192

  14. Processes State • TASK_RUNNING • The process is either executing on a CPU or waiting to be executed. • TASK_INTERRUPTIBLE • The Process is suspended until some condition becomes true. • TASK_UNINTERRUPTIBLE • Deliver a signal to the sleeping process leaves its state unchanged. • Execute when a process must wait until a given event occurs without being interrupted.

  15. Processes State • TASK_STOPPED • The process has been stopped, when it received one of the SIGSTOP, SIGSTP, SIGTTIN or SIGTTOU signal. • TASK_TRACED • When a process is being monitored by another, process execution has been stopped by a debugger. • EXIT_DEAD

  16. Wait_event_interruptible /include/linux/Wait.h:245~261

  17. Wait_event /include/linux/Wait.h:174~185

  18. Process ID • What is the Process ID? • The kernel's internal notion of a process identifier • Process ID refers to individual tasks, process groups • The Process ID storage way • The Process ID lives in a hash table • The hash table storage manner refers the process can be found quickly from the numeric pid value.

  19. Identifying a Process • Process ID recycle method • When the kernel reaches the max limit, it must start recycling the lower unused PIDs. • pidmap_array bitmap • Use to manage the condition of PIDs • In 32-bit architectures, the bitmap is stored in a single page. • tgid • All the threads of a multithreaded application share the same identifier (tgid). • tgid is the thread of the PID of the thread group leader. tgid pid pid pid pid pid pid Thread group

  20. Use PID to detect process descriptor get_pid_task(pid) Result=Pid_task(pid) hlist_entry(pid) /kernel/Pid.c

  21. Allocate a pid /kernel/Pid.c

  22. Doubly linked list(1) • The Linux kernel uses hundreds of doubly linked lists that store the various kernel data structures. • For each list, a set of primitive operations must be implemented.

  23. Process list structtask_struct{ …… structlist_headtasks; …… } /include/linux/Sched.h /include/linux/list.h

  24. Pid namespace • The PID namespace allows for creating sets of tasks, with each such set looking like a standalone machine with respect to process IDs. In other words, tasks in different namespaces can have the same IDs. • Provide safety for virtualization

  25. Relationships Among Processes • Processes created by a program have a parent/child relationship. • When a process creates multiple children, these children have sibling relationships. /include/linux/sched.h

  26. Parenthood Relationships P0 P1 P3 P2 Parent P4 Children.next Children.prev Sibling.prev Sibling.next

  27. Process Resource Limits • Each process has an associated set of resource limits. • Process resource limits specify the amount of system resources it can use. • These limit keeps a user from overwhelming the system. • The resource limits for current process are stored in the current->signal->rlim field 43 structrlimit { 44 unsigned long rlim_cur; 45 unsigned long rlim_max; 46 }; /include/ linux/ resource. c

  28. Process Resource Limits • Rlimit Macro /include/asm-generic/resource.h 15 #define RLIMIT_CPU 0 /* CPU time in sec */ 16 #define RLIMIT_FSIZE 1 /* Maximum filesize */ 17 #define RLIMIT_DATA 2 /* max data size */ 18 #define RLIMIT_STACK 3 /* max stack size */ 19 #define RLIMIT_CORE 4 /* max core file size */ • RLIMIT_STACK Example mm/Mmap.c

More Related