162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0+ */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2019 BayLibre, SAS 462306a36Sopenharmony_ci * Author: Neil Armstrong <narmstrong@baylibre.com> 562306a36Sopenharmony_ci */ 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#ifndef __MESON_OSD_AFBCD_H 862306a36Sopenharmony_ci#define __MESON_OSD_AFBCD_H 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include "meson_drv.h" 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci/* This is an internal address used to transfer pixel from AFBC to the VIU */ 1362306a36Sopenharmony_ci#define MESON_G12A_AFBCD_OUT_ADDR 0x1000000 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_cistruct meson_afbcd_ops { 1662306a36Sopenharmony_ci int (*init)(struct meson_drm *priv); 1762306a36Sopenharmony_ci void (*exit)(struct meson_drm *priv); 1862306a36Sopenharmony_ci int (*reset)(struct meson_drm *priv); 1962306a36Sopenharmony_ci int (*enable)(struct meson_drm *priv); 2062306a36Sopenharmony_ci int (*disable)(struct meson_drm *priv); 2162306a36Sopenharmony_ci int (*setup)(struct meson_drm *priv); 2262306a36Sopenharmony_ci int (*fmt_to_blk_mode)(u64 modifier, uint32_t format); 2362306a36Sopenharmony_ci bool (*supported_fmt)(u64 modifier, uint32_t format); 2462306a36Sopenharmony_ci}; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ciextern struct meson_afbcd_ops meson_afbcd_gxm_ops; 2762306a36Sopenharmony_ciextern struct meson_afbcd_ops meson_afbcd_g12a_ops; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci#endif /* __MESON_OSD_AFBCD_H */ 30