Coverage Report

Created: 2025-12-31 07:53

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aom/av1/common/frame_buffers.c
Line
Count
Source
1
/*
2
 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
3
 *
4
 * This source code is subject to the terms of the BSD 2 Clause License and
5
 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6
 * was not distributed with this source code in the LICENSE file, you can
7
 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8
 * Media Patent License 1.0 was not distributed with this source code in the
9
 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10
 */
11
12
#include <assert.h>
13
14
#include "av1/common/frame_buffers.h"
15
#include "aom_mem/aom_mem.h"
16
17
36.1k
int av1_alloc_internal_frame_buffers(InternalFrameBufferList *list) {
18
36.1k
  assert(list != NULL);
19
36.1k
  av1_free_internal_frame_buffers(list);
20
21
36.1k
  list->num_internal_frame_buffers =
22
36.1k
      AOM_MAXIMUM_REF_BUFFERS + AOM_MAXIMUM_WORK_BUFFERS;
23
36.1k
  list->int_fb = (InternalFrameBuffer *)aom_calloc(
24
36.1k
      list->num_internal_frame_buffers, sizeof(*list->int_fb));
25
36.1k
  if (list->int_fb == NULL) {
26
0
    list->num_internal_frame_buffers = 0;
27
0
    return 1;
28
0
  }
29
36.1k
  return 0;
30
36.1k
}
31
32
72.2k
void av1_free_internal_frame_buffers(InternalFrameBufferList *list) {
33
72.2k
  int i;
34
35
72.2k
  assert(list != NULL);
36
37
650k
  for (i = 0; i < list->num_internal_frame_buffers; ++i) {
38
577k
    aom_free(list->int_fb[i].data);
39
577k
    list->int_fb[i].data = NULL;
40
577k
  }
41
72.2k
  aom_free(list->int_fb);
42
72.2k
  list->int_fb = NULL;
43
72.2k
  list->num_internal_frame_buffers = 0;
44
72.2k
}
45
46
6.98k
void av1_zero_unused_internal_frame_buffers(InternalFrameBufferList *list) {
47
6.98k
  int i;
48
49
6.98k
  assert(list != NULL);
50
51
118k
  for (i = 0; i < list->num_internal_frame_buffers; ++i) {
52
111k
    if (list->int_fb[i].data && !list->int_fb[i].in_use)
53
9.40k
      memset(list->int_fb[i].data, 0, list->int_fb[i].size);
54
111k
  }
55
6.98k
}
56
57
int av1_get_frame_buffer(void *cb_priv, size_t min_size,
58
76.0k
                         aom_codec_frame_buffer_t *fb) {
59
76.0k
  int i;
60
76.0k
  InternalFrameBufferList *const int_fb_list =
61
76.0k
      (InternalFrameBufferList *)cb_priv;
62
76.0k
  if (int_fb_list == NULL) return -1;
63
64
  // Find a free frame buffer.
65
159k
  for (i = 0; i < int_fb_list->num_internal_frame_buffers; ++i) {
66
159k
    if (!int_fb_list->int_fb[i].in_use) break;
67
159k
  }
68
69
76.0k
  if (i == int_fb_list->num_internal_frame_buffers) return -1;
70
71
76.0k
  if (int_fb_list->int_fb[i].size < min_size) {
72
55.9k
    aom_free(int_fb_list->int_fb[i].data);
73
    // The data must be zeroed to fix a valgrind error from the C loop filter
74
    // due to access uninitialized memory in frame border. It could be
75
    // skipped if border were totally removed.
76
55.9k
    int_fb_list->int_fb[i].data = (uint8_t *)aom_calloc(1, min_size);
77
55.9k
    if (!int_fb_list->int_fb[i].data) {
78
0
      int_fb_list->int_fb[i].size = 0;
79
0
      return -1;
80
0
    }
81
55.9k
    int_fb_list->int_fb[i].size = min_size;
82
55.9k
  }
83
84
76.0k
  fb->data = int_fb_list->int_fb[i].data;
85
76.0k
  fb->size = int_fb_list->int_fb[i].size;
86
76.0k
  int_fb_list->int_fb[i].in_use = 1;
87
88
  // Set the frame buffer's private data to point at the internal frame buffer.
89
76.0k
  fb->priv = &int_fb_list->int_fb[i];
90
76.0k
  return 0;
91
76.0k
}
92
93
76.0k
int av1_release_frame_buffer(void *cb_priv, aom_codec_frame_buffer_t *fb) {
94
76.0k
  InternalFrameBuffer *const int_fb = (InternalFrameBuffer *)fb->priv;
95
76.0k
  (void)cb_priv;
96
76.0k
  if (int_fb) int_fb->in_use = 0;
97
76.0k
  return 0;
98
76.0k
}