diff options
Diffstat (limited to 'libvo')
-rw-r--r-- | libvo/vo_mpegpes.c | 71 |
1 files changed, 67 insertions, 4 deletions
diff --git a/libvo/vo_mpegpes.c b/libvo/vo_mpegpes.c index 62be9e6415..427d2f3d3e 100644 --- a/libvo/vo_mpegpes.c +++ b/libvo/vo_mpegpes.c @@ -1,4 +1,4 @@ -#undef HAVE_DVB +#define HAVE_DVB #define PES_MAX_SIZE 2048 /* * Based on: @@ -291,7 +291,7 @@ static void my_write(unsigned char* data,int len){ static unsigned char pes_header[PES_MAX_SIZE]; -static void send_pes_packet(unsigned char* data,int len,int id,int timestamp){ +void send_pes_packet(unsigned char* data,int len,int id,int timestamp){ int x; pes_header[0]=pes_header[1]=0; @@ -327,6 +327,69 @@ static void send_pes_packet(unsigned char* data,int len,int id,int timestamp){ } +void send_lpcm_packet(unsigned char* data,int len,int id,int timestamp){ + int x; + + pes_header[0]=pes_header[1]=0; + pes_header[2]=1; pes_header[3]=0xBD; + + while(len>=4){ + int payload_size; + + payload_size=PES_MAX_SIZE-6-20; // max possible data len + if(payload_size>len) payload_size=len; + payload_size&=(~3); // align! + + payload_size+=20; // PTS+headers + + //if(6+payload_size>PES_MAX_SIZE) payload_size=PES_MAX_SIZE-6; + + // construct PES header: (code from ffmpeg's libav) + // startcode: + // packetsize: + pes_header[4]=(payload_size)>>8; + pes_header[5]=(payload_size)&255; + // stuffing: + pes_header[6]=0x81; + pes_header[7]=0x80; + pes_header[8]=10; // hdrlen + // presentation time stamp: + x=(0x02 << 4) | (((timestamp >> 30) & 0x07) << 1) | 1; + pes_header[9]=x; + x=((((timestamp >> 15) & 0x7fff) << 1) | 1); + pes_header[10]=x>>8; pes_header[11]=x&255; + x=((((timestamp) & 0x7fff) << 1) | 1); + pes_header[12]=x>>8; pes_header[13]=x&255; + + pes_header[14]= + pes_header[15]= + pes_header[16]= + pes_header[17]= + pes_header[18]=0xFF; // stuffing + + pes_header[19]=id; + + pes_header[20]=0x07; // dunnowhat + pes_header[21]=0x00; + pes_header[22]=0x04; + pes_header[23]=0x0C; + + pes_header[24]=0x01; // LPCM id + pes_header[25]=0x80; + + payload_size-=20; + memcpy(&pes_header[6+20],data,payload_size); + my_write(pes_header,6+20+payload_size); + + len-=payload_size; data+=payload_size; + if(len<=0) break; + } + +// printf("PES: draw frame! pts=%d size=%d \n",timestamp,len); + +} + + static uint32_t draw_frame(uint8_t * src[]) { vo_mpegpes_t *p=(vo_mpegpes_t *)src[0]; @@ -400,9 +463,9 @@ static uint32_t draw_slice(uint8_t *srcimg[], int stride[], int w,int h,int x0,i static uint32_t query_format(uint32_t format) { - if(format==IMGFMT_MPEGPES) return 1; + if(format==IMGFMT_MPEGPES) return 1|256; #ifdef USE_LIBAVCODEC - if(format==IMGFMT_YV12) return 1; + if(format==IMGFMT_YV12) return 1|256; #endif return 0; } |