[tor-commits] [arm/master] Determining initial cmd with ctypes rather than ps

atagar at torproject.org atagar at torproject.org
Tue May 3 04:30:31 UTC 2011


commit 175fde6c4a92e1b52f060ef82baf35bf7d722639
Author: Damian Johnson <atagar at torproject.org>
Date:   Mon May 2 21:28:54 2011 -0700

    Determining initial cmd with ctypes rather than ps
    
    Using the ctypes argv rather than querying for our command via ps (thanks to
    ioerror).
---
 src/util/procname.py |   28 +++++++++++-----------------
 1 files changed, 11 insertions(+), 17 deletions(-)

diff --git a/src/util/procname.py b/src/util/procname.py
index 14a82b8..97dc707 100644
--- a/src/util/procname.py
+++ b/src/util/procname.py
@@ -9,13 +9,10 @@
 # argument replacement (ie, replace argv[0], argv[1], etc but with a string
 # the same size).
 
-import os
 import sys
 import ctypes
 import ctypes.util
 
-from util import sysTools
-
 # flag for setting the process name, found in '/usr/include/linux/prctl.h'
 PR_SET_NAME = 15
 
@@ -65,24 +62,21 @@ def _setArgv(processName):
   if currentProcessName == None:
     # Getting argv via...
     # currentProcessName = " ".join(["python"] + sys.argv)
-    #
+    # 
     # doesn't do the trick since this will miss interpretor arguments like...
     # python -W ignore::DeprecationWarning myScript.py
     # 
-    # hence simply getting an outside opinion of our command.
-    
-    psResults = sysTools.call("ps -p %i -o args" % os.getpid())
+    # Hence we're fetching this via our ctypes argv. Alternatively we could
+    # use ps, though this is less desirable:
+    # "ps -p %i -o args" % os.getpid()
     
-    if len(psResults) == 2:
-      # output looks like:
-      # COMMAND
-      # python ./src/starter.py
-      
-      currentProcessName = psResults[1]
-      maxNameLength = len(currentProcessName)
+    args = []
+    for i in range(100):
+      if argc[i] == None: break
+      args.append(str(argc[i]))
     
-    if not currentProcessName:
-      raise IOError("unable to determine our process name")
+    currentProcessName = " ".join(args)
+    maxNameLength = len(currentProcessName)
   
   if len(processName) > maxNameLength:
     msg = "can't rename process to something longer than our initial name since this would overwrite memory used for the env"
@@ -93,7 +87,7 @@ def _setArgv(processName):
   
   ctypes.memset(argc.contents, 0, zeroSize + 1) # null terminate the string's end
   ctypes.memmove(argc.contents, processName, len(processName))
-  currentProcessName = processName[:MAX_CHAR]
+  currentProcessName = processName
 
 def _setPrctlName(processName):
   """



More information about the tor-commits mailing list