From 20843f51e7f6652a7aa65f2b1afa5e961ad948ff Mon Sep 17 00:00:00 2001 From: =?utf8?q?M=C3=A5ns=20Rullg=C3=A5rd?= Date: Wed, 23 Jun 2010 00:08:21 +0000 Subject: [PATCH] Remove OS/2 threads support OS/2 SMP support is rare, and a pthreads library exists. No need to keep this code. Originally committed as revision 23731 to svn://svn.ffmpeg.org/ffmpeg/trunk --- configure | 2 - libavcodec/Makefile | 1 - libavcodec/os2thread.c | 148 ------------------------------------------------- 3 files changed, 151 deletions(-) delete mode 100644 libavcodec/os2thread.c diff --git a/configure b/configure index a96d43d..bc3efca 100755 --- a/configure +++ b/configure @@ -91,7 +91,6 @@ Configuration options: --enable-postproc enable GPLed postprocessing support [no] --disable-avfilter disable video filter support [no] --enable-avfilter-lavf video filters dependent on avformat [no] - --enable-os2threads use OS/2 threads [no] --enable-pthreads use pthreads [no] --enable-w32threads use Win32 threads [no] --enable-x11grab enable X11 grabbing [no] @@ -953,7 +952,6 @@ CONFIG_LIST=" " THREADS_LIST=' - os2threads pthreads w32threads ' diff --git a/libavcodec/Makefile b/libavcodec/Makefile index d1e6f8b..41ba406 100644 --- a/libavcodec/Makefile +++ b/libavcodec/Makefile @@ -599,7 +599,6 @@ OBJS-$(CONFIG_REMOVE_EXTRADATA_BSF) += remove_extradata_bsf.o OBJS-$(CONFIG_TEXT2MOVSUB_BSF) += movsub_bsf.o # thread libraries -OBJS-$(HAVE_OS2THREADS) += os2thread.o OBJS-$(HAVE_PTHREADS) += pthread.o OBJS-$(HAVE_W32THREADS) += w32thread.o diff --git a/libavcodec/os2thread.c b/libavcodec/os2thread.c deleted file mode 100644 index 3d1367c..0000000 --- a/libavcodec/os2thread.c +++ /dev/null @@ -1,148 +0,0 @@ -/* - * Copyright (c) 2004 Michael Niedermayer - * - * This file is part of FFmpeg. - * - * FFmpeg is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public - * License as published by the Free Software Foundation; either - * version 2.1 of the License, or (at your option) any later version. - * - * FFmpeg 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 - * Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public - * License along with FFmpeg; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - */ -//#define DEBUG - -// Ported by Vlad Stelmahovsky - -#include "avcodec.h" - -#define INCL_DOS -#define INCL_DOSERRORS -#define INCL_DOSDEVIOCTL -#include - -typedef struct ThreadContext{ - AVCodecContext *avctx; - int thread; - HEV work_sem; - HEV done_sem; - int (*func)(AVCodecContext *c, void *arg); - void *arg; - int ret; -}ThreadContext; - - -static void attribute_align_arg thread_func(void *v){ - ThreadContext *c= v; - - for(;;){ - //printf("thread_func %X enter wait\n", (int)v); fflush(stdout); - DosWaitEventSem(c->work_sem, SEM_INDEFINITE_WAIT); -// WaitForSingleObject(c->work_sem, INFINITE); -//printf("thread_func %X after wait (func=%X)\n", (int)v, (int)c->func); fflush(stdout); - if(c->func) - c->ret= c->func(c->avctx, c->arg); - else - return; - //printf("thread_func %X signal complete\n", (int)v); fflush(stdout); - DosPostEventSem(c->done_sem); -// ReleaseSemaphore(c->done_sem, 1, 0); - } - - return; -} - -/** - * free what has been allocated by avcodec_thread_init(). - * must be called after decoding has finished, especially do not call while avcodec_thread_execute() is running - */ -void avcodec_thread_free(AVCodecContext *s){ - ThreadContext *c= s->thread_opaque; - int i; - - for(i=0; ithread_count; i++){ - - c[i].func= NULL; - DosPostEventSem(c[i].work_sem); - // ReleaseSemaphore(c[i].work_sem, 1, 0); - DosWaitThread((PTID)&c[i].thread,DCWW_WAIT); -// WaitForSingleObject(c[i].thread, INFINITE); - if(c[i].work_sem) DosCloseEventSem(c[i].work_sem);//CloseHandle(c[i].work_sem); - if(c[i].done_sem) DosCloseEventSem(c[i].done_sem);//CloseHandle(c[i].done_sem); - } - - av_freep(&s->thread_opaque); -} - -static int avcodec_thread_execute(AVCodecContext *s, int (*func)(AVCodecContext *c2, void *arg2),void *arg, int *ret, int count, int size){ - ThreadContext *c= s->thread_opaque; - int i; - - assert(s == c->avctx); - assert(count <= s->thread_count); - - /* note, we can be certain that this is not called with the same AVCodecContext by different threads at the same time */ - - for(i=0; ithread_count= thread_count; - - if (thread_count <= 1) - return 0; - - assert(!s->thread_opaque); - c= av_mallocz(sizeof(ThreadContext)*thread_count); - s->thread_opaque= c; - - for(i=0; iexecute= avcodec_thread_execute; - - return 0; -fail: - avcodec_thread_free(s); - return -1; -} -- 2.7.4