X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=include%2Fstream_output.h;h=641ec997a789302052555c7c199178259d8b0189;hb=5d8a04ab4e44ed6e71b1984b952574104b68fc41;hp=26c4e0242013e65a60eb850ded010f26a9d23cc6;hpb=3a967bf6dde5a9591b83b45644c0a482bb1bad12;p=vlc diff --git a/include/stream_output.h b/include/stream_output.h index 26c4e02420..641ec997a7 100644 --- a/include/stream_output.h +++ b/include/stream_output.h @@ -1,12 +1,13 @@ /***************************************************************************** * stream_output.h : stream output module ***************************************************************************** - * Copyright (C) 2002 VideoLAN + * Copyright (C) 2002-2005 the VideoLAN team * $Id$ * * Authors: Christophe Massiot * Laurent Aimar * Eric Petit + * Jean-Paul Saman * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -20,7 +21,7 @@ * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ /***************************************************************************** @@ -29,21 +30,51 @@ #include "vlc_es.h" +/**************************************************************************** + * sout_instance_t: p_sout + ****************************************************************************/ +struct sout_instance_t +{ + VLC_COMMON_MEMBERS -typedef struct sout_stream_id_t sout_stream_id_t; + char *psz_sout; + char *psz_chain; -/* for mux */ -struct sout_input_t -{ - sout_instance_t *p_sout; + /* meta data (Read only) XXX it won't be set before the first packet received */ + vlc_meta_t *p_meta; - es_format_t *p_fmt; - block_fifo_t *p_fifo; + int i_out_pace_nocontrol; /* count of output that can't control the space */ - void *p_sys; + vlc_mutex_t lock; + sout_stream_t *p_stream; + + /* sout private */ + sout_instance_sys_t *p_sys; }; -/* for packetizer */ +/**************************************************************************** + * sout_cfg_t: + ****************************************************************************/ +struct sout_cfg_t +{ + sout_cfg_t *p_next; + + char *psz_name; + char *psz_value; +}; + +#define sout_CfgParse( a, b, c, d ) __sout_CfgParse( VLC_OBJECT(a), b, c, d ) +VLC_EXPORT( void, __sout_CfgParse, ( vlc_object_t *, char *psz_prefix, const char **ppsz_options, sout_cfg_t * ) ); +VLC_EXPORT( char *, sout_CfgCreate, ( char **, sout_cfg_t **, char * ) ); + +/**************************************************************************** + * sout_stream_id_t: opaque (private for all sout_stream_t) + ****************************************************************************/ +typedef struct sout_stream_id_t sout_stream_id_t; + +/**************************************************************************** + * sout_packetizer_input_t: p_sout <-> p_packetizer + ****************************************************************************/ struct sout_packetizer_input_t { sout_instance_t *p_sout; @@ -53,12 +84,17 @@ struct sout_packetizer_input_t sout_stream_id_t *id; }; +#define sout_NewInstance(a,b) __sout_NewInstance(VLC_OBJECT(a),b) +VLC_EXPORT( sout_instance_t *, __sout_NewInstance, ( vlc_object_t *, char * ) ); +VLC_EXPORT( void, sout_DeleteInstance, ( sout_instance_t * ) ); -#define SOUT_METHOD_NONE 0x00 -#define SOUT_METHOD_FILE 0x10 -#define SOUT_METHOD_NETWORK 0x20 +VLC_EXPORT( sout_packetizer_input_t *, sout_InputNew,( sout_instance_t *, es_format_t * ) ); +VLC_EXPORT( int, sout_InputDelete, ( sout_packetizer_input_t * ) ); +VLC_EXPORT( int, sout_InputSendBuffer, ( sout_packetizer_input_t *, block_t* ) ); -typedef struct sout_access_out_sys_t sout_access_out_sys_t; +/**************************************************************************** + * sout_access_out_t: + ****************************************************************************/ struct sout_access_out_t { VLC_COMMON_MEMBERS @@ -70,6 +106,10 @@ struct sout_access_out_t char *psz_access; sout_cfg_t *p_cfg; + int i_writes; + int64_t i_sent_bytes; ///< This is a "local" counter that is reset each + // time it is transferred to stats + char *psz_name; sout_access_out_sys_t *p_sys; int (*pf_seek)( sout_access_out_t *, off_t ); @@ -77,24 +117,15 @@ struct sout_access_out_t int (*pf_write)( sout_access_out_t *, block_t * ); }; -/* - * i_query parameter of pf_mux_capacity - */ -/* SOUT_MUX_CAP_GET_ADD_STREAM_ANY_TIME: p_args=NULL, p_answer=&boolean */ -#define SOUT_MUX_CAP_GET_ADD_STREAM_ANY_TIME 0x01 -/* SOUT_MUX_CAP_GET_STREAMABLE: p_args=NULL, p_answer=&boolean */ -#define SOUT_MUX_CAP_GET_STREAMABLE 0x02 -/* SOUT_MUX_CAP_GET_ADD_STREAM_WAIT: p_args=NULL, p_answer=&boolean */ -#define SOUT_MUX_CAP_GET_ADD_STREAM_WAIT 0x03 - -/* - * return error code - */ -#define SOUT_MUX_CAP_ERR_OK 0x00 -#define SOUT_MUX_CAP_ERR_UNKNOWN 0x01 -#define SOUT_MUX_CAP_ERR_UNIMPLEMENTED 0x02 - -typedef struct sout_mux_sys_t sout_mux_sys_t; +VLC_EXPORT( sout_access_out_t *,sout_AccessOutNew, ( sout_instance_t *, char *psz_access, char *psz_name ) ); +VLC_EXPORT( void, sout_AccessOutDelete, ( sout_access_out_t * ) ); +VLC_EXPORT( int, sout_AccessOutSeek, ( sout_access_out_t *, off_t ) ); +VLC_EXPORT( int, sout_AccessOutRead, ( sout_access_out_t *, block_t * ) ); +VLC_EXPORT( int, sout_AccessOutWrite, ( sout_access_out_t *, block_t * ) ); + +/**************************************************************************** + * mux: + ****************************************************************************/ struct sout_mux_t { VLC_COMMON_MEMBERS @@ -107,10 +138,10 @@ struct sout_mux_t sout_access_out_t *p_access; - int (*pf_capacity)( sout_mux_t *, int, void *, void *); int (*pf_addstream)( sout_mux_t *, sout_input_t * ); int (*pf_delstream)( sout_mux_t *, sout_input_t * ); int (*pf_mux) ( sout_mux_t * ); + int (*pf_control) ( sout_mux_t *, int, va_list ); /* here are all inputs accepted by muxer */ int i_nb_inputs; @@ -129,17 +160,46 @@ struct sout_mux_t mtime_t i_add_stream_start; }; +enum sout_mux_query_e +{ + /* capabilities */ + MUX_CAN_ADD_STREAM_WHILE_MUXING, /* arg1= vlc_bool_t *, res=cannot fail */ + /* properties */ + MUX_GET_ADD_STREAM_WAIT, /* arg1= vlc_bool_t *, res=cannot fail */ + MUX_GET_MIME, /* arg1= char ** res=can fail */ +}; - -struct sout_cfg_t +struct sout_input_t { - sout_cfg_t *p_next; + sout_instance_t *p_sout; - char *psz_name; - char *psz_value; + es_format_t *p_fmt; + block_fifo_t *p_fifo; + + void *p_sys; }; -typedef struct sout_stream_sys_t sout_stream_sys_t; + +VLC_EXPORT( sout_mux_t *, sout_MuxNew, ( sout_instance_t*, char *, sout_access_out_t * ) ); +VLC_EXPORT( sout_input_t *, sout_MuxAddStream, ( sout_mux_t *, es_format_t * ) ); +VLC_EXPORT( void, sout_MuxDeleteStream, ( sout_mux_t *, sout_input_t * ) ); +VLC_EXPORT( void, sout_MuxDelete, ( sout_mux_t * ) ); +VLC_EXPORT( void, sout_MuxSendBuffer, ( sout_mux_t *, sout_input_t *, block_t * ) ); + +static inline int sout_MuxControl( sout_mux_t *p_mux, int i_query, ... ) +{ + va_list args; + int i_result; + + va_start( args, i_query ); + i_result = p_mux->pf_control( p_mux, i_query, args ); + va_end( args ); + return i_result; +} + +/**************************************************************************** + * sout_stream: + ****************************************************************************/ struct sout_stream_t { VLC_COMMON_MEMBERS @@ -151,6 +211,9 @@ struct sout_stream_t sout_cfg_t *p_cfg; char *psz_next; + /* Subpicture unit */ + spu_t *p_spu; + /* add, remove a stream */ sout_stream_id_t *(*pf_add)( sout_stream_t *, es_format_t * ); int (*pf_del)( sout_stream_t *, sout_stream_id_t * ); @@ -161,26 +224,95 @@ struct sout_stream_t sout_stream_sys_t *p_sys; }; -typedef struct sout_instance_sys_t sout_instance_sys_t; -struct sout_instance_t +VLC_EXPORT( sout_stream_t *, sout_StreamNew, ( sout_instance_t *, char *psz_chain ) ); +VLC_EXPORT( void, sout_StreamDelete, ( sout_stream_t * ) ); + +static inline sout_stream_id_t *sout_StreamIdAdd( sout_stream_t *s, es_format_t *fmt ) { - VLC_COMMON_MEMBERS + return s->pf_add( s, fmt ); +} +static inline int sout_StreamIdDel( sout_stream_t *s, sout_stream_id_t *id ) +{ + return s->pf_del( s, id ); +} +static inline int sout_StreamIdSend( sout_stream_t *s, sout_stream_id_t *id, block_t *b ) +{ + return s->pf_send( s, id, b ); +} - char *psz_sout; - char *psz_chain; +/**************************************************************************** + * Announce handler mess + ****************************************************************************/ +struct sap_session_t; - /* meta data (Read only) XXX it won't be set before the first packet received */ - vlc_meta_t *p_meta; +struct session_descriptor_t +{ + char *psz_name; + char *psz_uri; + int i_port; + int i_ttl; + int i_payload; /* SAP Payload type */ - int i_out_pace_nocontrol; /* count of output that can't control the space */ + char *psz_group; - vlc_mutex_t lock; - sout_stream_t *p_stream; + sap_session_t *p_sap; /* If we have a sap session, remember it */ + char *psz_sdp; + vlc_bool_t b_rtp; +}; - /* sout private */ - sout_instance_sys_t *p_sys; +#define METHOD_TYPE_SAP 1 + +struct announce_method_t +{ + int i_type; +}; + + +/* A SAP session descriptor, enqueued in the SAP handler queue */ +struct sap_session_t +{ + char *psz_sdp; + uint8_t *psz_data; + unsigned i_length; + sap_address_t *p_address; + + /* Last and next send */ + mtime_t i_last; + mtime_t i_next; }; +/* The SAP handler, running in a separate thread */ +struct sap_handler_t +{ + VLC_COMMON_MEMBERS /* needed to create a thread */ + + sap_session_t **pp_sessions; + sap_address_t **pp_addresses; + + vlc_bool_t b_control; + + int i_sessions; + int i_addresses; + + int i_current_session; + + int (*pf_add) ( sap_handler_t*, session_descriptor_t *); + int (*pf_del) ( sap_handler_t*, session_descriptor_t *); + + /* private data, not in p_sys as there is one kind of sap_handler_t */ +}; + +/* The main announce handler object */ +struct announce_handler_t +{ + VLC_COMMON_MEMBERS + + sap_handler_t *p_sap; +}; + +/* End */ + + static inline sout_cfg_t *sout_cfg_find( sout_cfg_t *p_cfg, char *psz_name ) { while( p_cfg && strcmp( p_cfg->psz_name, psz_name ) ) @@ -205,30 +337,26 @@ static inline char *sout_cfg_find_value( sout_cfg_t *p_cfg, char *psz_name ) return NULL; } -/***************************************************************************** - * Prototypes - *****************************************************************************/ -#define sout_NewInstance(a,b) __sout_NewInstance(VLC_OBJECT(a),b) -VLC_EXPORT( sout_instance_t *, __sout_NewInstance, ( vlc_object_t *, char * ) ); -VLC_EXPORT( void, sout_DeleteInstance, ( sout_instance_t * ) ); -VLC_EXPORT( sout_packetizer_input_t *, sout_InputNew,( sout_instance_t *, es_format_t * ) ); -VLC_EXPORT( int, sout_InputDelete, ( sout_packetizer_input_t * ) ); -VLC_EXPORT( int, sout_InputSendBuffer, ( sout_packetizer_input_t *, block_t* ) ); +/* Announce system */ +VLC_EXPORT( int, sout_AnnounceRegister, (sout_instance_t *,session_descriptor_t*, announce_method_t* ) ); +VLC_EXPORT(session_descriptor_t*,sout_AnnounceRegisterSDP, (sout_instance_t *,const char *, const char *, announce_method_t* ) ); +VLC_EXPORT( int, sout_AnnounceUnRegister, (sout_instance_t *,session_descriptor_t* ) ); -VLC_EXPORT( sout_access_out_t *,sout_AccessOutNew, ( sout_instance_t *, char *psz_access, char *psz_name ) ); -VLC_EXPORT( void, sout_AccessOutDelete, ( sout_access_out_t * ) ); -VLC_EXPORT( int, sout_AccessOutSeek, ( sout_access_out_t *, off_t ) ); -VLC_EXPORT( int, sout_AccessOutRead, ( sout_access_out_t *, block_t * ) ); -VLC_EXPORT( int, sout_AccessOutWrite, ( sout_access_out_t *, block_t * ) ); +VLC_EXPORT(session_descriptor_t*,sout_AnnounceSessionCreate, (void) ); +VLC_EXPORT(void, sout_AnnounceSessionDestroy, (session_descriptor_t *) ); +VLC_EXPORT(announce_method_t*, sout_AnnounceMethodCreate, (int) ); -VLC_EXPORT( sout_mux_t *, sout_MuxNew, ( sout_instance_t*, char *, sout_access_out_t * ) ); -VLC_EXPORT( sout_input_t *, sout_MuxAddStream, ( sout_mux_t *, es_format_t * ) ); -VLC_EXPORT( void, sout_MuxDeleteStream, ( sout_mux_t *, sout_input_t * ) ); -VLC_EXPORT( void, sout_MuxDelete, ( sout_mux_t * ) ); -VLC_EXPORT( void, sout_MuxSendBuffer, ( sout_mux_t *, sout_input_t *, block_t * ) ); +#define announce_HandlerCreate(a) __announce_HandlerCreate(VLC_OBJECT(a)) +announce_handler_t* __announce_HandlerCreate( vlc_object_t *); -VLC_EXPORT( char *, sout_cfg_parser, ( char **, sout_cfg_t **, char * ) ); -VLC_EXPORT( sout_stream_t *, sout_stream_new, ( sout_instance_t *, char *psz_chain ) ); -VLC_EXPORT( void, sout_stream_delete, ( sout_stream_t *p_stream ) ); +/* Private functions for the announce handler */ +int announce_HandlerDestroy( announce_handler_t * ); +int announce_Register( announce_handler_t *p_announce, + session_descriptor_t *p_session, + announce_method_t *p_method ); +int announce_UnRegister( announce_handler_t *p_announce, + session_descriptor_t *p_session ); +sap_handler_t *announce_SAPHandlerCreate( announce_handler_t *p_announce ); +void announce_SAPHandlerDestroy( sap_handler_t *p_sap );