diff options
Diffstat (limited to 'src/dsp/intra_edge.cc')
-rw-r--r-- | src/dsp/intra_edge.cc | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/dsp/intra_edge.cc b/src/dsp/intra_edge.cc index fe66db2..9875ef1 100644 --- a/src/dsp/intra_edge.cc +++ b/src/dsp/intra_edge.cc @@ -100,7 +100,26 @@ void Init10bpp() { #endif #endif // LIBGAV1_ENABLE_ALL_DSP_FUNCTIONS } +#endif // LIBGAV1_MAX_BITDEPTH >= 10 + +#if LIBGAV1_MAX_BITDEPTH == 12 +void Init12bpp() { + Dsp* const dsp = dsp_internal::GetWritableDspTable(12); + assert(dsp != nullptr); +#if LIBGAV1_ENABLE_ALL_DSP_FUNCTIONS + dsp->intra_edge_filter = IntraEdgeFilter_C<uint16_t>; + dsp->intra_edge_upsampler = IntraEdgeUpsampler_C<12, uint16_t>; +#else // !LIBGAV1_ENABLE_ALL_DSP_FUNCTIONS + static_cast<void>(dsp); +#ifndef LIBGAV1_Dsp12bpp_IntraEdgeFilter + dsp->intra_edge_filter = IntraEdgeFilter_C<uint16_t>; +#endif +#ifndef LIBGAV1_Dsp12bpp_IntraEdgeUpsampler + dsp->intra_edge_upsampler = IntraEdgeUpsampler_C<12, uint16_t>; #endif +#endif // LIBGAV1_ENABLE_ALL_DSP_FUNCTIONS +} +#endif // LIBGAV1_MAX_BITDEPTH == 12 } // namespace @@ -109,6 +128,9 @@ void IntraEdgeInit_C() { #if LIBGAV1_MAX_BITDEPTH >= 10 Init10bpp(); #endif +#if LIBGAV1_MAX_BITDEPTH == 12 + Init12bpp(); +#endif } } // namespace dsp |