All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Alex Bennée" <alex.bennee@linaro.org>
To: "Philippe Mathieu-Daudé" <philmd@linaro.org>
Cc: qemu-devel@nongnu.org,
	"Wainer dos Santos Moschetta" <wainersm@redhat.com>,
	"Juan Quintela" <quintela@redhat.com>,
	"Thomas Huth" <thuth@redhat.com>,
	"Cleber Rosa" <crosa@redhat.com>,
	"Leonardo Bras" <leobras@redhat.com>,
	"Beraldo Leal" <bleal@redhat.com>,
	"Peter Maydell" <peter.maydell@linaro.org>,
	"Bin Meng" <bmeng.cn@gmail.com>,
	"Yanan Wang" <wangyanan55@huawei.com>,
	"Darren Kenny" <darren.kenny@oracle.com>,
	"Alexander Bulekov" <alxndr@bu.edu>,
	"Marcel Apfelbaum" <marcel.apfelbaum@gmail.com>,
	"Peter Xu" <peterx@redhat.com>,
	"Radoslaw Biernacki" <rad@semihalf.com>,
	"Laurent Vivier" <laurent@vivier.eu>,
	"Paolo Bonzini" <pbonzini@redhat.com>,
	"Eduardo Habkost" <eduardo@habkost.net>,
	qemu-arm@nongnu.org, "Stefan Hajnoczi" <stefanha@redhat.com>,
	"Richard Henderson" <richard.henderson@linaro.org>,
	"Bandan Das" <bsd@redhat.com>,
	"Daniel P. Berrangé" <berrange@redhat.com>,
	"Alexandre Iooss" <erdnaxe@crans.org>,
	"Marcin Juszkiewicz" <marcin.juszkiewicz@linaro.org>,
	"Leif Lindholm" <quic_llindhol@quicinc.com>,
	"Laurent Vivier" <lvivier@redhat.com>,
	"Qiuhao Li" <Qiuhao.Li@outlook.com>,
	"Mahmoud Mandour" <ma.mandourr@gmail.com>,
	"Riku Voipio" <riku.voipio@iki.fi>
Subject: Re: [PATCH v3 25/36] docs/devel: introduce some key concepts for QOM development
Date: Fri, 30 Jun 2023 09:03:56 +0100	[thread overview]
Message-ID: <87fs69xta2.fsf@linaro.org> (raw)
In-Reply-To: <b08189c8-38c2-adbf-7bb3-0304f4845fc0@linaro.org>


Philippe Mathieu-Daudé <philmd@linaro.org> writes:

> On 27/6/23 18:09, Alex Bennée wrote:
>> Using QOM correctly is increasingly important to maintaining a modern
>> code base. However the current documentation skips some important
>> concepts before launching into a simple example. Lets:
>>    - at least mention properties
>>    - mention TYPE_OBJECT and TYPE_DEVICE
>>    - talk about why we have realize/unrealize
>>    - mention the QOM tree
>>    - lightly re-arrange the order we mention things
>> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
>> Message-Id: <20230619171437.357374-6-alex.bennee@linaro.org>
>> ---
>> v3
>>    - moved around as per Paolo's review
>> ---
>>   docs/devel/qom.rst | 58 +++++++++++++++++++++++++++++++++++++++++-----
>>   1 file changed, 52 insertions(+), 6 deletions(-)
>
>
>> +Creating a QOM class
>> +====================
>> +
>> +A simple minimal device implementation may look something like bellow:
>>     .. code-block:: c
>>      :caption: Creating a minimal type
>> @@ -48,6 +66,12 @@ In the above example, we create a simple type that is described by #TypeInfo.
>>   #TypeInfo describes information about the type including what it inherits
>>   from, the instance and class size, and constructor/destructor hooks.
>>   +The TYPE_DEVICE class is the parent class for all modern devices
>> +implemented in QEMU and adds some specific methods to handle QEMU
>> +device model. This includes managing the lifetime of devices from
>> +creation through to when they become visible to the guest and
>> +eventually unrealized.
>
> Good enough but we are mixing QOM vs QDev...

Yeah, but one relies on the other. From the point of view of someone
coming new to the code I think we do want to mention them both together.
Most people implementing QOM classes will be for devices I think.

Maybe we should enumerate all the types that have TYPE_OBJECT as their
parent?

