diff options
author | Jan Kiszka <jan.kiszka@siemens.com> | 2013-07-02 11:36:39 +0200 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2013-07-04 17:42:49 +0200 |
commit | f08c03f3c404e85a2b81890191ccb48dc1ecc157 (patch) | |
tree | d5434b5d7304f9da641af763db654d032fa500b3 /qom | |
parent | 856d72454f03aea26fd61c728762ef9cd1d71512 (diff) | |
download | qemu-f08c03f3c404e85a2b81890191ccb48dc1ecc157.zip qemu-f08c03f3c404e85a2b81890191ccb48dc1ecc157.tar.gz qemu-f08c03f3c404e85a2b81890191ccb48dc1ecc157.tar.bz2 |
qom: Use atomics for object refcounting
Object reference counts will soon be changed outside the BQL. So we need
to use atomics in object_ref/unref.
Based on a patch by Liu Ping Fan.
Signed-off-by: Liu Ping Fan <qemulist@gmail.com>
Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'qom')
-rw-r--r-- | qom/object.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/qom/object.c b/qom/object.c index 803b94b..cbd7e86 100644 --- a/qom/object.c +++ b/qom/object.c @@ -683,16 +683,15 @@ GSList *object_class_get_list(const char *implements_type, void object_ref(Object *obj) { - obj->ref++; + atomic_inc(&obj->ref); } void object_unref(Object *obj) { g_assert(obj->ref > 0); - obj->ref--; /* parent always holds a reference to its children */ - if (obj->ref == 0) { + if (atomic_fetch_dec(&obj->ref) == 1) { object_finalize(obj); } } |