2012-02-14 04:18:59 +00:00
|
|
|
#!/usr/bin/env python
|
2017-11-20 19:49:47 +00:00
|
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
#
|
2012-02-14 04:18:59 +00:00
|
|
|
# Copyright (c) 2012, Neville-Neil Consulting
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions are
|
|
|
|
# met:
|
|
|
|
#
|
|
|
|
# Redistributions of source code must retain the above copyright notice,
|
|
|
|
# this list of conditions and the following disclaimer.
|
|
|
|
#
|
|
|
|
# Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
#
|
|
|
|
# Neither the name of Neville-Neil Consulting nor the names of its
|
|
|
|
# contributors may be used to endorse or promote products derived from
|
|
|
|
# this software without specific prior written permission.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
#
|
|
|
|
# Author: George V. Neville-Neil
|
|
|
|
#
|
|
|
|
# $FreeBSD$
|
|
|
|
|
|
|
|
# Description: A program to run a simple program against every available
|
|
|
|
# pmc counter present in a system.
|
|
|
|
#
|
|
|
|
# To use:
|
|
|
|
#
|
2012-02-14 18:51:21 +00:00
|
|
|
# pmctest.py -p ls > /dev/null
|
2012-02-14 04:18:59 +00:00
|
|
|
#
|
|
|
|
# This should result in ls being run with every available counter
|
|
|
|
# and the system should neither lock up nor panic.
|
2012-02-14 18:51:21 +00:00
|
|
|
#
|
|
|
|
# The default is to wait after each counter is tested. Since the
|
|
|
|
# prompt would go to stdout you won't see it, just press return
|
|
|
|
# to continue or Ctrl-D to stop.
|
2012-02-14 04:18:59 +00:00
|
|
|
|
|
|
|
import sys
|
|
|
|
import subprocess
|
|
|
|
from subprocess import PIPE
|
|
|
|
|
2013-05-13 19:53:19 +00:00
|
|
|
# Use input() for Python version 3
|
|
|
|
if sys.version_info[0] == 3:
|
|
|
|
raw_input = input
|
|
|
|
|
2012-02-14 04:18:59 +00:00
|
|
|
# A list of strings that are not really counters, just
|
|
|
|
# name tags that are output by pmccontrol -L
|
2012-09-10 16:32:28 +00:00
|
|
|
notcounter = ["IAF", "IAP", "TSC", "UNC", "UCF", "UCP", "SOFT" ]
|
2012-02-14 04:18:59 +00:00
|
|
|
|
|
|
|
def main():
|
|
|
|
|
2012-02-14 18:51:21 +00:00
|
|
|
from optparse import OptionParser
|
|
|
|
|
|
|
|
parser = OptionParser()
|
|
|
|
parser.add_option("-p", "--program", dest="program",
|
|
|
|
help="program to execute")
|
|
|
|
parser.add_option("-w", "--wait", action="store_true", dest="wait",
|
|
|
|
default=True, help="wait after each execution")
|
2012-02-14 04:18:59 +00:00
|
|
|
|
2012-02-14 18:51:21 +00:00
|
|
|
(options, args) = parser.parse_args()
|
2012-02-14 04:18:59 +00:00
|
|
|
|
2012-09-04 20:14:37 +00:00
|
|
|
if (options.program == None):
|
2012-10-22 02:12:02 +00:00
|
|
|
print("specify program, such as ls, with -p/--program")
|
2012-09-04 20:14:37 +00:00
|
|
|
sys.exit()
|
|
|
|
|
2012-02-14 04:18:59 +00:00
|
|
|
p = subprocess.Popen(["pmccontrol", "-L"], stdout=PIPE)
|
|
|
|
counters = p.communicate()[0]
|
|
|
|
|
|
|
|
if len(counters) <= 0:
|
2012-10-22 02:12:02 +00:00
|
|
|
print("no counters found")
|
2012-02-14 04:18:59 +00:00
|
|
|
sys.exit()
|
|
|
|
|
|
|
|
for counter in counters.split():
|
|
|
|
if counter in notcounter:
|
|
|
|
continue
|
2012-02-14 18:51:21 +00:00
|
|
|
p = subprocess.Popen(["pmcstat", "-p", counter, options.program],
|
|
|
|
stdout=PIPE)
|
2012-02-14 04:18:59 +00:00
|
|
|
result = p.communicate()[0]
|
2012-10-22 02:12:02 +00:00
|
|
|
print(result)
|
2012-02-14 18:51:21 +00:00
|
|
|
if (options.wait == True):
|
|
|
|
try:
|
2013-05-13 19:53:19 +00:00
|
|
|
value = raw_input("next?")
|
2012-02-14 18:51:21 +00:00
|
|
|
except EOFError:
|
|
|
|
sys.exit()
|
2012-02-14 04:18:59 +00:00
|
|
|
|
|
|
|
# The canonical way to make a python module into a script.
|
|
|
|
# Remove if unnecessary.
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|