* SOFTWARE.
*/
+#define BT_LOG_TAG "REF"
+#include <babeltrace/lib-logging-internal.h>
+
#include <babeltrace/ref-internal.h>
#include <babeltrace/object-internal.h>
{
struct bt_object *obj = ptr;
- if (!obj) {
+ if (unlikely(!obj)) {
goto end;
}
- if (obj->parent && bt_object_get_ref_count(obj) == 0) {
+ if (unlikely(obj->parent && bt_object_get_ref_count(obj) == 0)) {
+ BT_LOGV("Incrementing object's parent's reference count: "
+ "addr=%p, parent-addr=%p", ptr, obj->parent);
bt_get(obj->parent);
}
+ BT_LOGV("Incrementing object's reference count: %lu -> %lu: "
+ "addr=%p, cur-count=%lu, new-count=%lu",
+ obj->ref_count.count, obj->ref_count.count + 1,
+ ptr,
+ obj->ref_count.count, obj->ref_count.count + 1);
bt_ref_get(&obj->ref_count);
end:
return obj;
{
struct bt_object *obj = ptr;
- if (!obj) {
+ if (unlikely(!obj)) {
return;
}
+ BT_LOGV("Decrementing object's reference count: %lu -> %lu: "
+ "addr=%p, cur-count=%lu, new-count=%lu",
+ obj->ref_count.count, obj->ref_count.count - 1,
+ ptr,
+ obj->ref_count.count, obj->ref_count.count - 1);
bt_ref_put(&obj->ref_count);
}