From owner-freebsd-virtualization@freebsd.org Mon Jun 25 03:41:13 2018 Return-Path: Delivered-To: freebsd-virtualization@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 54BB71021ECD for ; Mon, 25 Jun 2018 03:41:13 +0000 (UTC) (envelope-from araujobsdport@gmail.com) Received: from mail-lj1-x22a.google.com (mail-lj1-x22a.google.com [IPv6:2a00:1450:4864:20::22a]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id A57E788C15; Mon, 25 Jun 2018 03:41:12 +0000 (UTC) (envelope-from araujobsdport@gmail.com) Received: by mail-lj1-x22a.google.com with SMTP id l12-v6so532031lja.1; Sun, 24 Jun 2018 20:41:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:reply-to:in-reply-to:references:from:date:message-id :subject:to:cc; bh=qfNWgxdpF5InScDXkMrZHLT8PD2GzLi8tZleuq0PiaI=; b=L7kqIuX6/obXXCF+8KQ3gHZVcErpSMABGtbYj1xE6Y7i5lM1Cc/Nbe7CIkVelBDb56 sFSgkELonOHwQvLIVaOlcatnI+UyNviRyfKmyotjvNtbNGfAg7FjeeFTXZPA9hFvidzG 0tgRO3F6kHp9HUZxLVBJ2LbYgpnxFPOiywDjOuu/gnVQyZgKzds2xOK8b3fvPKgBbWF+ 6sXyvar9ZCiJoq3VZocmn+Eye8k/z02VeNEK9K/3M1OIjcZLBL6Ummcy/hvZeita0+AI jy4wHQTeptCBcR7KW/RcB9dbgMisOZfTxZzXFDCrs5Dc4JT51rNjnpopqPId2qBpyzgC 7PJg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:reply-to:in-reply-to:references :from:date:message-id:subject:to:cc; bh=qfNWgxdpF5InScDXkMrZHLT8PD2GzLi8tZleuq0PiaI=; b=MeXA1on7zqHmk0RwOYgMzQWst9tIKYa5d3rfKgU2/u9MJYercARXzgpIkYHDelwYXT 80Kr8sYaI0cd6clsVoZ8Bzv9HBdn0Rxg6VdSqDeZmhYSRAbMmoiI09nMmSNcSGYgMJkT /mJeaZ7vJqQviuPi78hORUftCdEqU8FwRLKnFGdEjXJEeYYdcfBF9L103jMEWUUg7rMa rSBeMCnn8I+66Vm2GiGHGdbNHycHhpQHvVTTGys3U9/vys1lfNQPzB/4HOgybWKVEh2e VGvDqGVqSIymBuYb2ReEWzrPf6EbWd6Xwbp+IPKXEQVaCKohuPU63eqbWVe1ybdTBNwF 2F0A== X-Gm-Message-State: APt69E3/na0Nd89+JVI6hY0V9lAlfjGyr8d+amUBUgRDGVA5uzMrcjJO YmHYSO7PGh9TlL0XCFn1NzomPVo49THTUrT7L0HhZg== X-Google-Smtp-Source: ADUXVKIhoYWuEDAxiZDtqSs7LIA6Nz/8/JbZUl5AGrdEEUpjEU3nivfvVOcXK/SXINQDn2832mGHPyYpje6VzSLJ1bY= X-Received: by 2002:a2e:9cd8:: with SMTP id g24-v6mr6647528ljj.141.1529898070287; Sun, 24 Jun 2018 20:41:10 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a19:1f94:0:0:0:0:0 with HTTP; Sun, 24 Jun 2018 20:41:08 -0700 (PDT) Reply-To: araujo@freebsd.org In-Reply-To: <20180624101301.GB2252@kloomba> References: <20180624101301.GB2252@kloomba> From: Marcelo Araujo Date: Mon, 25 Jun 2018 11:41:08 +0800 Message-ID: Subject: Re: RFC: bhyve supported features reporting To: Roman Bogorodskiy Cc: freebsd-virtualization@freebsd.org Content-Type: text/plain; charset="UTF-8" X-Content-Filtered-By: Mailman/MimeDel 2.1.26 X-BeenThere: freebsd-virtualization@freebsd.org X-Mailman-Version: 2.1.26 Precedence: list List-Id: "Discussion of various virtualization techniques FreeBSD supports." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 25 Jun 2018 03:41:13 -0000 Hi Roman, I think it is doable, my only concern is the complexity and maintainability, as along the way we will add more devices and would be nice to have something transparent for those additions or at least something easy to be extended. As an example this patch that you made: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=210111 It has much less complexity, and seemed for me to be much easier to maintain, however doesn't give us a detailed information like the latest one you are proposing, I'm not sure if we really need so extensive details, I didn't see any bhyve device changing its options along the past years, but that doesn't means it would not in the future. I do believe if we remove the complexity or at least makes it easy to be extend, IMHO it is a good idea. Best, 2018-06-24 18:13 GMT+08:00 Roman Bogorodskiy : > Bhyve evolves over time, and new features get added, such as new > devices support, new guest configurations and so on. However, it's not > really straight-forward to figure out what features a given bhyve binary > supports. This makes it harder to develop tools on top of bhyve, > specifically error reporting. > > For example, libvirt's bhyve driver [1] probes bhyve capabilities [2] > using: > > * Running 'bhyve -h' and parsing output, > * For detecting devices, it runs 'bhyve -s 0,dev' and parses error > output to see if the device is supported. > > It's not very effective because 'bhyve' binary has to be executed > multiple times just to check things. Additionally, it's harder to check > things on a deeper level, e.g. specific device parameters. Also, this is > error-prone because help output generally is not designed for > machine-parsing, and this could easily break on slight formatting > change. > > I would like to discuss introducing a general way of reporting features > bhyve supports. To start a discussion, I've created a simple draft/PoC > which adds '-f' (as for features) command line switch to bhyve. This > switch makes bhyve print its supported features. I'll use JSON as > example, however, as it's done using libxo, XML is also supported. > Example JSON output with inline comments below: > > "bhyve": { > > // 'features' schema version using the common versioning pattern: > // major version increments on incompatible changes, > // minor version increments on compatible changes (extensions). > "schema_version": "1.0", > > // there could also go some general properties like max_cpus etc > > // list of specific features, mostly should be self-descriptive > "features": { > "rtc_utc": { > "description": "RTC keeps UTC time", > "cmd": { > "switch": "-u" > } > }, > "wire_guest_memory": { > "description": "Wire guest memory", > "cmd": { > "switch": "-S" > } > }, > "devices": { > "description": "Devices support", > "cmd": { > "switch": "-s", > "arguments": [ > > // Probably, it'd be better to make this more > organized, > // e.g. instead of a string with all arguments and > arg/value paris, > // use a list of objects which would include > possible values, > // required/optional, etc > > {"options": "virtio-net,tapN,mac=xx:xx:xx:xx:xx:xx", > "description": "Virtio network device" > }, > {"options": "virtio-blk,path,nocache, > direct,ro,sectorsize=logical/physical", > "description": "Virtio block device" > }, > {"options": "fbuf,rfb,rfb=IP:port,w=width, > h=heigh,vga=vgaconf,wait,password=password", > "description": "Framebuffer device" > } > ] > } > } > } > } > > Sample code is here: https://reviews.freebsd.org/D15992. At this point > it's just an excuse to start a discussion; it needs some macros to make > items creation easier, and it needs to have all the other > features/devices populated. > > 1: https://libvirt.org/drvbhyve.html > 2: > https://github.com/libvirt/libvirt/blob/master/src/bhyve/ > bhyve_capabilities.c > > Roman Bogorodskiy > -- -- Marcelo Araujo (__)araujo@FreeBSD.org \\\'',)http://www.FreeBSD.org \/ \ ^ Power To Server. .\. /_)