>
>>   Alternatively several static types could be registered using helper macro
>>   DEFINE_TYPES()
>
>
>> +.. _device-life-cycle:
>> +
>> +Device Life-cycle
>> +=================
>> +
>> +As class initialisation cannot fail devices have an two additional
>> +methods to handle the creation of dynamic devices. The ``realize``
>> +function is called with ``Error **`` pointer which should be set if
>> +the device cannot complete its setup. Otherwise on successful
>> +completion of the ``realize`` method the device object is added to the
>> +QOM tree and made visible to the guest.
>> +
>> +The reverse function is ``unrealize`` and should be were clean-up
>> +code lives to tidy up after the system is done with the device.
>
> Worth mentioning hotplug devices must implement it?
>
>> +All devices can be instantiated by C code, however only some can
>> +created dynamically via the command line or monitor.
>>   +Likewise only some can be unplugged after creation and need an
>> +explicit ``unrealize`` implementation.
>
> Ah, here we go.
>
>> This is determined by the
>> +``user_creatable`` variable in the root ``DeviceClass`` structure.
>> +Devices can only be unplugged if their ``parent_bus`` has a registered
>> +``HotplugHandler``.
>
> TODO on top, mentions the reset() handlers are called after realize(),
> and can be called multiple times.

Where is this TODO? I'm wary of talking about reset too much as the old
reset handler is a deprecated API.

>
>>   API Reference
>> --------------
>> +=============
>>     See the :ref:`QOM API<qom-api>` and :ref:`QDEV API<qdev-api>`
>>   documents for the complete API description.
>
> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>


-- 
Alex Bennée
Virtualisation Tech Lead @ Linaro

  reply	other threads:[~2023-06-30  8:12 UTC|newest]

