|
@@ -37,6 +37,7 @@ static struct {
|
|
bool clockid;
|
|
bool clockid;
|
|
bool clockid_wrong;
|
|
bool clockid_wrong;
|
|
bool lbr_flags;
|
|
bool lbr_flags;
|
|
|
|
+ bool write_backward;
|
|
} perf_missing_features;
|
|
} perf_missing_features;
|
|
|
|
|
|
static clockid_t clockid;
|
|
static clockid_t clockid;
|
|
@@ -1376,6 +1377,8 @@ fallback_missing_features:
|
|
if (perf_missing_features.lbr_flags)
|
|
if (perf_missing_features.lbr_flags)
|
|
evsel->attr.branch_sample_type &= ~(PERF_SAMPLE_BRANCH_NO_FLAGS |
|
|
evsel->attr.branch_sample_type &= ~(PERF_SAMPLE_BRANCH_NO_FLAGS |
|
|
PERF_SAMPLE_BRANCH_NO_CYCLES);
|
|
PERF_SAMPLE_BRANCH_NO_CYCLES);
|
|
|
|
+ if (perf_missing_features.write_backward)
|
|
|
|
+ evsel->attr.write_backward = false;
|
|
retry_sample_id:
|
|
retry_sample_id:
|
|
if (perf_missing_features.sample_id_all)
|
|
if (perf_missing_features.sample_id_all)
|
|
evsel->attr.sample_id_all = 0;
|
|
evsel->attr.sample_id_all = 0;
|
|
@@ -1438,6 +1441,12 @@ retry_open:
|
|
err = -EINVAL;
|
|
err = -EINVAL;
|
|
goto out_close;
|
|
goto out_close;
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ if (evsel->overwrite &&
|
|
|
|
+ perf_missing_features.write_backward) {
|
|
|
|
+ err = -EINVAL;
|
|
|
|
+ goto out_close;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1500,6 +1509,10 @@ try_fallback:
|
|
PERF_SAMPLE_BRANCH_NO_FLAGS))) {
|
|
PERF_SAMPLE_BRANCH_NO_FLAGS))) {
|
|
perf_missing_features.lbr_flags = true;
|
|
perf_missing_features.lbr_flags = true;
|
|
goto fallback_missing_features;
|
|
goto fallback_missing_features;
|
|
|
|
+ } else if (!perf_missing_features.write_backward &&
|
|
|
|
+ evsel->attr.write_backward) {
|
|
|
|
+ perf_missing_features.write_backward = true;
|
|
|
|
+ goto fallback_missing_features;
|
|
}
|
|
}
|
|
|
|
|
|
out_close:
|
|
out_close:
|