struct vdec_lat_buf *buf, *tmp;
        struct list_head *list_core[3];
        struct vdec_msg_queue_ctx *core_ctx;
-       int ret, i, in_core_count = 0;
+       int ret, i, in_core_count = 0, count = 0;
        long timeout_jiff;
 
        core_ctx = &msg_queue->ctx->dev->msg_queue_core_ctx;
                               msg_queue->lat_ctx.ready_num);
                return true;
        }
-       mtk_v4l2_err("failed with lat buf isn't full: %d",
-                    msg_queue->lat_ctx.ready_num);
+
+       spin_lock(&core_ctx->ready_lock);
+       list_for_each_entry_safe(buf, tmp, &core_ctx->ready_queue, core_list) {
+               if (buf && buf->ctx == msg_queue->ctx) {
+                       count++;
+                       list_del(&buf->core_list);
+               }
+       }
+       spin_unlock(&core_ctx->ready_lock);
+
+       mtk_v4l2_err("failed with lat buf isn't full: list(%d %d) count:%d",
+                    atomic_read(&msg_queue->lat_list_cnt),
+                    atomic_read(&msg_queue->core_list_cnt), count);
+
        return false;
 }