On 4/7/21 2:45 PM, Borislav Petkov wrote: > On Wed, Apr 07, 2021 at 01:25:55PM +0200, Borislav Petkov wrote: >> On Tue, Apr 06, 2021 at 02:42:43PM -0500, Tom Lendacky wrote: >>> The GHCB spec only defines the "0" reason code set. We could provide Linux >>> it's own reason code set with some more specific reason codes for >>> failures, if that is needed. >> >> Why Linux only? >> >> Don't we want to have a generalized set of error codes which say what >> has happened so that people can debug? > > To quote Tom from IRC - and that is perfectly fine too, AFAIC: > > <tlendacky> i'm ok with it, but i don't think it should be something dictated by the spec. the problem is if you want to provide a new error code then the spec has to be updated constantly > <tlendacky> that's why i said, pick a "reason code set" value and say those are what Linux will use. We could probably document them in Documentation/ > <tlendacky> the error code thing was an issue when introduced as part of the first spec. that's why only a small number of reason codes are specified > > Yap, makes sense. What we should do in the spec, though, is say: "This > range is for vendor-specific error codes". > > Also, is GHCBData[23:16] big enough and can we extend it simply? Or do > we need the spec to at least dictate some ranges so that it can use some bits > above, say, bit 32 or whatever the upper range of the extension is... Hopefully we won't have 255 different reason codes. But if we get to that point we should be able to expand the reason code field to 16-bits. Just need to be sure that if any new fields are added between now and then, they are added at bit 32 or above. Thanks, Tom > > Hmmm. >