@ -172,23 +172,25 @@ struct drm_output {
drmModeCrtcPtr original_crtc ;
drmModeCrtcPtr original_crtc ;
struct drm_edid edid ;
struct drm_edid edid ;
drmModePropertyPtr dpms_prop ;
drmModePropertyPtr dpms_prop ;
uint32_t gbm_format ;
enum dpms_enum dpms ;
enum dpms_enum dpms ;
struct backlight * backlight ;
int vblank_pending ;
int vblank_pending ;
int page_flip_pending ;
int page_flip_pending ;
int destroy_pending ;
int destroy_pending ;
int disable_pending ;
int disable_pending ;
struct gbm_surface * gbm_surface ;
struct drm_fb * gbm_cursor_fb [ 2 ] ;
struct drm_fb * gbm_cursor_fb [ 2 ] ;
struct weston_plane cursor_plane ;
struct weston_plane cursor_plane ;
struct weston_plane fb_plane ;
struct weston_view * cursor_view ;
struct weston_view * cursor_view ;
int current_cursor ;
int current_cursor ;
struct drm_fb * current , * next ;
struct backlight * backlight ;
struct gbm_surface * gbm_surface ;
uint32_t gbm_format ;
struct weston_plane fb_plane ;
struct drm_fb * fb_current , * fb_pending ;
struct drm_fb * dumb [ 2 ] ;
struct drm_fb * dumb [ 2 ] ;
pixman_image_t * image [ 2 ] ;
pixman_image_t * image [ 2 ] ;
@ -210,7 +212,7 @@ struct drm_sprite {
struct weston_plane plane ;
struct weston_plane plane ;
struct drm_fb * current , * next ;
struct drm_fb * fb_ current, * fb_pending ;
struct drm_output * output ;
struct drm_output * output ;
struct drm_backend * backend ;
struct drm_backend * backend ;
@ -682,13 +684,13 @@ drm_output_prepare_scanout_view(struct drm_output *output,
return NULL ;
return NULL ;
}
}
output - > next = drm_fb_get_from_bo ( bo , b , format , BUFFER_CLIENT ) ;
output - > fb_pending = drm_fb_get_from_bo ( bo , b , format , BUFFER_CLIENT ) ;
if ( ! output - > next ) {
if ( ! output - > fb_pending ) {
gbm_bo_destroy ( bo ) ;
gbm_bo_destroy ( bo ) ;
return NULL ;
return NULL ;
}
}
drm_fb_set_buffer ( output - > next , buffer ) ;
drm_fb_set_buffer ( output - > fb_pending , buffer ) ;
return & output - > fb_plane ;
return & output - > fb_plane ;
}
}
@ -708,14 +710,14 @@ drm_output_render_gl(struct drm_output *output, pixman_region32_t *damage)
return ;
return ;
}
}
output - > next = drm_fb_get_from_bo ( bo , b , output - > gbm_format ,
output - > fb_pending = drm_fb_get_from_bo ( bo , b , output - > gbm_format ,
BUFFER_GBM_SURFACE ) ;
BUFFER_GBM_SURFACE ) ;
if ( ! output - > next ) {
if ( ! output - > fb_pending ) {
weston_log ( " failed to get drm_fb for bo \n " ) ;
weston_log ( " failed to get drm_fb for bo \n " ) ;
gbm_surface_release_buffer ( output - > gbm_surface , bo ) ;
gbm_surface_release_buffer ( output - > gbm_surface , bo ) ;
return ;
return ;
}
}
output - > next - > gbm_surface = output - > gbm_surface ;
output - > fb_pending - > gbm_surface = output - > gbm_surface ;
}
}
static void
static void
@ -734,7 +736,7 @@ drm_output_render_pixman(struct drm_output *output, pixman_region32_t *damage)
output - > current_image ^ = 1 ;
output - > current_image ^ = 1 ;
output - > next = drm_fb_ref ( output - > dumb [ output - > current_image ] ) ;
output - > fb_pending = drm_fb_ref ( output - > dumb [ output - > current_image ] ) ;
pixman_renderer_output_set_buffer ( & output - > base ,
pixman_renderer_output_set_buffer ( & output - > base ,
output - > image [ output - > current_image ] ) ;
output - > image [ output - > current_image ] ) ;
@ -821,16 +823,16 @@ drm_output_repaint(struct weston_output *output_base,
if ( output - > disable_pending | | output - > destroy_pending )
if ( output - > disable_pending | | output - > destroy_pending )
return - 1 ;
return - 1 ;
if ( ! output - > next )
if ( ! output - > fb_pending )
drm_output_render ( output , damage ) ;
drm_output_render ( output , damage ) ;
if ( ! output - > next )
if ( ! output - > fb_pending )
return - 1 ;
return - 1 ;
mode = container_of ( output - > base . current_mode , struct drm_mode , base ) ;
mode = container_of ( output - > base . current_mode , struct drm_mode , base ) ;
if ( ! output - > current | |
if ( ! output - > fb_ current | |
output - > current - > stride ! = output - > next - > stride ) {
output - > fb_ current- > stride ! = output - > fb_pending - > stride ) {
ret = drmModeSetCrtc ( backend - > drm . fd , output - > crtc_id ,
ret = drmModeSetCrtc ( backend - > drm . fd , output - > crtc_id ,
output - > next - > fb_id , 0 , 0 ,
output - > fb_pending - > fb_id , 0 , 0 ,
& output - > connector_id , 1 ,
& output - > connector_id , 1 ,
& mode - > mode_info ) ;
& mode - > mode_info ) ;
if ( ret ) {
if ( ret ) {
@ -841,7 +843,7 @@ drm_output_repaint(struct weston_output *output_base,
}
}
if ( drmModePageFlip ( backend - > drm . fd , output - > crtc_id ,
if ( drmModePageFlip ( backend - > drm . fd , output - > crtc_id ,
output - > next - > fb_id ,
output - > fb_pending - > fb_id ,
DRM_MODE_PAGE_FLIP_EVENT , output ) < 0 ) {
DRM_MODE_PAGE_FLIP_EVENT , output ) < 0 ) {
weston_log ( " queueing pageflip failed: %m \n " ) ;
weston_log ( " queueing pageflip failed: %m \n " ) ;
goto err_pageflip ;
goto err_pageflip ;
@ -865,12 +867,12 @@ drm_output_repaint(struct weston_output *output_base,
. request . sequence = 1 ,
. request . sequence = 1 ,
} ;
} ;
if ( ( ! s - > current & & ! s - > next ) | |
if ( ( ! s - > fb_ current & & ! s - > fb_pending ) | |
! drm_sprite_crtc_supported ( output , s ) )
! drm_sprite_crtc_supported ( output , s ) )
continue ;
continue ;
if ( s - > next & & ! backend - > sprites_hidden )
if ( s - > fb_pending & & ! backend - > sprites_hidden )
fb_id = s - > next - > fb_id ;
fb_id = s - > fb_pending - > fb_id ;
ret = drmModeSetPlane ( backend - > drm . fd , s - > plane_id ,
ret = drmModeSetPlane ( backend - > drm . fd , s - > plane_id ,
output - > crtc_id , fb_id , flags ,
output - > crtc_id , fb_id , flags ,
@ -903,9 +905,9 @@ drm_output_repaint(struct weston_output *output_base,
err_pageflip :
err_pageflip :
output - > cursor_view = NULL ;
output - > cursor_view = NULL ;
if ( output - > next ) {
if ( output - > fb_pending ) {
drm_fb_unref ( output - > next ) ;
drm_fb_unref ( output - > fb_pending ) ;
output - > next = NULL ;
output - > fb_pending = NULL ;
}
}
return - 1 ;
return - 1 ;
@ -931,7 +933,7 @@ drm_output_start_repaint_loop(struct weston_output *output_base)
if ( output - > disable_pending | | output - > destroy_pending )
if ( output - > disable_pending | | output - > destroy_pending )
return ;
return ;
if ( ! output - > current ) {
if ( ! output - > fb_ current) {
/* We can't page flip if there's no mode set */
/* We can't page flip if there's no mode set */
goto finish_frame ;
goto finish_frame ;
}
}
@ -965,7 +967,7 @@ drm_output_start_repaint_loop(struct weston_output *output_base)
/* Immediate query didn't provide valid timestamp.
/* Immediate query didn't provide valid timestamp.
* Use pageflip fallback .
* Use pageflip fallback .
*/
*/
fb_id = output - > current - > fb_id ;
fb_id = output - > fb_ current- > fb_id ;
if ( drmModePageFlip ( backend - > drm . fd , output - > crtc_id , fb_id ,
if ( drmModePageFlip ( backend - > drm . fd , output - > crtc_id , fb_id ,
DRM_MODE_PAGE_FLIP_EVENT , output ) < 0 ) {
DRM_MODE_PAGE_FLIP_EVENT , output ) < 0 ) {
@ -1009,9 +1011,9 @@ vblank_handler(int fd, unsigned int frame, unsigned int sec, unsigned int usec,
drm_output_update_msc ( output , frame ) ;
drm_output_update_msc ( output , frame ) ;
output - > vblank_pending = 0 ;
output - > vblank_pending = 0 ;
drm_fb_unref ( s - > current ) ;
drm_fb_unref ( s - > fb_ current) ;
s - > current = s - > next ;
s - > fb_ current = s - > fb_pending ;
s - > next = NULL ;
s - > fb_pending = NULL ;
if ( ! output - > page_flip_pending ) {
if ( ! output - > page_flip_pending ) {
/* Stop the pageflip timer instead of rearming it here */
/* Stop the pageflip timer instead of rearming it here */
@ -1043,9 +1045,9 @@ page_flip_handler(int fd, unsigned int frame,
* we just want to page flip to the current buffer to get an accurate
* we just want to page flip to the current buffer to get an accurate
* timestamp */
* timestamp */
if ( output - > page_flip_pending ) {
if ( output - > page_flip_pending ) {
drm_fb_unref ( output - > current ) ;
drm_fb_unref ( output - > fb_ current) ;
output - > current = output - > next ;
output - > fb_ current = output - > fb_pending ;
output - > next = NULL ;
output - > fb_pending = NULL ;
}
}
output - > page_flip_pending = 0 ;
output - > page_flip_pending = 0 ;
@ -1147,7 +1149,7 @@ drm_output_prepare_overlay_view(struct drm_output *output,
if ( ! drm_sprite_crtc_supported ( output , s ) )
if ( ! drm_sprite_crtc_supported ( output , s ) )
continue ;
continue ;
if ( ! s - > next ) {
if ( ! s - > fb_pending ) {
found = 1 ;
found = 1 ;
break ;
break ;
}
}
@ -1206,13 +1208,13 @@ drm_output_prepare_overlay_view(struct drm_output *output,
return NULL ;
return NULL ;
}
}
s - > next = drm_fb_get_from_bo ( bo , b , format , BUFFER_CLIENT ) ;
s - > fb_pending = drm_fb_get_from_bo ( bo , b , format , BUFFER_CLIENT ) ;
if ( ! s - > next ) {
if ( ! s - > fb_pending ) {
gbm_bo_destroy ( bo ) ;
gbm_bo_destroy ( bo ) ;
return NULL ;
return NULL ;
}
}
drm_fb_set_buffer ( s - > next , ev - > surface - > buffer_ref . buffer ) ;
drm_fb_set_buffer ( s - > fb_pending , ev - > surface - > buffer_ref . buffer ) ;
box = pixman_region32_extents ( & ev - > transform . boundingbox ) ;
box = pixman_region32_extents ( & ev - > transform . boundingbox ) ;
s - > plane . x = box - > x1 ;
s - > plane . x = box - > x1 ;
@ -1580,9 +1582,9 @@ drm_output_switch_mode(struct weston_output *output_base, struct weston_mode *mo
WL_OUTPUT_MODE_CURRENT | WL_OUTPUT_MODE_PREFERRED ;
WL_OUTPUT_MODE_CURRENT | WL_OUTPUT_MODE_PREFERRED ;
/* reset rendering stuff. */
/* reset rendering stuff. */
drm_fb_unref ( output - > current ) ;
drm_fb_unref ( output - > fb_ current) ;
drm_fb_unref ( output - > next ) ;
drm_fb_unref ( output - > fb_pending ) ;
output - > current = output - > next = NULL ;
output - > fb_ current = output - > fb_pending = NULL ;
if ( b - > use_pixman ) {
if ( b - > use_pixman ) {
drm_output_fini_pixman ( output ) ;
drm_output_fini_pixman ( output ) ;
@ -2618,11 +2620,11 @@ drm_output_deinit(struct weston_output *base)
struct drm_output * output = to_drm_output ( base ) ;
struct drm_output * output = to_drm_output ( base ) ;
struct drm_backend * b = to_drm_backend ( base - > compositor ) ;
struct drm_backend * b = to_drm_backend ( base - > compositor ) ;
/* output->next must not be set here;
/* output->fb_pending must not be set here;
* destroy_pending / disable_pending exist to guarantee exactly this . */
* destroy_pending / disable_pending exist to guarantee exactly this . */
assert ( ! output - > next ) ;
assert ( ! output - > fb_pending ) ;
drm_fb_unref ( output - > current ) ;
drm_fb_unref ( output - > fb_ current) ;
output - > current = NULL ;
output - > fb_ current = NULL ;
if ( b - > use_pixman )
if ( b - > use_pixman )
drm_output_fini_pixman ( output ) ;
drm_output_fini_pixman ( output ) ;
@ -2809,8 +2811,8 @@ create_sprites(struct drm_backend *b)
sprite - > possible_crtcs = plane - > possible_crtcs ;
sprite - > possible_crtcs = plane - > possible_crtcs ;
sprite - > plane_id = plane - > plane_id ;
sprite - > plane_id = plane - > plane_id ;
sprite - > current = NULL ;
sprite - > fb_ current = NULL ;
sprite - > next = NULL ;
sprite - > fb_pending = NULL ;
sprite - > backend = b ;
sprite - > backend = b ;
sprite - > count_formats = plane - > count_formats ;
sprite - > count_formats = plane - > count_formats ;
memcpy ( sprite - > formats , plane - > formats ,
memcpy ( sprite - > formats , plane - > formats ,
@ -2840,8 +2842,8 @@ destroy_sprites(struct drm_backend *backend)
sprite - > plane_id ,
sprite - > plane_id ,
output - > crtc_id , 0 , 0 ,
output - > crtc_id , 0 , 0 ,
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ) ;
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ) ;
drm_fb_unref ( sprite - > current ) ;
drm_fb_unref ( sprite - > fb_ current) ;
drm_fb_unref ( sprite - > next ) ;
drm_fb_unref ( sprite - > fb_pending ) ;
weston_plane_release ( & sprite - > plane ) ;
weston_plane_release ( & sprite - > plane ) ;
free ( sprite ) ;
free ( sprite ) ;
}
}
@ -3277,7 +3279,7 @@ recorder_frame_notify(struct wl_listener *listener, void *data)
if ( ! output - > recorder )
if ( ! output - > recorder )
return ;
return ;
ret = drmPrimeHandleToFD ( b - > drm . fd , output - > current - > handle ,
ret = drmPrimeHandleToFD ( b - > drm . fd , output - > fb_ current- > handle ,
DRM_CLOEXEC , & fd ) ;
DRM_CLOEXEC , & fd ) ;
if ( ret ) {
if ( ret ) {
weston_log ( " [libva recorder] "
weston_log ( " [libva recorder] "
@ -3286,7 +3288,7 @@ recorder_frame_notify(struct wl_listener *listener, void *data)
}
}
ret = vaapi_recorder_frame ( output - > recorder , fd ,
ret = vaapi_recorder_frame ( output - > recorder , fd ,
output - > current - > stride ) ;
output - > fb_ current- > stride ) ;
if ( ret < 0 ) {
if ( ret < 0 ) {
weston_log ( " [libva recorder] aborted: %m \n " ) ;
weston_log ( " [libva recorder] aborted: %m \n " ) ;
recorder_destroy ( output ) ;
recorder_destroy ( output ) ;