Mercurial > mplayer.hg
changeset 36474:fdfc5ce7cf2a
XvMC: Handle shm xvimage allocation error.
Code based entirely on patches by Marcin Slusarz <marcin.slusarz at gmail>.
author | iive |
---|---|
date | Mon, 06 Jan 2014 20:01:48 +0000 |
parents | 45f770df48de |
children | 7a2dcbac77fb |
files | libvo/vo_xvmc.c |
diffstat | 1 files changed, 35 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/libvo/vo_xvmc.c Mon Jan 06 19:55:26 2014 +0000 +++ b/libvo/vo_xvmc.c Mon Jan 06 20:01:48 2014 +0000 @@ -181,11 +181,10 @@ return cur_render->state || (cur_render->mpi && cur_render->mpi->usage_count); } -static void allocate_xvimage(int xvimage_width,int xvimage_height,int xv_format) +static int allocate_xvimage(int xvimage_width,int xvimage_height,int xv_format) { /* * allocate XvImages. - * FIXME: no error checking */ #ifdef HAVE_SHM if ( mLocalDisplay && XShmQueryExtension( mDisplay ) ) Shmem_Flag = 1; @@ -198,23 +197,48 @@ { xvimage = (XvImage *) XvShmCreateImage(mDisplay, xv_port, xv_format, NULL, xvimage_width, xvimage_height, &Shminfo); + if (!xvimage) + goto noshmimage; Shminfo.shmid = shmget(IPC_PRIVATE, xvimage->data_size, IPC_CREAT | 0777); + if (Shminfo.shmid == -1) + goto shmgetfail; Shminfo.shmaddr = (char *) shmat(Shminfo.shmid, 0, 0); + if (Shminfo.shmaddr == (void *)-1) + goto shmatfail; Shminfo.readOnly = False; xvimage->data = Shminfo.shmaddr; - XShmAttach(mDisplay, &Shminfo); + if (!XShmAttach(mDisplay, &Shminfo)) + goto shmattachfail; XSync(mDisplay, False); shmctl(Shminfo.shmid, IPC_RMID, 0); - return; + return 0; +shmattachfail: + shmdt(Shminfo.shmaddr); +shmatfail: + shmctl(Shminfo.shmid, IPC_RMID, 0); +shmgetfail: + XFree(xvimage); +noshmimage: + Shmem_Flag = 0; } #endif + xvimage = (XvImage *) XvCreateImage(mDisplay, xv_port, xv_format, NULL, xvimage_width, xvimage_height); + if (!xvimage) return -1; + if (!xvimage->data_size) + { + mp_msg(MSGT_VO, MSGL_WARN, + "XServer's XvCreateImage implementation is buggy (returned 0-sized image)\n" ); + XFree(xvimage); + xvimage = NULL; + return -1; + } xvimage->data = malloc(xvimage->data_size); XSync(mDisplay,False); // memset(xvimage->data,128,xvimage->data_size); - return; + return 0; } static void deallocate_xvimage(void) @@ -813,7 +837,12 @@ mp_msg(MSGT_VO,MSGL_DBG4,"vo_xvmc: clearing subpicture\n"); clear_osd_fnc(0, 0, subpicture.width, subpicture.height); - allocate_xvimage(subpicture.width, subpicture.height, subpicture_info.id); + if (allocate_xvimage(subpicture.width, subpicture.height, subpicture_info.id)) + { + subpicture_mode = NO_SUBPICTURE; + mp_msg(MSGT_VO,MSGL_WARN, "vo_xvmc: OSD disabled\n"); + return; + } subpicture_alloc = 1; }