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.
17 gbm_buffer_base.cc: gbm_bo_get_width(bo),
18 gbm_buffer_base.cc: gbm_bo_get_height(bo),
19 gbm_buffer_base.cc: gbm_bo_get_stride(bo),
20 gbm_buffer_base.cc: gbm_bo_get_handle(bo).u32,
21 gbm_buffer_base.cc: return gbm_bo_get_handle(bo_).u32;
22 gbm_buffer_base.cc: return gfx::Size(gbm_bo_get_width(bo_), gbm_bo_get_height(bo_));
23 gbm_buffer.cc: gbm_bo_destroy(bo());
24 gbm_buffer.cc: gbm_bo* bo = gbm_bo_create(device,
25 gbm_surface.cc: gbm_bo_set_user_data(bo, this, GbmSurfaceBuffer::Destroy);
26 gbm_surface.cc: static_cast<GbmSurfaceBuffer*>(gbm_bo_get_user_data(buffer)));
27 gbm_surface.cc: gbm_surface_release_buffer(native_surface_, current_buffer_);
28 gbm_surface.cc: gbm_surface_destroy(native_surface_);
29 gbm_surface.cc: native_surface_ = gbm_surface_create(
30 gbm_surface.cc: gbm_bo* pending_buffer = gbm_surface_lock_front_buffer(native_surface_);
31 gbm_surface.cc: gbm_surface_release_buffer(native_surface_, current_buffer_);
32 ozone_platform_gbm.cc: device_(gbm_create_device(dri_->get_fd())) {}
33 ozone_platform_gbm.cc: gbm_device_destroy(device_);
36 extern struct gbm_driver gbm_driver_cirrus;
38 extern struct gbm_driver gbm_driver_exynos;
40 extern struct gbm_driver gbm_driver_gma500;
42 extern struct gbm_driver gbm_driver_i915;
45 extern struct gbm_driver gbm_driver_mediatek;
48 extern struct gbm_driver gbm_driver_rockchip;
51 extern struct gbm_driver gbm_driver_tegra;
53 extern struct gbm_driver gbm_driver_udl;
55 static struct gbm_driver *gbm_get_driver(int fd)
57 drmVersionPtr drm_version;
60 drm_version = drmGetVersion(fd);
65 struct gbm_driver *driver_list[] = {
86 for(i = 0; i < ARRAY_SIZE(driver_list); i++)
87 if (!strcmp(drm_version->name, driver_list[i]->name))
89 drmFreeVersion(drm_version);
90 return driver_list[i];
93 drmFreeVersion(drm_version);
98 gbm_device_get_fd(struct gbm_device *gbm)
104 gbm_device_get_backend_name(struct gbm_device *gbm)
106 return gbm->driver->name;
110 gbm_device_is_format_supported(struct gbm_device *gbm,
111 uint32_t format, uint32_t usage)
115 if (format == GBM_BO_FORMAT_XRGB8888)
116 format = GBM_FORMAT_XRGB8888;
117 if (format == GBM_BO_FORMAT_ARGB8888)
118 format = GBM_FORMAT_ARGB8888;
120 if (usage & GBM_BO_USE_CURSOR &&
121 usage & GBM_BO_USE_RENDERING)
124 for(i = 0 ; i < ARRAY_SIZE(gbm->driver->format_list); i++)
126 if (!gbm->driver->format_list[i].format)
129 if (gbm->driver->format_list[i].format == format &&
130 (gbm->driver->format_list[i].usage & usage) == usage)
137 PUBLIC struct gbm_device *gbm_create_device(int fd)
139 struct gbm_device *gbm;
142 gbm = (struct gbm_device*) malloc(sizeof(*gbm));
148 gbm->driver = gbm_get_driver(fd);
154 if (gbm->driver->init) {
155 ret = gbm->driver->init(gbm);
165 PUBLIC void gbm_device_destroy(struct gbm_device *gbm)
167 if (gbm->driver->close)
168 gbm->driver->close(gbm);
172 PUBLIC struct gbm_surface *gbm_surface_create(struct gbm_device *gbm, uint32_t width, uint32_t height, uint32_t format, uint32_t flags)
174 struct gbm_surface *surface = (struct gbm_surface*) malloc(sizeof(*surface));
181 PUBLIC void gbm_surface_destroy(struct gbm_surface *surface)
186 PUBLIC struct gbm_bo *gbm_surface_lock_front_buffer(struct gbm_surface *surface)
191 PUBLIC void gbm_surface_release_buffer(struct gbm_surface *surface, struct gbm_bo *bo)
195 PUBLIC struct gbm_bo *gbm_bo_create(struct gbm_device *gbm, uint32_t width, uint32_t height, uint32_t format, uint32_t flags)
200 bo = (struct gbm_bo*) malloc(sizeof(*bo));
210 bo->destroy_user_data = NULL;
211 bo->user_data = NULL;
213 ret = gbm->driver->bo_create(bo, width, height, format, flags);
222 PUBLIC void gbm_bo_destroy(struct gbm_bo *bo)
224 if (bo->destroy_user_data) {
225 bo->destroy_user_data(bo, bo->user_data);
226 bo->destroy_user_data = NULL;
227 bo->user_data = NULL;
230 bo->gbm->driver->bo_destroy(bo);
235 gbm_bo_get_width(struct gbm_bo *bo)
241 gbm_bo_get_height(struct gbm_bo *bo)
247 gbm_bo_get_stride(struct gbm_bo *bo)
253 gbm_bo_get_stride_or_tiling(struct gbm_bo *bo)
255 return bo->tiling ? bo->tiling : bo->stride;
259 gbm_bo_get_format(struct gbm_bo *bo)
264 PUBLIC struct gbm_device *
265 gbm_bo_get_device(struct gbm_bo *bo)
270 PUBLIC union gbm_bo_handle
271 gbm_bo_get_handle(struct gbm_bo *bo)
277 gbm_bo_get_fd(struct gbm_bo *bo)
281 if (drmPrimeHandleToFD(gbm_device_get_fd(bo->gbm),
282 gbm_bo_get_handle(bo).u32,
291 gbm_bo_set_user_data(struct gbm_bo *bo, void *data,
292 void (*destroy_user_data)(struct gbm_bo *, void *))
294 bo->user_data = data;
295 bo->destroy_user_data = destroy_user_data;
299 gbm_bo_get_user_data(struct gbm_bo *bo)
301 return bo->user_data;