[MOVED FROM BAD 08/56] gst/deinterlace2/tvtime/greedy.c: Implement a C version of the greedy low motion algorithm and mark the assembly opti...

Original commit message from CVS:
* gst/deinterlace2/tvtime/greedy.c:
(deinterlace_greedy_packed422_scanline_sse),
(deinterlace_greedy_packed422_scanline_c),
(deinterlace_greedy_packed422_scanline):
Implement a C version of the greedy low motion algorithm and mark the
assembly optimized version as SSE as it uses SSE instructions
additional to MMX instructions.
This commit is contained in:
Sebastian Dröge 2008-06-21 09:05:00 +00:00 committed by Sebastian Dröge
parent 6cc147c5d9
commit 98eddc859f

View file

@ -37,8 +37,6 @@
# include "config.h" # include "config.h"
#endif #endif
#include "mmx.h"
#include "sse.h"
#include "gstdeinterlace2.h" #include "gstdeinterlace2.h"
#include "speedtools.h" #include "speedtools.h"
#include "speedy.h" #include "speedy.h"
@ -64,11 +62,13 @@ copy_scanline (GstDeinterlace2 * object,
static int GreedyMaxComb = 15; static int GreedyMaxComb = 15;
#ifdef HAVE_CPU_I386
#include "mmx.h"
#include "sse.h"
static void static void
deinterlace_greedy_packed422_scanline_mmxext (GstDeinterlace2 * object, deinterlace_greedy_packed422_scanline_sse (GstDeinterlace2 * object,
deinterlace_scanline_data_t * data, uint8_t * output) deinterlace_scanline_data_t * data, uint8_t * output)
{ {
#ifdef HAVE_CPU_I386
mmx_t MaxComb; mmx_t MaxComb;
uint8_t *m0 = data->m0; uint8_t *m0 = data->m0;
@ -171,6 +171,72 @@ deinterlace_greedy_packed422_scanline_mmxext (GstDeinterlace2 * object,
} }
sfence (); sfence ();
emms (); emms ();
}
#endif
static void
deinterlace_greedy_packed422_scanline_c (GstDeinterlace2 * object,
deinterlace_scanline_data_t * data, uint8_t * output)
{
uint8_t *m0 = data->m0;
uint8_t *t1 = data->t1;
uint8_t *b1 = data->b1;
uint8_t *m2 = data->m2;
int width = 2 * object->frame_width;
uint16_t avg, l2_diff, lp2_diff, max, min, best;
// L2 == m0
// L1 == t1
// L3 == b1
// LP2 == m2
while (width--) {
avg = (*t1 + *b1) / 2;
l2_diff = ABS (*m0 - avg);
lp2_diff = ABS (*m2 - avg);
if (l2_diff > lp2_diff)
best = *m2;
else
best = *m0;
max = MAX (*t1, *b1);
min = MIN (*t1, *b1);
if (max < 256 - GreedyMaxComb)
max += GreedyMaxComb;
if (min > GreedyMaxComb)
min -= GreedyMaxComb;
*output = MIN (MAX (best, min), max);
// Advance to the next set of pixels.
output += 1;
m0 += 1;
t1 += 1;
b1 += 1;
m2 += 1;
}
}
static void
deinterlace_greedy_packed422_scanline (GstDeinterlace2 * object,
deinterlace_scanline_data_t * data, uint8_t * output)
{
#ifdef HAVE_CPU_I386
if (object->cpu_feature_flags & OIL_IMPL_FLAG_SSE) {
deinterlace_greedy_packed422_scanline_sse (object, data, output);
} else {
deinterlace_greedy_packed422_scanline_c (object, data, output);
}
#else
deinterlace_greedy_packed422_scanline_c (object, data, output);
#endif #endif
} }
@ -180,13 +246,13 @@ static deinterlace_method_t greedyl_method = {
"Motion Adaptive: Simple Detection", "Motion Adaptive: Simple Detection",
"AdaptiveSimple", "AdaptiveSimple",
3, 3,
OIL_IMPL_FLAG_MMXEXT, 0,
0, 0,
0, 0,
0, 0,
1, 1,
copy_scanline, copy_scanline,
deinterlace_greedy_packed422_scanline_mmxext, deinterlace_greedy_packed422_scanline,
0, 0,
{"Uses heuristics to detect motion in the input", {"Uses heuristics to detect motion in the input",
"frames and reconstruct image detail where", "frames and reconstruct image detail where",