mirror of
				https://git.proxmox.com/git/qemu
				synced 2025-10-25 19:03:12 +00:00 
			
		
		
		
	 23d15e860b
			
		
	
	
		23d15e860b
		
	
	
	
	
		
			
			The "-trace events" argument can be used to provide a file with a list of trace event names that will be enabled prior to starting execution, thus providing early tracing. This saves the user from manually toggling event states through the monitor interface or whichever backend-specific interface. Signed-off-by: Lluís Vilanova <vilanova@ac.upc.edu>
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Interface for configuring and controlling the state of tracing events.
 | |
|  *
 | |
|  * Copyright (C) 2011 Lluís Vilanova <vilanova@ac.upc.edu>
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2.  See
 | |
|  * the COPYING file in the top-level directory.
 | |
|  */
 | |
| 
 | |
| #include "trace/control.h"
 | |
| 
 | |
| 
 | |
| void trace_backend_init_events(const char *fname)
 | |
| {
 | |
|     if (fname == NULL) {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     FILE *fp = fopen(fname, "r");
 | |
|     if (!fp) {
 | |
|         fprintf(stderr, "error: could not open trace events file '%s': %s\n",
 | |
|                 fname, strerror(errno));
 | |
|         exit(1);
 | |
|     }
 | |
|     char line_buf[1024];
 | |
|     while (fgets(line_buf, sizeof(line_buf), fp)) {
 | |
|         size_t len = strlen(line_buf);
 | |
|         if (len > 1) {              /* skip empty lines */
 | |
|             line_buf[len - 1] = '\0';
 | |
|             if (!trace_event_set_state(line_buf, true)) {
 | |
|                 fprintf(stderr,
 | |
|                         "error: trace event '%s' does not exist\n", line_buf);
 | |
|                 exit(1);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     if (fclose(fp) != 0) {
 | |
|         fprintf(stderr, "error: closing file '%s': %s\n",
 | |
|                 fname, strerror(errno));
 | |
|         exit(1);
 | |
|     }
 | |
| }
 |