diff options
Diffstat (limited to 'libmpdemux')
-rw-r--r-- | libmpdemux/cache2.c | 45 |
1 files changed, 42 insertions, 3 deletions
diff --git a/libmpdemux/cache2.c b/libmpdemux/cache2.c index b4e82cb12b..353921177c 100644 --- a/libmpdemux/cache2.c +++ b/libmpdemux/cache2.c @@ -17,7 +17,14 @@ #include <sys/types.h> #include <unistd.h> +#include "../osdep/timer.h" +#ifndef WIN32 #include "../osdep/shmem.h" +#else +#undef DATADIR +#include <windows.h> +static DWORD WINAPI ThreadProc(void* s); +#endif #include "mp_msg.h" @@ -71,7 +78,7 @@ int cache_read(cache_vars_t* s,unsigned char* buf,int size){ // eof? if(s->eof) break; // waiting for buffer fill... - usleep(READ_USLEEP_TIME); // 10ms + usec_sleep(READ_USLEEP_TIME); // 10ms continue; // try again... } @@ -184,12 +191,20 @@ int cache_fill(cache_vars_t* s){ cache_vars_t* cache_init(int size,int sector){ int num; +#ifndef WIN32 cache_vars_t* s=shmem_alloc(sizeof(cache_vars_t)); +#else + cache_vars_t* s=malloc(sizeof(cache_vars_t)); +#endif memset(s,0,sizeof(cache_vars_t)); num=size/sector; s->buffer_size=num*sector; s->sector_size=sector; +#ifndef WIN32 s->buffer=shmem_alloc(s->buffer_size); +#else + s->buffer=malloc(s->buffer_size); +#endif s->fill_limit=8*sector; s->back_size=size/2; s->prefill=size/20; // default: 5% @@ -199,11 +214,21 @@ cache_vars_t* cache_init(int size,int sector){ void cache_uninit(stream_t *s) { cache_vars_t* c = s->cache_data; if(!s->cache_pid) return; +#ifndef WIN32 kill(s->cache_pid,SIGKILL); waitpid(s->cache_pid,NULL,0); +#else + TerminateThread((HANDLE)s->cache_pid,0); + free(c->stream); +#endif if(!c) return; +#ifndef WIN32 shmem_free(c->buffer,c->buffer_size); shmem_free(s->cache_data,sizeof(cache_vars_t)); +#else + free(c->buffer); + free(s->cache_data); +#endif } static void exit_sighandler(int x){ @@ -227,7 +252,16 @@ int stream_enable_cache(stream_t *stream,int size,int min,int prefill){ s->stream=stream; // callback s->prefill=size*prefill; +#ifndef WIN32 if((stream->cache_pid=fork())){ +#else + { + DWORD threadId; + stream_t* stream2=malloc(sizeof(stream_t)); + memcpy(stream2,s->stream,sizeof(stream_t)); + s->stream=stream2; + stream->cache_pid = CreateThread(NULL,0,ThreadProc,s,0,&threadId); +#endif // wait until cache is filled at least prefill_init % mp_msg(MSGT_CACHE,MSGL_V,"CACHE_PRE_INIT: %d [%d] %d pre:%d eof:%d \n", s->min_filepos,s->read_filepos,s->max_filepos,min,s->eof); @@ -243,11 +277,16 @@ int stream_enable_cache(stream_t *stream,int size,int min,int prefill){ return 1; // parent exits } +#ifdef WIN32 +} +static DWORD WINAPI ThreadProc(void*s){ +#endif + // cache thread mainloop: signal(SIGTERM,exit_sighandler); // kill while(1){ - if(!cache_fill(s)){ - usleep(FILL_USLEEP_TIME); // idle + if(!cache_fill((cache_vars_t*)s)){ + usec_sleep(FILL_USLEEP_TIME); // idle } // cache_stats(s->cache_data); } |