blob: 6b013154911dcd1e6a26d831bd5fc0e2f28c0b33 [file] [log] [blame]
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +02001#ifndef __DRM_GEM_FB_HELPER_H__
2#define __DRM_GEM_FB_HELPER_H__
3
Andrzej Pietrasiewicz55f7f722020-03-11 15:55:37 +01004struct drm_afbc_framebuffer;
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +02005struct drm_device;
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +02006struct drm_fb_helper_surface_size;
Noralf Trønnesa5ea8a62017-09-11 18:37:45 +02007struct drm_file;
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +02008struct drm_framebuffer;
9struct drm_framebuffer_funcs;
10struct drm_gem_object;
11struct drm_mode_fb_cmd2;
12struct drm_plane;
13struct drm_plane_state;
Daniel Vetterccc3b2b2018-04-05 17:44:42 +020014struct drm_simple_display_pipe;
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +020015
Andrzej Pietrasiewicz55f7f722020-03-11 15:55:37 +010016#define AFBC_VENDOR_AND_TYPE_MASK GENMASK_ULL(63, 52)
17
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +020018struct drm_gem_object *drm_gem_fb_get_obj(struct drm_framebuffer *fb,
19 unsigned int plane);
20void drm_gem_fb_destroy(struct drm_framebuffer *fb);
21int drm_gem_fb_create_handle(struct drm_framebuffer *fb, struct drm_file *file,
22 unsigned int *handle);
23
Andrzej Pietrasiewiczf2b816d2020-03-11 15:55:36 +010024int drm_gem_fb_init_with_funcs(struct drm_device *dev,
25 struct drm_framebuffer *fb,
26 struct drm_file *file,
27 const struct drm_mode_fb_cmd2 *mode_cmd,
28 const struct drm_framebuffer_funcs *funcs);
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +020029struct drm_framebuffer *
30drm_gem_fb_create_with_funcs(struct drm_device *dev, struct drm_file *file,
31 const struct drm_mode_fb_cmd2 *mode_cmd,
32 const struct drm_framebuffer_funcs *funcs);
33struct drm_framebuffer *
34drm_gem_fb_create(struct drm_device *dev, struct drm_file *file,
35 const struct drm_mode_fb_cmd2 *mode_cmd);
Noralf Trønnesdbd62e12019-01-15 05:36:39 +010036struct drm_framebuffer *
37drm_gem_fb_create_with_dirty(struct drm_device *dev, struct drm_file *file,
38 const struct drm_mode_fb_cmd2 *mode_cmd);
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +020039
Andrzej Pietrasiewicz55f7f722020-03-11 15:55:37 +010040#define drm_is_afbc(modifier) \
41 (((modifier) & AFBC_VENDOR_AND_TYPE_MASK) == DRM_FORMAT_MOD_ARM_AFBC(0))
42
43int drm_gem_fb_afbc_init(struct drm_device *dev,
44 const struct drm_mode_fb_cmd2 *mode_cmd,
45 struct drm_afbc_framebuffer *afbc_fb);
46
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +020047int drm_gem_fb_prepare_fb(struct drm_plane *plane,
48 struct drm_plane_state *state);
Daniel Vetterccc3b2b2018-04-05 17:44:42 +020049int drm_gem_fb_simple_display_pipe_prepare_fb(struct drm_simple_display_pipe *pipe,
50 struct drm_plane_state *plane_state);
Noralf Trønnes4c3dbb22017-08-13 15:31:44 +020051#endif