root/drivers/gpu/drm/imx/dc/dc-fu.h
/* SPDX-License-Identifier: GPL-2.0+ */
/*
 * Copyright 2024 NXP
 */

#ifndef __DC_FETCHUNIT_H__
#define __DC_FETCHUNIT_H__

#include <linux/bitfield.h>
#include <linux/bits.h>
#include <linux/regmap.h>
#include <linux/types.h>

#include <drm/drm_fourcc.h>

#include "dc-pe.h"

#define FRAC_OFFSET                     0x28

#define STATICCONTROL                   0x8
#define BURSTBUFFERMANAGEMENT           0xc

/* COLORCOMPONENTBITS */
#define R_BITS(x)                       FIELD_PREP_CONST(GENMASK(27, 24), (x))
#define G_BITS(x)                       FIELD_PREP_CONST(GENMASK(19, 16), (x))
#define B_BITS(x)                       FIELD_PREP_CONST(GENMASK(11, 8), (x))
#define A_BITS(x)                       FIELD_PREP_CONST(GENMASK(3, 0), (x))

/* COLORCOMPONENTSHIFT */
#define R_SHIFT(x)                      FIELD_PREP_CONST(GENMASK(28, 24), (x))
#define G_SHIFT(x)                      FIELD_PREP_CONST(GENMASK(20, 16), (x))
#define B_SHIFT(x)                      FIELD_PREP_CONST(GENMASK(12, 8), (x))
#define A_SHIFT(x)                      FIELD_PREP_CONST(GENMASK(4, 0), (x))

/* LAYERPROPERTY */
#define SOURCEBUFFERENABLE              BIT(31)
#define YUVCONVERSIONMODE_MASK          GENMASK(18, 17)
#define YUVCONVERSIONMODE(x)            FIELD_PREP(YUVCONVERSIONMODE_MASK, (x))

/* FRAMEDIMENSIONS */
#define FRAMEHEIGHT(x)                  FIELD_PREP(GENMASK(29, 16), (x))
#define FRAMEWIDTH(x)                   FIELD_PREP(GENMASK(13, 0), (x))

/* CONTROL */
#define INPUTSELECT_MASK                GENMASK(4, 3)
#define INPUTSELECT(x)                  FIELD_PREP(INPUTSELECT_MASK, (x))
#define RASTERMODE_MASK                 GENMASK(2, 0)
#define RASTERMODE(x)                   FIELD_PREP(RASTERMODE_MASK, (x))

enum dc_yuvconversionmode {
        YUVCONVERSIONMODE_OFF,
};

enum dc_inputselect {
        INPUTSELECT_INACTIVE,
};

enum dc_rastermode {
        RASTERMODE_NORMAL,
};

enum {
        DC_FETCHUNIT_FL0,
        DC_FETCHUNIT_FW2,
};

enum dc_fu_frac {
        DC_FETCHUNIT_FRAC0,
        DC_FETCHUNIT_FRAC1,
        DC_FETCHUNIT_FRAC2,
        DC_FETCHUNIT_FRAC3,
        DC_FETCHUNIT_FRAC4,
        DC_FETCHUNIT_FRAC5,
        DC_FETCHUNIT_FRAC6,
        DC_FETCHUNIT_FRAC7,
        DC_FETCHUNIT_FRAC_NUM
};

struct dc_fu;
struct dc_lb;

struct dc_fu_ops {
        void (*init)(struct dc_fu *fu);
        void (*set_burstlength)(struct dc_fu *fu, dma_addr_t baddr);
        void (*set_baseaddress)(struct dc_fu *fu, enum dc_fu_frac frac,
                                dma_addr_t baddr);
        void (*set_src_stride)(struct dc_fu *fu, enum dc_fu_frac frac,
                               unsigned int stride);
        void (*set_src_buf_dimensions)(struct dc_fu *fu, enum dc_fu_frac frac,
                                       int w, int h);
        void (*set_fmt)(struct dc_fu *fu, enum dc_fu_frac frac,
                        const struct drm_format_info *format);
        void (*enable_src_buf)(struct dc_fu *fu, enum dc_fu_frac frac);
        void (*disable_src_buf)(struct dc_fu *fu, enum dc_fu_frac frac);
        void (*set_framedimensions)(struct dc_fu *fu, int w, int h);
        void (*set_layerblend)(struct dc_fu *fu, struct dc_lb *lb);
        enum dc_link_id (*get_link_id)(struct dc_fu *fu);
        const char *(*get_name)(struct dc_fu *fu);
};

struct dc_fu {
        struct regmap *reg_pec;
        struct regmap *reg_cfg;
        char name[21];
        u32 reg_baseaddr[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_sourcebufferattributes[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_sourcebufferdimension[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_layeroffset[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_clipwindowoffset[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_clipwindowdimensions[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_constantcolor[DC_FETCHUNIT_FRAC_NUM];
        u32 reg_layerproperty[DC_FETCHUNIT_FRAC_NUM];
        unsigned int id;
        enum dc_link_id link_id;
        struct dc_fu_ops ops;
        struct dc_lb *lb;
};

extern const struct dc_fu_ops dc_fu_common_ops;

void dc_fu_get_pixel_format_bits(struct dc_fu *fu, u32 format, u32 *bits);
void dc_fu_get_pixel_format_shifts(struct dc_fu *fu, u32 format, u32 *shifts);
void dc_fu_shdldreq_sticky(struct dc_fu *fu, u8 layer_mask);
void dc_fu_set_src_bpp(struct dc_fu *fu, enum dc_fu_frac frac, unsigned int bpp);
void dc_fu_common_hw_init(struct dc_fu *fu);

const struct dc_fu_ops *dc_fu_get_ops(struct dc_fu *fu);

#endif /* __DC_FETCHUNIT_H__ */