diff options
author | Thomas Vander Stichele <thomas@apestaart.org> | 2001-12-23 19:40:53 +0000 |
---|---|---|
committer | Thomas Vander Stichele <thomas@apestaart.org> | 2001-12-23 19:40:53 +0000 |
commit | 82c5fb840e93289b9a6356d7daf7f79eb95c3ac7 (patch) | |
tree | 0deb67f1dfabd0c7524338e1d7d8ee978827d39b /gst-libs/gst/idct/idct.c | |
parent | 042f91736b7623b4365114fe2e4dc3b78c4d866a (diff) | |
download | gst-plugins-bad-82c5fb840e93289b9a6356d7daf7f79eb95c3ac7.tar.gz gst-plugins-bad-82c5fb840e93289b9a6356d7daf7f79eb95c3ac7.tar.bz2 gst-plugins-bad-82c5fb840e93289b9a6356d7daf7f79eb95c3ac7.zip |
more fixes
Original commit message from CVS:
more fixes
Diffstat (limited to 'gst-libs/gst/idct/idct.c')
-rw-r--r-- | gst-libs/gst/idct/idct.c | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/gst-libs/gst/idct/idct.c b/gst-libs/gst/idct/idct.c new file mode 100644 index 00000000..ae180e36 --- /dev/null +++ b/gst-libs/gst/idct/idct.c @@ -0,0 +1,128 @@ +/* Gnome-Streamer + * Copyright (C) <1999> Erik Walthinsen <omega@cse.ogi.edu> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public + * License along with this library; if not, write to the + * Free Software Foundation, Inc., 59 Temple Place - Suite 330, + * Boston, MA 02111-1307, USA. + */ + + +#include <config.h> + +#include <gst/gst.h> +#include "gstidct.h" +#include "dct.h" + +static void gst_idct_int_sparse_idct(short *data); + +GstIDCT *gst_idct_new(GstIDCTMethod method) +{ + GstIDCT *new = g_malloc(sizeof(GstIDCT)); + + new->need_transpose = FALSE; + + if (method == GST_IDCT_DEFAULT) { +#ifdef HAVE_LIBMMX + if (gst_cpu_get_flags() & GST_CPU_FLAG_MMX) { + method = GST_IDCT_MMX; + } + /* disabled for now + if (gst_cpu_get_flags() & GST_CPU_FLAG_SSE) { + method = GST_IDCT_SSE; + } + */ + else +#endif /* HAVE_LIBMMX */ + { + method = GST_IDCT_FAST_INT; + } + } + + new->convert_sparse = gst_idct_int_sparse_idct; + + switch (method) { + case GST_IDCT_FAST_INT: + GST_INFO (GST_CAT_PLUGIN_INFO, "using fast_int_idct"); + gst_idct_init_fast_int_idct(); + new->convert = gst_idct_fast_int_idct; + break; + case GST_IDCT_INT: + GST_INFO (GST_CAT_PLUGIN_INFO, "using int_idct"); + new->convert = gst_idct_int_idct; + break; + case GST_IDCT_FLOAT: + GST_INFO (GST_CAT_PLUGIN_INFO, "using float_idct"); + gst_idct_init_float_idct(); + new->convert = gst_idct_float_idct; + break; +#ifdef HAVE_LIBMMX + case GST_IDCT_MMX: + GST_INFO (GST_CAT_PLUGIN_INFO, "using MMX_idct"); + new->convert = gst_idct_mmx_idct; + new->need_transpose = TRUE; + break; + case GST_IDCT_MMX32: + GST_INFO (GST_CAT_PLUGIN_INFO, "using MMX32_idct"); + new->convert = gst_idct_mmx32_idct; + new->need_transpose = TRUE; + break; + case GST_IDCT_SSE: + GST_INFO (GST_CAT_PLUGIN_INFO, "using SSE_idct"); + new->convert = gst_idct_sse_idct; + new->need_transpose = TRUE; + break; +#endif /* HAVE_LIBMMX */ + default: + GST_INFO (GST_CAT_PLUGIN_INFO, "method not supported"); + g_free(new); + return NULL; + } + return new; +} + +static void gst_idct_int_sparse_idct(short *data) +{ + short val; + gint32 v, *dp = (guint32 *)data; + + v = *data; + + if (v < 0) { + val = -v; + val += (8 >> 1); + val /= 8; + val = -val; + } + else { + val = (v + (8 >> 1)) / 8; + } + v = (( val & 0xffff) | (val << 16)); + + dp[0] = v; dp[1] = v; dp[2] = v; dp[3] = v; + dp[4] = v; dp[5] = v; dp[6] = v; dp[7] = v; + dp[8] = v; dp[9] = v; dp[10] = v; dp[11] = v; + dp[12] = v; dp[13] = v; dp[14] = v; dp[15] = v; + dp[16] = v; dp[17] = v; dp[18] = v; dp[19] = v; + dp[20] = v; dp[21] = v; dp[22] = v; dp[23] = v; + dp[24] = v; dp[25] = v; dp[26] = v; dp[27] = v; + dp[28] = v; dp[29] = v; dp[30] = v; dp[31] = v; +} + +void gst_idct_destroy(GstIDCT *idct) +{ + g_return_if_fail(idct != NULL); + + g_free(idct); +} + |