root/sys/dev/pci/drm/i915/display/intel_cursor_regs.h
/* SPDX-License-Identifier: MIT */
/*
 * Copyright © 2024 Intel Corporation
 */

#ifndef __INTEL_CURSOR_REGS_H__
#define __INTEL_CURSOR_REGS_H__

#include "intel_display_reg_defs.h"

#define _CURACNTR               0x70080
#define CURCNTR(dev_priv, pipe) _MMIO_CURSOR2((dev_priv), (pipe), _CURACNTR)
/* Old style CUR*CNTR flags (desktop 8xx) */
#define   CURSOR_ENABLE                 REG_BIT(31)
#define   CURSOR_PIPE_GAMMA_ENABLE      REG_BIT(30)
#define   CURSOR_STRIDE_MASK    REG_GENMASK(29, 28)
#define   CURSOR_STRIDE(stride) REG_FIELD_PREP(CURSOR_STRIDE_MASK, ffs(stride) - 9) /* 256,512,1k,2k */
#define   CURSOR_FORMAT_MASK    REG_GENMASK(26, 24)
#define   CURSOR_FORMAT_2C      REG_FIELD_PREP(CURSOR_FORMAT_MASK, 0)
#define   CURSOR_FORMAT_3C      REG_FIELD_PREP(CURSOR_FORMAT_MASK, 1)
#define   CURSOR_FORMAT_4C      REG_FIELD_PREP(CURSOR_FORMAT_MASK, 2)
#define   CURSOR_FORMAT_ARGB    REG_FIELD_PREP(CURSOR_FORMAT_MASK, 4)
#define   CURSOR_FORMAT_XRGB    REG_FIELD_PREP(CURSOR_FORMAT_MASK, 5)
/* New style CUR*CNTR flags */
#define   MCURSOR_ARB_SLOTS_MASK        REG_GENMASK(30, 28) /* icl+ */
#define   MCURSOR_ARB_SLOTS(x)          REG_FIELD_PREP(MCURSOR_ARB_SLOTS_MASK, (x)) /* icl+ */
#define   MCURSOR_PIPE_SEL_MASK         REG_GENMASK(29, 28)
#define   MCURSOR_PIPE_SEL(pipe)        REG_FIELD_PREP(MCURSOR_PIPE_SEL_MASK, (pipe))
#define   MCURSOR_PIPE_GAMMA_ENABLE     REG_BIT(26)
#define   MCURSOR_PIPE_CSC_ENABLE       REG_BIT(24) /* ilk+ */
#define   MCURSOR_ROTATE_180            REG_BIT(15)
#define   MCURSOR_TRICKLE_FEED_DISABLE  REG_BIT(14)
#define   MCURSOR_MODE_MASK             0x27
#define   MCURSOR_MODE_DISABLE          0x00
#define   MCURSOR_MODE_128_32B_AX       0x02
#define   MCURSOR_MODE_256_32B_AX       0x03
#define   MCURSOR_MODE_64_2B            0x04
#define   MCURSOR_MODE_64_32B_AX        0x07
#define   MCURSOR_MODE_128_ARGB_AX      (0x20 | MCURSOR_MODE_128_32B_AX)
#define   MCURSOR_MODE_256_ARGB_AX      (0x20 | MCURSOR_MODE_256_32B_AX)
#define   MCURSOR_MODE_64_ARGB_AX       (0x20 | MCURSOR_MODE_64_32B_AX)

#define _CURABASE               0x70084
#define CURBASE(dev_priv, pipe) _MMIO_CURSOR2((dev_priv), (pipe), _CURABASE)

#define _CURAPOS                0x70088
#define CURPOS(dev_priv, pipe)  _MMIO_CURSOR2((dev_priv), (pipe), _CURAPOS)
#define   CURSOR_POS_Y_SIGN             REG_BIT(31)
#define   CURSOR_POS_Y_MASK             REG_GENMASK(30, 16)
#define   CURSOR_POS_Y(y)               REG_FIELD_PREP(CURSOR_POS_Y_MASK, (y))
#define   CURSOR_POS_X_SIGN             REG_BIT(15)
#define   CURSOR_POS_X_MASK             REG_GENMASK(14, 0)
#define   CURSOR_POS_X(x)               REG_FIELD_PREP(CURSOR_POS_X_MASK, (x))

