blob: b06e438c4efb9202a1514992c4ff49aeaf6be132 [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>
Tapani Pälli45a94512012-12-14 10:43:39 +020028#include "gralloc_drm_formats.h"
Chia-I Wu2ec32d42011-06-12 16:21:30 +080029
30struct gralloc_drm_t;
31struct gralloc_drm_bo_t;
32
33struct gralloc_drm_t *gralloc_drm_create(void);
34void gralloc_drm_destroy(struct gralloc_drm_t *drm);
35
36int gralloc_drm_get_fd(struct gralloc_drm_t *drm);
37int gralloc_drm_get_magic(struct gralloc_drm_t *drm, int32_t *magic);
38int gralloc_drm_auth_magic(struct gralloc_drm_t *drm, int32_t magic);
39int gralloc_drm_set_master(struct gralloc_drm_t *drm);
40void gralloc_drm_drop_master(struct gralloc_drm_t *drm);
41
42int gralloc_drm_init_kms(struct gralloc_drm_t *drm);
Chia-I Wud5c39c92011-07-31 17:09:11 +090043void gralloc_drm_fini_kms(struct gralloc_drm_t *drm);
44int gralloc_drm_is_kms_initialized(struct gralloc_drm_t *drm);
45
Chia-I Wu2ec32d42011-06-12 16:21:30 +080046void gralloc_drm_get_kms_info(struct gralloc_drm_t *drm, struct framebuffer_device_t *fb);
47int gralloc_drm_is_kms_pipelined(struct gralloc_drm_t *drm);
48
49static inline int gralloc_drm_get_bpp(int format)
50{
51 int bpp;
52
53 switch (format) {
54 case HAL_PIXEL_FORMAT_RGBA_8888:
55 case HAL_PIXEL_FORMAT_RGBX_8888:
56 case HAL_PIXEL_FORMAT_BGRA_8888:
57 bpp = 4;
58 break;
59 case HAL_PIXEL_FORMAT_RGB_888:
60 bpp = 3;
61 break;
62 case HAL_PIXEL_FORMAT_RGB_565:
63 case HAL_PIXEL_FORMAT_RGBA_5551:
64 case HAL_PIXEL_FORMAT_RGBA_4444:
Chia-I Wub65a3f82011-10-27 18:01:23 +080065 case HAL_PIXEL_FORMAT_YCbCr_422_I:
Chia-I Wu2ec32d42011-06-12 16:21:30 +080066 bpp = 2;
67 break;
Chia-I Wub65a3f82011-10-27 18:01:23 +080068 /* planar; only Y is considered */
69 case HAL_PIXEL_FORMAT_YV12:
Tapani Pälli45a94512012-12-14 10:43:39 +020070 case HAL_PIXEL_FORMAT_DRM_NV12:
Chia-I Wub65a3f82011-10-27 18:01:23 +080071 case HAL_PIXEL_FORMAT_YCbCr_422_SP:
72 case HAL_PIXEL_FORMAT_YCrCb_420_SP:
73 bpp = 1;
74 break;
Chia-I Wu2ec32d42011-06-12 16:21:30 +080075 default:
76 bpp = 0;
77 break;
78 }
79
80 return bpp;
81}
82
Chia-I Wub65a3f82011-10-27 18:01:23 +080083static inline void gralloc_drm_align_geometry(int format, int *width, int *height)
84{
85 int align_w = 1, align_h = 1, extra_height_div = 0;
86
87 switch (format) {
Tapani Pälli45a94512012-12-14 10:43:39 +020088 case HAL_PIXEL_FORMAT_DRM_NV12:
Chia-I Wub65a3f82011-10-27 18:01:23 +080089 case HAL_PIXEL_FORMAT_YV12:
90 align_w = 32;
91 align_h = 2;
92 extra_height_div = 2;
93 break;
94 case HAL_PIXEL_FORMAT_YCbCr_422_SP:
95 align_w = 2;
96 extra_height_div = 1;
97 break;
98 case HAL_PIXEL_FORMAT_YCrCb_420_SP:
99 align_w = 2;
100 align_h = 2;
101 extra_height_div = 2;
102 break;
103 case HAL_PIXEL_FORMAT_YCbCr_422_I:
104 align_w = 2;
105 break;
106 }
107
108 *width = (*width + align_w - 1) & ~(align_w - 1);
109 *height = (*height + align_h - 1) & ~(align_h - 1);
110
111 if (extra_height_div)
112 *height += *height / extra_height_div;
113}
114
Chia-I Wu8542de32011-07-31 16:35:21 +0900115int gralloc_drm_handle_register(buffer_handle_t handle, struct gralloc_drm_t *drm);
116int gralloc_drm_handle_unregister(buffer_handle_t handle);
117
Chia-I Wu2ec32d42011-06-12 16:21:30 +0800118struct gralloc_drm_bo_t *gralloc_drm_bo_create(struct gralloc_drm_t *drm, int width, int height, int format, int usage);
Tapani Pällia86ecd92012-08-01 16:06:00 +0300119void gralloc_drm_bo_decref(struct gralloc_drm_bo_t *bo);
Chia-I Wu2ec32d42011-06-12 16:21:30 +0800120
Chia-I Wu8542de32011-07-31 16:35:21 +0900121struct gralloc_drm_bo_t *gralloc_drm_bo_from_handle(buffer_handle_t handle);
122buffer_handle_t gralloc_drm_bo_get_handle(struct gralloc_drm_bo_t *bo, int *stride);
Tapani Pälli421d4ec2013-01-15 13:58:57 +0200123int gralloc_drm_get_gem_handle(buffer_handle_t handle);
Tapani Pällia8f03342013-01-18 15:01:43 +0200124void gralloc_drm_resolve_format(buffer_handle_t _handle, uint32_t *pitches, uint32_t *offsets, uint32_t *handles);
Chia-I Wu2fc5da42011-07-29 19:57:04 +0900125
Chia-I Wu25e04132011-07-29 20:43:12 +0900126int gralloc_drm_bo_lock(struct gralloc_drm_bo_t *bo, int x, int y, int w, int h, int enable_write, void **addr);
127void gralloc_drm_bo_unlock(struct gralloc_drm_bo_t *bo);
Chia-I Wu2ec32d42011-06-12 16:21:30 +0800128
129int gralloc_drm_bo_need_fb(const struct gralloc_drm_bo_t *bo);
130int gralloc_drm_bo_add_fb(struct gralloc_drm_bo_t *bo);
131void gralloc_drm_bo_rm_fb(struct gralloc_drm_bo_t *bo);
132int gralloc_drm_bo_post(struct gralloc_drm_bo_t *bo);
133
134#endif /* _GRALLOC_DRM_H_ */