support process group

This commit is contained in:
Tomoki Shirasawa
2014-08-18 17:08:28 +09:00
parent 663c121308
commit 78d10cce80
8 changed files with 103 additions and 3 deletions

View File

@@ -61,6 +61,7 @@ SYSCALL_DELEGATED(102, getuid)
SYSCALL_DELEGATED(104, getgid)
SYSCALL_DELEGATED(107, geteuid)
SYSCALL_DELEGATED(108, getegid)
SYSCALL_HANDLED(109, setpgid)
SYSCALL_DELEGATED(110, getppid)
SYSCALL_DELEGATED(111, getpgrp)
SYSCALL_HANDLED(127, rt_sigpending)

View File

@@ -159,6 +159,34 @@ extern unsigned long do_kill(int pid, int tid, int sig);
extern void interrupt_syscall(int all, int pid);
extern int num_processors;
void
do_setpgid(int pid, int pgid)
{
struct cpu_local_var *v;
struct process *p;
struct process *proc = cpu_local_var(current);
int i;
unsigned long irqstate;
if(pid == 0)
pid = proc->pid;
if(pgid == 0)
pgid = pid;
for(i = 0; i < num_processors; i++){
v = get_cpu_local_var(i);
irqstate = ihk_mc_spinlock_lock(&(v->runq_lock));
list_for_each_entry(p, &(v->runq), sched_list){
if(p->pid <= 0)
continue;
if(p->pid == pid){
p->pgid = pgid;
}
}
ihk_mc_spinlock_unlock(&(v->runq_lock), irqstate);
}
}
void
do_signal(unsigned long rc, void *regs0, struct process *proc, struct sig_pending *pending)
{
@@ -319,6 +347,52 @@ do_kill(int pid, int tid, int sig)
if(sig > 64 || sig < 0)
return -EINVAL;
if(tid == -1 && pid <= 0){
int pgid = -pid;
int rc = -ESRCH;
int *pids;
int i;
int n = 0;
int sendme = 0;
pids = kmalloc(sizeof(int) * num_processors, IHK_MC_AP_NOWAIT);
if(!pids)
return -ENOMEM;
if(pid == 0)
pgid = proc->pgid;
for(i = 0; i < num_processors; i++){
v = get_cpu_local_var(i);
irqstate = ihk_mc_spinlock_lock(&(v->runq_lock));
list_for_each_entry(p, &(v->runq), sched_list){
if(p->pid <= 0)
continue;
if(p->pid == proc->pid){
sendme = 1;
continue;
}
if(pgid == 1 || p->pgid == pgid){
int j;
for(j = 0; j < n; j++)
if(pids[j] == p->pid)
break;
if(j == n){
pids[n] = p->pid;
n++;
}
}
}
ihk_mc_spinlock_unlock(&(v->runq_lock), irqstate);
}
for(i = 0; i < n; i++)
rc = do_kill(pids[i], -1, sig);
if(sendme)
rc = do_kill(proc->pid, -1, sig);
kfree(pids);
return rc;
}
mask = __sigmask(sig);
if(tid == -1){
struct process *tproc0 = NULL;
@@ -381,7 +455,6 @@ do_kill(int pid, int tid, int sig)
if(sig == 0)
return 0;
doint = 0;
if(tid == -1){
irqstate = ihk_mc_spinlock_lock(&tproc->sigshared->lock);

View File

@@ -70,6 +70,7 @@ struct program_load_desc {
int pid;
int err;
int stack_prot;
int pgid;
unsigned long entry;
unsigned long user_start;
unsigned long user_end;

View File

@@ -215,6 +215,7 @@ struct program_load_desc *load_elf(FILE *fp, char **interp_pathp)
}
}
desc->pid = getpid();
desc->pgid = getpgid(0);
desc->entry = hdr.e_entry;
desc->at_phdr = load_addr + hdr.e_phoff;

View File

@@ -391,6 +391,7 @@ static int process_msg_prepare_process(unsigned long rphys)
}
proc->pid = pn->pid;
proc->tid = pn->pid;
proc->pgid = pn->pgid;
proc->ftn->pid = pn->pid;
proc->vm->region.user_start = pn->user_start;
proc->vm->region.user_end = pn->user_end;

View File

@@ -194,6 +194,7 @@ struct process {
cpu_set_t cpu_set;
unsigned long saved_auxv[AUXV_LEN];
int pgid; /* process group id */
};
struct process_vm {

View File

@@ -110,6 +110,7 @@ struct program_load_desc {
int pid;
int err;
int stack_prot;
int pgid;
unsigned long entry;
unsigned long user_start;
unsigned long user_end;

View File

@@ -98,6 +98,7 @@ void do_signal(long rc, void *regs, struct process *proc, struct sig_pending *pe
extern unsigned long do_kill(int pid, int tid, int sig);
int copy_from_user(struct process *, void *, const void *, size_t);
int copy_to_user(struct process *, void *, const void *, size_t);
void do_setpgid(int, int);
int prepare_process_ranges_args_envs(struct process *proc,
struct program_load_desc *pn,
@@ -1318,6 +1319,8 @@ SYSCALL_DECLARE(clone)
return -ENOMEM;
}
new->pgid = cpu_local_var(current)->pgid;
cpu_set(cpuid, &new->vm->cpu_set, &new->vm->cpu_set_lock);
if (clone_flags & CLONE_VM) {
@@ -1430,10 +1433,28 @@ SYSCALL_DECLARE(kill)
SYSCALL_DECLARE(tgkill)
{
int tgid = ihk_mc_syscall_arg0(ctx);
int pid = ihk_mc_syscall_arg1(ctx);
int tid = ihk_mc_syscall_arg1(ctx);
int sig = ihk_mc_syscall_arg2(ctx);
return do_kill(tgid, pid, sig);
if(tid <= 0)
return -EINVAL;
if(tgid <= 0 && tgid != -1)
return -EINVAL;
return do_kill(tgid, tid, sig);
}
SYSCALL_DECLARE(setpgid)
{
int pid = ihk_mc_syscall_arg0(ctx);
int pgid = ihk_mc_syscall_arg1(ctx);
long rc;
rc = syscall_generic_forwarding(__NR_setpgid, ctx);
if(rc == 0){
do_setpgid(pid, pgid);
}
return rc;
}
SYSCALL_DECLARE(set_robust_list)