On Tue, Jul 20, 2021 at 02:42:12PM -0500, Michael Roth wrote: > On Tue, Jul 13, 2021 at 03:46:19PM +0200, Markus Armbruster wrote: > > Brijesh Singh <brijesh.singh@xxxxxxx> writes: > > > > > To launch the SEV-SNP guest, a user can specify up to 8 parameters. > > > Passing all parameters through command line can be difficult. To simplify > > > the launch parameter passing, introduce a .ini-like config file that can be > > > used for passing the parameters to the launch flow. > > > > > > The contents of the config file will look like this: > > > > > > $ cat snp-launch.init > > > > > > # SNP launch parameters > > > [SEV-SNP] > > > init_flags = 0 > > > policy = 0x1000 > > > id_block = "YWFhYWFhYWFhYWFhYWFhCg==" > > > > > > > > > Add 'snp' property that can be used to indicate that SEV guest launch > > > should enable the SNP support. > > > > > > SEV-SNP guest launch examples: > > > > > > 1) launch without additional parameters > > > > > > $(QEMU_CLI) \ > > > -object sev-guest,id=sev0,snp=on > > > > > > 2) launch with optional parameters > > > $(QEMU_CLI) \ > > > -object sev-guest,id=sev0,snp=on,launch-config=<file> > > > > > > Signed-off-by: Brijesh Singh <brijesh.singh@xxxxxxx> > > > > I acknowledge doing complex configuration on the command line can be > > awkward. But if we added a separate configuration file for every > > configurable thing where that's the case, we'd have too many already, > > and we'd constantly grow more. I don't think this is a viable solution. > > > > In my opinion, much of what we do on the command line should be done in > > configuration files instead. Not in several different configuration > > languages, mind, but using one common language for all our configuration > > needs. > > > > Some of us argue this language already exists: QMP. It can't do > > everything the command line can do, but that's a matter of putting in > > the work. However, JSON isn't a good configuration language[1]. To get > > a decent one, we'd have to to extend JSON[2], or wrap another concrete > > syntax around QMP's abstract syntax. > > > > But this doesn't help you at all *now*. > > > > I recommend to do exactly what we've done before for complex > > configuration: define it in the QAPI schema, so we can use both dotted > > keys and JSON on the command line, and can have QMP, too. Examples: > > -blockdev, -display, -compat. > > > > Questions? > > Hi Markus, Daniel, > > I'm dealing with similar considerations with some SNP config options > relating to CPUID enforcement, so I've started looking into this as > well, but am still a little confused on the best way to proceed. > > I see that -blockdev supports both JSON command-line arguments (via > qobject_input_visitor_new) and dotted keys > (via qobject_input_vistior_new_keyval). > > We could introduce a new config group do the same, maybe something specific > to ConfidentialGuestSupport objects, e.g.: > > -confidential-guest-support sev-guest,id=sev0,key_a.subkey_b=... We don't wnt to be adding new CLI options anymore. -object with json syntx should ultimately be able to cover everything we'll ever need to do. > > and use the same mechanisms to parse the options, but this seems to > either involve adding a layer of option translations between command-line > and the underlying object properties, or, if we keep the 1:1 mapping > between QAPI-defined keys and object properties, it basically becomes a > way to pass a different Visitor implementation into object_property_set(), > in this case one created by object_input_visitor_new_keyval() instead of > opts_visitor_new(). > > In either case, genericizing it beyond CGS/SEV would basically be > introducing: > > -object2 sev-guest,id=sev0,key_a.subkey_b=... > > Which one seems preferable? Or is the answer neither? Yep, neither is the answer. > > I've also been looking at whether this could all be handled via -object, > and it seems -object already supports JSON command-line arguments, and that > switching it from using OptsVisitor to QObjectVisitor for non-JSON case > would be enough to have it handle dotted keys, but I'm not sure what the > fall-out would be compatibility-wise. > > All lot of that falls under making sure the QObject/keyval parser is > compatible with existing command-lines parsed via OptsVisitor. One example > where there still seems to be a difference is lack of support for ranges > such as "cpus=1-4" in keyval parser. Daniel had a series that addressed > this: > > https://lists.gnu.org/archive/html/qemu-devel/2016-09/msg08248.html > > but it doesn't seem to have made it into the tree, which is why I feel like > maybe there are complications with this approach I haven't considered? The core problem with QemuOpts is that it has hacked various hacks grafted onto it to cope with non-scalar data. My patch was adding yet another hack. It very hard to introduce new hacks without risk of causing incompatibility with other existing hacks, or introducing unexpected edge cases that we don't anticipate. Ultimately I think we've come to the conclusion that QemuOpts is an unfixable dead end that should be left alone. Our future is trending towards being entirely JSON, configured via the QMP monitor not the CLI. As such the json support for -object is a step towards the pure JSON world. IOW, if you have things that work today with QemuOpts that's fine. If, however, you're coming across situations that need non-scalar data and it doesn't work with QemuOpts, then just declare that -object json syntax is mandatory for that scenario. Don't invest time trying to improve QemuOpts for non-scalar data, nor inventing new CLI args. FWIW, specificallly in the case of parameters that take an integer range, like cores=1-4, in JSON we'd end up representing that as a array of integers and having to specify all values explicitly. This is quite verbose, but functionally works. I think it would have been nice if we defined an explicit 'bitmap' scalar data type in QAPI for these kind of things, but at this point in time I think that ship has sailed, and trying to add that now would create an inconsistent representation across different places. Regards, Daniel -- |: https://berrange.com -o- https://www.flickr.com/photos/dberrange :| |: https://libvirt.org -o- https://fstop138.berrange.com :| |: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|