Re: [PATCH] x86/rapl: Do not load in a guest

From: Ingo Molnar
Date: Fri Dec 04 2015 - 03:28:32 EST



* Peter Zijlstra <peterz@xxxxxxxxxxxxx> wrote:

> On Fri, Dec 04, 2015 at 08:42:06AM +0100, Ingo Molnar wrote:
> >
> > * Borislav Petkov <bp@xxxxxxxxx> wrote:
> >
> > > From: Borislav Petkov <bp@xxxxxxx>
> > >
> > > qemu/kvm doesn't support RAPL and RAPL doesn't have a CPUID feature bit
> > > so check whether we're in a guest instead.
> >
> > So when a hypervisor starts supporting RAPL we'll disable the driver erroneously?
> >
> > Isn't there any better method to detect RAPL support?
> >
> > So in particular in drivers/powercap/intel_rapl.c there's an enumerated list of
> > CPU models, which is used via a x86_match_cpu() call. That's still not ideal (it
> > does not work on hypervisors for example), but even better would be to detect RAPL
> > support in some other fashion, that does not rely on us statically enumerating CPU
> > models that support it.
>
> RAPL isn't enumerated, the best we could do is attempt to write to one
> of the writable MSRs and see if that 'works'.

Hm, bad - writing to MSRs like that is generally dangerous.

So we should at least provide a central 'is RAPL available' call instead of
spreading multiple X86_FEATURE_HYPERVISOR checks.

Thanks,

Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/