> +     /* Probe the MSRs. */
> +     for (i = PERF_MSR_TSC + 1; i < PERF_MSR_EVENT_MAX; i++) {
> +             u64 val;
> 
> -     default:
> -             err = -ENOTSUPP;
> +             if (!msr[i].test() || rdmsrl_safe(msr[i].msr, &val))
> +                     msr[i].attr = NULL;
>       }
> 
> -     if (err != 0) {
> -             pr_cont("no msr PMU driver.\n");
> -             return 0;
> +     /* List remaining MSRs in the sysfs attrs. */
> +     for (i = 0; i < PERF_MSR_EVENT_MAX; i++) {

i should start from PERF_MSR_TSC + 1. The tsc has already been
inserted into events_attrs by default.

> +             if (msr[i].attr)
> +                     events_attrs[j++] = &msr[i].attr->attr.attr;
>       }
> +     events_attrs[j] = NULL;
> 
>       perf_pmu_register(&pmu_msr, "msr", -1);
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to