283 lines
8.8 KiB
C
283 lines
8.8 KiB
C
|
/*
|
||
|
* Copyright (c) 2019 The WebM project authors. All Rights Reserved.
|
||
|
*
|
||
|
* Use of this source code is governed by a BSD-style license
|
||
|
* that can be found in the LICENSE file in the root of the source
|
||
|
* tree. An additional intellectual property rights grant can be found
|
||
|
* in the file PATENTS. All contributing project authors may
|
||
|
* be found in the AUTHORS file in the root of the source tree.
|
||
|
*/
|
||
|
|
||
|
#include <assert.h>
|
||
|
#include <stdio.h>
|
||
|
#include <string.h>
|
||
|
#include "vpx_util/vpx_debug_util.h"
|
||
|
|
||
|
#if CONFIG_BITSTREAM_DEBUG || CONFIG_MISMATCH_DEBUG
|
||
|
static int frame_idx_w = 0;
|
||
|
static int frame_idx_r = 0;
|
||
|
|
||
|
void bitstream_queue_set_frame_write(int frame_idx) { frame_idx_w = frame_idx; }
|
||
|
|
||
|
int bitstream_queue_get_frame_write(void) { return frame_idx_w; }
|
||
|
|
||
|
void bitstream_queue_set_frame_read(int frame_idx) { frame_idx_r = frame_idx; }
|
||
|
|
||
|
int bitstream_queue_get_frame_read(void) { return frame_idx_r; }
|
||
|
#endif
|
||
|
|
||
|
#if CONFIG_BITSTREAM_DEBUG
|
||
|
#define QUEUE_MAX_SIZE 2000000
|
||
|
static int result_queue[QUEUE_MAX_SIZE];
|
||
|
static int prob_queue[QUEUE_MAX_SIZE];
|
||
|
|
||
|
static int queue_r = 0;
|
||
|
static int queue_w = 0;
|
||
|
static int queue_prev_w = -1;
|
||
|
static int skip_r = 0;
|
||
|
static int skip_w = 0;
|
||
|
void bitstream_queue_set_skip_write(int skip) { skip_w = skip; }
|
||
|
|
||
|
void bitstream_queue_set_skip_read(int skip) { skip_r = skip; }
|
||
|
|
||
|
void bitstream_queue_record_write(void) { queue_prev_w = queue_w; }
|
||
|
|
||
|
void bitstream_queue_reset_write(void) { queue_w = queue_prev_w; }
|
||
|
|
||
|
int bitstream_queue_get_write(void) { return queue_w; }
|
||
|
|
||
|
int bitstream_queue_get_read(void) { return queue_r; }
|
||
|
|
||
|
void bitstream_queue_pop(int *result, int *prob) {
|
||
|
if (!skip_r) {
|
||
|
if (queue_w == queue_r) {
|
||
|
printf("buffer underflow queue_w %d queue_r %d\n", queue_w, queue_r);
|
||
|
assert(0);
|
||
|
}
|
||
|
*result = result_queue[queue_r];
|
||
|
*prob = prob_queue[queue_r];
|
||
|
queue_r = (queue_r + 1) % QUEUE_MAX_SIZE;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void bitstream_queue_push(int result, const int prob) {
|
||
|
if (!skip_w) {
|
||
|
result_queue[queue_w] = result;
|
||
|
prob_queue[queue_w] = prob;
|
||
|
queue_w = (queue_w + 1) % QUEUE_MAX_SIZE;
|
||
|
if (queue_w == queue_r) {
|
||
|
printf("buffer overflow queue_w %d queue_r %d\n", queue_w, queue_r);
|
||
|
assert(0);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
#endif // CONFIG_BITSTREAM_DEBUG
|
||
|
|
||
|
#if CONFIG_MISMATCH_DEBUG
|
||
|
static int frame_buf_idx_r = 0;
|
||
|
static int frame_buf_idx_w = 0;
|
||
|
#define MAX_FRAME_BUF_NUM 20
|
||
|
#define MAX_FRAME_STRIDE 1920
|
||
|
#define MAX_FRAME_HEIGHT 1080
|
||
|
static uint16_t
|
||
|
frame_pre[MAX_FRAME_BUF_NUM][3]
|
||
|
[MAX_FRAME_STRIDE * MAX_FRAME_HEIGHT]; // prediction only
|
||
|
static uint16_t
|
||
|
frame_tx[MAX_FRAME_BUF_NUM][3]
|
||
|
[MAX_FRAME_STRIDE * MAX_FRAME_HEIGHT]; // prediction + txfm
|
||
|
static int frame_stride = MAX_FRAME_STRIDE;
|
||
|
static int frame_height = MAX_FRAME_HEIGHT;
|
||
|
static int frame_size = MAX_FRAME_STRIDE * MAX_FRAME_HEIGHT;
|
||
|
void mismatch_move_frame_idx_w(void) {
|
||
|
frame_buf_idx_w = (frame_buf_idx_w + 1) % MAX_FRAME_BUF_NUM;
|
||
|
if (frame_buf_idx_w == frame_buf_idx_r) {
|
||
|
printf("frame_buf overflow\n");
|
||
|
assert(0);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void mismatch_reset_frame(int num_planes) {
|
||
|
int plane;
|
||
|
for (plane = 0; plane < num_planes; ++plane) {
|
||
|
memset(frame_pre[frame_buf_idx_w][plane], 0,
|
||
|
sizeof(frame_pre[frame_buf_idx_w][plane][0]) * frame_size);
|
||
|
memset(frame_tx[frame_buf_idx_w][plane], 0,
|
||
|
sizeof(frame_tx[frame_buf_idx_w][plane][0]) * frame_size);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void mismatch_move_frame_idx_r(void) {
|
||
|
if (frame_buf_idx_w == frame_buf_idx_r) {
|
||
|
printf("frame_buf underflow\n");
|
||
|
assert(0);
|
||
|
}
|
||
|
frame_buf_idx_r = (frame_buf_idx_r + 1) % MAX_FRAME_BUF_NUM;
|
||
|
}
|
||
|
|
||
|
void mismatch_record_block_pre(const uint8_t *src, int src_stride, int plane,
|
||
|
int pixel_c, int pixel_r, int blk_w, int blk_h,
|
||
|
int highbd) {
|
||
|
const uint16_t *src16 = highbd ? CONVERT_TO_SHORTPTR(src) : NULL;
|
||
|
int r, c;
|
||
|
|
||
|
if (pixel_c + blk_w >= frame_stride || pixel_r + blk_h >= frame_height) {
|
||
|
printf("frame_buf undersized\n");
|
||
|
assert(0);
|
||
|
}
|
||
|
|
||
|
for (r = 0; r < blk_h; ++r) {
|
||
|
for (c = 0; c < blk_w; ++c) {
|
||
|
frame_pre[frame_buf_idx_w][plane]
|
||
|
[(r + pixel_r) * frame_stride + c + pixel_c] =
|
||
|
src16 ? src16[r * src_stride + c] : src[r * src_stride + c];
|
||
|
}
|
||
|
}
|
||
|
#if 0
|
||
|
{
|
||
|
int ref_frame_idx = 3;
|
||
|
int ref_plane = 1;
|
||
|
int ref_pixel_c = 162;
|
||
|
int ref_pixel_r = 16;
|
||
|
if (frame_idx_w == ref_frame_idx && plane == ref_plane &&
|
||
|
ref_pixel_c >= pixel_c && ref_pixel_c < pixel_c + blk_w &&
|
||
|
ref_pixel_r >= pixel_r && ref_pixel_r < pixel_r + blk_h) {
|
||
|
printf(
|
||
|
"\nrecord_block_pre frame_idx %d plane %d pixel_c %d pixel_r %d blk_w"
|
||
|
" %d blk_h %d\n",
|
||
|
frame_idx_w, plane, pixel_c, pixel_r, blk_w, blk_h);
|
||
|
}
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
void mismatch_record_block_tx(const uint8_t *src, int src_stride, int plane,
|
||
|
int pixel_c, int pixel_r, int blk_w, int blk_h,
|
||
|
int highbd) {
|
||
|
const uint16_t *src16 = highbd ? CONVERT_TO_SHORTPTR(src) : NULL;
|
||
|
int r, c;
|
||
|
if (pixel_c + blk_w >= frame_stride || pixel_r + blk_h >= frame_height) {
|
||
|
printf("frame_buf undersized\n");
|
||
|
assert(0);
|
||
|
}
|
||
|
|
||
|
for (r = 0; r < blk_h; ++r) {
|
||
|
for (c = 0; c < blk_w; ++c) {
|
||
|
frame_tx[frame_buf_idx_w][plane]
|
||
|
[(r + pixel_r) * frame_stride + c + pixel_c] =
|
||
|
src16 ? src16[r * src_stride + c] : src[r * src_stride + c];
|
||
|
}
|
||
|
}
|
||
|
#if 0
|
||
|
{
|
||
|
int ref_frame_idx = 3;
|
||
|
int ref_plane = 1;
|
||
|
int ref_pixel_c = 162;
|
||
|
int ref_pixel_r = 16;
|
||
|
if (frame_idx_w == ref_frame_idx && plane == ref_plane &&
|
||
|
ref_pixel_c >= pixel_c && ref_pixel_c < pixel_c + blk_w &&
|
||
|
ref_pixel_r >= pixel_r && ref_pixel_r < pixel_r + blk_h) {
|
||
|
printf(
|
||
|
"\nrecord_block_tx frame_idx %d plane %d pixel_c %d pixel_r %d blk_w "
|
||
|
"%d blk_h %d\n",
|
||
|
frame_idx_w, plane, pixel_c, pixel_r, blk_w, blk_h);
|
||
|
}
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
void mismatch_check_block_pre(const uint8_t *src, int src_stride, int plane,
|
||
|
int pixel_c, int pixel_r, int blk_w, int blk_h,
|
||
|
int highbd) {
|
||
|
const uint16_t *src16 = highbd ? CONVERT_TO_SHORTPTR(src) : NULL;
|
||
|
int mismatch = 0;
|
||
|
int r, c;
|
||
|
if (pixel_c + blk_w >= frame_stride || pixel_r + blk_h >= frame_height) {
|
||
|
printf("frame_buf undersized\n");
|
||
|
assert(0);
|
||
|
}
|
||
|
|
||
|
for (r = 0; r < blk_h; ++r) {
|
||
|
for (c = 0; c < blk_w; ++c) {
|
||
|
if (frame_pre[frame_buf_idx_r][plane]
|
||
|
[(r + pixel_r) * frame_stride + c + pixel_c] !=
|
||
|
(uint16_t)(src16 ? src16[r * src_stride + c]
|
||
|
: src[r * src_stride + c])) {
|
||
|
mismatch = 1;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (mismatch) {
|
||
|
int rr, cc;
|
||
|
printf(
|
||
|
"\ncheck_block_pre failed frame_idx %d plane %d "
|
||
|
"pixel_c %d pixel_r "
|
||
|
"%d blk_w %d blk_h %d\n",
|
||
|
frame_idx_r, plane, pixel_c, pixel_r, blk_w, blk_h);
|
||
|
printf("enc\n");
|
||
|
for (rr = 0; rr < blk_h; ++rr) {
|
||
|
for (cc = 0; cc < blk_w; ++cc) {
|
||
|
printf("%d ", frame_pre[frame_buf_idx_r][plane]
|
||
|
[(rr + pixel_r) * frame_stride + cc + pixel_c]);
|
||
|
}
|
||
|
printf("\n");
|
||
|
}
|
||
|
|
||
|
printf("dec\n");
|
||
|
for (rr = 0; rr < blk_h; ++rr) {
|
||
|
for (cc = 0; cc < blk_w; ++cc) {
|
||
|
printf("%d ",
|
||
|
src16 ? src16[rr * src_stride + cc] : src[rr * src_stride + cc]);
|
||
|
}
|
||
|
printf("\n");
|
||
|
}
|
||
|
assert(0);
|
||
|
}
|
||
|
}
|
||
|
void mismatch_check_block_tx(const uint8_t *src, int src_stride, int plane,
|
||
|
int pixel_c, int pixel_r, int blk_w, int blk_h,
|
||
|
int highbd) {
|
||
|
const uint16_t *src16 = highbd ? CONVERT_TO_SHORTPTR(src) : NULL;
|
||
|
int mismatch = 0;
|
||
|
int r, c;
|
||
|
if (pixel_c + blk_w >= frame_stride || pixel_r + blk_h >= frame_height) {
|
||
|
printf("frame_buf undersized\n");
|
||
|
assert(0);
|
||
|
}
|
||
|
|
||
|
for (r = 0; r < blk_h; ++r) {
|
||
|
for (c = 0; c < blk_w; ++c) {
|
||
|
if (frame_tx[frame_buf_idx_r][plane]
|
||
|
[(r + pixel_r) * frame_stride + c + pixel_c] !=
|
||
|
(uint16_t)(src16 ? src16[r * src_stride + c]
|
||
|
: src[r * src_stride + c])) {
|
||
|
mismatch = 1;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (mismatch) {
|
||
|
int rr, cc;
|
||
|
printf(
|
||
|
"\ncheck_block_tx failed frame_idx %d plane %d pixel_c "
|
||
|
"%d pixel_r "
|
||
|
"%d blk_w %d blk_h %d\n",
|
||
|
frame_idx_r, plane, pixel_c, pixel_r, blk_w, blk_h);
|
||
|
printf("enc\n");
|
||
|
for (rr = 0; rr < blk_h; ++rr) {
|
||
|
for (cc = 0; cc < blk_w; ++cc) {
|
||
|
printf("%d ", frame_tx[frame_buf_idx_r][plane]
|
||
|
[(rr + pixel_r) * frame_stride + cc + pixel_c]);
|
||
|
}
|
||
|
printf("\n");
|
||
|
}
|
||
|
|
||
|
printf("dec\n");
|
||
|
for (rr = 0; rr < blk_h; ++rr) {
|
||
|
for (cc = 0; cc < blk_w; ++cc) {
|
||
|
printf("%d ",
|
||
|
src16 ? src16[rr * src_stride + cc] : src[rr * src_stride + cc]);
|
||
|
}
|
||
|
printf("\n");
|
||
|
}
|
||
|
assert(0);
|
||
|
}
|
||
|
}
|
||
|
#endif // CONFIG_MISMATCH_DEBUG
|