diff --git a/main/astobj2.c b/main/astobj2.c
index da113b1188176a8145b5d416bbc07609a045f64c..678517bf6e5883ae2523ff2eca9474c397a5dc8e 100644
--- a/main/astobj2.c
+++ b/main/astobj2.c
@@ -499,14 +499,8 @@ int __ao2_ref_debug(void *user_data, int delta, const char *tag, const char *fil
 {
 	struct astobj2 *obj = INTERNAL_OBJ(user_data);
 
-	if (obj == NULL) {
-		ast_log_backtrace();
-		ast_assert(0);
-		return -1;
-	}
-
-	if (ref_log) {
-		if (obj->priv_data.ref_counter + delta == 0) {
+	if (ref_log && user_data) {
+		if (obj && obj->priv_data.ref_counter + delta == 0) {
 			fprintf(ref_log, "%p,%d,%d,%s,%d,%s,**destructor**,%s\n", user_data, delta, ast_get_tid(), file, line, func, tag);
 			fflush(ref_log);
 		} else if (delta != 0) {
@@ -515,6 +509,13 @@ int __ao2_ref_debug(void *user_data, int delta, const char *tag, const char *fil
 			fflush(ref_log);
 		}
 	}
+
+	if (obj == NULL) {
+		ast_log_backtrace();
+		ast_assert(0);
+		return -1;
+	}
+
 	return internal_ao2_ref(user_data, delta, file, line, func);
 }