gst-plugins-mythtv/src/gstmythtvsrc.c
branchtrunk
changeset 101 cf4a26332b8c
parent 98 d0f379fc4173
child 102 4f7789e3bfd4
     1.1 --- a/gst-plugins-mythtv/src/gstmythtvsrc.c	Wed Nov 22 00:16:33 2006 +0000
     1.2 +++ b/gst-plugins-mythtv/src/gstmythtvsrc.c	Wed Nov 22 19:53:52 2006 +0000
     1.3 @@ -83,10 +83,10 @@
     1.4  
     1.5  static void gst_mythtv_src_finalize (GObject * gobject);
     1.6  
     1.7 -static GstFlowReturn gst_mythtv_src_create (GstBaseSrc * psrc, guint64 offset, 
     1.8 -	guint size, GstBuffer ** outbuf);
     1.9 +//static GstFlowReturn gst_mythtv_src_create (GstBaseSrc * psrc, guint64 offset, 
    1.10 +//	guint size, GstBuffer ** outbuf);
    1.11  
    1.12 -//static GstFlowReturn gst_mythtv_src_create ( GstPushSrc* psrc, GstBuffer** outbuf );
    1.13 +static GstFlowReturn gst_mythtv_src_create ( GstPushSrc* psrc, GstBuffer** outbuf );
    1.14  
    1.15  static gboolean gst_mythtv_src_start (GstBaseSrc * bsrc);
    1.16  static gboolean gst_mythtv_src_stop (GstBaseSrc * bsrc);
    1.17 @@ -96,7 +96,7 @@
    1.18  //static void gst_mythtv_src_get_times (GstBaseSrc * src, GstBuffer * buffer,
    1.19  //   GstClockTime * start, GstClockTime * end);
    1.20  
    1.21 -//static gboolean gst_mythtv_src_do_seek( GstBaseSrc *base, GstSegment *segment );
    1.22 +static gboolean gst_mythtv_src_do_seek( GstBaseSrc *base, GstSegment *segment );
    1.23  
    1.24  static gboolean gst_mythtv_src_next_program_chain ( GstMythtvSrc *src );
    1.25  
    1.26 @@ -137,8 +137,8 @@
    1.27  //GST_BOILERPLATE_FULL (GstMythtvSrc, gst_mythtv_src, GstBaseSrc,
    1.28  //    GST_TYPE_BASE_SRC, _urihandler_init)
    1.29      
    1.30 -GST_BOILERPLATE_FULL (GstMythtvSrc, gst_mythtv_src, GstBaseSrc,
    1.31 -    GST_TYPE_BASE_SRC, _urihandler_init)
    1.32 +GST_BOILERPLATE_FULL (GstMythtvSrc, gst_mythtv_src, GstPushSrc,
    1.33 +    GST_TYPE_PUSH_SRC, _urihandler_init)
    1.34      
    1.35  static void
    1.36  gst_mythtv_src_base_init (gpointer g_class)
    1.37 @@ -158,12 +158,12 @@
    1.38  gst_mythtv_src_class_init (GstMythtvSrcClass * klass)
    1.39  {
    1.40    GObjectClass *gobject_class; 
    1.41 -  //GstPushSrcClass *gstpushsrc_class;
    1.42 +  GstPushSrcClass *gstpushsrc_class;
    1.43    GstBaseSrcClass *gstbasesrc_class;
    1.44  
    1.45    gobject_class = (GObjectClass *) klass;
    1.46    gstbasesrc_class = (GstBaseSrcClass *) klass;
    1.47 -  //gstpushsrc_class = (GstPushSrcClass *) klass;
    1.48 +  gstpushsrc_class = (GstPushSrcClass *) klass;
    1.49  
    1.50    gobject_class->set_property = gst_mythtv_src_set_property;
    1.51    gobject_class->get_property = gst_mythtv_src_get_property;
    1.52 @@ -235,8 +235,8 @@
    1.53    
    1.54    //gstbasesrc_class->get_times = gst_mythtv_src_get_times;
    1.55    
    1.56 -  //gstbasesrc_class->do_seek = gst_mythtv_src_do_seek;
    1.57 -  gstbasesrc_class->create = gst_mythtv_src_create;
    1.58 +  gstbasesrc_class->do_seek = gst_mythtv_src_do_seek;
    1.59 +  gstpushsrc_class->create = gst_mythtv_src_create;
    1.60      
    1.61    GST_DEBUG_CATEGORY_INIT (mythtvsrc_debug, "mythtvsrc", 0,
    1.62        "MythTV Client Source");
    1.63 @@ -281,9 +281,6 @@
    1.64    
    1.65    this->th_mutex = NULL;
    1.66    
    1.67 -  //this->srcpad = gst_pad_new_from_static_template (&srctemplate, "src");
    1.68 -  //gst_element_add_pad (GST_ELEMENT (this), this->srcpad);
    1.69 -  
    1.70    gst_base_src_set_format( GST_BASE_SRC( this ), GST_FORMAT_BYTES );  
    1.71  
    1.72    //gst_base_src_set_live ( GST_BASE_SRC( this ), TRUE );
    1.73 @@ -327,6 +324,11 @@
    1.74    if (this->user_agent) {
    1.75      g_free (this->user_agent);
    1.76    }
    1.77 +  
    1.78 +  if ( this->bytes_queue ) {
    1.79 +  	g_byte_array_free( this->bytes_queue, TRUE );
    1.80 +  	this->bytes_queue = NULL;
    1.81 +  }
    1.82  
    1.83    G_OBJECT_CLASS (parent_class)->finalize (gobject);
    1.84  }
    1.85 @@ -343,7 +345,7 @@
    1.86     * Retry whilst authentication fails and we supply it. */
    1.87    gint len = 0;
    1.88    
    1.89 -  //while ( sizetoread > 0 ) {
    1.90 +  while ( sizetoread > 0 ) {
    1.91  
    1.92      len = gmyth_file_transfer_read( src->file_transfer,
    1.93  	*data_ptr + offset + read, sizetoread, TRUE );
    1.94 @@ -365,20 +367,7 @@
    1.95  	if ( len == GMYTHTV_FILE_TRANSFER_READ_ERROR ) { /* -314 */
    1.96  	  src->update_prog_chain = TRUE;
    1.97  	  goto done;	  	
    1.98 -	} /*if ( abs( src->content_size - src->bytes_read ) < GMYTHTV_TRANSFER_MAX_BUFFER ) {
    1.99 -	    src->update_prog_chain = TRUE;
   1.100 -	    if ( src->enable_timing_position ) {
   1.101 -	      gint64 size_tmp = 0;
   1.102 -get_file_pos:
   1.103 -	      size_tmp = gmyth_file_transfer_get_file_position( src->file_transfer );
   1.104 -	      if ( size_tmp > ( src->content_size + GMYTHTV_TRANSFER_MAX_BUFFER ) )
   1.105 -		src->content_size = size_tmp;
   1.106 -	      else if ( size_tmp > 0 )
   1.107 -		goto get_file_pos;
   1.108 -	      g_print( "\t[%s]\tGET_POSITION: file_position = %lld\n",
   1.109 -		  __FUNCTION__, size_tmp );
   1.110 -	    }
   1.111 -	  }*/
   1.112 +	} 
   1.113  	goto done;
   1.114        }
   1.115  
   1.116 @@ -386,7 +375,7 @@
   1.117  
   1.118      if ( read == sizetoread )
   1.119        goto done;
   1.120 -  //}
   1.121 +  }
   1.122  
   1.123    if ( read < 0 && !src->live_tv )
   1.124      goto eos;
   1.125 @@ -401,15 +390,12 @@
   1.126    return read;
   1.127  }
   1.128  
   1.129 -#if 0
   1.130  static GstFlowReturn
   1.131  gst_mythtv_src_create ( GstPushSrc* psrc, GstBuffer** outbuf )
   1.132  {
   1.133    GstMythtvSrc *src;
   1.134    GstFlowReturn ret = GST_FLOW_OK;
   1.135    gint read = -1;
   1.136 -  gint adapter_size = 0;
   1.137 -  guint max_adapter_rep = 1;
   1.138  
   1.139    src = GST_MYTHTV_SRC ( psrc );
   1.140  
   1.141 @@ -420,34 +406,17 @@
   1.142      goto change_progchain;
   1.143  
   1.144    //g_static_rec_mutex_lock( &th_mutex );
   1.145 -  g_print ( "[%s] %d - Adapter size = (%d)...\n", __FUNCTION__, max_adapter_rep, adapter_size );
   1.146 -
   1.147 -  /* just get from the adapter, no network effort... */
   1.148 -  GstBuffer *buffer;
   1.149 -  guint size = (src->buffer_remain < MAX_READ_SIZE) ? src->buffer_remain : MAX_READ_SIZE;
   1.150 +  g_print ( "[%s] offset = %llu, size = %d...\n", __FUNCTION__, 
   1.151 +  		src->read_offset, MAX_READ_SIZE );
   1.152  
   1.153    g_print ( "[%s]\t\tCreate: buffer_remain: %d\n", __FUNCTION__, 
   1.154        (gint) src->buffer_remain);
   1.155  
   1.156 -  /* Create the buffer. */
   1.157 -  ret = gst_pad_alloc_buffer ( GST_BASE_SRC_PAD (GST_BASE_SRC (psrc)),
   1.158 -      src->read_offset /*GST_BUFFER_OFFSET_NONE*/, size,
   1.159 -      GST_PAD_CAPS (GST_BASE_SRC_PAD (GST_BASE_SRC (psrc))), outbuf );    
   1.160 +  /* just get from the byte array, no network effort... */
   1.161 +  if ( ( src->buffer_remain = src->bytes_queue->len ) < MAX_READ_SIZE ) {
   1.162 +  	guint8 *buffer = g_malloc0( INTERNAL_BUFFER_SIZE - src->buffer_remain );
   1.163  
   1.164 -  if (G_UNLIKELY (ret != GST_FLOW_OK)) {
   1.165 -    if ( src->live_tv )
   1.166 -      goto change_progchain;
   1.167 -    else
   1.168 -      goto done;
   1.169 -  }
   1.170 -
   1.171 -  if ( ( src->buffer_remain = gst_adapter_available_fast( src->adapter ) ) < MAX_READ_SIZE ) {
   1.172 -
   1.173 -    ret = gst_pad_alloc_buffer ( GST_BASE_SRC_PAD (GST_BASE_SRC (psrc)),
   1.174 -      src->read_offset /*GST_BUFFER_OFFSET_NONE*/, INTERNAL_BUFFER_SIZE - src->buffer_remain,
   1.175 -      GST_PAD_CAPS (GST_BASE_SRC_PAD (GST_BASE_SRC (psrc))), &buffer );
   1.176 -
   1.177 -    read = do_read_request_response( src, 0, INTERNAL_BUFFER_SIZE - src->buffer_remain, &(GST_BUFFER_DATA(buffer)) );
   1.178 +    read = do_read_request_response( src, 0, INTERNAL_BUFFER_SIZE - src->buffer_remain, &(buffer) );
   1.179  
   1.180      if (G_UNLIKELY (read < 0)) {
   1.181        if ( src->live_tv )
   1.182 @@ -458,33 +427,41 @@
   1.183  
   1.184      if ( G_UNLIKELY (src->update_prog_chain) )
   1.185        goto change_progchain;
   1.186 -
   1.187 -    gst_adapter_push( src->adapter, buffer );
   1.188 +      
   1.189 +    src->bytes_queue = g_byte_array_append( src->bytes_queue, buffer, read );
   1.190  
   1.191      src->buffer_remain = src->buffer_remain + read;
   1.192  
   1.193      g_print( "[%s]\tBYTES READ (actual) = %d, BYTES READ (cumulative) = %llu, "\
   1.194  	"OFFSET = %llu, CONTENT SIZE = %llu.\n", __FUNCTION__, read, src->bytes_read, 
   1.195  	src->read_offset, src->content_size );
   1.196 -
   1.197 +	
   1.198    }
   1.199    
   1.200 -  if ( now == -1 )
   1.201 -  	now = gst_element_get_base_time( GST_ELEMENT( src ) );
   1.202 -  //else
   1.203 -  //	now;
   1.204 +  guint buffer_size = ( src->buffer_remain < MAX_READ_SIZE) ? src->buffer_remain : MAX_READ_SIZE;
   1.205 +  
   1.206 +  /* Create the buffer. */
   1.207 +  ret = gst_pad_alloc_buffer ( GST_BASE_SRC_PAD (GST_BASE_SRC (psrc)),
   1.208 +      src->read_offset, buffer_size,
   1.209 +      GST_PAD_CAPS (GST_BASE_SRC_PAD (GST_BASE_SRC (psrc))), outbuf );    
   1.210  
   1.211 -  size = ( src->buffer_remain < MAX_READ_SIZE) ? src->buffer_remain : MAX_READ_SIZE;
   1.212 +  if (G_UNLIKELY (ret != GST_FLOW_OK)) {
   1.213 +    if ( src->live_tv )
   1.214 +      goto change_progchain;
   1.215 +    else
   1.216 +      goto done;
   1.217 +  }
   1.218 +  
   1.219 +  /* gets the first buffer_size bytes from the byte array buffer variable */ 
   1.220 +  guint8 *buf = g_memdup( src->bytes_queue->data, buffer_size );
   1.221  
   1.222 -  buffer = gst_adapter_take_buffer( src->adapter, size );
   1.223 +  g_print( "[%s] read from network? %s!, buffer_remain = %d\n", __FUNCTION__, 
   1.224 +  	read == -1 ? "NO, got from buffer" : "YES, go see the backend's log file", src->buffer_remain );
   1.225  
   1.226 -  g_print( "[%s] read = %d, buffer_remain = %d\n", __FUNCTION__, read, src->buffer_remain );
   1.227 -
   1.228 -  GST_BUFFER_SIZE (*outbuf) = size;
   1.229 +  GST_BUFFER_SIZE (*outbuf) = buffer_size;
   1.230    GST_BUFFER_MALLOCDATA( *outbuf ) = g_malloc0( GST_BUFFER_SIZE (*outbuf) );
   1.231    GST_BUFFER_DATA( *outbuf ) = GST_BUFFER_MALLOCDATA( *outbuf );
   1.232 -  g_memmove( GST_BUFFER_DATA( (*outbuf) ), GST_BUFFER_DATA(buffer), GST_BUFFER_SIZE(*outbuf) );
   1.233 -  //GST_BUFFER_TIMESTAMP( *outbuf ) = now;
   1.234 +  g_memmove( GST_BUFFER_DATA( (*outbuf) ), buf, GST_BUFFER_SIZE(*outbuf) );
   1.235    GST_BUFFER_OFFSET (*outbuf) = src->read_offset;
   1.236    GST_BUFFER_OFFSET_END (*outbuf) = src->read_offset + GST_BUFFER_SIZE (*outbuf);
   1.237  
   1.238 @@ -493,17 +470,14 @@
   1.239    src->read_offset += GST_BUFFER_SIZE (*outbuf);
   1.240    src->bytes_read += GST_BUFFER_SIZE (*outbuf);
   1.241    g_print ( "[%s]\t\tBuffer output with size: %d\n", __FUNCTION__, GST_BUFFER_SIZE (*outbuf) );
   1.242 -
   1.243 -  //gst_adapter_flush( src->adapter, size );
   1.244 -  gst_buffer_unref( buffer );
   1.245 +  
   1.246 +  /* flushs the newly buffer got from byte array */
   1.247 +  src->bytes_queue = g_byte_array_remove_range( src->bytes_queue, 0, buffer_size );
   1.248  
   1.249    g_print( "Got buffer: [%s]\t\tBUFFER --->SIZE = %d, OFFSET = %llu, "\
   1.250        "OFFSET_END = %llu.\n\n", __FUNCTION__, GST_BUFFER_SIZE (*outbuf), 
   1.251        GST_BUFFER_OFFSET (*outbuf), GST_BUFFER_OFFSET_END (*outbuf) );
   1.252  
   1.253 -  /* just get from the adapter, no network effort... */
   1.254 -
   1.255 -
   1.256    return ret;
   1.257  
   1.258  done:
   1.259 @@ -546,8 +520,8 @@
   1.260    }
   1.261  
   1.262  }
   1.263 -#endif
   1.264  
   1.265 +#if 0
   1.266  static GstFlowReturn
   1.267  gst_mythtv_src_create ( GstBaseSrc * psrc, guint64 offset, guint size, GstBuffer **outbuf )
   1.268  {
   1.269 @@ -566,15 +540,12 @@
   1.270      goto change_progchain;
   1.271  
   1.272    //g_static_rec_mutex_lock( &th_mutex );
   1.273 -  g_print ( "[%s] %d - Adapter size = (%d), offset = %llu, size = %d...\n", __FUNCTION__, 
   1.274 -  		max_adapter_rep, adapter_size, offset, size );
   1.275 -
   1.276 -  /* just get from the adapter, no network effort... */
   1.277 -  //GstBuffer *buffer = NULL;
   1.278 +  g_print ( "[%s] offset = %llu, size = %d...\n", __FUNCTION__, offset, size );
   1.279  
   1.280    g_print ( "[%s]\t\tCreate: buffer_remain: %d\n", __FUNCTION__, 
   1.281        (gint) src->buffer_remain);
   1.282  
   1.283 +  /* just get from the byte array, no network effort... */
   1.284    if ( ( src->buffer_remain = src->bytes_queue->len ) < MAX_READ_SIZE ) {
   1.285    	guint8 *buffer = g_malloc0( INTERNAL_BUFFER_SIZE - src->buffer_remain );
   1.286  
   1.287 @@ -631,15 +602,14 @@
   1.288    src->read_offset += GST_BUFFER_SIZE (*outbuf);
   1.289    src->bytes_read += GST_BUFFER_SIZE (*outbuf);
   1.290    g_print ( "[%s]\t\tBuffer output with size: %d\n", __FUNCTION__, GST_BUFFER_SIZE (*outbuf) );
   1.291 -
   1.292 +  
   1.293 +  /* flushs the newly buffer got from byte array */
   1.294    src->bytes_queue = g_byte_array_remove_range( src->bytes_queue, 0, buffer_size );
   1.295  
   1.296    g_print( "Got buffer: [%s]\t\tBUFFER --->SIZE = %d, OFFSET = %llu, "\
   1.297        "OFFSET_END = %llu.\n\n", __FUNCTION__, GST_BUFFER_SIZE (*outbuf), 
   1.298        GST_BUFFER_OFFSET (*outbuf), GST_BUFFER_OFFSET_END (*outbuf) );
   1.299  
   1.300 -  /* just get from the adapter, no network effort... */
   1.301 -
   1.302    return ret;
   1.303  
   1.304  done:
   1.305 @@ -682,6 +652,7 @@
   1.306    }
   1.307  
   1.308  }
   1.309 +#endif
   1.310  
   1.311  gint64
   1.312  gst_mythtv_src_get_position ( GstMythtvSrc* src ) 
   1.313 @@ -709,7 +680,6 @@
   1.314  
   1.315  }
   1.316  
   1.317 -#if 0
   1.318  static gboolean
   1.319  gst_mythtv_src_do_seek( GstBaseSrc *base, GstSegment *segment )
   1.320  {
   1.321 @@ -750,13 +720,7 @@
   1.322      }
   1.323  
   1.324    }
   1.325 -   /*
   1.326 -   g_static_rec_mutex_lock( &th_mutex );
   1.327  
   1.328 -   GST_TASK_SIGNAL( src->th_read_ahead );
   1.329 -
   1.330 -   g_static_rec_mutex_unlock( &th_mutex );
   1.331 -   */
   1.332  done:
   1.333     return ret;
   1.334  
   1.335 @@ -785,7 +749,6 @@
   1.336    }
   1.337  
   1.338  }
   1.339 -#endif
   1.340  
   1.341  #if 0
   1.342  static void 
   1.343 @@ -920,15 +883,12 @@
   1.344  
   1.345    src->do_start = FALSE;
   1.346  
   1.347 -  //if ( src->live_tv ) {
   1.348 -  src->bytes_queue = g_byte_array_new();
   1.349 +  src->bytes_queue = g_byte_array_sized_new( INTERNAL_BUFFER_SIZE );
   1.350    //src->th_read_ahead = gst_task_create( (GstTaskFunction)gst_mythtv_src_read_ahead, src );
   1.351    //gst_task_set_lock( src->th_read_ahead, &th_mutex );
   1.352    //gst_task_start( src->th_read_ahead );
   1.353 -  // }
   1.354    src->buffer_remain = 0;
   1.355  
   1.356 -
   1.357  done:
   1.358    return TRUE;
   1.359  
   1.360 @@ -1075,6 +1035,12 @@
   1.361  
   1.362    src->read_offset = 0;  
   1.363    
   1.364 +  if ( src->bytes_queue != NULL ) {
   1.365 +  	g_byte_array_free( src->bytes_queue, TRUE );
   1.366 +  }
   1.367 +  
   1.368 +  src->bytes_queue = g_byte_array_sized_new( INTERNAL_BUFFER_SIZE );
   1.369 +  
   1.370  done:
   1.371  	src->update_prog_chain = FALSE;
   1.372  	
   1.373 @@ -1109,15 +1075,11 @@
   1.374    g_print( "[%s] Differs from previous content size: %d (max.: %d)\n", __FUNCTION__, 
   1.375    			abs( src->content_size - src->prev_content_size ), GMYTHTV_TRANSFER_MAX_BUFFER );
   1.376    			
   1.377 -  if ( src->live_tv )
   1.378 -  	//src->content_size = (guint64)-1;
   1.379 +  if ( src->live_tv ) {
   1.380    	ret = FALSE;
   1.381 -	else if (src->content_size == -1) {
   1.382 -    //ret= FALSE;
   1.383 -  } else if ( src->live_tv && ( abs( src->content_size - src->bytes_read ) < 
   1.384 +	} else if ( src->live_tv && src->enable_timing_position && ( abs( src->content_size - src->bytes_read ) < 
   1.385  				GMYTHTV_TRANSFER_MAX_BUFFER ) ) {
   1.386      //g_static_mutex_lock( &update_size_mutex );
   1.387 -    //GST_OBJECT_LOCK(src);
   1.388      
   1.389      gint64 new_offset = gmyth_file_transfer_get_file_position( src->file_transfer );
   1.390      if ( new_offset > 0 && new_offset > src->content_size ) {
   1.391 @@ -1126,24 +1088,6 @@
   1.392  			src->update_prog_chain = TRUE;
   1.393  	  }
   1.394  
   1.395 -    if ( src->enable_timing_position ) {
   1.396 -      gint64 size_tmp = 0;
   1.397 -      if (src->live_tv == TRUE) {
   1.398 -get_file_pos:
   1.399 -	g_usleep( 5 );
   1.400 -	size_tmp = gmyth_file_transfer_get_file_position( src->file_transfer );
   1.401 -	if ( size_tmp > ( src->content_size + GMYTHTV_TRANSFER_MAX_BUFFER ) )
   1.402 -	  src->content_size = size_tmp;
   1.403 -	else if ( size_tmp > 0  )
   1.404 -	  goto get_file_pos;
   1.405 -	g_print( "\t[%s]\tGET_POSITION: file_position = %lld\n",
   1.406 -	    __FUNCTION__, size_tmp );
   1.407 -      }
   1.408 -    }
   1.409 -    
   1.410 -    src->prev_content_size = src->content_size;
   1.411 -    
   1.412 -    //GST_OBJECT_UNLOCK(src);
   1.413      //g_static_mutex_unlock( &update_size_mutex );
   1.414    }
   1.415  
   1.416 @@ -1272,7 +1216,7 @@
   1.417  static gboolean
   1.418  gst_mythtv_src_is_seekable( GstBaseSrc *push_src )
   1.419  {
   1.420 -  return FALSE;
   1.421 +  return TRUE;
   1.422  }
   1.423  
   1.424  static gboolean
   1.425 @@ -1444,7 +1388,7 @@
   1.426    return;
   1.427  }
   1.428  
   1.429 -  static void
   1.430 +static void
   1.431  gst_mythtv_src_get_property (GObject * object, guint prop_id,
   1.432      GValue * value, GParamSpec * pspec)
   1.433  {