demux.c
上传用户:kjfoods
上传日期:2020-07-06
资源大小:29949k
文件大小:6k
源码类别:

midi

开发平台:

Unix_Linux

  1. /*****************************************************************************
  2.  * demux.c: demux functions for dvdplay.
  3.  *****************************************************************************
  4.  * Copyright (C) 1998-2001 the VideoLAN team
  5.  * $Id: b2077b7ad57bf9637ed058ba41a706827d360f36 $
  6.  *
  7.  * Author: Stéphane Borel <stef@via.ecp.fr>
  8.  *
  9.  * This program is free software; you can redistribute it and/or modify
  10.  * it under the terms of the GNU General Public License as published by
  11.  * the Free Software Foundation; either version 2 of the License, or
  12.  * (at your option) any later version.
  13.  *
  14.  * This program is distributed in the hope that it will be useful,
  15.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  17.  * GNU General Public License for more details.
  18.  *
  19.  * You should have received a copy of the GNU General Public License
  20.  * along with this program; if not, write to the Free Software
  21.  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
  22.  *****************************************************************************/
  23. /*****************************************************************************
  24.  * Preamble
  25.  *****************************************************************************/
  26. #ifdef HAVE_CONFIG_H
  27. # include "config.h"
  28. #endif
  29. #include <stddef.h>
  30. #include <vlc_common.h>
  31. #include <vlc_input.h>
  32. #include <vlc_access.h>
  33. #include <vlc_interface.h>
  34. #ifdef HAVE_UNISTD_H
  35. #   include <unistd.h>
  36. #endif
  37. #include <fcntl.h>
  38. #include <sys/types.h>
  39. #include <sys/stat.h>
  40. #include <errno.h>
  41. #ifdef STRNCASECMP_IN_STRINGS_H
  42. #   include <strings.h>
  43. #endif
  44. #include "vcd.h"
  45. #include "vcdplayer.h"
  46. #include "intf.h"
  47. /* how many packets vcdx_Demux will read in each loop */
  48. /* #define vcdplay_READ_ONCE 64 */
  49. /*****************************************************************************
  50.  * Local prototypes
  51.  *****************************************************************************/
  52. static int  Demux         ( input_thread_t * );
  53. /*****************************************************************************
  54.  * Private structure
  55.  *****************************************************************************/
  56. struct demux_sys_t
  57. {
  58.     vcd_data_t * p_vcd;
  59.     module_t *   p_module;
  60.     mpeg_demux_t mpeg;
  61. };
  62. /*****************************************************************************
  63.  * VCDInit: initializes structures
  64.  *****************************************************************************/
  65. int VCDInit ( vlc_object_t *p_this )
  66. {
  67.     input_thread_t *p_input = (input_thread_t *)p_this;
  68.     vcd_data_t *    p_vcd = (vcd_data_t *)p_input->p_sys;
  69.     demux_sys_t *   p_demux;
  70.     printf("++++ VCDInit CALLEDn");
  71.  
  72.     if( p_input->stream.i_method != INPUT_METHOD_VCD )
  73.     {
  74.         return VLC_EGENERIC;
  75.     }
  76.     p_demux = p_input->p_demux_data = malloc( sizeof(demux_sys_t ) );
  77.     if( p_demux == NULL )
  78.     {
  79.         return VLC_ENOMOD;
  80.     }
  81.     p_input->p_private = (void*)&p_demux->mpeg;
  82.     p_demux->p_module = module_need( p_input, "mpeg-system", NULL, false );
  83.     if( p_demux->p_module == NULL )
  84.     {
  85.         free( p_input->p_demux_data );
  86.         return VLC_ENOMOD;
  87.     }
  88.     p_input->p_demux_data->p_vcd = p_vcd;
  89.     p_input->pf_demux = Demux;
  90.     p_input->pf_demux_control = demux_vaControlDefault;
  91.     p_input->pf_rewind = NULL;
  92.     p_vcd->p_intf = NULL;
  93.     p_vcd->i_still_time = 0;
  94.     return VLC_SUCCESS;
  95. }
  96. /*****************************************************************************
  97.  * VCDEnd: frees unused data
  98.  *****************************************************************************/
  99. void VCDEnd ( vlc_object_t *p_this )
  100. {
  101.     input_thread_t *p_input = (input_thread_t *)p_this;
  102.     vcd_data_t *    p_vcd = p_input->p_demux_data->p_vcd;
  103. #if FIXED
  104.     intf_thread_t * p_intf = NULL;
  105.     p_intf = vlc_object_find( p_input, VLC_OBJECT_INTF, FIND_CHILD );
  106.     if( p_intf != NULL )
  107.     {
  108.         intf_StopThread( p_intf );
  109.         vlc_object_detach( p_intf );
  110.         vlc_object_release( p_intf );
  111.         vlc_object_release( p_intf );
  112.     }
  113.     p_vcd->p_intf = NULL;
  114. #endif
  115.     module_unneed( p_input, p_input->p_demux_data->p_module );
  116.     free( p_input->p_demux_data );
  117. }
  118. /*****************************************************************************
  119.  * Demux
  120.  *****************************************************************************/
  121. static int Demux( input_thread_t * p_input )
  122. {
  123.     vcd_data_t *            p_vcd;
  124.     data_packet_t *         p_data;
  125.     ssize_t                 i_result;
  126.     ptrdiff_t               i_remains;
  127.     int                     i_data_nb = 0;
  128.     p_vcd = p_input->p_demux_data->p_vcd;
  129.     /* Read headers to compute payload length */
  130.     do
  131.     {
  132.         i_result = p_input->p_demux_data->mpeg.pf_read_ps( p_input, &p_data );
  133.         if( i_result <= 0 )
  134.         {
  135.             return i_result;
  136.         }
  137.         i_remains = p_input->p_last_data - p_input->p_current_data;
  138.         p_input->p_demux_data->mpeg.pf_demux_ps( p_input, p_data );
  139.         ++i_data_nb;
  140.     }
  141.     while( i_remains );
  142. //    if( p_vcd->b_still && p_vcd->b_end_of_cell && p_vcd->p_intf != NULL )
  143.     if( p_vcd->i_still_time && p_vcd->b_end_of_cell && p_vcd->p_intf != NULL )
  144.     {
  145.         pgrm_descriptor_t * p_pgrm;
  146.         /* when we receive still_time flag, we have to pause immediately */
  147.         var_SetInteger( p_input, "state", PAUSE_S );
  148.         vcdIntfStillTime( p_vcd->p_intf, p_vcd->i_still_time );
  149.         p_vcd->i_still_time = 0;
  150.         vlc_mutex_lock( &p_input->stream.stream_lock );
  151.         p_pgrm = p_input->stream.p_selected_program;
  152.         p_pgrm->i_synchro_state = SYNCHRO_REINIT;
  153.         vlc_mutex_unlock( &p_input->stream.stream_lock );
  154.         input_ClockManageControl( p_input, p_pgrm, 0 );
  155.     }
  156.     return i_data_nb;
  157. }