Thread overview: 58+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-06-27 16:09 [PATCH v3 00/36] maintainer omnibus: testing, fuzz, plugins, documentation, gdbstub (pre-PR) Alex Bennée
2023-06-27 16:09 ` [PATCH v3 01/36] gitlab: explicit set artifacts publishing criteria Alex Bennée
2023-06-27 16:09 ` [PATCH v3 02/36] gitlab: ensure coverage job also publishes meson log Alex Bennée
2023-06-27 16:09 ` [PATCH v3 03/36] gitlab: reduce testing scope of check-gcov Alex Bennée
2023-06-27 21:08   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 04/36] docs/devel: remind developers to run CI container pipeline when updating images Alex Bennée
2023-06-29 13:42   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 05/36] tests/tcg: add mechanism to handle plugin arguments Alex Bennée
2023-06-27 16:09 ` [PATCH v3 06/36] qemu-keymap: properly check return from xkb_keymap_mod_get_index Alex Bennée
2023-06-27 16:09 ` [PATCH v3 07/36] scripts/oss-fuzz: add a suppression for keymap Alex Bennée
2023-06-27 16:09 ` [PATCH v3 08/36] tests/qtests: clean-up and fix leak in generic_fuzz Alex Bennée
2023-06-27 21:07   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 09/36] tests/docker: add test-fuzz Alex Bennée
2023-06-27 16:09 ` [PATCH v3 10/36] Makefile: add lcitool-refresh to UNCHECKED_GOALS Alex Bennée
2023-06-27 16:09 ` [PATCH v3 11/36] tests/lcitool: update to latest version Alex Bennée
2023-06-27 16:09 ` [PATCH v3 12/36] tests/lcitool: Bump fedora container versions Alex Bennée
2023-06-27 21:06   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 13/36] tests/lcitool: add an explicit gcc-native package Alex Bennée
2023-06-27 16:09 ` [PATCH v3 14/36] tests/lcitool: introduce qemu-minimal Alex Bennée
2023-06-27 16:09 ` [PATCH v3 15/36] tests/docker: convert riscv64-cross to lcitool Alex Bennée
2023-06-28  8:38   ` Richard Henderson
2023-06-29 13:47     ` Alex Bennée
2023-06-27 16:09 ` [PATCH v3 16/36] tests/avocado: update firmware to enable sbsa-ref/max Alex Bennée
2023-06-27 21:06   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 17/36] plugins: force slow path when plugins instrument memory ops Alex Bennée
2023-06-28  8:40   ` Richard Henderson
2023-06-28  9:06     ` Alex Bennée
2023-06-28  9:20       ` Richard Henderson
2023-06-29 11:59         ` Alex Bennée
2023-06-27 16:09 ` [PATCH v3 18/36] plugins: fix memory leak while parsing options Alex Bennée
2023-06-27 16:09 ` [PATCH v3 19/36] plugins: update lockstep to use g_memdup2 Alex Bennée
2023-06-27 21:05   ` Philippe Mathieu-Daudé
2023-11-13 11:03   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 20/36] docs/devel: add some front matter to the devel index Alex Bennée
2023-06-29 13:31   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 21/36] include/migration: mark vmstate_register() as a legacy function Alex Bennée
2023-06-27 16:09 ` [PATCH v3 22/36] include/hw/qdev-core: fixup kerneldoc annotations Alex Bennée
2023-06-29 13:34   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 23/36] docs/devel/qom.rst: Correct code style Alex Bennée
2023-06-27 16:09 ` [PATCH v3 24/36] docs/devel: split qom-api reference into new file Alex Bennée
2023-06-27 16:09 ` [PATCH v3 25/36] docs/devel: introduce some key concepts for QOM development Alex Bennée
2023-06-29 13:41   ` Philippe Mathieu-Daudé
2023-06-30  8:03     ` Alex Bennée [this message]
2023-06-30  8:57     ` Paolo Bonzini
2023-06-27 16:09 ` [PATCH v3 26/36] gdbstub: lightly refactor connection to avoid snprintf Alex Bennée
2023-06-27 16:09 ` [PATCH v3 27/36] gdbstub: Permit reverse step/break to provide stop response Alex Bennée
2023-06-27 16:09 ` [PATCH v3 28/36] gdbstub: clean-up vcont handling to avoid goto Alex Bennée
2023-06-28  8:42   ` Richard Henderson
2023-06-27 16:09 ` [PATCH v3 29/36] linux-user: Expose do_guest_openat() and do_guest_readlink() Alex Bennée
2023-06-27 16:09 ` [PATCH v3 30/36] linux-user: Add "safe" parameter to do_guest_openat() Alex Bennée
2023-06-27 16:09 ` [PATCH v3 31/36] linux-user: Emulate /proc/self/smaps Alex Bennée
2023-06-27 16:09 ` [PATCH v3 32/36] gdbstub: Expose gdb_get_process() and gdb_get_first_cpu_in_process() Alex Bennée
2023-06-27 20:59   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 33/36] gdbstub: Report the actual qemu-user pid Alex Bennée
2023-06-27 16:09 ` [PATCH v3 34/36] gdbstub: Add support for info proc mappings Alex Bennée
2023-06-27 16:09 ` [PATCH v3 35/36] docs: Document security implications of debugging Alex Bennée
2023-06-27 21:00   ` Philippe Mathieu-Daudé
2023-06-27 16:09 ` [PATCH v3 36/36] tests/tcg: Add a test for info proc mappings Alex Bennée

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87fs69xta2.fsf@linaro.org \
    --to=alex.bennee@linaro.org \
    --cc=Qiuhao.Li@outlook.com \
    --cc=alxndr@bu.edu \
    --cc=berrange@redhat.com \
    --cc=bleal@redhat.com \
    --cc=bmeng.cn@gmail.com \
    --cc=bsd@redhat.com \
    --cc=crosa@redhat.com \
    --cc=darren.kenny@oracle.com \
    --cc=eduardo@habkost.net \
    --cc=erdnaxe@crans.org \
    --cc=laurent@vivier.eu \
    --cc=leobras@redhat.com \
    --cc=lvivier@redhat.com \
    --cc=ma.mandourr@gmail.com \
    --cc=marcel.apfelbaum@gmail.com \
    --cc=marcin.juszkiewicz@linaro.org \
    --cc=pbonzini@redhat.com \
    --cc=peter.maydell@linaro.org \
    --cc=peterx@redhat.com \
    --cc=philmd@linaro.org \
    --cc=qemu-arm@nongnu.org \
    --cc=qemu-devel@nongnu.org \
    --cc=quic_llindhol@quicinc.com \
    --cc=quintela@redhat.com \
    --cc=rad@semihalf.com \
    --cc=richard.henderson@linaro.org \
    --cc=riku.voipio@iki.fi \
    --cc=stefanha@redhat.com \
    --cc=thuth@redhat.com \
    --cc=wainersm@redhat.com \
    --cc=wangyanan55@huawei.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.