NULL,
};
-static unsigned long single_24x7_request(u8 domain, u32 offset, u16 ix,
- u16 lpar, u64 *count)
+static unsigned long single_24x7_request(struct perf_event *event, u64 *count)
{
+ u16 idx;
unsigned long ret;
struct hv_24x7_request_buffer *request_buffer;
memset(request_buffer, 0, 4096);
memset(result_buffer, 0, 4096);
+ if (is_physical_domain(event_get_domain(event)))
+ idx = event_get_core(event);
+ else
+ idx = event_get_vcpu(event);
+
request_buffer->interface_version = HV_24X7_IF_VERSION_CURRENT;
request_buffer->num_requests = 1;
req = &request_buffer->requests[0];
- req->performance_domain = domain;
+ req->performance_domain = event_get_domain(event);
req->data_size = cpu_to_be16(8);
- req->data_offset = cpu_to_be32(offset);
- req->starting_lpar_ix = cpu_to_be16(lpar),
+ req->data_offset = cpu_to_be32(event_get_offset(event));
+ req->starting_lpar_ix = cpu_to_be16(event_get_lpar(event)),
req->max_num_lpars = cpu_to_be16(1);
- req->starting_ix = cpu_to_be16(ix);
+ req->starting_ix = cpu_to_be16(idx);
req->max_ix = cpu_to_be16(1);
/*
if (ret) {
pr_devel_ratelimited("hcall failed: %d %#x %#x %d => "
"0x%lx (%ld) detail=0x%x failing ix=%x\n",
- domain, offset, ix, lpar, ret, ret,
+ req->performance_domain, req->data_offset,
+ idx, req->starting_lpar_ix, ret, ret,
result_buffer->detailed_rc,
result_buffer->failing_request_ix);
goto out;
return ret;
}
-static unsigned long event_24x7_request(struct perf_event *event, u64 *res)
-{
- u16 idx;
- unsigned domain = event_get_domain(event);
-
- if (is_physical_domain(domain))
- idx = event_get_core(event);
- else
- idx = event_get_vcpu(event);
-
- return single_24x7_request(event_get_domain(event),
- event_get_offset(event),
- idx,
- event_get_lpar(event),
- res);
-}
static int h_24x7_event_init(struct perf_event *event)
{
}
/* see if the event complains */
- if (event_24x7_request(event, &ct)) {
+ if (single_24x7_request(event, &ct)) {
pr_devel("test hcall failed\n");
return -EIO;
}
{
unsigned long ret;
u64 ct;
- ret = event_24x7_request(event, &ct);
+ ret = single_24x7_request(event, &ct);
if (ret)
/* We checked this in event init, shouldn't fail here... */
return 0;