ipctrace.py 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. """
  2. ipctrace.py
  3. Write a trace of instantaneous IPC values for all cores.
  4. First argument is either a filename, or none to write to standard output.
  5. Second argument is the interval size in nanoseconds (default is 10000)
  6. """
  7. import sys, os, sim
  8. class IpcTrace:
  9. def setup(self, args):
  10. args = dict(enumerate((args or '').split(':')))
  11. filename = args.get(0, None)
  12. interval_ns = long(args.get(1, 10000))
  13. if filename:
  14. self.fd = file(os.path.join(sim.config.output_dir, filename), 'w')
  15. self.isTerminal = False
  16. else:
  17. self.fd = sys.stdout
  18. self.isTerminal = True
  19. self.sd = sim.util.StatsDelta()
  20. self.stats = {
  21. 'time': [ self.sd.getter('performance_model', core, 'elapsed_time') for core in range(sim.config.ncores) ],
  22. 'ffwd_time': [ self.sd.getter('fastforward_performance_model', core, 'fastforwarded_time') for core in range(sim.config.ncores) ],
  23. 'instrs': [ self.sd.getter('performance_model', core, 'instruction_count') for core in range(sim.config.ncores) ],
  24. 'coreinstrs': [ self.sd.getter('core', core, 'instructions') for core in range(sim.config.ncores) ],
  25. }
  26. sim.util.Every(interval_ns * sim.util.Time.NS, self.periodic, statsdelta = self.sd, roi_only = True)
  27. def periodic(self, time, time_delta):
  28. if self.isTerminal:
  29. self.fd.write('[IPC] ')
  30. self.fd.write('%u' % (time / 1e6)) # Time in ns
  31. for core in range(sim.config.ncores):
  32. # detailed-only IPC
  33. cycles = (self.stats['time'][core].delta - self.stats['ffwd_time'][core].delta) * sim.dvfs.get_frequency(core) / 1e9 # convert fs to cycles
  34. instrs = self.stats['instrs'][core].delta
  35. ipc = instrs / (cycles or 1) # Avoid division by zero
  36. #self.fd.write(' %.3f' % ipc)
  37. # include fast-forward IPCs
  38. cycles = self.stats['time'][core].delta * sim.dvfs.get_frequency(core) / 1e9 # convert fs to cycles
  39. instrs = self.stats['coreinstrs'][core].delta
  40. ipc = instrs / (cycles or 1)
  41. self.fd.write(' %.3f' % ipc)
  42. self.fd.write('\n')
  43. sim.util.register(IpcTrace())