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.
16 extern struct gbm_driver gbm_driver_cirrus;
18 extern struct gbm_driver gbm_driver_exynos;
20 extern struct gbm_driver gbm_driver_gma500;
22 extern struct gbm_driver gbm_driver_i915;
25 extern struct gbm_driver gbm_driver_mediatek;
28 extern struct gbm_driver gbm_driver_rockchip;
31 extern struct gbm_driver gbm_driver_tegra;
33 extern struct gbm_driver gbm_driver_udl;
35 static struct gbm_driver *gbm_get_driver(int fd)
37 drmVersionPtr drm_version;
40 drm_version = drmGetVersion(fd);
45 struct gbm_driver *driver_list[] = {
66 for(i = 0; i < ARRAY_SIZE(driver_list); i++)
67 if (!strcmp(drm_version->name, driver_list[i]->name))
69 drmFreeVersion(drm_version);
70 return driver_list[i];
73 drmFreeVersion(drm_version);
78 gbm_device_get_fd(struct gbm_device *gbm)
84 gbm_device_get_backend_name(struct gbm_device *gbm)
86 return gbm->driver->name;
90 gbm_device_is_format_supported(struct gbm_device *gbm,
91 uint32_t format, uint32_t usage)
95 if (format == GBM_BO_FORMAT_XRGB8888)
96 format = GBM_FORMAT_XRGB8888;
97 if (format == GBM_BO_FORMAT_ARGB8888)
98 format = GBM_FORMAT_ARGB8888;
100 if (usage & GBM_BO_USE_CURSOR &&
101 usage & GBM_BO_USE_RENDERING)
104 for(i = 0 ; i < ARRAY_SIZE(gbm->driver->format_list); i++)
106 if (!gbm->driver->format_list[i].format)
109 if (gbm->driver->format_list[i].format == format &&
110 (gbm->driver->format_list[i].usage & usage) == usage)
117 PUBLIC struct gbm_device *gbm_create_device(int fd)
119 struct gbm_device *gbm;
122 gbm = (struct gbm_device*) malloc(sizeof(*gbm));
128 gbm->driver = gbm_get_driver(fd);
134 if (gbm->driver->init) {
135 ret = gbm->driver->init(gbm);
145 PUBLIC void gbm_device_destroy(struct gbm_device *gbm)
147 if (gbm->driver->close)
148 gbm->driver->close(gbm);
152 PUBLIC struct gbm_surface *gbm_surface_create(struct gbm_device *gbm,
153 uint32_t width, uint32_t height,
154 uint32_t format, uint32_t flags)
156 struct gbm_surface *surface =
157 (struct gbm_surface*) malloc(sizeof(*surface));
165 PUBLIC void gbm_surface_destroy(struct gbm_surface *surface)
170 PUBLIC struct gbm_bo *gbm_surface_lock_front_buffer(struct gbm_surface *surface)
175 PUBLIC void gbm_surface_release_buffer(struct gbm_surface *surface,
180 PUBLIC struct gbm_bo *gbm_bo_create(struct gbm_device *gbm, uint32_t width,
181 uint32_t height, uint32_t format,
187 bo = (struct gbm_bo*) malloc(sizeof(*bo));
197 bo->destroy_user_data = NULL;
198 bo->user_data = NULL;
200 ret = gbm->driver->bo_create(bo, width, height, format, flags);
209 PUBLIC void gbm_bo_destroy(struct gbm_bo *bo)
211 if (bo->destroy_user_data) {
212 bo->destroy_user_data(bo, bo->user_data);
213 bo->destroy_user_data = NULL;
214 bo->user_data = NULL;
217 bo->gbm->driver->bo_destroy(bo);
222 gbm_bo_get_width(struct gbm_bo *bo)
228 gbm_bo_get_height(struct gbm_bo *bo)
234 gbm_bo_get_stride(struct gbm_bo *bo)
240 gbm_bo_get_stride_or_tiling(struct gbm_bo *bo)
242 return bo->tiling ? bo->tiling : bo->stride;
246 gbm_bo_get_format(struct gbm_bo *bo)
251 PUBLIC struct gbm_device *
252 gbm_bo_get_device(struct gbm_bo *bo)
257 PUBLIC union gbm_bo_handle
258 gbm_bo_get_handle(struct gbm_bo *bo)
264 gbm_bo_get_fd(struct gbm_bo *bo)
268 if (drmPrimeHandleToFD(gbm_device_get_fd(bo->gbm),
269 gbm_bo_get_handle(bo).u32,
278 gbm_bo_set_user_data(struct gbm_bo *bo, void *data,
279 void (*destroy_user_data)(struct gbm_bo *, void *))
281 bo->user_data = data;
282 bo->destroy_user_data = destroy_user_data;
286 gbm_bo_get_user_data(struct gbm_bo *bo)
288 return bo->user_data;