进程描述
1、在Linux内核中用一个数据结构struct task_struct来描述进程,其中包含了进程的状态(-1 就绪态;0 运行态;>0阻塞态),进程双向链表的管理,控制台tty,文件系统fs的描述,进程打开文件的文件描述符files,内存管理的描述mm,进程间通信的信号signal的描述等
2、在Linux内核中,当进程是TASK_RUNNING状态时,它是可运行的,即就绪态,是否在运行取决于它有没有获得CPU的控制权,如果在CPU中实际执行了,就是运行态;如果在等待队列中就是就绪态
进程创建
1、init_task为0号进程的进程描述符结构体变量,它的初始化是通过硬编码方式固定下来的,其余进程的初始化都是通过do_fork复制父进程的方式初始化的
2、进程描述符通过struct list_head tasks双向链表来管理所有进程
3、具体进程的创建为把当前进程的描述符等相关资源复制一份,从而产生一个子进程,并根据子进程的需要对复制的进程描述符做一些修改,然后把创建好的子进程放入运行队列
4、fork系统调用创建子进程,它把当前进程又复制了一个子进程,两个进程执行相同的代码,在父进程和子进程中的返回值不同,父子进程共享内存存储空间
5、进程创建过程:复制进程描述符,采用写时复制技术一一复制其他进程资源,分配子进程的内核堆栈并对内核堆栈关键信息进行初始化
实验
cd LinuxKernel
rm -rf menu
git clone git://github.com/mengning/menu.git
cd menu
mv test_fork.c test.c
make rootfs
MenuOS>>help
gdb
(gdb)file linux-3.18.6/vmlinux
(gdb)target remote:1234
(gdb)b sys_clone
(gdb)b do_fork
(gdb)b dup_task_struct
(gdb)b copy_process
(gdb)b copy_thread
(gdb)b ret_from_fork
问题
1、当虚拟机容量不足时,在设置中对虚拟机进行扩容之后,需要对其进行分区挂载
2、要记住自己下载的内核版本号,进入时第一个为原版本,第三个才是我们下载的版本,不要选错