# HG changeset patch # User mswitch # Date 1011479070 0 # Node ID 68c78efeea2b08a56f57ab47fd0c579fd0b3a250 # Parent 83aedfde69f8e182856611512febd037463320bc Reverted to using software sync again, some day I'll die of a heartattack if I can't get this m*f*er to work on both fast and slow machines... May all hell be let loose on sigma for not cooperating with us diff -r 83aedfde69f8 -r 68c78efeea2b libvo/vo_dxr3.c --- a/libvo/vo_dxr3.c Sat Jan 19 22:16:47 2002 +0000 +++ b/libvo/vo_dxr3.c Sat Jan 19 22:24:30 2002 +0000 @@ -75,7 +75,6 @@ /* Static variable used in ioctl's */ static int ioval = 0; -static int pts = 0; static vo_info_t vo_info = { @@ -382,21 +381,11 @@ size_t data_left = p->size; if (p->id == 0x20) { - /* Set subpic timestamp */ - if (ioctl(fd_spu, EM8300_IOCTL_SPU_SETPTS, &pts) < 0) { - printf("VO: [dxr3] Unable to set pts\n"); - } - /* Force subpic data into buffer */ while (data_left) { data_left -= write(fd_spu, (void*) (p->data + p->size-data_left), data_left); } } else { - /* Set frame timestamp */ - if (ioctl(fd_video, EM8300_IOCTL_VIDEO_SETPTS, &pts) < 0) { - printf("VO: [dxr3] Unable to set pts\n"); - } - /* Force video data into buffer */ while (data_left) { data_left -= write(fd_video, (void*) (p->data + p->size-data_left), data_left); @@ -429,7 +418,7 @@ rgb24toyv12(s, dY, dU, dV, w, h, picture_linesize[0], picture_linesize[1], v_width * 3); mp1e_buffer.data = picture_data[0]; - mp1e_buffer.time = pts / 90000.0; + mp1e_buffer.time = vo_pts / 90000.0; mp1e_buffer.user_data = NULL; vo_draw_text(osd_w, osd_h, draw_alpha); rte_push_video_buffer(mp1e_context, &mp1e_buffer); @@ -443,33 +432,25 @@ { static int prev_pts = 0; /* Flush the device if a seek occured */ - if (prev_pts > pts) { - printf("Seek\n"); + if (prev_pts > vo_pts) { + /* Flush video */ ioval = EM8300_SUBDEVICE_VIDEO; ioctl(fd_control, EM8300_IOCTL_FLUSH, &ioval); - pts += 90000.0 / vo_fps; - if (img_format == IMGFMT_MPEGPES) { - ioctl(fd_control, EM8300_IOCTL_SCR_SET, &pts); - if (ioctl(fd_video, EM8300_IOCTL_VIDEO_SETPTS, &pts) < 0) { - printf("VO: [dxr3] Unable to set pts\n"); - } - } } - prev_pts = pts; + prev_pts = vo_pts; #ifdef USE_MP1E if (img_format == IMGFMT_YV12) { mp1e_buffer.data = picture_data[0]; - mp1e_buffer.time = pts / 90000.0; + mp1e_buffer.time = vo_pts / 90000.0; mp1e_buffer.user_data = NULL; rte_push_video_buffer(mp1e_context, &mp1e_buffer); } else if (img_format == IMGFMT_YUY2) { mp1e_buffer.data = picture_data[0]; - mp1e_buffer.time = pts / 90000.0; + mp1e_buffer.time = vo_pts / 90000.0; mp1e_buffer.user_data = NULL; rte_push_video_buffer(mp1e_context, &mp1e_buffer); } #endif - pts += 90000.0 / vo_fps; } static uint32_t draw_slice(uint8_t *srcimg[], int stride[], int w, int h, int x0, int y0) @@ -527,7 +508,7 @@ if (format == IMGFMT_MPEGPES) { /* Hardware accelerated | Hardware supports subpics | Hardware handles syncing */ - flag = 0x2 | 0x8 | 0x100; + flag = 0x2 | 0x8; #ifdef USE_MP1E } else if (format == IMGFMT_YV12) { /* Conversion needed | OSD Supported */