mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 02:43:41 +00:00 
			
		
		
		
	 a785c87d6e
			
		
	
	
		a785c87d6e
		
	
	
	
	
		
			
			Tested on macOS 10.11 dtrace, Ubuntu 16.04 SystemTap, and libbcc. Largely based by an initial patch by Jesús Cea Avión, with some influence from Dave Malcolm's SystemTap patch and Nikhil Benesch's unification patch. Things deliberately left out for simplicity: - ustack helpers, I have no way of testing them at this point since they are Solaris-specific - PyFrameObject * in function__entry/function__return, this is SystemTap-specific - SPARC support - dynamic tracing - sys module dtrace facility introspection All of those might be added later.
		
			
				
	
	
		
			41 lines
		
	
	
	
		
			807 B
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
	
		
			807 B
		
	
	
	
		
			Text
		
	
	
	
	
	
| global tracing
 | |
| 
 | |
| function basename:string(path:string)
 | |
| {
 | |
|     last_token = token = tokenize(path, "/");
 | |
|     while (token != "") {
 | |
|         last_token = token;
 | |
|         token = tokenize("", "/");
 | |
|     }
 | |
|     return last_token;
 | |
| }
 | |
| 
 | |
| probe process.mark("function__entry")
 | |
| {
 | |
|     funcname = user_string($arg2);
 | |
| 
 | |
|     if (funcname == "start") {
 | |
|         tracing = 1;
 | |
|     }
 | |
| }
 | |
| 
 | |
| probe process.mark("function__entry"), process.mark("function__return")
 | |
| {
 | |
|     filename = user_string($arg1);
 | |
|     funcname = user_string($arg2);
 | |
|     lineno = $arg3;
 | |
| 
 | |
|     if (tracing) {
 | |
|         printf("%d\t%s:%s:%s:%d\n", gettimeofday_us(), $$name,
 | |
|                basename(filename), funcname, lineno);
 | |
|     }
 | |
| }
 | |
| 
 | |
| probe process.mark("function__return")
 | |
| {
 | |
|     funcname = user_string($arg2);
 | |
| 
 | |
|     if (funcname == "start") {
 | |
|         tracing = 0;
 | |
|     }
 | |
| }
 |