Commit ec728f13 authored by Sam Hocevar's avatar Sam Hocevar

  * Fixed an alignment issue in the ifo parser. The Matrix problem should
    be solved.
  * Minor cosmetic fixes and warning removals here and there.
parent 7340778f
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* css.h: Structures for DVD authentification and unscrambling * css.h: Structures for DVD authentification and unscrambling
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2001 VideoLAN * Copyright (C) 1999-2001 VideoLAN
* $Id: css.h,v 1.1 2001/06/12 22:14:44 sam Exp $ * $Id: css.h,v 1.2 2001/06/20 07:43:48 sam Exp $
* *
* Author: Stphane Borel <stef@via.ecp.fr> * Author: Stphane Borel <stef@via.ecp.fr>
* *
...@@ -56,7 +56,7 @@ typedef struct css_s ...@@ -56,7 +56,7 @@ typedef struct css_s
} css_t; } css_t;
/***************************************************************************** /*****************************************************************************
* Prototypes in dvd_css.c * Prototypes in css.c
*****************************************************************************/ *****************************************************************************/
struct css_s; struct css_s;
......
/***************************************************************************** /*****************************************************************************
* dvd_ioctl.h: DVD ioctl replacement function * ioctl.h: DVD ioctl replacement function
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2001 VideoLAN * Copyright (C) 1999-2001 VideoLAN
* $Id: ioctl.h,v 1.2 2001/06/14 02:47:44 sam Exp $ * $Id: ioctl.h,v 1.3 2001/06/20 07:43:48 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* *
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* libdvdcss.h: DVD reading library, exported functions. * libdvdcss.h: DVD reading library, exported functions.
***************************************************************************** *****************************************************************************
* Copyright (C) 1998-2001 VideoLAN * Copyright (C) 1998-2001 VideoLAN
* $Id: dvdcss.h,v 1.2 2001/06/14 01:49:44 sam Exp $ * $Id: dvdcss.h,v 1.3 2001/06/20 07:43:48 sam Exp $
* *
* Authors: Stphane Borel <stef@via.ecp.fr> * Authors: Stphane Borel <stef@via.ecp.fr>
* Samuel Hocevar <sam@zoy.org> * Samuel Hocevar <sam@zoy.org>
...@@ -32,10 +32,10 @@ typedef struct dvdcss_s* dvdcss_handle; ...@@ -32,10 +32,10 @@ typedef struct dvdcss_s* dvdcss_handle;
*****************************************************************************/ *****************************************************************************/
#define DVDCSS_NOFLAGS 0 #define DVDCSS_NOFLAGS 0
#define DVDCSS_INIT_QUIET 1 << 0 #define DVDCSS_INIT_QUIET (1 << 0)
#define DVDCSS_INIT_DEBUG 1 << 1 #define DVDCSS_INIT_DEBUG (1 << 1)
#define DVDCSS_READ_DECRYPT 1 << 0 #define DVDCSS_READ_DECRYPT (1 << 0)
#define DVDCSS_BLOCK_SIZE 2048 #define DVDCSS_BLOCK_SIZE 2048
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* dvd_ifo.c: Functions for ifo parsing * dvd_ifo.c: Functions for ifo parsing
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2001 VideoLAN * Copyright (C) 1999-2001 VideoLAN
* $Id: dvd_ifo.c,v 1.33 2001/06/12 22:14:44 sam Exp $ * $Id: dvd_ifo.c,v 1.34 2001/06/20 07:43:48 sam Exp $
* *
* Authors: Stphane Borel <stef@via.ecp.fr> * Authors: Stphane Borel <stef@via.ecp.fr>
* German Tischler <tanis@gaspode.franken.de> * German Tischler <tanis@gaspode.franken.de>
...@@ -287,8 +287,9 @@ int IfoInit( ifo_t * p_ifo ) ...@@ -287,8 +287,9 @@ int IfoInit( ifo_t * p_ifo )
for( i = 0 ; i < PARINF.i_country_nb ; i++ ) for( i = 0 ; i < PARINF.i_country_nb ; i++ )
{ {
p_tmp = FillBuffer( p_ifo, p_buf, LB2OFF( i_start ) + p_tmp = FillBuffer( p_ifo, p_buf, i_start + OFF2LB(
PARINF.p_parental_desc[i].i_parental_mask_start_byte ); PARINF.p_parental_desc[i].i_parental_mask_start_byte ) )
+ (PARINF.p_parental_desc[i].i_parental_mask_start_byte & 0x7ff);
for( j = 0 ; j < 8 ; j++ ) for( j = 0 ; j < 8 ; j++ )
{ {
...@@ -378,8 +379,8 @@ int IfoInit( ifo_t * p_ifo ) ...@@ -378,8 +379,8 @@ int IfoInit( ifo_t * p_ifo )
for( j = 0 ; j < 28 ; j++ ) for( j = 0 ; j < 28 ; j++ )
{ {
ReadBytes( p_ifo, p_buf, &p_tmp, (u8*)(&i_temp), 6 );
/* FIXME : Fix endianness issue here */ /* FIXME : Fix endianness issue here */
ReadBytes( p_ifo, p_buf, &p_tmp, (u8*)(&i_temp), 6 );
} }
DumpBytes( p_ifo, p_buf, &p_tmp, 2 ); DumpBytes( p_ifo, p_buf, &p_tmp, 2 );
...@@ -401,8 +402,8 @@ int IfoInit( ifo_t * p_ifo ) ...@@ -401,8 +402,8 @@ int IfoInit( ifo_t * p_ifo )
for( j = 0 ; j < 28 /*VTSINF.p_vts_vts_inf[i].i_vtstt_subpic_nb*/ ; j++ ) for( j = 0 ; j < 28 /*VTSINF.p_vts_vts_inf[i].i_vtstt_subpic_nb*/ ; j++ )
{ {
ReadBytes( p_ifo, p_buf, &p_tmp, (u8*)(&i_temp), 6 );
/* FIXME : Fix endianness issue here */ /* FIXME : Fix endianness issue here */
ReadBytes( p_ifo, p_buf, &p_tmp, (u8*)(&i_temp), 6 );
} }
} }
} }
...@@ -461,17 +462,18 @@ int IfoTitleSet( ifo_t * p_ifo ) ...@@ -461,17 +462,18 @@ int IfoTitleSet( ifo_t * p_ifo )
i_off = p_ifo->vmg.title_inf.p_attr[p_ifo->i_title-1].i_start_sector i_off = p_ifo->vmg.title_inf.p_attr[p_ifo->i_title-1].i_start_sector
+ p_ifo->i_start; + p_ifo->i_start;
//fprintf(stderr, "offset: %d\n" , i_off ); //fprintf(stderr, "offset: %d\n" , i_off );
p_tmp = FillBuffer( p_ifo, p_buf, i_off ); p_tmp = FillBuffer( p_ifo, p_buf, i_off );
//i_start = p_ifo->i_pos; //i_start = p_ifo->i_pos;
p_ifo->vts.i_pos = p_ifo->i_pos; p_ifo->vts.i_pos = p_ifo->i_pos;
#define MGINF p_ifo->vts.manager_inf #define MGINF p_ifo->vts.manager_inf
/* /*
* reads manager information * read manager information
*/ */
//fprintf( stderr, "VTSI\n" ); //fprintf( stderr, "VTSI\n" );
ReadBytes( p_ifo, p_buf, &p_tmp, MGINF.psz_id , 12 ); ReadBytes( p_ifo, p_buf, &p_tmp, MGINF.psz_id , 12 );
MGINF.psz_id[12] = '\0'; MGINF.psz_id[12] = '\0';
...@@ -509,8 +511,8 @@ int IfoTitleSet( ifo_t * p_ifo ) ...@@ -509,8 +511,8 @@ int IfoTitleSet( ifo_t * p_ifo )
for( i = 0 ; i < 28 ; i++ ) for( i = 0 ; i < 28 ; i++ )
{ {
ReadBytes( p_ifo, p_buf, &p_tmp, (u8*)(&i_temp), 6 );
/* FIXME : take care of endianness */ /* FIXME : take care of endianness */
ReadBytes( p_ifo, p_buf, &p_tmp, (u8*)(&i_temp), 6 );
} }
DumpBytes( p_ifo, p_buf, &p_tmp, 2 ); DumpBytes( p_ifo, p_buf, &p_tmp, 2 );
...@@ -588,7 +590,7 @@ int IfoTitleSet( ifo_t * p_ifo ) ...@@ -588,7 +590,7 @@ int IfoTitleSet( ifo_t * p_ifo )
} }
/* /*
* reads title information: set of pointers to title * read title information: set of pointers to title
*/ */
#define TITINF p_ifo->vts.title_inf #define TITINF p_ifo->vts.title_inf
if( MGINF.i_title_inf_start_sector ) if( MGINF.i_title_inf_start_sector )
...@@ -630,13 +632,12 @@ int IfoTitleSet( ifo_t * p_ifo ) ...@@ -630,13 +632,12 @@ int IfoTitleSet( ifo_t * p_ifo )
{ {
p_tmp = FillBuffer( p_ifo, p_buf, i_start + p_tmp = FillBuffer( p_ifo, p_buf, i_start +
OFF2LB( TITINF.pi_start_byte[i] ) ) OFF2LB( TITINF.pi_start_byte[i] ) )
+ TITINF.pi_start_byte[i]; + (TITINF.pi_start_byte[i] & 0x7ff);
TITINF.p_title_start[i].i_title_id = TITINF.p_title_start[i].i_title_id =
ReadWord( p_ifo, p_buf, &p_tmp ); ReadWord( p_ifo, p_buf, &p_tmp );
TITINF.p_title_start[i].i_chapter = TITINF.p_title_start[i].i_chapter =
ReadWord( p_ifo, p_buf, &p_tmp ); ReadWord( p_ifo, p_buf, &p_tmp );
//fprintf( stderr, "VTS %d title_inf Pgc: %d Prg: %d\n", i,title_inf.p_title_start[i].i_program_chain_num, TITINF.p_title_start[i].i_program_num );
} }
} }
#undef TITINF #undef TITINF
...@@ -724,41 +725,33 @@ int IfoTitleSet( ifo_t * p_ifo ) ...@@ -724,41 +725,33 @@ int IfoTitleSet( ifo_t * p_ifo )
} }
#undef TIMINF #undef TIMINF
if( MGINF.i_menu_cell_inf_start_sector ) if( MGINF.i_menu_cell_inf_start_sector
{ && ReadCellInf( p_ifo, &p_ifo->vts.menu_cell_inf, p_ifo->vts.i_pos +
if( ReadCellInf( p_ifo, &p_ifo->vts.menu_cell_inf, p_ifo->vts.i_pos +
MGINF.i_menu_cell_inf_start_sector ) < 0 ) MGINF.i_menu_cell_inf_start_sector ) < 0 )
{ {
return -1; return -1;
} }
}
if( MGINF.i_menu_vobu_map_start_sector ) if( MGINF.i_menu_vobu_map_start_sector
{ && ReadVobuMap( p_ifo, &p_ifo->vts.menu_vobu_map, p_ifo->vts.i_pos +
if( ReadVobuMap( p_ifo, &p_ifo->vts.menu_vobu_map, p_ifo->vts.i_pos +
MGINF.i_menu_vobu_map_start_sector ) < 0 ) MGINF.i_menu_vobu_map_start_sector ) < 0 )
{ {
return -1; return -1;
} }
}
if( MGINF.i_cell_inf_start_sector ) if( MGINF.i_cell_inf_start_sector
{ && ReadCellInf( p_ifo, &p_ifo->vts.cell_inf, p_ifo->vts.i_pos +
if( ReadCellInf( p_ifo, &p_ifo->vts.cell_inf, p_ifo->vts.i_pos +
MGINF.i_cell_inf_start_sector ) ) MGINF.i_cell_inf_start_sector ) )
{ {
return -1; return -1;
} }
}
if( MGINF.i_vobu_map_start_sector ) if( MGINF.i_vobu_map_start_sector
{ && ReadVobuMap( p_ifo, &p_ifo->vts.vobu_map, p_ifo->vts.i_pos +
if( ReadVobuMap( p_ifo, &p_ifo->vts.vobu_map, p_ifo->vts.i_pos +
MGINF.i_vobu_map_start_sector ) ) MGINF.i_vobu_map_start_sector ) )
{ {
return -1; return -1;
} }
}
#undef MGINF #undef MGINF
intf_WarnMsg( 2, "ifo info: vts %d initialized", intf_WarnMsg( 2, "ifo info: vts %d initialized",
...@@ -945,14 +938,13 @@ static int ReadTitle( ifo_t * p_ifo, title_t * p_title, int i_block, int i_bytes ...@@ -945,14 +938,13 @@ static int ReadTitle( ifo_t * p_ifo, title_t * p_title, int i_block, int i_bytes
p_title->i_next_title_num = ReadWord( p_ifo, p_buf, &p_tmp ); p_title->i_next_title_num = ReadWord( p_ifo, p_buf, &p_tmp );
p_title->i_prev_title_num = ReadWord( p_ifo, p_buf, &p_tmp ); p_title->i_prev_title_num = ReadWord( p_ifo, p_buf, &p_tmp );
p_title->i_go_up_title_num = ReadWord( p_ifo, p_buf, &p_tmp ); p_title->i_go_up_title_num = ReadWord( p_ifo, p_buf, &p_tmp );
//fprintf( stderr, "title: Prev: %d Next: %d Up: %d\n",pgc.i_prev_pgc_nb ,pgc.i_next_pgc_nb, pgc.i_goup_pgc_nb );
p_title->i_still_time = ReadByte( p_ifo, p_buf, &p_tmp ); p_title->i_still_time = ReadByte( p_ifo, p_buf, &p_tmp );
p_title->i_play_mode = ReadByte( p_ifo, p_buf, &p_tmp ); p_title->i_play_mode = ReadByte( p_ifo, p_buf, &p_tmp );
for( i = 0 ; i < 16 ; i++ ) for( i = 0 ; i < 16 ; i++ )
{ {
p_title->pi_yuv_color[i] = ReadDouble( p_ifo, p_buf, &p_tmp );
/* FIXME : We have to erase the extra bit */ /* FIXME : We have to erase the extra bit */
p_title->pi_yuv_color[i] = ReadDouble( p_ifo, p_buf, &p_tmp );
} }
p_title->i_command_start_byte = ReadWord( p_ifo, p_buf, &p_tmp ); p_title->i_command_start_byte = ReadWord( p_ifo, p_buf, &p_tmp );
...@@ -1348,7 +1340,7 @@ static int ReadCellInf( ifo_t * p_ifo, cell_inf_t * p_cell_inf, int i_block ) ...@@ -1348,7 +1340,7 @@ static int ReadCellInf( ifo_t * p_ifo, cell_inf_t * p_cell_inf, int i_block )
MAP.i_cell_id = ReadByte( p_ifo, p_buf, &p_tmp ); MAP.i_cell_id = ReadByte( p_ifo, p_buf, &p_tmp );
DumpBytes( p_ifo, p_buf, &p_tmp, 1 ); DumpBytes( p_ifo, p_buf, &p_tmp, 1 );
MAP.i_start_sector = ReadDouble( p_ifo, p_buf, &p_tmp ); MAP.i_start_sector = ReadDouble( p_ifo, p_buf, &p_tmp );
//fprintf(stderr, "sector[%d] %d (%lld)\n", i,ntohl(*(u32*)(p_tmp)), p_ifo->i_pos); //fprintf(stderr, "sector[%d] %d (%d)\n", i,ntohl(*(u32*)(p_tmp)), p_ifo->i_pos);
MAP.i_end_sector = ReadDouble( p_ifo, p_buf, &p_tmp ); MAP.i_end_sector = ReadDouble( p_ifo, p_buf, &p_tmp );
#undef MAP #undef MAP
} }
...@@ -2094,33 +2086,30 @@ void CommandPrint( ifo_t ifo ) ...@@ -2094,33 +2086,30 @@ void CommandPrint( ifo_t ifo )
*****************************************************************************/ *****************************************************************************/
static u8* FillBuffer( ifo_t* p_ifo, u8* p_buf, int i_pos ) static u8* FillBuffer( ifo_t* p_ifo, u8* p_buf, int i_pos )
{ {
memset( p_buf, 0, DVD_LB_SIZE );
p_ifo->i_pos = dvdcss_seek( p_ifo->dvdhandle, i_pos ); p_ifo->i_pos = dvdcss_seek( p_ifo->dvdhandle, i_pos );
dvdcss_read( p_ifo->dvdhandle, p_buf, 1, DVDCSS_NOFLAGS ); dvdcss_read( p_ifo->dvdhandle, p_buf, 1, DVDCSS_NOFLAGS );
return p_buf; return p_buf;
} }
static u8 ReadByte( ifo_t * p_ifo, u8* p_buf, u8** pp_tmp ) static void ReadBytes( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp,
u8* pi_dest, int i_nb )
{ {
u8 i_ret; if( i_nb > DVD_LB_SIZE )
if( *pp_tmp > p_buf + DVD_LB_SIZE )
{ {
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 ); intf_ErrMsg( "ifo error: excessive ReadBytes call (%i)", i_nb );
} }
i_ret = *(*pp_tmp)++; if( *pp_tmp + i_nb >= p_buf + DVD_LB_SIZE )
{
int i_spare = (int)( (p_buf + DVD_LB_SIZE) - *pp_tmp );
return i_ret; /* Copy the bytes remaining in the current buffer */
} memcpy( pi_dest, *pp_tmp, i_spare );
pi_dest += i_spare;
i_nb -= i_spare;
static void ReadBytes( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp, /* Load the next buffer */
u8* pi_dest, int i_nb )
{
if( *pp_tmp > p_buf + DVD_LB_SIZE - i_nb )
{
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 ); *pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 );
} }
...@@ -2130,64 +2119,57 @@ static void ReadBytes( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp, ...@@ -2130,64 +2119,57 @@ static void ReadBytes( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp,
return; return;
} }
static void DumpBytes( ifo_t* p_ifo, u8* p_buf, static void DumpBytes( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp, int i_nb )
u8** pp_tmp, int i_nb )
{ {
if( *pp_tmp > p_buf + DVD_LB_SIZE - i_nb ) if( i_nb > DVD_LB_SIZE )
{ {
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 ); intf_ErrMsg( "ifo error: excessive DumpBytes call (%i)", i_nb );
} }
*pp_tmp += i_nb; *pp_tmp += i_nb;
return; if( *pp_tmp >= p_buf + DVD_LB_SIZE )
}
static u16 ReadWord( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp )
{
u16 i_ret;
if( *pp_tmp > p_buf + DVD_LB_SIZE - 2 )
{ {
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 ); /* If we went too far, load the next buffer */
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 )
+ (int)( (*pp_tmp) - (p_buf - DVD_LB_SIZE) );
} }
i_ret = U16_AT(*pp_tmp); return;
(*pp_tmp) += 2; }
#define ADDBYTE \
if( *pp_tmp >= p_buf + DVD_LB_SIZE ) \
{ \
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 ); \
} \
i_ret <<= 8; i_ret |= **pp_tmp; (*pp_tmp)++;
static u8 ReadByte( ifo_t * p_ifo, u8* p_buf, u8** pp_tmp )
{
u8 i_ret = 0;
ADDBYTE;
return i_ret; return i_ret;
} }
static u32 ReadDouble( ifo_t * p_ifo, u8* p_buf, static u16 ReadWord( ifo_t * p_ifo, u8* p_buf, u8** pp_tmp )
u8** pp_tmp )
{ {
u32 i_ret; u16 i_ret = 0;
ADDBYTE; ADDBYTE;
if( *pp_tmp > p_buf + DVD_LB_SIZE - 4 )
{
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 );
//intf_WarnMsg( 1, "new buffer in double @ %lld", p_ifo->i_pos );
}
i_ret = U32_AT(*pp_tmp);
(*pp_tmp) += 4;
return i_ret; return i_ret;
} }
static u64 ReadQuad( ifo_t* p_ifo, u8* p_buf, u8** pp_tmp ) static u32 ReadDouble( ifo_t * p_ifo, u8* p_buf, u8** pp_tmp )
{ {
u64 i_ret; u32 i_ret = 0;
ADDBYTE; ADDBYTE; ADDBYTE; ADDBYTE;
if( *pp_tmp > p_buf + DVD_LB_SIZE - 8 )
{
*pp_tmp = FillBuffer( p_ifo, p_buf, p_ifo->i_pos + 1 );
}
i_ret = U64_AT(*pp_tmp);
(*pp_tmp) += 8;
return i_ret; return i_ret;
} }
static u64 ReadQuad( ifo_t * p_ifo, u8* p_buf, u8** pp_tmp )
{
u64 i_ret = 0;
ADDBYTE; ADDBYTE; ADDBYTE; ADDBYTE; ADDBYTE; ADDBYTE; ADDBYTE; ADDBYTE;
return i_ret;
}
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* vdec_block_c.c: Macroblock copy functions in C * vdec_block_c.c: Macroblock copy functions in C
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000, 2001 VideoLAN * Copyright (C) 1999, 2000, 2001 VideoLAN
* $Id: vdec_block_c.c,v 1.3 2001/06/03 12:47:21 sam Exp $ * $Id: vdec_block_c.c,v 1.4 2001/06/20 07:43:48 sam Exp $
* *
* Authors: Christophe Massiot <massiot@via.ecp.fr> * Authors: Christophe Massiot <massiot@via.ecp.fr>
* *
...@@ -33,6 +33,8 @@ ...@@ -33,6 +33,8 @@
*****************************************************************************/ *****************************************************************************/
#include "defs.h" #include "defs.h"
#include <string.h>
#include "config.h" #include "config.h"
#include "common.h" #include "common.h"
#include "threads.h" #include "threads.h"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* vdec_block_mmx.c: Macroblock copy functions in MMX assembly * vdec_block_mmx.c: Macroblock copy functions in MMX assembly
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000, 2001 VideoLAN * Copyright (C) 1999, 2000, 2001 VideoLAN
* $Id: vdec_block_mmx.c,v 1.3 2001/06/03 12:47:21 sam Exp $ * $Id: vdec_block_mmx.c,v 1.4 2001/06/20 07:43:48 sam Exp $
* *
* Authors: Gal Hendryckx <jimmy@via.ecp.fr> * Authors: Gal Hendryckx <jimmy@via.ecp.fr>
* *
...@@ -33,6 +33,8 @@ ...@@ -33,6 +33,8 @@
*****************************************************************************/ *****************************************************************************/
#include "defs.h" #include "defs.h"
#include <string.h>
#include "config.h" #include "config.h"
#include "common.h" #include "common.h"
#include "threads.h" #include "threads.h"
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* input_ts.h: structures of the input not exported to other modules * input_ts.h: structures of the input not exported to other modules
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* $Id: input_ts.h,v 1.7 2001/06/02 01:09:03 sam Exp $ * $Id: input_ts.h,v 1.8 2001/06/20 07:43:48 sam Exp $
* *
* Authors: Henri Fallon <henri@via.ecp.fr> * Authors: Henri Fallon <henri@via.ecp.fr>
* *
...@@ -32,3 +32,4 @@ typedef struct thread_ts_data_s { ...@@ -32,3 +32,4 @@ typedef struct thread_ts_data_s {
fd_set fds; fd_set fds;
} thread_ts_data_t; } thread_ts_data_t;
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment