summaryrefslogtreecommitdiffstats
path: root/tapset-perfmon.cxx
diff options
context:
space:
mode:
authorJosh Stone <jistone@redhat.com>2010-03-17 19:06:56 -0700
committerJosh Stone <jistone@redhat.com>2010-03-17 19:09:40 -0700
commit5e0ae7b6e3fe6e739b03c3ab4ef675113e38350f (patch)
tree4f379043a5f64e7b219e3ebb952a1eae14217436 /tapset-perfmon.cxx
parent61cbdef4a69f73155b2d1e2934729f6cc8338511 (diff)
downloadsystemtap-steved-5e0ae7b6e3fe6e739b03c3ab4ef675113e38350f.tar.gz
systemtap-steved-5e0ae7b6e3fe6e739b03c3ab4ef675113e38350f.tar.xz
systemtap-steved-5e0ae7b6e3fe6e739b03c3ab4ef675113e38350f.zip
Preserve perf initialization errors
* runtime/perf.c (_stp_perf_init): Pass through ERR_PTRs, and create our own -ENOMEM for allocation failures. * tapset-perfmon.cxx (perf_derived_probe_group::emit_module_init): Check IS_ERR for registration status.
Diffstat (limited to 'tapset-perfmon.cxx')
-rw-r--r--tapset-perfmon.cxx5
1 files changed, 3 insertions, 2 deletions
diff --git a/tapset-perfmon.cxx b/tapset-perfmon.cxx
index 05a2bcd8..5c2d73e8 100644
--- a/tapset-perfmon.cxx
+++ b/tapset-perfmon.cxx
@@ -152,8 +152,9 @@ perf_derived_probe_group::emit_module_init (systemtap_session& s)
s.op->newline() << "for (i=0; i<" << probes.size() << "; i++) {";
s.op->newline(1) << "struct stap_perf_probe* stp = & stap_perf_probes [i];";
s.op->newline() << "stp->perf = _stp_perf_init(&stp->attr, stp->cb, stp->pp, stp->ph);";
- s.op->newline() << "if (stp->perf == NULL) {";
- s.op->newline(1) << "rc = -EINVAL;";
+ s.op->newline() << "if (IS_ERR(stp->perf)) {";
+ s.op->newline(1) << "rc = PTR_ERR(stp->perf);";
+ s.op->newline() << "stp->perf = NULL;";
s.op->newline() << "probe_point = stp->pp;";
s.op->newline() << "for (j=0; j<i; j++) {";
s.op->newline(1) << "stp = & stap_perf_probes [j];";