X-Git-Url: http://git.onelab.eu/?p=util-vserver.git;a=blobdiff_plain;f=src%2Fvserver-info.c;h=9683cbc029309d45bb6d8b083761e17ada146693;hp=819c4615e18520e58992e76fd83666744bef15ee;hb=a741f6faf2baae1e823d334012f6a09e6a1bda51;hpb=426a0d3a38995dc25a839aaa56d8642e6bdcbba5 diff --git a/src/vserver-info.c b/src/vserver-info.c index 819c461..9683cbc 100644 --- a/src/vserver-info.c +++ b/src/vserver-info.c @@ -1,4 +1,4 @@ -// $Id: vserver-info.c 2403 2006-11-24 23:06:08Z dhozac $ --*- c -*-- +// $Id: vserver-info.c 2589 2007-08-16 03:06:50Z dhozac $ --*- c -*-- // Copyright (C) 2003 Enrico Scholz // @@ -53,6 +53,7 @@ typedef enum { tgNONE,tgCONTEXT, tgID, tgRUNNING, tgXID, tgUTS, tgSYSINFO, tgFEATURE, tgCANONIFY, tgVERIFYCAP, tgXIDTYPE, tgVERIFYPROC, + tgNID, tgTAG, } VserverTag; static struct { @@ -82,6 +83,8 @@ static struct { { "VERIFYCAP", tgVERIFYCAP, "test if the kernel supports linux capabilities" }, { "VERIFYPROC", tgVERIFYPROC, "test if /proc can be read by contexts!=0" }, { "XIDTYPE", tgXIDTYPE, "returns the type of the given XID" }, + { "NID", tgNID, "outputs the network context-id of the given pid" }, + { "TAG", tgTAG, "outputs the filesystem tag of the given pid" }, }; int wrapper_exit_code = 1; @@ -230,13 +233,13 @@ getAPIVer(char *buf) return buf; } -static char * -getXid(char *buf, char const *pid_str) +static inline char * +getCtxId(char *buf, const char *pid_str, xid_t (*get_id)(pid_t pid), const char *err_str) { pid_t pid = atoi(pid_str); - xid_t xid = vc_get_task_xid(pid); + xid_t xid = get_id(pid); - if (xid==VC_NOCTX) perror("vc_get_task_xid()"); + if (xid==VC_NOCTX) perror(err_str); else { utilvserver_fmt_long(buf, xid); return buf; @@ -245,6 +248,24 @@ getXid(char *buf, char const *pid_str) return 0; } +static char * +getXid(char *buf, char const *pid_str) +{ + return getCtxId(buf, pid_str, vc_get_task_xid, "vc_get_task_xid()"); +} + +static char * +getNid(char *buf, const char *pid_str) +{ + return getCtxId(buf, pid_str, vc_get_task_nid, "vc_get_task_nid()"); +} + +static char * +getTag(char *buf, const char *pid_str) +{ + return getCtxId(buf, pid_str, vc_get_task_tag, "vc_get_task_tag()"); +} + static char * getPXid(char UNUSED *buf, char const UNUSED *vserver) { @@ -434,7 +455,7 @@ static char * getContext(char *buf, char const *vserver, bool allow_only_static) { xid_t xid = vc_getVserverCtx(vserver, vcCFG_AUTO, - allow_only_static, 0); + allow_only_static, 0, vcCTX_XID); if (xid==VC_NOCTX) return 0; utilvserver_fmt_long(buf, xid); @@ -502,7 +523,7 @@ execQuery(char const *vserver, VserverTag tag, int argc, char *argv[]) if (isNumber(vserver, &xid, true) && xid>=0) res = (vc_get_vx_info(xid, &info)==-1) ? 0 : "1"; else - res = (vc_getVserverCtx(vserver, vcCFG_AUTO, false, 0)==VC_NOCTX) ? 0 : "1"; + res = (vc_getVserverCtx(vserver, vcCFG_AUTO, false, 0, vcCTX_XID)==VC_NOCTX) ? 0 : "1"; break; } @@ -522,6 +543,8 @@ execQuery(char const *vserver, VserverTag tag, int argc, char *argv[]) case tgFEATURE : return testFeature(argc,argv); break; case tgVERIFYCAP : return verifyCap() ? 0 : 1; break; case tgVERIFYPROC : return verifyProc() ? 0 : 1; break; + case tgNID : res = getNid(buf, vserver); break; + case tgTAG : res = getTag(buf, vserver); break; default : {