blob: e016e1ea5b4e0471cf6627782603e72d0475c4e8 [file] [log] [blame]
/* 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 YUVCONVERSIONMODE_MASK GENMASK(18, 17)
#define YUVCONVERSIONMODE(x) FIELD_PREP(YUVCONVERSIONMODE_MASK, (x))
#define SOURCEBUFFERENABLE BIT(31)
/* FRAMEDIMENSIONS */
#define FRAMEWIDTH(x) FIELD_PREP(GENMASK(13, 0), (x))
#define FRAMEHEIGHT(x) FIELD_PREP(GENMASK(29, 16), (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__ */