mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
clean up pthread for linux
This commit is contained in:
parent
2709e6e368
commit
2a931b7266
3 changed files with 62 additions and 73 deletions
|
@ -33,11 +33,6 @@ notelstk(addr)
|
||||||
_stk({"PC", pc, "SP", sp, linkreg(addr)}, 1);
|
_stk({"PC", pc, "SP", sp, linkreg(addr)}, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
// defn labstk(l) // trace from a label
|
|
||||||
// {
|
|
||||||
// _stk({"PC", *(l+4), "SP", *l, linkreg(0)}, 0);
|
|
||||||
// }
|
|
||||||
|
|
||||||
defn params(param)
|
defn params(param)
|
||||||
{
|
{
|
||||||
while param do {
|
while param do {
|
||||||
|
@ -119,7 +114,6 @@ defn _stk(regs, dolocals)
|
||||||
if callerpc == 0 then
|
if callerpc == 0 then
|
||||||
done=1;
|
done=1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if callerpc && !done then {
|
if callerpc && !done then {
|
||||||
print(stkprefix, fmt(callerpc, 'a'), " ");
|
print(stkprefix, fmt(callerpc, 'a'), " ");
|
||||||
pfl(callerpc);
|
pfl(callerpc);
|
||||||
|
|
53
acid/pthread-linux-386
Normal file
53
acid/pthread-linux-386
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
// Linux NPTL 2.3.2
|
||||||
|
complex list_head {
|
||||||
|
'X' 0 next;
|
||||||
|
'X' 4 prev;
|
||||||
|
};
|
||||||
|
complex nptl_pthread {
|
||||||
|
'X' 0 loopback;
|
||||||
|
'X' 0x48 tid;
|
||||||
|
};
|
||||||
|
|
||||||
|
// cannot be done at load time -- need shared library symbols
|
||||||
|
defn guessnptl() {
|
||||||
|
if var("nptl_version") then {
|
||||||
|
pthreadlibrary = "nptl";
|
||||||
|
isnptl = 1;
|
||||||
|
} else {
|
||||||
|
pthreadlibrary = "linuxclone";
|
||||||
|
isnptl = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
defn pthread2tid(p) {
|
||||||
|
guessnptl();
|
||||||
|
if p == 0 then
|
||||||
|
return 0;
|
||||||
|
if isnptl then {
|
||||||
|
complex nptl_pthread p;
|
||||||
|
if p.loopback != p then
|
||||||
|
error("bad pthread "+itoa(p, "%x"));
|
||||||
|
return p.tid;
|
||||||
|
}else {
|
||||||
|
return p\X;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
defn pthreadlist() {
|
||||||
|
local all, p, n, l;
|
||||||
|
|
||||||
|
if isnptl then {
|
||||||
|
all = {};
|
||||||
|
l = (list_head)stack_used;
|
||||||
|
l = (list_head)l.next;
|
||||||
|
while l != stack_used do {
|
||||||
|
p = l - *_thread_db_pthread_list;
|
||||||
|
all = append all, p;
|
||||||
|
l = (list_head)l.next;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
all = {};
|
||||||
|
}
|
||||||
|
return all;
|
||||||
|
}
|
||||||
|
|
76
acid/thread
76
acid/thread
|
@ -3,62 +3,7 @@
|
||||||
// avoid complicated libthread_db interface
|
// avoid complicated libthread_db interface
|
||||||
//
|
//
|
||||||
|
|
||||||
// Linux NPTL 2.3.2
|
include("pthread-"+systype+"-"+objtype);
|
||||||
complex list_head {
|
|
||||||
'X' 0 next;
|
|
||||||
'X' 4 prev;
|
|
||||||
};
|
|
||||||
complex nptl_pthread {
|
|
||||||
'X' 0 loopback;
|
|
||||||
'X' 0x48 tid;
|
|
||||||
};
|
|
||||||
defn isnptl() {
|
|
||||||
return var("nptl_version") != {};
|
|
||||||
}
|
|
||||||
defn nptl2tid(p) {
|
|
||||||
complex nptl_pthread p;
|
|
||||||
if p.loopback != p then
|
|
||||||
error("bad pthread "+itoa(p, "%x"));
|
|
||||||
return p.tid;
|
|
||||||
}
|
|
||||||
defn nptlpthreadlist() {
|
|
||||||
local all, p, n, l;
|
|
||||||
|
|
||||||
all = {};
|
|
||||||
l = (list_head)stack_used;
|
|
||||||
l = (list_head)l.next;
|
|
||||||
while l != stack_used do {
|
|
||||||
p = l - *_thread_db_pthread_list;
|
|
||||||
all = append all, p;
|
|
||||||
l = (list_head)l.next;
|
|
||||||
}
|
|
||||||
return all;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Generic dispatch
|
|
||||||
//
|
|
||||||
defn pthreadlibrary() {
|
|
||||||
if var("_pthreadlibrary") == {} then {
|
|
||||||
if isnptl() then
|
|
||||||
_pthreadlibrary = "nptl";
|
|
||||||
else
|
|
||||||
_pthreadlibrary = "unknown";
|
|
||||||
}
|
|
||||||
return _pthreadlibrary;
|
|
||||||
}
|
|
||||||
|
|
||||||
defn id2tid(id) {
|
|
||||||
if pthreadlibrary() == "nptl" then
|
|
||||||
return nptl2tid(id);
|
|
||||||
error("unknown pthread library: "+pthreadlibrary);
|
|
||||||
}
|
|
||||||
|
|
||||||
defn pthreadlist() {
|
|
||||||
if pthreadlibrary() == "nptl" then
|
|
||||||
return nptlpthreadlist(id);
|
|
||||||
error("unknown pthread library: "+pthreadlibrary);
|
|
||||||
}
|
|
||||||
|
|
||||||
// pick apart system mcontext_t structures
|
// pick apart system mcontext_t structures
|
||||||
defn mcontext(m)
|
defn mcontext(m)
|
||||||
|
@ -98,7 +43,7 @@ defn altfmt(A){
|
||||||
complex Alt A;
|
complex Alt A;
|
||||||
|
|
||||||
s = "alt(";
|
s = "alt(";
|
||||||
s = s + "tag(*" + itoa(A.tag, "%x") + "=" + itoa(*A.tag, "%x") + ") ";
|
s = s + "tag(*" + itoa(A.tag, "%#x") + "=" + itoa(*A.tag, "%#x") + ") ";
|
||||||
i = 0;
|
i = 0;
|
||||||
yes = 0;
|
yes = 0;
|
||||||
while A.op != CHANEND && A.op != CHANNOBLK do{
|
while A.op != CHANEND && A.op != CHANNOBLK do{
|
||||||
|
@ -109,7 +54,7 @@ defn altfmt(A){
|
||||||
if A.op == CHANSND then s = s + "send";
|
if A.op == CHANSND then s = s + "send";
|
||||||
if A.op == CHANRCV then s = s + "recv";
|
if A.op == CHANRCV then s = s + "recv";
|
||||||
s = s + "(channel(";
|
s = s + "(channel(";
|
||||||
s = s + itoa(A.c, "%x");
|
s = s + itoa(A.c, "%#x");
|
||||||
s = s + "))";
|
s = s + "))";
|
||||||
yes = 1;
|
yes = 1;
|
||||||
}
|
}
|
||||||
|
@ -184,7 +129,7 @@ defn fnname(a){
|
||||||
return sym[0];
|
return sym[0];
|
||||||
s = tail s;
|
s = tail s;
|
||||||
}
|
}
|
||||||
return itoa(a, "%x");
|
return itoa(a, "%#x");
|
||||||
}
|
}
|
||||||
|
|
||||||
stkignorelist = {};
|
stkignorelist = {};
|
||||||
|
@ -199,7 +144,7 @@ defn threadstkline(T){
|
||||||
P = (Proc)T.proc;
|
P = (Proc)T.proc;
|
||||||
if P.thread == T then {
|
if P.thread == T then {
|
||||||
mainpid = pid;
|
mainpid = pid;
|
||||||
setproc(id2tid(P.osprocid));
|
setproc(pthread2tid(P.osprocid));
|
||||||
stk = strace({});
|
stk = strace({});
|
||||||
setproc(mainpid);
|
setproc(mainpid);
|
||||||
} else
|
} else
|
||||||
|
@ -230,7 +175,7 @@ defn threadfmt(T){
|
||||||
local P, s, name;
|
local P, s, name;
|
||||||
|
|
||||||
P = (Proc)T.proc;
|
P = (Proc)T.proc;
|
||||||
s = "t=(_Thread)"+itoa(T, "%-10x")+" // ";
|
s = "t=(_Thread)"+itoa(T, "%#-10x")+" // ";
|
||||||
|
|
||||||
if P.thread == T then
|
if P.thread == T then
|
||||||
s = s + "Running ";
|
s = s + "Running ";
|
||||||
|
@ -296,12 +241,10 @@ defn threadstks(P){
|
||||||
complex Proc P;
|
complex Proc P;
|
||||||
local T, mainpid, pref, ign;
|
local T, mainpid, pref, ign;
|
||||||
|
|
||||||
// mainpid = pid;
|
|
||||||
pref = stkprefix;
|
pref = stkprefix;
|
||||||
stkprefix = pref+"\t\t";
|
stkprefix = pref+"\t\t";
|
||||||
ign = stkignore;
|
ign = stkignore;
|
||||||
stkignore = threadstkignore;
|
stkignore = threadstkignore;
|
||||||
// setproc(P.pid);
|
|
||||||
T = (_Thread)P.allthreads.$head;
|
T = (_Thread)P.allthreads.$head;
|
||||||
while T != 0 do{
|
while T != 0 do{
|
||||||
print("\t");
|
print("\t");
|
||||||
|
@ -310,7 +253,6 @@ defn threadstks(P){
|
||||||
T = (_Thread)T.allnext;
|
T = (_Thread)T.allnext;
|
||||||
print("\n");
|
print("\n");
|
||||||
}
|
}
|
||||||
// setproc(mainpid);
|
|
||||||
stkprefix = pref;
|
stkprefix = pref;
|
||||||
stkignore = ign;
|
stkignore = ign;
|
||||||
}
|
}
|
||||||
|
@ -318,7 +260,7 @@ defn threadstks(P){
|
||||||
defn proc(P){
|
defn proc(P){
|
||||||
complex Proc P;
|
complex Proc P;
|
||||||
|
|
||||||
print("p=(Proc)", itoa(P, "%-10x"), " // pthread ", P.osprocid\X, " pid ", id2tid(P.osprocid)\D, " ");
|
print("p=(Proc)", itoa(P, "%#-10x"), " // pthread ", P.osprocid\X, " pid ", pthread2tid(P.osprocid)\D, " ");
|
||||||
if P.thread==0 then
|
if P.thread==0 then
|
||||||
print(" Sched");
|
print(" Sched");
|
||||||
else
|
else
|
||||||
|
@ -332,7 +274,7 @@ defn threadlstk(T){
|
||||||
|
|
||||||
P = (Proc)T.proc;
|
P = (Proc)T.proc;
|
||||||
mainpid = pid;
|
mainpid = pid;
|
||||||
setproc(id2tid(P.osprocid));
|
setproc(pthread2tid(P.osprocid));
|
||||||
|
|
||||||
if P.thread == T then
|
if P.thread == T then
|
||||||
lstk();
|
lstk();
|
||||||
|
@ -347,7 +289,7 @@ defn threadstk(T){
|
||||||
|
|
||||||
P = (Proc)T.proc;
|
P = (Proc)T.proc;
|
||||||
mainpid = pid;
|
mainpid = pid;
|
||||||
setproc(id2tid(P.osprocid));
|
setproc(pthread2tid(P.osprocid));
|
||||||
|
|
||||||
if P.thread == T then
|
if P.thread == T then
|
||||||
stk();
|
stk();
|
||||||
|
|
Loading…
Reference in a new issue