drm: use IMPORT_FD for INVALID modifier

GBM_BO_IMPORT_FD_MODIFIER doesn't accept the INVALID modifier.
This commit is contained in:
Ivan Molodetskikh 2019-09-26 22:52:35 +03:00 committed by Simon Ser
parent ebeef0fbe8
commit 5f78ea20fa

View file

@ -1,4 +1,5 @@
#include <assert.h> #include <assert.h>
#include <drm_fourcc.h>
#include <gbm.h> #include <gbm.h>
#include <stdbool.h> #include <stdbool.h>
#include <stdlib.h> #include <stdlib.h>
@ -165,26 +166,40 @@ void post_drm_surface(struct wlr_drm_surface *surf) {
struct gbm_bo *import_gbm_bo(struct wlr_drm_renderer *renderer, struct gbm_bo *import_gbm_bo(struct wlr_drm_renderer *renderer,
struct wlr_dmabuf_attributes *attribs) { struct wlr_dmabuf_attributes *attribs) {
struct gbm_import_fd_modifier_data data = { if (attribs->modifier == DRM_FORMAT_MOD_INVALID && attribs->n_planes == 1
.width = attribs->width, && attribs->offset[0] == 0) {
.height = attribs->height, struct gbm_import_fd_data data = {
.format = attribs->format, .fd = attribs->fd[0],
.num_fds = attribs->n_planes, .width = attribs->width,
.modifier = attribs->modifier, .height = attribs->height,
}; .stride = attribs->stride[0],
.format = attribs->format,
};
if ((size_t)attribs->n_planes > sizeof(data.fds) / sizeof(data.fds[0])) { return gbm_bo_import(renderer->gbm, GBM_BO_IMPORT_FD,
return NULL; &data, GBM_BO_USE_SCANOUT);
} else {
struct gbm_import_fd_modifier_data data = {
.width = attribs->width,
.height = attribs->height,
.format = attribs->format,
.num_fds = attribs->n_planes,
.modifier = attribs->modifier,
};
if ((size_t)attribs->n_planes > sizeof(data.fds) / sizeof(data.fds[0])) {
return NULL;
}
for (size_t i = 0; i < (size_t)attribs->n_planes; ++i) {
data.fds[i] = attribs->fd[i];
data.strides[i] = attribs->stride[i];
data.offsets[i] = attribs->offset[i];
}
return gbm_bo_import(renderer->gbm, GBM_BO_IMPORT_FD_MODIFIER,
&data, GBM_BO_USE_SCANOUT);
} }
for (size_t i = 0; i < (size_t)attribs->n_planes; ++i) {
data.fds[i] = attribs->fd[i];
data.strides[i] = attribs->stride[i];
data.offsets[i] = attribs->offset[i];
}
return gbm_bo_import(renderer->gbm, GBM_BO_IMPORT_FD_MODIFIER,
&data, GBM_BO_USE_SCANOUT);
} }
bool export_drm_bo(struct gbm_bo *bo, struct wlr_dmabuf_attributes *attribs) { bool export_drm_bo(struct gbm_bo *bo, struct wlr_dmabuf_attributes *attribs) {