2 * Copyright (c) 2014 The Chromium OS Authors. All rights reserved.
3 * Use of this source code is governed by a BSD-style license that can be
4 * found in the LICENSE file.
18 extern struct gbm_driver gbm_driver_cirrus;
19 extern struct gbm_driver gbm_driver_evdi;
21 extern struct gbm_driver gbm_driver_exynos;
23 extern struct gbm_driver gbm_driver_gma500;
25 extern struct gbm_driver gbm_driver_i915;
28 extern struct gbm_driver gbm_driver_marvell;
31 extern struct gbm_driver gbm_driver_mediatek;
34 extern struct gbm_driver gbm_driver_rockchip;
37 extern struct gbm_driver gbm_driver_tegra;
39 extern struct gbm_driver gbm_driver_udl;
41 static struct gbm_driver *gbm_get_driver(int fd)
43 drmVersionPtr drm_version;
46 drm_version = drmGetVersion(fd);
51 struct gbm_driver *driver_list[] = {
76 for(i = 0; i < ARRAY_SIZE(driver_list); i++)
77 if (!strcmp(drm_version->name, driver_list[i]->name))
79 drmFreeVersion(drm_version);
80 return driver_list[i];
83 drmFreeVersion(drm_version);
88 gbm_device_get_fd(struct gbm_device *gbm)
94 gbm_device_get_backend_name(struct gbm_device *gbm)
96 return gbm->driver->name;
100 gbm_device_is_format_supported(struct gbm_device *gbm,
101 uint32_t format, uint32_t usage)
105 if (format == GBM_BO_FORMAT_XRGB8888)
106 format = GBM_FORMAT_XRGB8888;
107 if (format == GBM_BO_FORMAT_ARGB8888)
108 format = GBM_FORMAT_ARGB8888;
110 if (usage & GBM_BO_USE_CURSOR &&
111 usage & GBM_BO_USE_RENDERING)
114 for(i = 0 ; i < ARRAY_SIZE(gbm->driver->format_list); i++)
116 if (!gbm->driver->format_list[i].format)
119 if (gbm->driver->format_list[i].format == format &&
120 (gbm->driver->format_list[i].usage & usage) == usage)
127 PUBLIC struct gbm_device *gbm_create_device(int fd)
129 struct gbm_device *gbm;
132 gbm = (struct gbm_device*) malloc(sizeof(*gbm));
138 gbm->driver = gbm_get_driver(fd);
144 if (gbm->driver->init) {
145 ret = gbm->driver->init(gbm);
155 PUBLIC void gbm_device_destroy(struct gbm_device *gbm)
157 if (gbm->driver->close)
158 gbm->driver->close(gbm);
162 PUBLIC struct gbm_surface *gbm_surface_create(struct gbm_device *gbm,
163 uint32_t width, uint32_t height,
164 uint32_t format, uint32_t flags)
166 struct gbm_surface *surface =
167 (struct gbm_surface*) malloc(sizeof(*surface));
175 PUBLIC void gbm_surface_destroy(struct gbm_surface *surface)
180 PUBLIC struct gbm_bo *gbm_surface_lock_front_buffer(struct gbm_surface *surface)
185 PUBLIC void gbm_surface_release_buffer(struct gbm_surface *surface,
190 static struct gbm_bo *gbm_bo_new(struct gbm_device *gbm,
191 uint32_t width, uint32_t height,
192 uint32_t format, uint32_t stride)
196 bo = (struct gbm_bo*) malloc(sizeof(*bo));
206 bo->destroy_user_data = NULL;
207 bo->user_data = NULL;
212 PUBLIC struct gbm_bo *gbm_bo_create(struct gbm_device *gbm, uint32_t width,
213 uint32_t height, uint32_t format,
219 bo = gbm_bo_new(gbm, width, height, format,
220 width * gbm_bytes_from_format(format));
224 ret = gbm->driver->bo_create(bo, width, height, format, flags);
233 PUBLIC void gbm_bo_destroy(struct gbm_bo *bo)
235 if (bo->destroy_user_data) {
236 bo->destroy_user_data(bo, bo->user_data);
237 bo->destroy_user_data = NULL;
238 bo->user_data = NULL;
241 bo->gbm->driver->bo_destroy(bo);
245 PUBLIC struct gbm_bo *
246 gbm_bo_import(struct gbm_device *gbm, uint32_t type,
247 void *buffer, uint32_t usage)
249 struct gbm_import_fd_data *fd_data = buffer;
251 struct drm_prime_handle prime_handle;
254 if (type != GBM_BO_IMPORT_FD)
257 if (!gbm_device_is_format_supported(gbm, fd_data->format, usage))
260 bo = gbm_bo_new(gbm, fd_data->width, fd_data->height, fd_data->format,
265 prime_handle.fd = fd_data->fd;
267 ret = drmIoctl(bo->gbm->fd, DRM_IOCTL_PRIME_FD_TO_HANDLE, &prime_handle);
269 fprintf(stderr, "minigbm: DRM_IOCTL_PRIME_FD_TO_HANDLE failed "
270 "(fd=%u)\n", prime_handle.fd);
275 bo->handle.u32 = prime_handle.handle;
281 gbm_bo_get_width(struct gbm_bo *bo)
287 gbm_bo_get_height(struct gbm_bo *bo)
293 gbm_bo_get_stride(struct gbm_bo *bo)
299 gbm_bo_get_stride_or_tiling(struct gbm_bo *bo)
301 return bo->tiling ? bo->tiling : bo->stride;
305 gbm_bo_get_format(struct gbm_bo *bo)
310 PUBLIC struct gbm_device *
311 gbm_bo_get_device(struct gbm_bo *bo)
316 PUBLIC union gbm_bo_handle
317 gbm_bo_get_handle(struct gbm_bo *bo)
323 gbm_bo_get_fd(struct gbm_bo *bo)
327 if (drmPrimeHandleToFD(gbm_device_get_fd(bo->gbm),
328 gbm_bo_get_handle(bo).u32,
337 gbm_bo_set_user_data(struct gbm_bo *bo, void *data,
338 void (*destroy_user_data)(struct gbm_bo *, void *))
340 bo->user_data = data;
341 bo->destroy_user_data = destroy_user_data;
345 gbm_bo_get_user_data(struct gbm_bo *bo)
347 return bo->user_data;