You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

101 lines
2.3 KiB

/*
* Copyright 2002-2019 Intel Corporation.
*
* This software is provided to you as Sample Source Code as defined in the accompanying
* End User License Agreement for the Intel(R) Software Development Products ("Agreement")
* section 1.L.
*
* This software and the related documents are provided as is, with no express or implied
* warranties, other than those that are expressly stated in the License.
*/
#include <iostream>
#include "pin.H"
#include "instlib.H"
#include "control_manager.H"
using namespace INSTLIB;
using namespace CONTROLLER;
#if defined(__GNUC__)
# if defined(__APPLE__)
# define ALIGN_LOCK __attribute__ ((aligned(16))) /* apple only supports 16B alignment */
# else
# define ALIGN_LOCK __attribute__ ((aligned(64)))
# endif
#else
# define ALIGN_LOCK __declspec(align(64))
#endif
LOCALVAR PIN_LOCK ALIGN_LOCK output_lock;
// Track the number of instructions executed
ICOUNT icount;
// Contains knobs and instrumentation to recognize start/stop points
CONTROL_MANAGER control("controller_");
VOID Handler(EVENT_TYPE ev, VOID * v, CONTEXT * ctxt, VOID * ip, THREADID tid, BOOL bcast)
{
PIN_GetLock(&output_lock, tid+1);
std::cout << "tid: " << tid << " ";
std::cout << "ip: " << ip << " " << icount.Count() ;
switch(ev)
{
case EVENT_START:
std::cout << "Start" << endl;
break;
case EVENT_STOP:
std::cout << "Stop" << endl;
break;
case EVENT_THREADID:
std::cout << "ThreadID" << endl;
break;
default:
ASSERTX(false);
break;
}
PIN_ReleaseLock(&output_lock);
}
INT32 Usage()
{
cerr <<
"This pin tool demonstrates use of CONTROL to identify start/stop points in a program\n"
"\n";
cerr << KNOB_BASE::StringKnobSummary() << endl;
return -1;
}
// argc, argv are the entire command line, including pin -t <toolname> -- ...
int main(int argc, char * argv[])
{
if( PIN_Init(argc,argv) )
{
return Usage();
}
PIN_InitLock(&output_lock);
icount.Activate();
// Activate alarm, must be done before PIN_StartProgram
control.RegisterHandler(Handler, 0, FALSE);
control.Activate();
// Start the program, never returns
PIN_StartProgram();
return 0;
}