4cd24d4b1a
Pass an instance of struct drm_format_conv_state to DRM's format conversion helpers. Update all callers. Most drivers can use the format-conversion state from their shadow- plane state. The shadow plane's destroy function releases the allocated buffer. Drivers will later be able to allocate a buffer of appropriate size in their plane's atomic_check code. The gud driver uses a separate thread for committing updates. For now, the update worker contains its own format-conversion state. Images in the format-helper tests are small. The tests preallocate a static page for the temporary buffer. Unloading the module releases the memory. v6: * update patch for ssd132x support v5: * avoid using unusupported shadow-plane state in repaper (Noralf) * fix documentation (Noralf, kernel test robot) v3: * store buffer in shadow-plane state (Javier, Maxime) * replace ARRAY_SIZE() with sizeof() (Jani) Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Reviewed-by: Javier Martinez Canillas <javierm@redhat.com> Tested-by: Javier Martinez Canillas <javierm@redhat.com> # ssd130x Cc: Noralf Trønnes <noralf@tronnes.org> Cc: Javier Martinez Canillas <javierm@redhat.com> Cc: Gerd Hoffmann <kraxel@redhat.com> Cc: David Lechner <david@lechnology.com> Link: https://patchwork.freedesktop.org/patch/msgid/20231009141018.11291-4-tzimmermann@suse.de
126 lines
5.3 KiB
C
126 lines
5.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Copyright (C) 2016 Noralf Trønnes
|
|
*/
|
|
|
|
#ifndef __LINUX_DRM_FORMAT_HELPER_H
|
|
#define __LINUX_DRM_FORMAT_HELPER_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
struct drm_device;
|
|
struct drm_format_info;
|
|
struct drm_framebuffer;
|
|
struct drm_rect;
|
|
|
|
struct iosys_map;
|
|
|
|
/**
|
|
* struct drm_format_conv_state - Stores format-conversion state
|
|
*
|
|
* DRM helpers for format conversion store temporary state in
|
|
* struct drm_xfrm_buf. The buffer's resources can be reused
|
|
* among multiple conversion operations.
|
|
*
|
|
* All fields are considered private.
|
|
*/
|
|
struct drm_format_conv_state {
|
|
struct {
|
|
void *mem;
|
|
size_t size;
|
|
bool preallocated;
|
|
} tmp;
|
|
};
|
|
|
|
#define __DRM_FORMAT_CONV_STATE_INIT(_mem, _size, _preallocated) { \
|
|
.tmp = { \
|
|
.mem = (_mem), \
|
|
.size = (_size), \
|
|
.preallocated = (_preallocated), \
|
|
} \
|
|
}
|
|
|
|
/**
|
|
* DRM_FORMAT_CONV_STATE_INIT - Initializer for struct drm_format_conv_state
|
|
*
|
|
* Initializes an instance of struct drm_format_conv_state to default values.
|
|
*/
|
|
#define DRM_FORMAT_CONV_STATE_INIT \
|
|
__DRM_FORMAT_CONV_STATE_INIT(NULL, 0, false)
|
|
|
|
/**
|
|
* DRM_FORMAT_CONV_STATE_INIT_PREALLOCATED - Initializer for struct drm_format_conv_state
|
|
* @_mem: The preallocated memory area
|
|
* @_size: The number of bytes in _mem
|
|
*
|
|
* Initializes an instance of struct drm_format_conv_state to preallocated
|
|
* storage. The caller is responsible for releasing the provided memory range.
|
|
*/
|
|
#define DRM_FORMAT_CONV_STATE_INIT_PREALLOCATED(_mem, _size) \
|
|
__DRM_FORMAT_CONV_STATE_INIT(_mem, _size, true)
|
|
|
|
void drm_format_conv_state_init(struct drm_format_conv_state *state);
|
|
void drm_format_conv_state_copy(struct drm_format_conv_state *state,
|
|
const struct drm_format_conv_state *old_state);
|
|
void *drm_format_conv_state_reserve(struct drm_format_conv_state *state,
|
|
size_t new_size, gfp_t flags);
|
|
void drm_format_conv_state_release(struct drm_format_conv_state *state);
|
|
|
|
unsigned int drm_fb_clip_offset(unsigned int pitch, const struct drm_format_info *format,
|
|
const struct drm_rect *clip);
|
|
|
|
void drm_fb_memcpy(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip);
|
|
void drm_fb_swab(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, bool cached,
|
|
struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_rgb332(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_rgb565(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state,
|
|
bool swab);
|
|
void drm_fb_xrgb8888_to_xrgb1555(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_argb1555(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_rgba5551(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_rgb888(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_argb8888(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_xrgb2101010(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip,
|
|
struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_argb2101010(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip,
|
|
struct drm_format_conv_state *state);
|
|
void drm_fb_xrgb8888_to_gray8(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
|
|
int drm_fb_blit(struct iosys_map *dst, const unsigned int *dst_pitch, uint32_t dst_format,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
|
|
void drm_fb_xrgb8888_to_mono(struct iosys_map *dst, const unsigned int *dst_pitch,
|
|
const struct iosys_map *src, const struct drm_framebuffer *fb,
|
|
const struct drm_rect *clip, struct drm_format_conv_state *state);
|
|
|
|
size_t drm_fb_build_fourcc_list(struct drm_device *dev,
|
|
const u32 *native_fourccs, size_t native_nfourccs,
|
|
u32 *fourccs_out, size_t nfourccs_out);
|
|
|
|
#endif /* __LINUX_DRM_FORMAT_HELPER_H */
|