summaryrefslogtreecommitdiffstats
path: root/main.cxx
diff options
context:
space:
mode:
authorJosh Stone <jistone@redhat.com>2010-03-02 15:57:58 -0800
committerJosh Stone <jistone@redhat.com>2010-03-02 16:05:18 -0800
commitd105f6642677bd9ef1b20d1ba180ba0163cb0fa6 (patch)
tree49c4869c7c4a687e692bb33beabab3b008beb43d /main.cxx
parent9b3c54b2fc836e20a0a7895aa759938e62eaacf9 (diff)
downloadsystemtap-steved-d105f6642677bd9ef1b20d1ba180ba0163cb0fa6.tar.gz
systemtap-steved-d105f6642677bd9ef1b20d1ba180ba0163cb0fa6.tar.xz
systemtap-steved-d105f6642677bd9ef1b20d1ba180ba0163cb0fa6.zip
PR11246 cont'd: Add options for cache control
--disable-cache : turn off all caching --clean-cache : clean up stale entries and then quit --poison-cache : force regeneration of items that would have hit the cache These are undocumented for now, until we decide whether they are generally useful. * main.cxx (main): Parse the new options. * session.h (systemtap_session): Add poison_cache; document the others. * clean.cxx (clean_cache): No longer static. (get_stapconf_from_cache, get_script_from_cache): Respect poison. * tapsets.cxx (tracepoint_builder::get_tracequery_module): Ditto. (dwarf_cast_expanding_visitor::filter_special_modules): Ditto.
Diffstat (limited to 'main.cxx')
-rw-r--r--main.cxx31
1 files changed, 31 insertions, 0 deletions
diff --git a/main.cxx b/main.cxx
index 6d3f649b..9cc0370d 100644
--- a/main.cxx
+++ b/main.cxx
@@ -537,6 +537,7 @@ main (int argc, char * const argv [])
s.symtab = false;
s.use_cache = true;
s.use_script_cache = true;
+ s.poison_cache = false;
s.tapset_compile_coverage = false;
s.need_uprobes = false;
s.consult_symtab = false;
@@ -633,6 +634,9 @@ main (int argc, char * const argv [])
#define LONG_OPT_OMIT_WERROR 8
#define LONG_OPT_CLIENT_OPTIONS 9
#define LONG_OPT_HELP 10
+#define LONG_OPT_DISABLE_CACHE 11
+#define LONG_OPT_POISON_CACHE 12
+#define LONG_OPT_CLEAN_CACHE 13
// NB: also see find_hash(), usage(), switch stmt below, stap.1 man page
static struct option long_options[] = {
{ "kelf", 0, &long_opt, LONG_OPT_KELF },
@@ -651,6 +655,9 @@ main (int argc, char * const argv [])
{ OWE4 OWE6 OWE1 OWE2 OWE3 OWE5, 0, &long_opt, LONG_OPT_OMIT_WERROR },
{ "client-options", 0, &long_opt, LONG_OPT_CLIENT_OPTIONS },
{ "help", 0, &long_opt, LONG_OPT_HELP },
+ { "disable-cache", 0, &long_opt, LONG_OPT_DISABLE_CACHE },
+ { "poison-cache", 0, &long_opt, LONG_OPT_POISON_CACHE },
+ { "clean-cache", 0, &long_opt, LONG_OPT_CLEAN_CACHE },
{ NULL, 0, NULL, 0 }
};
int grc = getopt_long (argc, argv, "hVvtp:I:e:o:R:r:a:m:kgPc:x:D:bs:uqwl:d:L:FS:B:W",
@@ -948,6 +955,30 @@ main (int argc, char * const argv [])
case LONG_OPT_HELP:
usage (s, 0);
break;
+
+ // The caching options should not be available to server clients
+ case LONG_OPT_DISABLE_CACHE:
+ if (client_options) {
+ cerr << "ERROR: --disable-cache is invalid with --client-options" << endl;
+ exit(1);
+ }
+ s.use_cache = s.use_script_cache = false;
+ break;
+ case LONG_OPT_POISON_CACHE:
+ if (client_options) {
+ cerr << "ERROR: --poison-cache is invalid with --client-options" << endl;
+ exit(1);
+ }
+ s.poison_cache = true;
+ break;
+ case LONG_OPT_CLEAN_CACHE:
+ if (client_options) {
+ cerr << "ERROR: --clean-cache is invalid with --client-options" << endl;
+ exit(1);
+ }
+ clean_cache(s);
+ exit(0);
+
default:
exit(1);
}