ref: ea993877a96cd535199d0cd437e49f8d616615d9
dir: /sys/src/libthread/kill.c/
#include <u.h> #include <libc.h> #include <thread.h> #include "threadimpl.h" static void tinterrupt(Proc*, Thread*); static void threadxxxgrp(int grp, int dokill) { Proc *p; Thread *t; lock(&_threadpq.lock); for(p=_threadpq.head; p; p=p->next){ lock(&p->lock); for(t=p->threads.head; t; t=t->nextt) if(t->grp == grp){ if(dokill) t->moribund = 1; tinterrupt(p, t); } unlock(&p->lock); } unlock(&_threadpq.lock); _threadbreakrendez(); } static void threadxxx(int id, int dokill) { Proc *p; Thread *t; lock(&_threadpq.lock); for(p=_threadpq.head; p; p=p->next){ lock(&p->lock); for(t=p->threads.head; t; t=t->nextt) if(t->id == id){ if(dokill) t->moribund = 1; tinterrupt(p, t); unlock(&p->lock); unlock(&_threadpq.lock); _threadbreakrendez(); return; } unlock(&p->lock); } unlock(&_threadpq.lock); _threaddebug(DBGNOTE, "Can't find thread to kill"); return; } void threadkillgrp(int grp) { threadxxxgrp(grp, 1); } void threadkill(int id) { threadxxx(id, 1); } void threadintgrp(int grp) { threadxxxgrp(grp, 0); } void threadint(int id) { threadxxx(id, 0); } static void tinterrupt(Proc *p, Thread *t) { char buf[64]; int fd; switch(t->state){ case Running: snprint(buf, sizeof(buf), "/proc/%d/ctl", p->pid); fd = open(buf, OWRITE|OCEXEC); if(fd >= 0){ if(write(fd, "interrupt", 9) == 9){ close(fd); break; } close(fd); } postnote(PNPROC, p->pid, "threadint"); break; case Rendezvous: _threadflagrendez(t); break; } }