summaryrefslogtreecommitdiff
path: root/cli
diff options
context:
space:
mode:
authorJose Fonseca <jfonseca@vmware.com>2016-09-07 16:06:09 +0100
committerJose Fonseca <jfonseca@vmware.com>2016-09-07 16:06:09 +0100
commitff5a585edca3a56aa7d42285f0e75a048993b23e (patch)
tree8ca074b0cd82bc163ab7d1835632e6e13a001659 /cli
parentb78a7710199fb1414776047f85d54684bbd8bdce (diff)
inject: Initial mhook integration.
Essentially fork injectee module into two variants: IAT and mhook.
Diffstat (limited to 'cli')
-rw-r--r--cli/cli_trace.cpp30
1 files changed, 21 insertions, 9 deletions
diff --git a/cli/cli_trace.cpp b/cli/cli_trace.cpp
index 97c1cc83..32c5fd27 100644
--- a/cli/cli_trace.cpp
+++ b/cli/cli_trace.cpp
@@ -97,7 +97,8 @@ traceProgram(trace::API api,
char * const *argv,
const char *output,
int verbose,
- bool debug)
+ bool debug,
+ bool mhook)
{
const char *wrapperFilename;
std::vector<const char *> args;
@@ -159,6 +160,9 @@ traceProgram(trace::API api,
if (debug) {
args.push_back("-d");
}
+ if (mhook) {
+ args.push_back("-m");
+ }
for (int i = 1; i < verbose; ++i) {
args.push_back("-v");
}
@@ -341,20 +345,24 @@ usage(void)
#ifdef TRACE_VARIABLE
" -d, --debug run inside debugger (gdb/lldb)\n"
#endif
+#ifdef _WIN32
+ " -m, --mhook use Mhook (instead of IAT patching)\n"
+#endif
;
}
const static char *
-shortOptions = "+hva:o:d";
+shortOptions = "+hva:o:dm";
const static struct option
longOptions[] = {
- {"help", no_argument, 0, 'h'},
- {"verbose", no_argument, 0, 'v'},
- {"api", required_argument, 0, 'a'},
- {"output", required_argument, 0, 'o'},
- {"debug", no_argument, 0, 'd'},
- {0, 0, 0, 0}
+ { "help", no_argument, 0, 'h' },
+ { "verbose", no_argument, 0, 'v' },
+ { "api", required_argument, 0, 'a' },
+ { "output", required_argument, 0, 'o' },
+ { "debug", no_argument, 0, 'd' },
+ { "mhook", no_argument, 0, 'm' },
+ { 0, 0, 0, 0 }
};
static int
@@ -364,6 +372,7 @@ command(int argc, char *argv[])
trace::API api = trace::API_GL;
const char *output = NULL;
bool debug = false;
+ bool mhook = false;
int opt;
while ((opt = getopt_long(argc, argv, shortOptions, longOptions, NULL)) != -1) {
@@ -408,6 +417,9 @@ command(int argc, char *argv[])
case 'd':
debug = true;
break;
+ case 'm':
+ mhook = true;
+ break;
default:
std::cerr << "error: unexpected option `" << (char)opt << "`\n";
usage();
@@ -422,7 +434,7 @@ command(int argc, char *argv[])
}
assert(argv[argc] == 0);
- return traceProgram(api, argv + optind, output, verbose, debug);
+ return traceProgram(api, argv + optind, output, verbose, debug, mhook);
}
const Command trace_command = {