kernel_liteos_a/syscall
zhushengle cf89f016e9 fix: 解决kill进程时无法保证进程的已持有的内核资源合理释放.
背景: 当前信号实现原理是在系统调用结束和中断结束时检查是否有信号处理,
      如果有信号处理就切去处理信号,信号处理结束后回来继续按原来流程执行。
问题:当用户态线程在执行系统调用或缺页异常时,运行在内核态,如果此时有信
      号需要处理,且该线程已经持有了部分内核资源(如:锁,内存等), 此时如
      果有中断发生,则在中断结束时,就会去处理该信号,此时用户态线程持有
      了内核未释放的资源跑到了用户态去运行,如果该线程在用户态出现问题,
      那么它持有的内核资源就无法被释放了。
方案:用户态线程在执行系统调用和缺页异常时暂时屏蔽信号,防止此时有中断去
      处理信号,等系统调用结束或缺页异常结束时再去处理信号。
解决的问题:
  1. 执行系统调用或缺页异常时屏蔽信号,防止中断去处理信号
  2.解决无法kill 因为用户态的锁、ipc等阻塞的用户态线程
  3.进程退出方式转变为: 依次通过kill去杀死该进程的所有线程

Close #I3S0N0

Change-Id: I0c48b9c89382826191b8a9326c71b57ba84124c2
2021-05-24 14:29:37 +08:00
..
Makefile remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00
fs_syscall.c use -include option instead of including menuconfig manually 2021-04-14 17:56:48 +08:00
ipc_syscall.c remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00
los_syscall.c fix: 解决kill进程时无法保证进程的已持有的内核资源合理释放. 2021-05-24 14:29:37 +08:00
los_syscall.h feat: add and fix some syscall 2021-04-09 14:45:53 +08:00
misc_syscall.c remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00
net_syscall.c remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00
process_syscall.c fix: correct spelling 2021-05-08 11:23:08 +08:00
syscall_lookup.h remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00
syscall_pub.c update openharmony 1.0.1 2021-03-11 18:43:57 +08:00
syscall_pub.h IssueNo:#I3G1Q7 2021-04-17 16:15:35 +08:00
time_syscall.c remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00
vm_syscall.c remove __cplusplus guards in .c files 2021-04-19 18:28:25 +08:00