mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-04-05 15:49:54 +00:00
remove GstAtomic. Use plain ints instead for the time being
Original commit message from CVS: * gst/Makefile.am: * gst/gstatomic.c: * gst/gstatomic.h: * gst/gstatomic_impl.h: * gst/gstbuffer.c: * gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write), (gst_data_ref), (gst_data_ref_by_count), (gst_data_unref): * gst/gstdata.h: * gst/gstdata_private.h: * gst/gstinfo.c: (_gst_debug_init), (gst_debug_set_colored), (gst_debug_is_colored), (gst_debug_set_default_threshold), (gst_debug_get_default_threshold), (_gst_debug_category_new), (gst_debug_category_free), (gst_debug_category_set_threshold), (gst_debug_category_get_threshold): * gst/gstinfo.h: * testsuite/elements/struct_i386.h: remove GstAtomic. Use plain ints instead for the time being
This commit is contained in:
parent
ea75a90a32
commit
3fd2b73da3
13 changed files with 42 additions and 648 deletions
20
ChangeLog
20
ChangeLog
|
@ -1,3 +1,23 @@
|
|||
2005-05-16 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||
|
||||
* gst/Makefile.am:
|
||||
* gst/gstatomic.c:
|
||||
* gst/gstatomic.h:
|
||||
* gst/gstatomic_impl.h:
|
||||
* gst/gstbuffer.c:
|
||||
* gst/gstdata.c: (gst_data_is_writable), (gst_data_copy_on_write),
|
||||
(gst_data_ref), (gst_data_ref_by_count), (gst_data_unref):
|
||||
* gst/gstdata.h:
|
||||
* gst/gstdata_private.h:
|
||||
* gst/gstinfo.c: (_gst_debug_init), (gst_debug_set_colored),
|
||||
(gst_debug_is_colored), (gst_debug_set_default_threshold),
|
||||
(gst_debug_get_default_threshold), (_gst_debug_category_new),
|
||||
(gst_debug_category_free), (gst_debug_category_set_threshold),
|
||||
(gst_debug_category_get_threshold):
|
||||
* gst/gstinfo.h:
|
||||
* testsuite/elements/struct_i386.h:
|
||||
remove GstAtomic. Use plain ints instead for the time being
|
||||
|
||||
2005-05-16 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||
|
||||
* configure.ac:
|
||||
|
|
|
@ -82,7 +82,6 @@ EXTRA_libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
|
|||
libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
|
||||
gst.c \
|
||||
gstobject.c \
|
||||
gstatomic.c \
|
||||
gstbin.c \
|
||||
gstbuffer.c \
|
||||
gstcaps.c \
|
||||
|
@ -152,7 +151,6 @@ libgstreamer_@GST_MAJORMINOR@includedir = $(includedir)/gstreamer-@GST_MAJORMINO
|
|||
|
||||
gst_headers = \
|
||||
gst.h \
|
||||
gstatomic.h \
|
||||
gstobject.h \
|
||||
gstbin.h \
|
||||
gstbuffer.h \
|
||||
|
@ -204,7 +202,6 @@ noinst_HEADERS = \
|
|||
gst-i18n-lib.h \
|
||||
gst-i18n-app.h \
|
||||
gst_private.h \
|
||||
gstatomic_impl.h \
|
||||
gstdata_private.h \
|
||||
gstarch.h \
|
||||
cothreads.h
|
||||
|
|
|
@ -1,25 +0,0 @@
|
|||
/* GStreamer
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#define GST_IMPLEMENT_INLINES 1
|
||||
#define __GST_ATOMIC_C__
|
||||
|
||||
#include "gst_private.h"
|
||||
#include "gstatomic.h"
|
||||
#include "gstatomic_impl.h"
|
|
@ -1,48 +0,0 @@
|
|||
/* GStreamer
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#ifndef __GST_ATOMIC_H__
|
||||
#define __GST_ATOMIC_H__
|
||||
|
||||
#include <glib.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
typedef volatile gint gst_vgint; /* gtk-doc volatile workaround */
|
||||
|
||||
typedef struct _GstAtomicInt GstAtomicInt;
|
||||
|
||||
struct _GstAtomicInt {
|
||||
gst_vgint counter;
|
||||
GMutex *lock; /* for C fallback */
|
||||
};
|
||||
|
||||
|
||||
void gst_atomic_int_init (GstAtomicInt *aint, gint val);
|
||||
void gst_atomic_int_destroy (GstAtomicInt *aint);
|
||||
void gst_atomic_int_set (GstAtomicInt *aint, gint val);
|
||||
gint gst_atomic_int_read (GstAtomicInt *aint);
|
||||
void gst_atomic_int_add (GstAtomicInt *aint, gint val);
|
||||
void gst_atomic_int_inc (GstAtomicInt *aint);
|
||||
gboolean gst_atomic_int_dec_and_test (GstAtomicInt *aint);
|
||||
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __GST_ATOMIC_H__ */
|
|
@ -1,523 +0,0 @@
|
|||
/* GStreamer
|
||||
* Copyright (C) 1999, 2003 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.
|
||||
*
|
||||
*
|
||||
* Much of the code in this file is taken from the Linux kernel.
|
||||
* The code is relicensed under the LGPL with the kind permission of
|
||||
* Linus Torvalds,Ralf Baechle and Alan Cox
|
||||
*/
|
||||
|
||||
#ifndef __GST_ATOMIC_IMPL_H__
|
||||
#define __GST_ATOMIC_IMPL_H__
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#include <glib.h>
|
||||
#include "gstatomic.h"
|
||||
#include "gstmacros.h"
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
#if defined (GST_CAN_INLINE) || defined (__GST_ATOMIC_C__)
|
||||
|
||||
/***** Intel x86 *****/
|
||||
#if (defined (HAVE_CPU_I386) || defined (HAVE_CPU_X86_64)) && defined(__GNUC__)
|
||||
|
||||
#ifdef GST_CONFIG_NO_SMP
|
||||
#define SMP_LOCK ""
|
||||
#else
|
||||
#define SMP_LOCK "lock ; "
|
||||
#endif
|
||||
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC void gst_atomic_int_destroy (GstAtomicInt *aint) { }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC gint gst_atomic_int_read (GstAtomicInt *aint) { return aint->counter; }
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
__asm__ __volatile__(
|
||||
SMP_LOCK "addl %1,%0"
|
||||
:"=m" (aint->counter)
|
||||
:"ir" (val), "m" (aint->counter));
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
__asm__ __volatile__(
|
||||
SMP_LOCK "incl %0"
|
||||
:"=m" (aint->counter)
|
||||
:"m" (aint->counter));
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
guchar res;
|
||||
|
||||
__asm__ __volatile__(
|
||||
SMP_LOCK "decl %0; sete %1"
|
||||
:"=m" (aint->counter), "=qm" (res)
|
||||
:"m" (aint->counter) : "memory");
|
||||
|
||||
return res != 0;
|
||||
}
|
||||
|
||||
/***** PowerPC *****/
|
||||
#elif defined (HAVE_CPU_PPC) && defined(__GNUC__)
|
||||
|
||||
#ifdef GST_CONFIG_NO_SMP
|
||||
#define SMP_SYNC ""
|
||||
#define SMP_ISYNC
|
||||
#else
|
||||
#define SMP_SYNC "\tsync\n"
|
||||
#define SMP_ISYNC "\tisync\n"
|
||||
#endif
|
||||
|
||||
/* Erratum #77 on the 405 means we need a sync or dcbt before every stwcx.
|
||||
* The old ATOMIC_SYNC_FIX covered some but not all of this.
|
||||
*/
|
||||
#ifdef GST_CONFIG_IBM405_ERR77
|
||||
#define PPC405_ERR77(ra,rb) "\tdcbt " #ra "," #rb "\n"
|
||||
#else
|
||||
#define PPC405_ERR77(ra,rb)
|
||||
#endif
|
||||
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC void gst_atomic_int_destroy (GstAtomicInt *aint) { }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC gint gst_atomic_int_read (GstAtomicInt *aint) { return aint->counter; }
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
int t;
|
||||
|
||||
__asm__ __volatile__(
|
||||
"1: lwarx %0,0,%3\n"
|
||||
" add %0,%2,%0\n"
|
||||
PPC405_ERR77(0,%3)
|
||||
" stwcx. %0,0,%3 \n"
|
||||
" bne- 1b\n"
|
||||
: "=&r" (t), "=m" (aint->counter)
|
||||
: "r" (val), "r" (&aint->counter), "m" (aint->counter)
|
||||
: "cc");
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
int t;
|
||||
|
||||
__asm__ __volatile__(
|
||||
"1: lwarx %0,0,%2\n"
|
||||
" addic %0,%0,1\n"
|
||||
PPC405_ERR77(0,%2)
|
||||
" stwcx. %0,0,%2\n"
|
||||
" bne- 1b\n"
|
||||
: "=&r" (t), "=m" (aint->counter)
|
||||
: "r" (&aint->counter), "m" (aint->counter)
|
||||
: "cc");
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
int t;
|
||||
|
||||
__asm__ __volatile__(
|
||||
"1: lwarx %0,0,%1\n"
|
||||
" addic %0,%0,-1\n"
|
||||
PPC405_ERR77(0,%1)
|
||||
" stwcx. %0,0,%1\n"
|
||||
" bne- 1b\n"
|
||||
SMP_ISYNC
|
||||
: "=&r" (t)
|
||||
: "r" (&aint->counter)
|
||||
: "cc", "memory");
|
||||
|
||||
return t == 0;
|
||||
}
|
||||
|
||||
/***** DEC[/Compaq/HP?/Intel?] Alpha *****/
|
||||
#elif defined(HAVE_CPU_ALPHA) && defined(__GNUC__)
|
||||
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC void gst_atomic_int_destroy (GstAtomicInt *aint) { }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC gint gst_atomic_int_read (GstAtomicInt *aint) { return aint->counter; }
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
unsigned long temp;
|
||||
|
||||
__asm__ __volatile__(
|
||||
"1: ldl_l %0,%1\n"
|
||||
" addl %0,%2,%0\n"
|
||||
" stl_c %0,%1\n"
|
||||
" beq %0,2f\n"
|
||||
".subsection 2\n"
|
||||
"2: br 1b\n"
|
||||
".previous"
|
||||
:"=&r" (temp), "=m" (aint->counter)
|
||||
:"Ir" (val), "m" (aint->counter));
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
gst_atomic_int_add (aint, 1);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
long temp, result;
|
||||
int val = 1;
|
||||
__asm__ __volatile__(
|
||||
"1: ldl_l %0,%1\n"
|
||||
" subl %0,%3,%2\n"
|
||||
" subl %0,%3,%0\n"
|
||||
" stl_c %0,%1\n"
|
||||
" beq %0,2f\n"
|
||||
" mb\n"
|
||||
".subsection 2\n"
|
||||
"2: br 1b\n"
|
||||
".previous"
|
||||
:"=&r" (temp), "=m" (aint->counter), "=&r" (result)
|
||||
:"Ir" (val), "m" (aint->counter) : "memory");
|
||||
|
||||
return result == 0;
|
||||
}
|
||||
|
||||
/***** Sun SPARC *****/
|
||||
#elif 0 && defined(HAVE_CPU_SPARC) && defined(__GNUC__)
|
||||
/* allegedly broken again */
|
||||
|
||||
GST_INLINE_FUNC void gst_atomic_int_destroy (GstAtomicInt *aint) { }
|
||||
|
||||
#ifdef GST_CONFIG_NO_SMP
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC gint gst_atomic_int_read (GstAtomicInt *aint) { return aint->counter; }
|
||||
#else
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = (val<<8); }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = (val<<8); }
|
||||
|
||||
/*
|
||||
* For SMP the trick is you embed the spin lock byte within
|
||||
* the word, use the low byte so signedness is easily retained
|
||||
* via a quick arithmetic shift. It looks like this:
|
||||
*
|
||||
* ----------------------------------------
|
||||
* | signed 24-bit counter value | lock | atomic_t
|
||||
* ----------------------------------------
|
||||
* 31 8 7 0
|
||||
*/
|
||||
GST_INLINE_FUNC gint
|
||||
gst_atomic_int_read (GstAtomicInt *aint)
|
||||
{
|
||||
int ret = aint->counter;
|
||||
|
||||
while (ret & 0xff)
|
||||
ret = aint->counter;
|
||||
|
||||
return ret >> 8;
|
||||
}
|
||||
#endif /* GST_CONFIG_NO_SMP */
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
volatile int increment, *ptr;
|
||||
int lock = 1;
|
||||
int ignore = 0;
|
||||
|
||||
ptr = &(aint->counter);
|
||||
|
||||
#if __GNUC__ > 3 || (__GNUC__ >=3 && __GNUC_MINOR__ >= 2)
|
||||
__asm__ __volatile__("1: ldstub [%[ptr] + 3], %[lock]\n"
|
||||
"\torcc %[lock], 0, %[ignore]\n"
|
||||
"\tbne 1b\n" /* go back until we have the lock */
|
||||
"\tld [%[ptr]], %[inc]\n"
|
||||
"\tsra %[inc], 8, %[inc]\n"
|
||||
"\tadd %[inc], %[val], %[inc]\n"
|
||||
"\tsll %[inc], 8, %[lock]\n"
|
||||
"\tst %[lock],[%[ptr]]\n" /* Release the lock */
|
||||
: [inc] "=&r" (increment), [lock] "=r" (lock),
|
||||
[ignore] "=&r" (ignore)
|
||||
: "0" (increment), [ptr] "r" (ptr), [val] "r" (val)
|
||||
);
|
||||
#else
|
||||
__asm__ __volatile__("1: ldstub [%4 + 3], %1\n"
|
||||
"\torcc %1, 0, %2\n"
|
||||
"\tbne 1b\n" /* go back until we have the lock */
|
||||
"\tld [%4], %0\n"
|
||||
"\tsra %0, 8, %0\n"
|
||||
"\tadd %0, %5, %0\n"
|
||||
"\tsll %0, 8, %1\n"
|
||||
"\tst %1,[%4]\n" /* Release the lock */
|
||||
: "=&r" (increment), "=r" (lock), "=&r" (ignore)
|
||||
: "0" (increment), "r" (ptr), "r" (val)
|
||||
);
|
||||
#endif
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
gst_atomic_int_add (aint, 1);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
volatile int increment, *ptr;
|
||||
int lock = 1;
|
||||
int ignore = 0;
|
||||
|
||||
ptr = &aint->counter;
|
||||
|
||||
#if __GNUC__ > 3 || (__GNUC__ >=3 && __GNUC_MINOR__ >= 2)
|
||||
__asm__ __volatile__("1: ldstub [%[ptr] + 3], %[lock]\n"
|
||||
"\torcc %[lock], 0, %[ignore]\n"
|
||||
"\tbne 1b\n" /* go back until we have the lock */
|
||||
"\tld [%[ptr]], %[inc]\n"
|
||||
"\tsra %[inc], 8, %[inc]\n"
|
||||
"\tsub %[inc], 1, %[inc]\n"
|
||||
"\tsll %[inc], 8, %[lock]\n"
|
||||
"\tst %[lock],[%[ptr]]\n" /* Release the lock */
|
||||
: [inc] "=&r" (increment), [lock] "=r" (lock),
|
||||
[ignore] "=&r" (ignore)
|
||||
: "0" (increment), [ptr] "r" (ptr)
|
||||
);
|
||||
#else
|
||||
__asm__ __volatile__("1: ldstub [%4 + 3], %1\n"
|
||||
"\torcc %1, 0, %2\n"
|
||||
"\tbne 1b\n" /* go back until we have the lock */
|
||||
"\tld [%4], %0\n"
|
||||
"\tsra %0, 8, %0\n"
|
||||
"\tsub %0, 1, %0\n"
|
||||
"\tsll %0, 8, %1\n"
|
||||
"\tst %1,[%4]\n" /* Release the lock */
|
||||
: "=&r" (increment), "=r" (lock), "=&r" (ignore)
|
||||
: "0" (increment), "r" (ptr)
|
||||
);
|
||||
#endif
|
||||
|
||||
return increment == 0;
|
||||
}
|
||||
|
||||
/***** MIPS *****/
|
||||
/* This is disabled because the asm code is broken on most MIPS
|
||||
* processors and doesn't generally compile. */
|
||||
#elif defined(HAVE_CPU_MIPS) && defined(__GNUC__) && 0
|
||||
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC void gst_atomic_int_destroy (GstAtomicInt *aint) { }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC gint gst_atomic_int_read (GstAtomicInt *aint) { return aint->counter; }
|
||||
|
||||
/* this only works on MIPS II and better */
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
unsigned long temp;
|
||||
|
||||
__asm__ __volatile__(
|
||||
"1: ll %0, %1 # atomic_add\n"
|
||||
" addu %0, %2 \n"
|
||||
" sc %0, %1 \n"
|
||||
" beqz %0, 1b \n"
|
||||
: "=&r" (temp), "=m" (aint->counter)
|
||||
: "Ir" (val), "m" (aint->counter));
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
gst_atomic_int_add (aint, 1);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
unsigned long temp, result;
|
||||
int val = 1;
|
||||
|
||||
__asm__ __volatile__(
|
||||
".set push \n"
|
||||
".set noreorder # atomic_sub_return\n"
|
||||
"1: ll %1, %2 \n"
|
||||
" subu %0, %1, %3 \n"
|
||||
" sc %0, %2 \n"
|
||||
" beqz %0, 1b \n"
|
||||
" subu %0, %1, %3 \n"
|
||||
".set pop \n"
|
||||
: "=&r" (result), "=&r" (temp), "=m" (aint->counter)
|
||||
: "Ir" (val), "m" (aint->counter)
|
||||
: "memory");
|
||||
|
||||
return result == 0;
|
||||
}
|
||||
|
||||
/***** S/390 *****/
|
||||
#elif defined(HAVE_CPU_S390) && defined(__GNUC__)
|
||||
typedef struct { volatile int counter; } atomic_t __attribute__ ((aligned (4)));
|
||||
|
||||
GST_INLINE_FUNC void gst_atomic_int_init (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC void gst_atomic_int_destroy (GstAtomicInt *aint) { }
|
||||
GST_INLINE_FUNC void gst_atomic_int_set (GstAtomicInt *aint, gint val) { aint->counter = val; }
|
||||
GST_INLINE_FUNC gint gst_atomic_int_read (GstAtomicInt *aint) { return aint->counter; }
|
||||
|
||||
#define __CS_LOOP(old_val, new_val, ptr, op_val, op_string) \
|
||||
__asm__ __volatile__(" l %0,0(%3)\n" \
|
||||
"0: lr %1,%0\n" \
|
||||
op_string " %1,%4\n" \
|
||||
" cs %0,%1,0(%3)\n" \
|
||||
" jl 0b" \
|
||||
: "=&d" (old_val), "=&d" (new_val), \
|
||||
"+m" (((atomic_t *)(ptr))->counter) \
|
||||
: "a" (ptr), "d" (op_val) : "cc" );
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
int old_val, new_val;
|
||||
__CS_LOOP(old_val, new_val, aint, val, "ar");
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
int old_val, new_val;
|
||||
__CS_LOOP(old_val, new_val, aint, 1, "ar");
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
int old_val, new_val;
|
||||
__CS_LOOP(old_val, new_val, aint, 1, "sr");
|
||||
return new_val == 0;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
/* no need warning about this if we can't do inline assembly */
|
||||
#ifdef __GNUC__
|
||||
#warning consider putting your architecture specific atomic implementations here
|
||||
#endif
|
||||
|
||||
/*
|
||||
* generic implementation
|
||||
*/
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_init (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
aint->counter = val;
|
||||
aint->lock = g_mutex_new ();
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_destroy (GstAtomicInt *aint)
|
||||
{
|
||||
g_mutex_free (aint->lock);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_set (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
g_mutex_lock (aint->lock);
|
||||
aint->counter = val;
|
||||
g_mutex_unlock (aint->lock);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gint
|
||||
gst_atomic_int_read (GstAtomicInt *aint)
|
||||
{
|
||||
gint res;
|
||||
|
||||
g_mutex_lock (aint->lock);
|
||||
res = aint->counter;
|
||||
g_mutex_unlock (aint->lock);
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_add (GstAtomicInt *aint, gint val)
|
||||
{
|
||||
g_mutex_lock (aint->lock);
|
||||
aint->counter += val;
|
||||
g_mutex_unlock (aint->lock);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_inc (GstAtomicInt *aint)
|
||||
{
|
||||
g_mutex_lock (aint->lock);
|
||||
aint->counter++;
|
||||
g_mutex_unlock (aint->lock);
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC gboolean
|
||||
gst_atomic_int_dec_and_test (GstAtomicInt *aint)
|
||||
{
|
||||
gboolean res;
|
||||
|
||||
g_mutex_lock (aint->lock);
|
||||
aint->counter--;
|
||||
res = (aint->counter == 0);
|
||||
g_mutex_unlock (aint->lock);
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
#endif
|
||||
/*
|
||||
* common functions
|
||||
*/
|
||||
GST_INLINE_FUNC GstAtomicInt*
|
||||
gst_atomic_int_new (gint val)
|
||||
{
|
||||
GstAtomicInt *aint;
|
||||
|
||||
aint = g_new0 (GstAtomicInt, 1);
|
||||
gst_atomic_int_init (aint, val);
|
||||
|
||||
return aint;
|
||||
}
|
||||
|
||||
GST_INLINE_FUNC void
|
||||
gst_atomic_int_free (GstAtomicInt *aint)
|
||||
{
|
||||
gst_atomic_int_destroy (aint);
|
||||
g_free (aint);
|
||||
}
|
||||
|
||||
#endif /* defined (GST_CAN_INLINE) || defined (__GST_TRASH_STACK_C__)*/
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* __GST_ATOMIC_IMPL_H__ */
|
|
@ -22,7 +22,6 @@
|
|||
|
||||
#include "gst_private.h"
|
||||
|
||||
#include "gstatomic_impl.h"
|
||||
#include "gstdata_private.h"
|
||||
#include "gstbuffer.h"
|
||||
#include "gstinfo.h"
|
||||
|
|
|
@ -22,7 +22,6 @@
|
|||
|
||||
#include "gst_private.h"
|
||||
|
||||
#include "gstatomic_impl.h"
|
||||
#include "gstdata.h"
|
||||
#include "gstdata_private.h"
|
||||
#include "gstinfo.h"
|
||||
|
@ -122,13 +121,9 @@ gst_data_copy (const GstData * data)
|
|||
gboolean
|
||||
gst_data_is_writable (GstData * data)
|
||||
{
|
||||
gint refcount;
|
||||
|
||||
g_return_val_if_fail (data != NULL, FALSE);
|
||||
|
||||
refcount = gst_atomic_int_read (&data->refcount);
|
||||
|
||||
if (refcount > 1)
|
||||
if (data->refcount > 1)
|
||||
return FALSE;
|
||||
if (GST_DATA_FLAG_IS_SET (data, GST_DATA_READONLY))
|
||||
return FALSE;
|
||||
|
@ -152,13 +147,9 @@ gst_data_is_writable (GstData * data)
|
|||
GstData *
|
||||
gst_data_copy_on_write (GstData * data)
|
||||
{
|
||||
gint refcount;
|
||||
|
||||
g_return_val_if_fail (data != NULL, NULL);
|
||||
|
||||
refcount = gst_atomic_int_read (&data->refcount);
|
||||
|
||||
if (refcount == 1 && !GST_DATA_FLAG_IS_SET (data, GST_DATA_READONLY))
|
||||
if (data->refcount == 1 && !GST_DATA_FLAG_IS_SET (data, GST_DATA_READONLY))
|
||||
return GST_DATA (data);
|
||||
|
||||
if (data->copy) {
|
||||
|
@ -188,7 +179,7 @@ gst_data_ref (GstData * data)
|
|||
GST_CAT_LOG (GST_CAT_BUFFER, "%p %d->%d", data,
|
||||
GST_DATA_REFCOUNT_VALUE (data), GST_DATA_REFCOUNT_VALUE (data) + 1);
|
||||
|
||||
gst_atomic_int_inc (&data->refcount);
|
||||
data->refcount++;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
@ -212,7 +203,7 @@ gst_data_ref_by_count (GstData * data, gint count)
|
|||
GST_CAT_LOG (GST_CAT_BUFFER, "%p %d->%d", data,
|
||||
GST_DATA_REFCOUNT_VALUE (data), GST_DATA_REFCOUNT_VALUE (data) + count);
|
||||
|
||||
gst_atomic_int_add (&data->refcount, count);
|
||||
data->refcount += count;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
@ -231,18 +222,16 @@ gst_data_ref_by_count (GstData * data, gint count)
|
|||
void
|
||||
gst_data_unref (GstData * data)
|
||||
{
|
||||
gint zero;
|
||||
|
||||
g_return_if_fail (data != NULL);
|
||||
|
||||
GST_CAT_LOG (GST_CAT_BUFFER, "%p %d->%d", data,
|
||||
GST_DATA_REFCOUNT_VALUE (data), GST_DATA_REFCOUNT_VALUE (data) - 1);
|
||||
g_return_if_fail (GST_DATA_REFCOUNT_VALUE (data) > 0);
|
||||
|
||||
zero = gst_atomic_int_dec_and_test (&data->refcount);
|
||||
data->refcount--;
|
||||
|
||||
/* if we ended up with the refcount at zero, free the data */
|
||||
if (zero) {
|
||||
if (data->refcount == 0) {
|
||||
if (data->free)
|
||||
data->free (data);
|
||||
}
|
||||
|
|
|
@ -25,7 +25,6 @@
|
|||
#define __GST_DATA_H__
|
||||
|
||||
#include <glib-object.h>
|
||||
#include <gst/gstatomic.h>
|
||||
#include <gst/gsttypes.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
@ -58,8 +57,7 @@ typedef enum
|
|||
} GstDataFlags;
|
||||
|
||||
/* refcount */
|
||||
#define GST_DATA_REFCOUNT(data) ((GST_DATA(data))->refcount)
|
||||
#define GST_DATA_REFCOUNT_VALUE(data) (gst_atomic_int_read (&(GST_DATA(data))->refcount))
|
||||
#define GST_DATA_REFCOUNT_VALUE(data) ((GST_DATA(data))->refcount)
|
||||
|
||||
/* copy/free functions */
|
||||
#define GST_DATA_COPY_FUNC(data) (GST_DATA(data)->copy)
|
||||
|
@ -70,7 +68,7 @@ struct _GstData {
|
|||
GType type;
|
||||
|
||||
/* refcounting */
|
||||
GstAtomicInt refcount;
|
||||
guint refcount;
|
||||
|
||||
guint16 flags;
|
||||
|
||||
|
|
|
@ -20,19 +20,14 @@
|
|||
* Boston, MA 02111-1307, USA.
|
||||
*/
|
||||
|
||||
#include "gstatomic_impl.h"
|
||||
|
||||
#define _GST_DATA_INIT(data, ptype, pflags, pfree, pcopy) \
|
||||
G_STMT_START { \
|
||||
gst_atomic_int_init (&(data)->refcount, 1); \
|
||||
(data)->refcount = 1; \
|
||||
(data)->type = ptype; \
|
||||
(data)->flags = pflags; \
|
||||
(data)->free = pfree; \
|
||||
(data)->copy = pcopy; \
|
||||
} G_STMT_END;
|
||||
|
||||
#define _GST_DATA_DISPOSE(data) \
|
||||
G_STMT_START { \
|
||||
gst_atomic_int_destroy (&(data)->refcount); \
|
||||
} G_STMT_END;
|
||||
#define _GST_DATA_DISPOSE(data)
|
||||
|
||||
|
|
|
@ -118,8 +118,8 @@ LogFuncEntry;
|
|||
static GStaticMutex __log_func_mutex = G_STATIC_MUTEX_INIT;
|
||||
static GSList *__log_functions = NULL;
|
||||
|
||||
static GstAtomicInt __default_level;
|
||||
static GstAtomicInt __use_color;
|
||||
static GstDebugLevel __default_level;
|
||||
static gboolean __use_color;
|
||||
gboolean __gst_debug_enabled = TRUE;
|
||||
|
||||
|
||||
|
@ -168,8 +168,8 @@ GstDebugCategory *GST_CAT_PROBE = NULL;
|
|||
void
|
||||
_gst_debug_init (void)
|
||||
{
|
||||
gst_atomic_int_init (&__default_level, GST_LEVEL_DEFAULT);
|
||||
gst_atomic_int_init (&__use_color, 1);
|
||||
__default_level = GST_LEVEL_DEFAULT;
|
||||
__use_color = TRUE;
|
||||
|
||||
#ifdef HAVE_PRINTF_EXTENSION
|
||||
register_printf_function (GST_PTR_FORMAT[0], _gst_info_printf_extension,
|
||||
|
@ -650,7 +650,7 @@ gst_debug_remove_log_function_by_data (gpointer data)
|
|||
void
|
||||
gst_debug_set_colored (gboolean colored)
|
||||
{
|
||||
gst_atomic_int_set (&__use_color, colored ? 1 : 0);
|
||||
__use_color = colored;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -663,7 +663,7 @@ gst_debug_set_colored (gboolean colored)
|
|||
gboolean
|
||||
gst_debug_is_colored (void)
|
||||
{
|
||||
return gst_atomic_int_read (&__use_color) == 0 ? FALSE : TRUE;
|
||||
return __use_color;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -705,7 +705,7 @@ gst_debug_is_active (void)
|
|||
void
|
||||
gst_debug_set_default_threshold (GstDebugLevel level)
|
||||
{
|
||||
gst_atomic_int_set (&__default_level, level);
|
||||
__default_level = level;
|
||||
gst_debug_reset_all_thresholds ();
|
||||
}
|
||||
|
||||
|
@ -719,7 +719,7 @@ gst_debug_set_default_threshold (GstDebugLevel level)
|
|||
GstDebugLevel
|
||||
gst_debug_get_default_threshold (void)
|
||||
{
|
||||
return (GstDebugLevel) gst_atomic_int_read (&__default_level);
|
||||
return __default_level;
|
||||
}
|
||||
static void
|
||||
gst_debug_reset_threshold (gpointer category, gpointer unused)
|
||||
|
@ -842,8 +842,7 @@ _gst_debug_category_new (gchar * name, guint color, gchar * description)
|
|||
} else {
|
||||
cat->description = g_strdup ("no description");
|
||||
}
|
||||
cat->threshold = g_new (GstAtomicInt, 1);
|
||||
gst_atomic_int_init (cat->threshold, 0);
|
||||
cat->threshold = 0;
|
||||
gst_debug_reset_threshold (cat, NULL);
|
||||
|
||||
/* add to category list */
|
||||
|
@ -873,8 +872,6 @@ gst_debug_category_free (GstDebugCategory * category)
|
|||
|
||||
g_free ((gpointer) category->name);
|
||||
g_free ((gpointer) category->description);
|
||||
gst_atomic_int_destroy (category->threshold);
|
||||
g_free (category->threshold);
|
||||
g_free (category);
|
||||
}
|
||||
|
||||
|
@ -898,7 +895,7 @@ gst_debug_category_set_threshold (GstDebugCategory * category,
|
|||
{
|
||||
g_return_if_fail (category != NULL);
|
||||
|
||||
gst_atomic_int_set (category->threshold, level);
|
||||
category->threshold = level;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -928,7 +925,7 @@ gst_debug_category_reset_threshold (GstDebugCategory * category)
|
|||
GstDebugLevel
|
||||
gst_debug_category_get_threshold (GstDebugCategory * category)
|
||||
{
|
||||
return gst_atomic_int_read (category->threshold);
|
||||
return category->threshold;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -26,7 +26,6 @@
|
|||
|
||||
#include <glib.h>
|
||||
#include <glib-object.h>
|
||||
#include <gst/gstatomic.h>
|
||||
#include <gst/gstconfig.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
@ -96,7 +95,7 @@ typedef enum {
|
|||
typedef struct _GstDebugCategory GstDebugCategory;
|
||||
struct _GstDebugCategory {
|
||||
/*< private >*/
|
||||
GstAtomicInt * threshold;
|
||||
GstDebugLevel threshold;
|
||||
guint color; /* see defines above */
|
||||
|
||||
const gchar * name;
|
||||
|
|
|
@ -2,8 +2,6 @@
|
|||
Struct list[] = {
|
||||
{"GstPoptOption", sizeof (GstPoptOption), 28}
|
||||
,
|
||||
{"GstAtomicInt", sizeof (GstAtomicInt), 8}
|
||||
,
|
||||
{"GstBuffer", sizeof (GstBuffer), 108}
|
||||
,
|
||||
{"GstCaps", sizeof (GstCaps), 28}
|
||||
|
|
|
@ -2,8 +2,6 @@
|
|||
Struct list[] = {
|
||||
{"GstPoptOption", sizeof (GstPoptOption), 28}
|
||||
,
|
||||
{"GstAtomicInt", sizeof (GstAtomicInt), 8}
|
||||
,
|
||||
{"GstBuffer", sizeof (GstBuffer), 108}
|
||||
,
|
||||
{"GstCaps", sizeof (GstCaps), 28}
|
||||
|
|
Loading…
Reference in a new issue