#define _CURAPOS_ERLY_TPT       0x7008c
#define CURPOS_ERLY_TPT(dev_priv, pipe) _MMIO_CURSOR2((dev_priv), (pipe), _CURAPOS_ERLY_TPT)

#define _CURASIZE               0x700a0 /* 845/865 */
#define CURSIZE(dev_priv, pipe) _MMIO_CURSOR2((dev_priv), (pipe), _CURASIZE)
#define   CURSOR_HEIGHT_MASK            REG_GENMASK(21, 12)
#define   CURSOR_HEIGHT(h)              REG_FIELD_PREP(CURSOR_HEIGHT_MASK, (h))
#define   CURSOR_WIDTH_MASK             REG_GENMASK(9, 0)
#define   CURSOR_WIDTH(w)               REG_FIELD_PREP(CURSOR_WIDTH_MASK, (w))

#define _CUR_FBC_CTL_A          0x700a0 /* ivb+ */
#define CUR_FBC_CTL(dev_priv, pipe)     _MMIO_CURSOR2((dev_priv), (pipe), _CUR_FBC_CTL_A)
#define   CUR_FBC_EN                    REG_BIT(31)
#define   CUR_FBC_HEIGHT_MASK           REG_GENMASK(7, 0)
#define   CUR_FBC_HEIGHT(h)             REG_FIELD_PREP(CUR_FBC_HEIGHT_MASK, (h))

#define _CUR_CHICKEN_A          0x700a4 /* mtl+ */
#define CUR_CHICKEN(dev_priv, pipe)     _MMIO_CURSOR2((dev_priv), (pipe), _CUR_CHICKEN_A)

#define _CURASURFLIVE           0x700ac /* g4x+ */
#define CURSURFLIVE(dev_priv, pipe)     _MMIO_CURSOR2((dev_priv), (pipe), _CURASURFLIVE)

/* skl+ */
#define _CUR_WM_A_0             0x70140
#define _CUR_WM_B_0             0x71140
#define CUR_WM(pipe, level)     _MMIO(_PIPE((pipe), _CUR_WM_A_0, _CUR_WM_B_0) + (level) * 4)
#define   CUR_WM_EN                             REG_BIT(31)
#define   CUR_WM_IGNORE_LINES                   REG_BIT(30)
#define   CUR_WM_LINES_MASK                     REG_GENMASK(26, 14)
#define   CUR_WM_BLOCKS_MASK                    REG_GENMASK(11, 0)

#define _CUR_WM_SAGV_A          0x70158
#define _CUR_WM_SAGV_B          0x71158
#define CUR_WM_SAGV(pipe)       _MMIO_PIPE((pipe), _CUR_WM_SAGV_A, _CUR_WM_SAGV_B)

#define _CUR_WM_SAGV_TRANS_A    0x7015C
#define _CUR_WM_SAGV_TRANS_B    0x7115C
#define CUR_WM_SAGV_TRANS(pipe) _MMIO_PIPE((pipe), _CUR_WM_SAGV_TRANS_A, _CUR_WM_SAGV_TRANS_B)

#define _CUR_WM_TRANS_A         0x70168
#define _CUR_WM_TRANS_B         0x71168
#define CUR_WM_TRANS(pipe)      _MMIO_PIPE((pipe), _CUR_WM_TRANS_A, _CUR_WM_TRANS_B)

#define _CUR_BUF_CFG_A          0x7017c
#define _CUR_BUF_CFG_B          0x7117c
#define CUR_BUF_CFG(pipe)       _MMIO_PIPE((pipe), _CUR_BUF_CFG_A, _CUR_BUF_CFG_B)
/* skl+: 10 bits, icl+ 11 bits, adlp+ 12 bits */
#define   CUR_BUF_END_MASK              REG_GENMASK(27, 16)
#define   CUR_BUF_END(end)              REG_FIELD_PREP(CUR_BUF_END_MASK, (end))
#define   CUR_BUF_START_MASK            REG_GENMASK(11, 0)
#define   CUR_BUF_START(start)          REG_FIELD_PREP(CUR_BUF_START_MASK, (start))

/* tgl+ */
#define _SEL_FETCH_CUR_CTL_A    0x70880
#define _SEL_FETCH_CUR_CTL_B    0x71880
#define SEL_FETCH_CUR_CTL(pipe) _MMIO_PIPE((pipe), _SEL_FETCH_CUR_CTL_A, _SEL_FETCH_CUR_CTL_B)

#endif /* __INTEL_CURSOR_REGS_H__ */