Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
c0e40cc1
Commit
c0e40cc1
authored
Dec 13, 2009
by
Laurent Aimar
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Updated vout display modules after ::get -> ::pool change.
parent
149587ec
Changes
17
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
150 additions
and
155 deletions
+150
-155
modules/misc/dummy/dummy.c
modules/misc/dummy/dummy.c
+2
-2
modules/misc/dummy/dummy.h
modules/misc/dummy/dummy.h
+1
-0
modules/misc/dummy/vout.c
modules/misc/dummy/vout.c
+30
-10
modules/video_output/aa.c
modules/video_output/aa.c
+10
-12
modules/video_output/caca.c
modules/video_output/caca.c
+13
-15
modules/video_output/directfb.c
modules/video_output/directfb.c
+9
-12
modules/video_output/fb.c
modules/video_output/fb.c
+8
-10
modules/video_output/msw/direct3d.c
modules/video_output/msw/direct3d.c
+9
-12
modules/video_output/msw/glwin32.c
modules/video_output/msw/glwin32.c
+11
-13
modules/video_output/sdl.c
modules/video_output/sdl.c
+9
-10
modules/video_output/snapshot.c
modules/video_output/snapshot.c
+8
-7
modules/video_output/vmem.c
modules/video_output/vmem.c
+10
-9
modules/video_output/wrapper.c
modules/video_output/wrapper.c
+4
-1
modules/video_output/xcb/glx.c
modules/video_output/xcb/glx.c
+5
-8
modules/video_output/xcb/x11.c
modules/video_output/xcb/x11.c
+6
-10
modules/video_output/xcb/xvideo.c
modules/video_output/xcb/xvideo.c
+6
-10
modules/video_output/yuv.c
modules/video_output/yuv.c
+9
-14
No files found.
modules/misc/dummy/dummy.c
View file @
c0e40cc1
...
...
@@ -98,7 +98,7 @@ vlc_module_begin ()
set_description
(
N_
(
"Dummy video output function"
)
)
set_section
(
N_
(
"Dummy Video output"
),
NULL
)
set_capability
(
"vout display"
,
1
)
set_callbacks
(
OpenVideo
,
NULL
)
set_callbacks
(
OpenVideo
,
CloseVideo
)
set_category
(
CAT_VIDEO
)
set_subcategory
(
SUBCAT_VIDEO_VOUT
)
add_category_hint
(
N_
(
"Video"
),
NULL
,
false
)
...
...
@@ -108,7 +108,7 @@ vlc_module_begin ()
set_description
(
N_
(
"Stats video output function"
)
)
set_capability
(
"vout display"
,
0
)
add_shortcut
(
"stats"
)
set_callbacks
(
OpenVideoStat
,
NULL
)
set_callbacks
(
OpenVideoStat
,
CloseVideo
)
add_submodule
()
set_description
(
N_
(
"Dummy font renderer function"
)
)
set_capability
(
"text renderer"
,
1
)
...
...
modules/misc/dummy/dummy.h
View file @
c0e40cc1
...
...
@@ -40,5 +40,6 @@ int OpenAudio ( vlc_object_t * );
int
OpenVideo
(
vlc_object_t
*
);
int
OpenVideoStat
(
vlc_object_t
*
);
void
CloseVideo
(
vlc_object_t
*
);
int
OpenRenderer
(
vlc_object_t
*
);
modules/misc/dummy/vout.c
View file @
c0e40cc1
...
...
@@ -36,11 +36,14 @@
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
void
DisplayStat
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
struct
vout_display_sys_t
{
picture_pool_t
*
pool
;
};
static
picture_pool_t
*
Pool
(
vout_display_t
*
,
unsigned
count
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
void
DisplayStat
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
/*****************************************************************************
* OpenVideo: activates dummy vout display method
...
...
@@ -48,6 +51,12 @@ static void Manage (vout_display_t *);
static
int
OpenVideoCommon
(
vlc_object_t
*
object
,
bool
display_stat
)
{
vout_display_t
*
vd
=
(
vout_display_t
*
)
object
;
vout_display_sys_t
*
sys
;
vd
->
sys
=
sys
=
calloc
(
1
,
sizeof
(
*
sys
));
if
(
!
sys
)
return
VLC_EGENERIC
;
sys
->
pool
=
NULL
;
/* p_vd->info is not modified */
...
...
@@ -60,11 +69,11 @@ static int OpenVideoCommon(vlc_object_t *object, bool display_stat)
}
free
(
chroma
);
}
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
display_stat
?
DisplayStat
:
Display
;
vd
->
control
=
Control
;
vd
->
manage
=
Manage
;
vd
->
manage
=
Manage
;
return
VLC_SUCCESS
;
}
...
...
@@ -77,10 +86,21 @@ int OpenVideoStat(vlc_object_t *object)
return
OpenVideoCommon
(
object
,
true
);
}
static
picture_t
*
Get
(
vout_display_t
*
vd
)
void
CloseVideo
(
vlc_object_t
*
object
)
{
VLC_UNUSED
(
vd
);
return
picture_NewFromFormat
(
&
vd
->
fmt
);
vout_display_t
*
vd
=
(
vout_display_t
*
)
object
;
vout_display_sys_t
*
sys
=
vd
->
sys
;
picture_pool_Delete
(
sys
->
pool
);
free
(
sys
);
}
static
picture_pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
if
(
!
sys
->
pool
)
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
count
);
return
sys
->
pool
;
}
static
void
Display
(
vout_display_t
*
vd
,
picture_t
*
picture
)
...
...
modules/video_output/aa.c
View file @
c0e40cc1
...
...
@@ -58,10 +58,10 @@ vlc_module_end()
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
/* */
static
void
Manage
(
vout_display_t
*
);
...
...
@@ -115,11 +115,11 @@ static int Open(vlc_object_t *object)
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
Prepare
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
vd
->
manage
=
Manage
;
vd
->
manage
=
Manage
;
/* Inspect initial configuration and send correction events
* FIXME how to handle aspect ratio with aa ? */
...
...
@@ -152,11 +152,12 @@ static void Close(vlc_object_t *object)
}
/**
* Return a
direct buffer
* Return a
pool of direct buffers
*/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
VLC_UNUSED
(
count
);
if
(
!
sys
->
pool
)
{
picture_resource_t
rsc
;
...
...
@@ -171,11 +172,8 @@ static picture_t *Get(vout_display_t *vd)
return
NULL
;
sys
->
pool
=
picture_pool_New
(
1
,
&
p_picture
);
if
(
!
sys
->
pool
)
return
NULL
;
}
return
picture_pool_Get
(
sys
->
pool
);
return
sys
->
pool
;
}
/**
...
...
modules/video_output/caca.c
View file @
c0e40cc1
...
...
@@ -55,10 +55,10 @@ vlc_module_end()
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
/* */
static
void
Manage
(
vout_display_t
*
);
...
...
@@ -164,11 +164,6 @@ static int Open(vlc_object_t *object)
fmt
.
i_bmask
=
0x000000ff
;
}
/* */
sys
->
pool
=
picture_pool_NewFromFormat
(
&
fmt
,
1
);
if
(
!
sys
->
pool
)
goto
error
;
/* TODO */
vout_display_info_t
info
=
vd
->
info
;
...
...
@@ -176,11 +171,11 @@ static int Open(vlc_object_t *object)
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
Prepare
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
vd
->
manage
=
Manage
;
vd
->
manage
=
Manage
;
/* Fix initial state */
vout_display_SendEventFullscreen
(
vd
,
false
);
...
...
@@ -215,7 +210,8 @@ static void Close(vlc_object_t *object)
vout_display_t
*
vd
=
(
vout_display_t
*
)
object
;
vout_display_sys_t
*
sys
=
vd
->
sys
;
picture_pool_Delete
(
sys
->
pool
);
if
(
sys
->
pool
)
picture_pool_Delete
(
sys
->
pool
);
if
(
sys
->
dither
)
cucul_free_dither
(
sys
->
dither
);
caca_free_display
(
sys
->
dp
);
...
...
@@ -229,13 +225,15 @@ static void Close(vlc_object_t *object)
}
/**
* Return a
direct buffer
* Return a
pool of direct buffers
*/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
return
picture_pool_Get
(
sys
->
pool
);
if
(
!
sys
->
pool
)
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
count
);
return
sys
->
pool
;
}
/**
...
...
modules/video_output/directfb.c
View file @
c0e40cc1
...
...
@@ -55,10 +55,10 @@ vlc_module_end()
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
/* */
static
int
OpenDisplay
(
vout_display_t
*
);
...
...
@@ -157,7 +157,7 @@ static int Open(vlc_object_t *object)
/* */
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -182,16 +182,13 @@ static void Close(vlc_object_t *object)
}
/* */
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
if
(
!
sys
->
pool
)
{
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
1
);
if
(
!
sys
->
pool
)
return
NULL
;
}
return
picture_pool_Get
(
sys
->
pool
);
if
(
!
sys
->
pool
)
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
count
);
return
sys
->
pool
;
}
static
void
Display
(
vout_display_t
*
vd
,
picture_t
*
picture
)
...
...
modules/video_output/fb.c
View file @
c0e40cc1
...
...
@@ -98,10 +98,10 @@ vlc_module_end ()
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
/* */
static
int
OpenDisplay
(
vout_display_t
*
,
bool
force_resolution
);
...
...
@@ -262,7 +262,7 @@ static int Open(vlc_object_t *object)
/* */
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -296,7 +296,7 @@ static void Close(vlc_object_t *object)
}
/* */
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
...
...
@@ -322,11 +322,9 @@ static picture_t *Get(vout_display_t *vd)
if
(
sys
->
is_hw_accel
)
sys
->
pool
=
picture_pool_New
(
1
,
&
sys
->
picture
);
else
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
1
);
if
(
!
sys
->
pool
)
return
NULL
;
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
count
);
}
return
picture_pool_Get
(
sys
->
pool
)
;
return
sys
->
pool
;
}
static
void
Display
(
vout_display_t
*
vd
,
picture_t
*
picture
)
{
...
...
modules/video_output/msw/direct3d.c
View file @
c0e40cc1
...
...
@@ -97,11 +97,11 @@ struct picture_sys_t
static
int
Open
(
vlc_object_t
*
);
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
int
Direct3DCreate
(
vout_display_t
*
);
static
int
Direct3DReset
(
vout_display_t
*
);
...
...
@@ -177,7 +177,7 @@ static int Open(vlc_object_t *object)
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
Prepare
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -231,13 +231,10 @@ static void Close(vlc_object_t *object)
}
/* */
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
if
(
!
sys
->
pool
)
return
NULL
;
return
picture_pool_Get
(
sys
->
pool
);
VLC_UNUSED
(
count
);
return
vd
->
sys
->
pool
;
}
static
int
Direct3DLockSurface
(
picture_t
*
);
...
...
modules/video_output/msw/glwin32.c
View file @
c0e40cc1
...
...
@@ -74,13 +74,13 @@ vlc_module_end()
/*****************************************************************************
* Local prototypes.
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Prepare
(
vout_display_t
*
,
picture_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
void
Swap
(
vout_opengl_t
*
);
static
void
Swap
(
vout_opengl_t
*
);
/**
* It creates an OpenGL vout display.
...
...
@@ -140,7 +140,7 @@ static int Open(vlc_object_t *object)
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
Prepare
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -177,16 +177,14 @@ static void Close(vlc_object_t *object)
}
/* */
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
VLC_UNUSED
(
count
);
if
(
!
sys
->
pool
)
{
if
(
!
sys
->
pool
)
sys
->
pool
=
vout_display_opengl_GetPool
(
&
sys
->
vgl
);
if
(
!
sys
->
pool
)
return
NULL
;
}
return
picture_pool_Get
(
sys
->
pool
);
return
sys
->
pool
;
}
static
void
Prepare
(
vout_display_t
*
vd
,
picture_t
*
picture
)
...
...
modules/video_output/sdl.c
View file @
c0e40cc1
...
...
@@ -77,10 +77,10 @@ vlc_module_end()
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
/* */
static
int
ConvertKey
(
SDLKey
);
...
...
@@ -337,7 +337,7 @@ static int Open(vlc_object_t *object)
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -389,11 +389,12 @@ static void Close(vlc_object_t *object)
}
/**
* Return a
direct buffer
* Return a
pool of direct buffers
*/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
VLC_UNUSED
(
count
);
if
(
!
sys
->
pool
)
{
picture_resource_t
rsc
;
...
...
@@ -430,11 +431,9 @@ static picture_t *Get(vout_display_t *vd)
return
NULL
;
sys
->
pool
=
picture_pool_New
(
1
,
&
picture
);
if
(
!
sys
->
pool
)
return
NULL
;
}
return
picture_pool_Get
(
sys
->
pool
)
;
return
sys
->
pool
;
}
/**
...
...
modules/video_output/snapshot.c
View file @
c0e40cc1
...
...
@@ -90,10 +90,10 @@ vlc_module_end ()
/*****************************************************************************
* Local prototypes
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
typedef
struct
{
mtime_t
date
;
/* Presentation time */
...
...
@@ -243,7 +243,7 @@ static int Open(vlc_object_t *object)
/* */
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -281,9 +281,10 @@ static void Close(vlc_object_t *object)
/*****************************************************************************
*
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
return
picture_pool_Get
(
vd
->
sys
->
pool
);
VLC_UNUSED
(
count
);
return
vd
->
sys
->
pool
;
}
/* Return the position in ms from the start of the movie */
...
...
modules/video_output/vmem.c
View file @
c0e40cc1
...
...
@@ -98,13 +98,13 @@ struct vout_display_sys_t {
picture_pool_t
*
pool
;
};
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
int
Lock
(
picture_t
*
);
static
void
Unlock
(
picture_t
*
);
static
int
Lock
(
picture_t
*
);
static
void
Unlock
(
picture_t
*
);
/*****************************************************************************
* Open: allocates video thread
...
...
@@ -228,7 +228,7 @@ static int Open(vlc_object_t *object)
/* */
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -250,9 +250,10 @@ static void Close(vlc_object_t *object)
}
/* */
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
return
picture_pool_Get
(
vd
->
sys
->
pool
);
VLC_UNUSED
(
count
);
return
vd
->
sys
->
pool
;
}
static
void
Display
(
vout_display_t
*
vd
,
picture_t
*
picture
)
...
...
modules/video_output/wrapper.c
View file @
c0e40cc1
...
...
@@ -301,7 +301,10 @@ static int Init(vout_thread_t *vout)
picture
->
p_sys
=
malloc
(
sizeof
(
*
picture
->
p_sys
));
if
(
sys
->
use_dr
)
{
picture_t
*
direct
=
vout_display_Get
(
vd
);
picture_pool_t
*
pool
=
vout_display_Pool
(
vd
,
picture_max
);
if
(
!
pool
)
break
;
picture_t
*
direct
=
picture_pool_Get
(
pool
);
if
(
!
direct
)
break
;
picture
->
format
=
direct
->
format
;
...
...
modules/video_output/xcb/glx.c
View file @
c0e40cc1
...
...
@@ -76,7 +76,7 @@ struct vout_display_sys_t
picture_pool_t
*
pool
;
/* picture pool */
};
static
picture_
t
*
Get
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
PictureRender
(
vout_display_t
*
,
picture_t
*
);
static
void
PictureDisplay
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
...
...
@@ -375,7 +375,7 @@ static int Open (vlc_object_t *obj)
/* Setup vout_display_t once everything is fine */
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
PictureRender
;
vd
->
display
=
PictureDisplay
;
vd
->
control
=
Control
;
...
...
@@ -431,17 +431,14 @@ static void SwapBuffers (vout_opengl_t *gl)
/**
* Return a direct buffer
*/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
requested_count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
(
void
)
requested_count
;
if
(
!
sys
->
pool
)
{
sys
->
pool
=
vout_display_opengl_GetPool
(
&
sys
->
vgl
);
if
(
!
sys
->
pool
)
return
NULL
;
}
return
picture_pool_Get
(
sys
->
pool
);
return
sys
->
pool
;
}
static
void
PictureRender
(
vout_display_t
*
vd
,
picture_t
*
pic
)
...
...
modules/video_output/xcb/x11.c
View file @
c0e40cc1
...
...
@@ -83,7 +83,7 @@ struct vout_display_sys_t
picture_resource_t
resource
[
MAX_PICTURES
];
};
static
picture_
t
*
Get
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
...
...
@@ -281,7 +281,7 @@ static int Open (vlc_object_t *obj)
vd
->
fmt
=
fmt_pic
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -317,9 +317,10 @@ static void Close (vlc_object_t *obj)
/**
* Return a direct buffer
*/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
requested_count
)
{
vout_display_sys_t
*
p_sys
=
vd
->
sys
;
(
void
)
requested_count
;
if
(
!
p_sys
->
pool
)
{
...
...
@@ -366,16 +367,11 @@ static picture_t *Get (vout_display_t *vd)
return
NULL
;
p_sys
->
pool
=
picture_pool_New
(
count
,
pic_array
);
if
(
!
p_sys
->
pool
)
{
/* TODO release picture resources */
return
NULL
;
}
/* FIXME should also do it in case of error ? */
/* TODO release picture resources if NULL */
xcb_flush
(
p_sys
->
conn
);
}
return
p
icture_pool_Get
(
p_sys
->
pool
)
;
return
p
_sys
->
pool
;
}
/**
...
...
modules/video_output/xcb/xvideo.c
View file @
c0e40cc1
...
...
@@ -94,7 +94,7 @@ struct vout_display_sys_t
picture_resource_t
resource
[
MAX_PICTURES
];
};
static
picture_
t
*
Get
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
...
...
@@ -514,7 +514,7 @@ static int Open (vlc_object_t *obj)
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -564,9 +564,10 @@ static void Close (vlc_object_t *obj)
/**
* Return a direct buffer
*/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
requested_count
)
{
vout_display_sys_t
*
p_sys
=
vd
->
sys
;
(
void
)
requested_count
;
if
(
!
p_sys
->
pool
)
{
...
...
@@ -621,16 +622,11 @@ static picture_t *Get (vout_display_t *vd)
return
NULL
;
p_sys
->
pool
=
picture_pool_New
(
count
,
pic_array
);
if
(
!
p_sys
->
pool
)
{
/* TODO release picture resources */
return
NULL
;
}
/* FIXME should also do it in case of error ? */
/* TODO release picture resources if NULL */
xcb_flush
(
p_sys
->
conn
);
}
return
p
icture_pool_Get
(
p_sys
->
pool
)
;
return
p
_sys
->
pool
;
}
/**
...
...
modules/video_output/yuv.c
View file @
c0e40cc1
...
...
@@ -80,10 +80,10 @@ static const char *const ppsz_vout_options[] = {
};
/* */
static
picture_
t
*
Get
(
vout_display_t
*
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
static
picture_
pool_t
*
Pool
(
vout_display_t
*
,
unsigned
);
static
void
Display
(
vout_display_t
*
,
picture_t
*
);
static
int
Control
(
vout_display_t
*
,
int
,
va_list
);
static
void
Manage
(
vout_display_t
*
);
/*****************************************************************************
* vout_display_sys_t: video output descriptor
...
...
@@ -92,7 +92,6 @@ struct vout_display_sys_t {
FILE
*
f
;
bool
is_first
;
bool
is_yuv4mpeg2
;
bool
use_dr
;
picture_pool_t
*
pool
;
};
...
...
@@ -133,7 +132,6 @@ static int Open(vlc_object_t *object)
return
VLC_EGENERIC
;
}
}
sys
->
use_dr
=
chroma
==
vd
->
fmt
.
i_chroma
;
msg_Dbg
(
vd
,
"Using chroma %4.4s"
,
(
char
*
)
&
chroma
);
/* */
...
...
@@ -166,7 +164,7 @@ static int Open(vlc_object_t *object)
/* */
vd
->
fmt
=
fmt
;
vd
->
info
=
info
;
vd
->
get
=
Get
;
vd
->
pool
=
Pool
;
vd
->
prepare
=
NULL
;
vd
->
display
=
Display
;
vd
->
control
=
Control
;
...
...
@@ -191,15 +189,12 @@ static void Close(vlc_object_t *object)
/*****************************************************************************
*
*****************************************************************************/
static
picture_
t
*
Get
(
vout_display_t
*
vd
)
static
picture_
pool_t
*
Pool
(
vout_display_t
*
vd
,
unsigned
count
)
{
vout_display_sys_t
*
sys
=
vd
->
sys
;
if
(
!
sys
->
pool
)
{
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
sys
->
use_dr
?
VOUT_MAX_PICTURES
:
1
);
if
(
!
sys
->
pool
)
return
NULL
;
}
return
picture_pool_Get
(
sys
->
pool
);
if
(
!
sys
->
pool
)
sys
->
pool
=
picture_pool_NewFromFormat
(
&
vd
->
fmt
,
count
);
return
sys
->
pool
;
}
static
void
Display
(
vout_display_t
*
vd
,
picture_t
*
picture
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment