blob: 6d3aa1f83757efba989072dd052adf127dc9d4e1 [file] [log] [blame]
Chia-I Wu2ec32d42011-06-12 16:21:30 +08001/*
2 * Copyright (C) 2010-2011 Chia-I Wu <olvaffe@gmail.com>
3 * Copyright (C) 2010-2011 LunarG Inc.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice shall be included
13 * in all copies or substantial portions of the Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
22 */
23
24#ifndef _GRALLOC_DRM_H_
25#define _GRALLOC_DRM_H_
26
27#include <hardware/gralloc.h>
28
29struct gralloc_drm_t;
30struct gralloc_drm_bo_t;
31
32struct gralloc_drm_t *gralloc_drm_create(void);
33void gralloc_drm_destroy(struct gralloc_drm_t *drm);
34
35int gralloc_drm_get_fd(struct gralloc_drm_t *drm);
36int gralloc_drm_get_magic(struct gralloc_drm_t *drm, int32_t *magic);
37int gralloc_drm_auth_magic(struct gralloc_drm_t *drm, int32_t magic);
38int gralloc_drm_set_master(struct gralloc_drm_t *drm);
39void gralloc_drm_drop_master(struct gralloc_drm_t *drm);
40
41int gralloc_drm_init_kms(struct gralloc_drm_t *drm);
Chia-I Wud5c39c92011-07-31 17:09:11 +090042void gralloc_drm_fini_kms(struct gralloc_drm_t *drm);
43int gralloc_drm_is_kms_initialized(struct gralloc_drm_t *drm);
44
Chia-I Wu2ec32d42011-06-12 16:21:30 +080045void gralloc_drm_get_kms_info(struct gralloc_drm_t *drm, struct framebuffer_device_t *fb);
46int gralloc_drm_is_kms_pipelined(struct gralloc_drm_t *drm);
47
48static inline int gralloc_drm_get_bpp(int format)
49{
50 int bpp;
51
52 switch (format) {
53 case HAL_PIXEL_FORMAT_RGBA_8888:
54 case HAL_PIXEL_FORMAT_RGBX_8888:
55 case HAL_PIXEL_FORMAT_BGRA_8888:
56 bpp = 4;
57 break;
58 case HAL_PIXEL_FORMAT_RGB_888:
59 bpp = 3;
60 break;
61 case HAL_PIXEL_FORMAT_RGB_565:
62 case HAL_PIXEL_FORMAT_RGBA_5551:
63 case HAL_PIXEL_FORMAT_RGBA_4444:
64 bpp = 2;
65 break;
66 default:
67 bpp = 0;
68 break;
69 }
70
71 return bpp;
72}
73
74struct gralloc_drm_bo_t *gralloc_drm_bo_create(struct gralloc_drm_t *drm, int width, int height, int format, int usage);
Chia-I Wu2ec32d42011-06-12 16:21:30 +080075void gralloc_drm_bo_destroy(struct gralloc_drm_bo_t *bo);
76
Chia-I Wu2fc5da42011-07-29 19:57:04 +090077struct gralloc_drm_bo_t *gralloc_drm_bo_register(struct gralloc_drm_t *drm, buffer_handle_t handle, int create);
78void gralloc_drm_bo_unregister(struct gralloc_drm_bo_t *bo);
79
80static inline struct gralloc_drm_bo_t *gralloc_drm_bo_validate(struct gralloc_drm_t *drm, buffer_handle_t handle)
81{
82 return gralloc_drm_bo_register(drm, handle, 0);
83}
84
Chia-I Wu25e04132011-07-29 20:43:12 +090085int gralloc_drm_bo_lock(struct gralloc_drm_bo_t *bo, int x, int y, int w, int h, int enable_write, void **addr);
86void gralloc_drm_bo_unlock(struct gralloc_drm_bo_t *bo);
Chia-I Wu2ec32d42011-06-12 16:21:30 +080087buffer_handle_t gralloc_drm_bo_get_handle(struct gralloc_drm_bo_t *bo, int *stride);
88
89int gralloc_drm_bo_need_fb(const struct gralloc_drm_bo_t *bo);
90int gralloc_drm_bo_add_fb(struct gralloc_drm_bo_t *bo);
91void gralloc_drm_bo_rm_fb(struct gralloc_drm_bo_t *bo);
92int gralloc_drm_bo_post(struct gralloc_drm_bo_t *bo);
93
94#endif /* _GRALLOC_DRM_H_ */