From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:52113) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dwN1Y-0004R7-Vx for qemu-devel@nongnu.org; Mon, 25 Sep 2017 02:37:49 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dwN1Y-0004y2-5x for qemu-devel@nongnu.org; Mon, 25 Sep 2017 02:37:49 -0400 Received: from mx1.redhat.com ([209.132.183.28]:49514) by eggs.gnu.org with esmtps (TLS1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.71) (envelope-from ) id 1dwN1X-0004x4-Vk for qemu-devel@nongnu.org; Mon, 25 Sep 2017 02:37:48 -0400 From: Peter Xu Date: Mon, 25 Sep 2017 14:37:26 +0800 Message-Id: <1506321449-24013-2-git-send-email-peterx@redhat.com> In-Reply-To: <1506321449-24013-1-git-send-email-peterx@redhat.com> References: <1506321449-24013-1-git-send-email-peterx@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable Subject: [Qemu-devel] [PATCH v2 1/4] qom: provide root container for internal objs List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: Paolo Bonzini , "Daniel P . Berrange" , Stefan Hajnoczi , Fam Zheng , "Dr . David Alan Gilbert" , peterx@redhat.com, =?UTF-8?q?Andreas=20F=C3=A4rber?= , Markus Armbruster We have object_get_objects_root() to keep user created objects, however no place for objects that will be used internally. Create such a container for internal objects. CC: Andreas F=C3=A4rber CC: Markus Armbruster CC: Paolo Bonzini Suggested-by: Daniel P. Berrange Signed-off-by: Peter Xu --- include/qom/object.h | 10 ++++++++++ qom/object.c | 5 +++++ 2 files changed, 15 insertions(+) diff --git a/include/qom/object.h b/include/qom/object.h index f3e5cff..f567052 100644 --- a/include/qom/object.h +++ b/include/qom/object.h @@ -1214,6 +1214,16 @@ Object *object_get_root(void); Object *object_get_objects_root(void); =20 /** + * object_get_internal_root: + * + * Get the container object that holds internally used object + * instances. This is the object at path "/internal-objects" + * + * Returns: the internal object container + */ +Object *object_get_internal_root(void); + +/** * object_get_canonical_path_component: * * Returns: The final component in the object's canonical path. The can= onical diff --git a/qom/object.c b/qom/object.c index 3e18537..857cee7 100644 --- a/qom/object.c +++ b/qom/object.c @@ -1370,6 +1370,11 @@ Object *object_get_objects_root(void) return container_get(object_get_root(), "/objects"); } =20 +Object *object_get_internal_root(void) +{ + return container_get(object_get_root(), "/internal-objects"); +} + static void object_get_child_property(Object *obj, Visitor *v, const char *name, void *opaque, Error **errp) --=20 2.7.4