On Thu, 7 Jan 2021 21:10:29 -0800 Dave Hansen wrote: > On 1/7/21 6:00 PM, Kai Huang wrote: > > On Thu, 7 Jan 2021 07:41:25 +0100 Borislav Petkov wrote: > >> On Thu, Jan 07, 2021 at 12:09:46PM +1300, Kai Huang wrote: > >>> There's no urgent request to support them for now (and given basic SGX > >>> virtualization is not in upstream), but I don't know whether they need to be > >>> supported in the future. > >> > >> If that is the case, then wasting a whole leaf for two bits doesn't make > >> too much sense. And it looks like the kvm reverse lookup can be taught > >> to deal with composing that leaf dynamically when needed instead. > > > > I am not sure changing reverse lookup to handle dynamic would be acceptable. To > > me it is ugly, and I don't have a first glance on how to do it. KVM can query > > host CPUID when dealing with SGX w/o X86_FEATURE_SGX1/2, but it is not as > > straightforward as having X86_FEATURE_SGX1/2. > > So, Boris was pretty direct here. Could you please go spend a bit of > time to see what it would take to make these dynamic? You can check > what our (Intel) plans are for this leaf, but if it's going to remain > sparsely-used, we need to look into making the leaves a bit more dynamic. I don't think reverse lookup can be made dyanmic, but like I said if we don't have X86_FEATURE_SGX1/2, KVM needs to query raw CPUID when dealing with SGX. The purpose of reverse lookup is to simplify KVM to have one common helper to check whether guest's CPUID has particular hardware feature bit or not. For instance, it changes guest_cpuid_has_xxx(cpuid) to guest_cpuid_has(cpuid, X86_FEATURE_xxx), so KVM can get rid of bunch of dedicated guest_cpuid_has_xxx() for each feature, but just use X86_FEATURE_xxx with one function. W/o X86_FEATURE_SGX1/2, when dealing with them, KVM needs to have dedicated functions but cannot use common one. That is a drawback for KVM. Btw, one thing I forgot to say is with X86_FEATURE_SGX1/2, "sgx1" and "sgx2" will be in /proc/cpuinfo auatomatically. I think showing "sgx2" (and other future SGX features) in /proc/cpuinfo is helpful. W/o X86_FEATURE_SGX1/2, we need specific handling, if we want to show them in /proc/cpuinfo. That being said, if all those doesn't convince Boris and you guys, and Sean has no say here, I'll remove X86_FEATURE_SGX1/2 in next version. > > > And regarding to other bits of this leaf, to me: 1) we cannot rule out > > possibility that bit 5 and bit 6 will be supported in the future; 2) I cannot > > talk more but we cannot rule out the possibility that there will be other bits > > introduced in the future. > > From the Intel side, let's go look at the features that are coming. We > have a list of CPUID bits that have been dedicated to future CPU > features. Let's look if 1 of these bits or 30 is coming. I don't think > it's exactly a state secret approximately how many CPUID bits we *think* > will get used in this leaf. > > We can't exactly put together a roadmap of bits, microarchitectures and > chip release dates. But, we can at least say, "we have immediate plans > for most of the leaf" or "we don't plan to fill up the leaf any time soon."