diff options
Diffstat (limited to 'debian/transcode/transcode-1.1.7/export/export_pvm.c')
| -rw-r--r-- | debian/transcode/transcode-1.1.7/export/export_pvm.c | 1076 |
1 files changed, 1076 insertions, 0 deletions
diff --git a/debian/transcode/transcode-1.1.7/export/export_pvm.c b/debian/transcode/transcode-1.1.7/export/export_pvm.c new file mode 100644 index 00000000..da8fa713 --- /dev/null +++ b/debian/transcode/transcode-1.1.7/export/export_pvm.c @@ -0,0 +1,1076 @@ +/* + * export_pvm.c + * + * Copyright (C) Malanchini Marzio - June 2003 + * + * This file is part of transcode, a video stream processing tool + * + * transcode is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2, or (at your option) + * any later version. + * + * transcode 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with GNU Make; see the file COPYING. If not, write to + * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. + * + */ + +#include "transcode.h" + +#include <stdio.h> +#include <stdlib.h> + +#include "pvm_version.h" +#include "pvm_interface.h" +#include "pvm_parser.h" +#include "external_codec.h" +#include "vob_pack_unpack.h" + +#define MOD_NAME "export_pvm.so" +#define MOD_VERSION EXPORT_PVM_VERSION +#define MOD_CODEC "(video) * | (audio) *" + +#define MAX_BUF 1024 + +#define MIN_TOT_NPROC 1 +#define MIN_FRAME 10 + +static int verbose_flag=TC_QUIET; +static int capability_flag=-1; //all codecs are welcome + +#define MOD_PRE pvm +#include "export_def.h" + +static int s_merger_tid_audio[]={-1,-1},s_merger_tid_video[]={-1,-1},s_init_check=0; +static int s_merger_tid_system[]={-1,-1}; +static int s_null_video_module=0,s_null_audio_module=0,s_sys_merger_started=-1; +static void *p_handle=NULL; +static pvm_func_t s_pvm_single_proc_audio,s_pvm_single_proc_video,s_pvm_fun_audio,s_pvm_fun_video,s_pvm_single_proc_system; +static pvm_config_env s_pvm_conf,*p_pvm_conf=NULL; + +static char *p_par1=NULL,*p_par2=NULL; + + +extern pthread_mutex_t s_channel_lock; + +static void adjust_ch(char *line, char ch) +{ + char *src = &line[strlen(line)]; + char *dst = line; + + //-- remove blanks from right and left side -- + do { src--; } while ( (src != line) && (*src == ch) ); + *(src+1) = '\0'; + src = line; + while (*src == ch) src++; + + if (src == line) return; + + //-- copy rest -- + while (*src) + { + *dst = *src; + src++; + dst++; + } + *dst = '\0'; +} + +static void f_pvm_balancer(char *p_option,pvm_func_t *p_func,int s_seq,int s_type) +{ + int s_cont,s_dummy,s_dummy1,s_rc; + + if (!strcasecmp(p_option, "open")) + { + for(s_cont=0;s_cont<p_func->s_nproc;s_cont++) + p_func->p_used_tid[s_cont]=INT_MAX; /*setup to INT_MAX*/ + p_func->s_current_tid=0; /*First tid*/ + } + else if (!strcasecmp(p_option, "close")) + { + for(s_cont=0;s_cont<p_func->s_nproc;s_cont++) + p_func->p_used_tid[s_cont]=INT_MAX; /*setup to INT_MAX*/ + } + else if (!strcasecmp(p_option, "set-seq")) + { + p_func->p_used_tid[p_func->s_current_tid]=s_seq; + } + else if (!strcasecmp(p_option, "first-free")) + { + for(s_cont=(((1+p_func->s_current_tid)==p_func->s_nproc)?0:(1+p_func->s_current_tid));((p_func->p_used_tid[s_cont]!=INT_MAX)&&(s_cont<p_func->s_current_tid));s_cont=((((1+s_cont)==p_func->s_nproc)?0:(1+s_cont)))); /*det the first task free*/ +// for(s_cont=0;((p_func->p_used_tid[s_cont]!=INT_MAX)&&(s_cont<p_func->s_nproc));s_cont++); /*det the first task free*/ + if ((s_cont<p_func->s_nproc)&&(p_func->p_used_tid[s_cont]==INT_MAX)) /*it's already assigned to a running task?*/ + { + p_func->s_current_tid=s_cont; /*setting up the new task*/ + if (verbose_flag & TC_DEBUG) + { + if (s_type== TC_VIDEO) + tc_log_info(MOD_NAME, "The new task for video is %d",s_cont); + else + tc_log_info(MOD_NAME, "The new task for audio is %d",s_cont); + } + } + else /*stop and wait for the first free task*/ + { + if (verbose_flag & TC_DEBUG) + { + if (s_type== TC_VIDEO) + tc_log_info(MOD_NAME, "Waiting for a video free task..."); + else + tc_log_info(MOD_NAME, "Waiting for an audio free task..."); + } + s_cont=s_seq; + if (s_type== TC_VIDEO) + (int)f_pvm_set_recv(PVM_MSG_ENDTASK_VIDEO); /*set up to receive the PVM_MSG_ENDTASK_VIDEO*/ + else + (int)f_pvm_set_recv(PVM_MSG_ENDTASK_AUDIO); /*set up to receive the PVM_MSG_ENDTASK_AUDIO*/ + s_seq=f_pvm_recv(&s_dummy,(char *)&s_dummy1,&s_rc); /*Waiting for a free task */ + (int)f_pvm_set_recv(s_cont); /*set up to receive the prev seq*/ + for(s_cont=0;p_func->p_used_tid[s_cont]!=s_seq;s_cont++); /*det the task free*/ + p_func->s_current_tid=s_cont; /*setting up the new task*/ + if (verbose_flag & TC_DEBUG) + { + if (s_type== TC_VIDEO) + tc_log_info(MOD_NAME, "The new video task free is %d",s_cont); + else + tc_log_info(MOD_NAME, "The new audio task free is %d",s_cont); + } + } + } +} + +static void f_help(void) +{ + tc_log_info(MOD_NAME, "%s",MOD_VERSION); + tc_log_info(MOD_NAME, " -F configfile,[[nproc]:[maxproc]:[nfrxtask]]"); + tc_log_info(MOD_NAME, " nproc,maxproc,nfrxtask override the parameter present in the config file"); + tc_log_info(MOD_NAME, " List of known and supported codecs:"); + f_help_codec(MOD_NAME); +} + +#define PVM_DEINIT do { \ + if (s_init_check == 1) { \ + void *ret = f_init_pvm_func("close", p_handle); \ + s_init_check = (ret != NULL) ?1 :0; /* uhm... -- Fromani */ \ + } else { \ + s_init_check -= 1; \ + } \ +} while (0) + +#define PVM_CLOSE do { \ + f_pvm_balancer("close", p_pvm_fun, 0, param->flag); \ + f_pvm_master_start_stop("close", "tcpvmexportd", NULL, \ + p_pvm_conf->s_nproc, p_pvm_conf->s_max_proc, p_pvm_fun); \ + PVM_DEINIT; \ +} while (0) + +/* ------------------------------------------------------------ + * + * open codec + * + * ------------------------------------------------------------*/ + +MOD_open +{ + pvm_func_t *p_pvm_fun=NULL; + int s_null_module; + + pthread_mutex_lock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + if(param->flag == TC_VIDEO) + { + s_null_module=s_null_video_module; + p_pvm_fun=&s_pvm_fun_video; + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "enter in MOD_OPEN Video"); + } + else + { + s_null_module=s_null_audio_module; + p_pvm_fun=&s_pvm_fun_audio; + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "enter in MOD_OPEN Video"); + } + if (!s_null_module) + { + if((f_pvm_multi_send(0,(char *)0,PVM_EXP_OPT_OPEN,p_pvm_fun))==-1) + { + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + } + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "exit MOD_OPEN Video"); + return TC_OK; +} + +/* ------------------------------------------------------------ + * + * init codec + * + * ------------------------------------------------------------*/ + +MOD_init +{ + char *p_file_to_open=NULL; + char *p_tmp=NULL; + char *p_vob_buffer=NULL; + char *p_argv[]={"-s",(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0}; + char *p_argv_merger[]={"-s","-j",(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0}; + char *p_argv_merger_sys[]={"-s","-j",(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0,(char*)0}; + int s_cont = 1, s_contj = 2, s_contsys = 2, s_vob_buffer_size; + pvm_config_codec *p_conf_codec; + pvm_func_t *p_pvm_fun=NULL; + pvm_func_t *p_pvm_single_proc=NULL; + int *p_merger_tid,*p_merger_sys_tid=0; + int s_null_module=0; + pvm_config_merger *p_merger_conf=NULL; + char s_version[MAX_BUF]; + static int s_msys=0; + + pthread_mutex_lock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "enter in MOD_INIT"); + if (s_init_check==0) + { + s_init_check++; //do it only for the first time + memset((char *)&s_pvm_conf,'\0',sizeof(pvm_config_env)); + p_pvm_conf=&s_pvm_conf; + if(vob->ex_v_fcc != NULL && strlen(vob->ex_v_fcc) != 0) + { + p_par1 = tc_strdup(vob->ex_v_fcc); /* ...and memleaks for all! */ + adjust_ch(p_par1, ' '); /*-- module to recall --*/ + if(!strcasecmp(p_par1,"list")) + { + f_help(); + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + p_pvm_conf = pvm_parser_open(p_par1, verbose, 0); + if (p_pvm_conf == NULL) + { + tc_log_warn(MOD_NAME, "error checking %s",p_par1); + f_help(); + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + ac_memcpy((char *)&s_pvm_conf,(char *)p_pvm_conf,sizeof(pvm_config_env)); + p_pvm_conf=&s_pvm_conf; + } + else //need at least the config file + { + f_help(); + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if(vob->ex_a_fcc != NULL && strlen(vob->ex_a_fcc) != 0) + { + p_par2 = tc_strdup(vob->ex_a_fcc); + adjust_ch(p_par2, ' '); /*-- first parameter of the module --*/ + if (p_par2[0]==':') + { + if (p_pvm_conf->s_nproc==0) + p_pvm_conf->s_nproc=1; /*default nproc per host*/ + if (p_par2[1]==':') + { + if (p_pvm_conf->s_max_proc==0) + p_pvm_conf->s_max_proc=10; + } + else + { + p_tmp=strtok(p_par2,":"); + if (p_tmp==NULL) + { + if (p_pvm_conf->s_max_proc==0) + p_pvm_conf->s_max_proc=10; + } + else + { + p_pvm_conf->s_max_proc=atoi(p_tmp); + p_pvm_conf->s_max_proc=(p_pvm_conf->s_max_proc<MIN_TOT_NPROC)?10:p_pvm_conf->s_max_proc; /*the max is set to 10*/ + } + } + p_tmp=strtok(NULL,":"); + if (p_tmp==NULL) + { + if (p_pvm_conf->s_num_frame_task==0) + p_pvm_conf->s_num_frame_task=100; + } + else + { + p_pvm_conf->s_num_frame_task=atoi(p_tmp); + p_pvm_conf->s_num_frame_task=(p_pvm_conf->s_num_frame_task<MIN_FRAME)?100:p_pvm_conf->s_num_frame_task; /*the to the default */ + } + } + else + { + p_pvm_conf->s_nproc=atoi(strtok(p_par2,":")); + p_pvm_conf->s_nproc=((p_pvm_conf->s_nproc)<1)?1:p_pvm_conf->s_nproc; /*the min is set to 2*/ + p_tmp=strtok(NULL,":"); + if (p_tmp==NULL) + { + if (p_pvm_conf->s_max_proc==0) + p_pvm_conf->s_max_proc=10; + } + else + { + p_pvm_conf->s_max_proc=atoi(p_tmp); + p_pvm_conf->s_max_proc=(p_pvm_conf->s_max_proc<MIN_TOT_NPROC)?10:p_pvm_conf->s_max_proc; /*the max is set to 10*/ + } + p_tmp=strtok(NULL,":"); + if (p_tmp==NULL) + { + if (p_pvm_conf->s_num_frame_task==0) + p_pvm_conf->s_num_frame_task=100; + } + else + { + p_pvm_conf->s_num_frame_task=atoi(p_tmp); + p_pvm_conf->s_num_frame_task=(p_pvm_conf->s_num_frame_task<MIN_FRAME)?100:p_pvm_conf->s_num_frame_task; + } + } + } + } + else + { + s_init_check++; + } + if(param->flag == TC_VIDEO) + { + p_conf_codec=&(p_pvm_conf->s_video_codec); + p_file_to_open = tc_strdup(vob->video_out_file); + p_merger_conf=&(p_pvm_conf->s_video_merger); + } + else + { + p_conf_codec=&(p_pvm_conf->s_audio_codec); + if (vob->audio_out_file !=NULL) + p_file_to_open = tc_strdup(vob->audio_out_file); + else + p_file_to_open = tc_strdup(vob->video_out_file); + p_merger_conf=&(p_pvm_conf->s_audio_merger); + } + if (p_pvm_conf->p_multiplex_cmd!=NULL) + { + p_argv_merger_sys[s_contsys++]="-x"; + p_argv_merger_sys[s_contsys++]=p_pvm_conf->p_multiplex_cmd; + } + if (f_supported_export_module(p_conf_codec->p_codec)) + { + p_argv[s_cont++]="-c"; + p_argv[s_cont++]=p_conf_codec->p_codec; /*store the parameter*/ + p_argv_merger[s_contj++]="-c"; + p_argv_merger[s_contj++]=p_conf_codec->p_codec; /*store the parameter*/ + p_argv_merger_sys[s_contsys++]="-c"; + if ((p_argv_merger_sys[s_contsys++]=f_supported_system((pvm_config_codec *)&(p_pvm_conf->s_video_codec),(pvm_config_codec *)&(p_pvm_conf->s_audio_codec)))!=NULL) + { + if (p_pvm_conf->s_system_merger.p_hostname!=NULL) + { + if (vob->divxmultipass!=1) + s_sys_merger_started=0; + else /*if multipass == 1 i don't need to start the system merger*/ + { + s_contsys--; + p_argv_merger_sys[s_contsys]="unknown"; /*store the parameter*/ + s_sys_merger_started=-1; /*so the system merger never started*/ + } + } + else + { + s_contsys--; + p_argv_merger_sys[s_contsys]="unknown"; /*store the parameter*/ + s_sys_merger_started=-1; /*so the system merger never started*/ + } + } + else + { + p_argv_merger_sys[s_contsys-1]="unknown"; /*store the parameter*/ + s_sys_merger_started=-1; /*so the system merger never started*/ + } + if (p_conf_codec->p_par1!=NULL) + if (p_conf_codec->p_par1[0]!=' ') + { + p_argv[s_cont++]="-1"; + p_argv[s_cont++]=p_conf_codec->p_par1; /*store the parameter*/ + p_argv_merger[s_contj++]="-1"; + p_argv_merger[s_contj++]=p_conf_codec->p_par1; /*store the parameter*/ + p_argv_merger_sys[s_contsys++]="-1"; + p_argv_merger_sys[s_contsys++]=p_conf_codec->p_par1; /*store the parameter*/ + } + if (p_conf_codec->p_par2!=NULL) + if (p_conf_codec->p_par2[0]!=' ') + { + p_argv[s_cont++]="-2"; + p_argv[s_cont++]=p_conf_codec->p_par2; /*store the parameter*/ + } + if (p_conf_codec->p_par3!=NULL) + if (p_conf_codec->p_par3[0]!=' ') + { + p_argv[s_cont++]="-3"; + p_argv[s_cont++]=p_conf_codec->p_par3; /*store the parameter*/ + } + } + else if (!strcasecmp(p_conf_codec->p_codec, "null")) + { + s_null_module=1; + if(param->flag == TC_VIDEO) + { + s_null_video_module=s_null_module; + tc_log_info(MOD_NAME, "use internal video null codec"); + } + else + { + s_null_audio_module=s_null_module; + tc_log_info(MOD_NAME, "use internal audio null codec"); + } + } + else + { + tc_log_warn(MOD_NAME, "unsupported %s codec",p_conf_codec->p_codec); + f_help(); /*unsupported codec parameter*/ + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if ((!strcasecmp(p_pvm_conf->s_audio_codec.p_codec, "null"))||(!strcasecmp(p_pvm_conf->s_video_codec.p_codec, "null"))) + { + s_sys_merger_started=-1; /*so the system merger never started*/ + p_pvm_conf->s_system_merger.p_hostname=NULL; + } + if (!s_null_module) /*skip if null module is requested*/ + { + /*check the default setup*/ + p_pvm_conf->s_nproc=(p_pvm_conf->s_nproc<1)?1:p_pvm_conf->s_nproc; + p_pvm_conf->s_max_proc=(p_pvm_conf->s_max_proc<MIN_TOT_NPROC)?10:p_pvm_conf->s_max_proc; + p_pvm_conf->s_num_frame_task=(p_pvm_conf->s_num_frame_task<MIN_FRAME)?100:p_pvm_conf->s_num_frame_task; + + if ((vob->divxmultipass==0)&&(p_pvm_conf->s_internal_multipass)) + { + p_argv[s_cont++]="-M"; /*use internale multipass only if -R option isn't set*/ + } + else + { + p_argv_merger[s_contj++]="-p"; + switch(vob->divxmultipass) + { + case 3: + p_argv_merger[s_contj++]="3"; + break; + case 2: + p_argv_merger[s_contj++]="2"; + break; + case 1: + p_argv_merger[s_contj++]="1"; + break; + case 0: + default: + p_argv_merger[s_contj++]="0"; + break; + } + } + p_argv[s_cont++]="-d"; + p_argv_merger[s_contj++]="-d"; + p_argv_merger_sys[s_contsys++]="-d"; + if (verbose == 0) + { + p_argv[s_cont++]="0"; + p_argv_merger[s_contj++]="0"; + p_argv_merger_sys[s_contsys++]="0"; + } + else if (verbose==1) + { + p_argv[s_cont++]="1"; + p_argv_merger[s_contj++]="1"; + p_argv_merger_sys[s_contsys++]="1"; + } + else + { + p_argv[s_cont++]="2"; + p_argv_merger[s_contj++]="2"; + p_argv_merger_sys[s_contsys++]="2"; + } + if (p_file_to_open !=NULL) + { + p_argv[s_cont++]="-f"; + p_argv[s_cont++]=p_file_to_open; /*video/audio out file name*/ + p_argv_merger[s_contj++]="-f"; + p_argv_merger[s_contj++]=p_file_to_open; /*video/audio out file name*/ + p_argv_merger_sys[s_contsys++]="-f"; + p_argv_merger_sys[s_contsys++]=p_file_to_open; + } + p_argv_merger_sys[s_contsys++]="-L"; /*need to create system list every time*/ + if (p_merger_conf->s_build_only_list) + p_argv_merger[s_contj++]="-L"; + if ((verbose_flag & TC_INFO)||(verbose_flag & TC_DEBUG)) + tc_log_info(MOD_NAME, "P1=%s, P2=%s (%d %d %d)", + p_par1,p_par2,p_pvm_conf->s_nproc, + p_pvm_conf->s_max_proc, + p_pvm_conf->s_num_frame_task); + if (p_handle==NULL) + { + if((p_handle=f_init_pvm_func("open",NULL))==NULL) + { + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + } + p_argv[s_cont++]="-t"; + p_argv_merger[s_contj++]="-t"; + p_argv_merger_sys[s_contsys++]="-t"; + if (p_pvm_conf->s_system_merger.s_build_only_list==2) + p_argv_merger_sys[s_contsys++]="multisystem"; + else + p_argv_merger_sys[s_contsys++]="system"; + if (s_sys_merger_started==0) + { + memset((char *)&s_pvm_single_proc_system,'\0',sizeof(pvm_func_t)); + s_pvm_single_proc_system.p_slave_tids=&s_merger_tid_system[0]; /*data for the merger process*/ + s_pvm_single_proc_system.s_nproc=1; + s_pvm_single_proc_system.s_current_tid=0; /*data for the merger process*/ + p_merger_sys_tid=(int *)&s_merger_tid_system[0]; + } + if(param->flag == TC_VIDEO) + { + p_argv[s_cont++]="video"; /*video parameter*/ + p_argv_merger[s_contj++]="video"; /*video parameter*/ + memset((char *)&s_pvm_fun_video,'\0',sizeof(pvm_func_t)); + p_pvm_fun=&s_pvm_fun_video; + p_merger_tid=&s_merger_tid_video[0]; + memset((char *)&s_pvm_single_proc_video,'\0',sizeof(pvm_func_t)); + p_pvm_single_proc=&s_pvm_single_proc_video; + p_pvm_single_proc->p_slave_tids=&s_merger_tid_video[0]; /*data for the merger process*/ + } + else + { + p_argv[s_cont++]="audio"; /*audio parameter*/ + p_argv_merger[s_contj++]="audio";/*audio parameter*/ + memset((char *)&s_pvm_fun_audio,'\0',sizeof(pvm_func_t)); + p_pvm_fun=&s_pvm_fun_audio; + p_merger_tid=&s_merger_tid_audio[0]; + memset((char *)&s_pvm_single_proc_audio,'\0',sizeof(pvm_func_t)); + p_pvm_single_proc=&s_pvm_single_proc_audio; + p_pvm_single_proc->p_slave_tids=&s_merger_tid_audio[0]; /*data for the merger process*/ + } + p_pvm_single_proc->s_nproc=1; /*data for the merger process*/ + p_pvm_single_proc->s_current_tid=0; /*data for the merger process*/ + if (f_pvm_master_start_stop("open","tcpvmexportd",p_argv,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun)==NULL) + { + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + memset((char *)&s_version,'\0',MAX_BUF); + tc_snprintf((char *)&s_version,MAX_BUF,"%s",EXPORT_PVM_VERSION); + if((f_pvm_multi_send(strlen(&s_version[0]),(char *)&s_version[0],PVM_CHECK_VERSION,p_pvm_fun))==-1) + { + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (p_pvm_conf->s_system_merger.p_hostname!=NULL) + { + if ((s_sys_merger_started==0)&&(s_msys==0)) + { + s_sys_merger_started=1; /*execute only 1 time*/ + s_msys=1; + if ((*p_merger_sys_tid=f_pvm_start_single_process("tcpvmexportd",p_argv_merger_sys,p_pvm_conf->s_system_merger.p_hostname)) ==-1) + { + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "System merger tid %d",*p_merger_sys_tid); + /*send the output file name*/ + if(f_pvm_send(strlen(p_file_to_open),(char *)p_file_to_open,PVM_JOIN_OPT_INIT,s_pvm_single_proc_system.s_current_tid,&s_pvm_single_proc_system)==-1) + { + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + } + } + if ((*p_merger_tid=f_pvm_start_single_process("tcpvmexportd",p_argv_merger,p_merger_conf->p_hostname)) ==-1) + { + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "MOD_INIT stop f_pvm_start_single_process"); + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "MOD_INIT start PVM_INIT_SKED"); + if((f_pvm_multi_send(sizeof(int),(char *)&p_pvm_conf->s_num_frame_task,PVM_INIT_SKED,p_pvm_fun))==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "MOD_INIT stop PVM_INIT_SKED"); + if (verbose_flag & TC_DEBUG) + { + if(param->flag == TC_VIDEO) + tc_log_info(MOD_NAME, "Video merger tid %d",*p_merger_tid); + else + tc_log_info(MOD_NAME, "Audio merger tid %d",*p_merger_tid); + } + if((f_pvm_multi_send(sizeof(int),(char *)p_merger_tid,PVM_INIT_JOIN,p_pvm_fun))==-1) /*send the merger tid*/ + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + /*initial send of the vob structures to the slave processes*/ + p_vob_buffer=f_vob_pack("open",vob,&s_vob_buffer_size); + if (vob->divxmultipass==2) + { + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "enter in preinit msg"); + for(s_cont=0;s_cont<p_pvm_fun->s_nproc;s_cont++) + { + if(f_pvm_send(sizeof(int),(char *)&s_cont,PVM_EXP_OPT_PREINIT,s_cont,p_pvm_fun)==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "exit from preinit msg"); + } + if((f_pvm_multi_send(s_vob_buffer_size,p_vob_buffer,PVM_EXP_OPT_INIT,p_pvm_fun))==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + (char *)f_vob_pack("close",NULL,&s_vob_buffer_size); + if(f_pvm_send(strlen(p_file_to_open),(char *)p_file_to_open,PVM_JOIN_OPT_INIT,p_pvm_single_proc->s_current_tid,p_pvm_single_proc)==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (s_msys==1) + { + if(f_pvm_send(sizeof(int),(char *)p_merger_sys_tid,PVM_MERGER_INIT,p_pvm_single_proc->s_current_tid,p_pvm_single_proc)==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + PVM_DEINIT; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + } + } + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "exit from MOD_INIT"); + return TC_OK; +} + + +/* ------------------------------------------------------------ + * + * encode and export + * + * ------------------------------------------------------------*/ + +MOD_encode +{ + static int s_video_cont=0,s_audio_cont=0,s_video_seq=0,s_audio_seq=0; + static char *p_video_buffer=NULL,*p_audio_buffer=NULL; + pvm_func_t *p_pvm_fun=NULL; + char *p_buffer=NULL; + int s_seq,s_cont=0; + int *p_merger_tid=0,*p_merger_sys_tid=0; + int s_null_module; + + pthread_mutex_lock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + p_merger_sys_tid=(int *)&s_merger_tid_system[0]; + if(param->flag == TC_VIDEO) + { + s_null_module=s_null_video_module; + if (!s_null_module) + { + p_pvm_fun=&s_pvm_fun_video; + p_buffer=p_video_buffer; + s_seq=s_video_seq; + p_merger_tid=&s_merger_tid_video[0]; + s_cont=s_video_cont; + } + } + else + { + s_null_module=s_null_audio_module; + if (!s_null_module) + { + p_pvm_fun=&s_pvm_fun_audio; + p_buffer=p_audio_buffer; + s_seq=s_audio_seq; + p_merger_tid=&s_merger_tid_audio[0]; + s_cont=s_audio_cont; + } + } + if (!s_null_module) + { + if (p_buffer==NULL) + { + p_buffer=(char *)malloc(sizeof(transfer_t)+param->size); + f_pvm_balancer("open",p_pvm_fun,0,param->flag); + } + (int)f_pvm_set_send(s_seq); /*set the seq number*/ + ac_memcpy(p_buffer,(char *)param,sizeof(transfer_t)); + ac_memcpy(p_buffer+sizeof(transfer_t),(char *)param->buffer,param->size); + if((s_seq=f_pvm_send((sizeof(transfer_t)+param->size),(char *)p_buffer,PVM_EXP_OPT_ENCODE,p_pvm_fun->s_current_tid,p_pvm_fun))==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + { + if(param->flag == TC_VIDEO) + tc_log_info(MOD_NAME,"Send %d video sequence number",s_seq); + else + tc_log_info(MOD_NAME,"Send %d audio sequence number",s_seq); + } + f_pvm_balancer("set-seq",p_pvm_fun,s_seq,param->flag); /*the tid in s_tid_pos now elab the seq*/ + if (s_cont<p_pvm_conf->s_num_frame_task) + { + s_cont++; + } + else + { + (int)f_pvm_set_send(s_seq); /*set the prev. seq number*/ + if((s_seq=f_pvm_send(0,(char *)0,PVM_EXP_OPT_RESTART_ENCODE1,p_pvm_fun->s_current_tid,p_pvm_fun))==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + f_pvm_balancer("first-free",p_pvm_fun,s_seq,param->flag); + if((s_seq=f_pvm_send(0,(char *)0,PVM_EXP_OPT_RESTART_ENCODE2,p_pvm_fun->s_current_tid,p_pvm_fun))==-1) /*automatic increment of seq*/ + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + s_cont=0; + } + if(param->flag == TC_VIDEO) + { + p_video_buffer=p_buffer; + s_video_seq=s_seq; + s_video_cont=s_cont; + } + else + { + p_audio_buffer=p_buffer; + s_audio_seq=s_seq; + s_audio_cont=s_cont; + } + } + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_OK; +} + + +/* ------------------------------------------------------------ + * + * stop codec + * + * ------------------------------------------------------------*/ + +MOD_stop +{ + pvm_func_t *p_pvm_fun=NULL; + int *p_merger_tid=0,*p_merger_sys_tid=0; + int s_null_module; + static int s_msys=0; + + p_merger_sys_tid=(int *)&s_merger_tid_system[0]; + pthread_mutex_lock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + if(param->flag == TC_VIDEO) + { + s_null_module=s_null_video_module; + if (!s_null_module) + { + p_pvm_fun=&s_pvm_fun_video; + p_merger_tid=&s_merger_tid_video[0]; + } + } + else + { + s_null_module=s_null_audio_module; + if (!s_null_module) + { + p_pvm_fun=&s_pvm_fun_audio; + p_merger_tid=&s_merger_tid_audio[0]; + } + } + if (!s_null_module) + { + if (p_handle!=NULL) + { + if (p_pvm_fun!=NULL) + { + (int)f_pvm_multi_send(0,(char *)0,PVM_EXP_OPT_STOP,p_pvm_fun); + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started!=-1) + { + if (s_msys==0) + { + s_msys=1; + f_pvm_stop_single_process(*p_merger_sys_tid); + memset((char *)&s_pvm_single_proc_system,'\0',sizeof(pvm_func_t)); + s_merger_tid_system[0]=-1; + } + } + f_pvm_balancer("close",p_pvm_fun,0,param->flag); + (pvm_func_t*)f_pvm_master_start_stop("close","tcpvmexportd",(char **)0,p_pvm_conf->s_nproc,p_pvm_conf->s_max_proc,p_pvm_fun); + } + PVM_DEINIT; + if (s_init_check==0) + p_handle=NULL; + } + if(param->flag == TC_VIDEO) + { + memset((char *)&s_pvm_fun_video,'\0',sizeof(pvm_func_t)); + s_merger_tid_video[0]=-1; + } + else + { + memset((char *)&s_pvm_fun_video,'\0',sizeof(pvm_func_t)); + s_merger_tid_audio[0]=-1; + } + } + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_OK; +} + + +/* ------------------------------------------------------------ + * + * close codec + * + * ------------------------------------------------------------*/ + +MOD_close +{ + int s_seq=0,s_dummy,s_dummy1,s_rc; + pvm_func_t *p_pvm_fun=NULL; + int *p_merger_tid=0,*p_merger_sys_tid=0; + pvm_func_t *p_pvm_single_proc=NULL; + int s_null_module; + static int s_msys=0; + + p_merger_sys_tid=(int *)&s_merger_tid_system[0]; + pthread_mutex_lock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + if(param->flag == TC_VIDEO) + { + s_null_module=s_null_video_module; + if (!s_null_module) + { + p_pvm_fun=&s_pvm_fun_video; + p_merger_tid=&s_merger_tid_video[0]; + p_pvm_single_proc=&s_pvm_single_proc_video; + } + } + else + { + s_null_module=s_null_audio_module; + if (!s_null_module) + { + p_pvm_fun=&s_pvm_fun_audio; + p_merger_tid=&s_merger_tid_audio[0]; + p_pvm_single_proc=&s_pvm_single_proc_audio; + } + } + if (!s_null_module) + { + if((s_seq=f_pvm_send(0,(char *)0,PVM_EXP_OPT_RESTART_ENCODE1,p_pvm_fun->s_current_tid,p_pvm_fun))==-1) /*flush the buffer*/ + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if((f_pvm_multi_send(0,(char *)0,PVM_EXP_OPT_CLOSE,p_pvm_fun))==-1) + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if((s_seq=f_pvm_send(0,(char *)0,PVM_JOIN_OPT_RUN,0,p_pvm_single_proc))==-1) /*s_seq not really used*/ + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + { + if(param->flag == TC_VIDEO) + tc_log_info(MOD_NAME,"Waiting for video merger task (seq %d) termination...",s_seq); + else + tc_log_info(MOD_NAME,"Waiting for audio merger task (seq %d) termination...",s_seq); + } + (int)f_pvm_set_recv(s_seq); /*set the last s_seq send*/ + (int)f_pvm_recv(&s_dummy,(char *)&s_dummy1,&s_rc); + if (s_rc) + { + tc_log_warn(MOD_NAME,"Can't close destination file"); + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "done."); + if (s_sys_merger_started!=-1) + { + if((s_seq=f_pvm_send(0,(char *)0,PVM_JOIN_OPT_SENDFILE,0,p_pvm_single_proc))==-1) /*s_seq not really used*/ + { + f_pvm_stop_single_process(*p_merger_tid); + if (s_sys_merger_started==1) + s_sys_merger_started--; + else if (s_sys_merger_started==0) + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + } + if (s_msys) + { + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "Waiting for system merger build list..."); + (int)f_pvm_set_recv(PVM_MSG_ENDTASK_SYSTEM); /*wait for system merger end task*/ + (int)f_pvm_recv(&s_dummy,(char *)&s_dummy1,&s_rc); + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME, "done."); + if (s_rc) + { + tc_log_warn(MOD_NAME,"Can't close destination file"); + f_pvm_stop_single_process(*p_merger_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if ((p_pvm_conf->s_system_merger.p_hostname!=NULL)&&(p_pvm_conf->s_system_merger.s_build_only_list!=1)) /*do it for 0 and 2*/ + { + if((s_seq=f_pvm_send(0,(char *)0,PVM_JOIN_OPT_RUN,0,&s_pvm_single_proc_system))==-1) /*s_seq not really used*/ + { + f_pvm_stop_single_process(*p_merger_tid); + f_pvm_stop_single_process(*p_merger_sys_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME,"Waiting for system merger task (seq %d) termination...",s_seq); + (int)f_pvm_set_recv(s_seq); /*set the last s_seq send*/ + (int)f_pvm_recv(&s_dummy,(char *)&s_dummy1,&s_rc); + if (s_rc) + { + tc_log_warn(MOD_NAME,"Can't close destination file"); + f_pvm_stop_single_process(*p_merger_tid); + PVM_CLOSE; + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_ERROR; + } + if (verbose_flag & TC_DEBUG) + tc_log_info(MOD_NAME,"done."); + } + } + if (s_sys_merger_started!=-1) + s_msys=1; + } + pthread_mutex_unlock(&s_channel_lock); /*this is the only way to make my module work with nultithreads: need to change all the code*/ + return TC_OK; +} + + |
