1/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * Copyright (C) 2019-2022 Bootlin
4 * Author: Paul Kocialkowski <paul.kocialkowski@bootlin.com>
5 *
6 * Copyright (C) 2014 Xylon d.o.o.
7 * Author: Davor Joja <davor.joja@logicbricks.com>
8 */
9
10#ifndef _LOGICVC_REGS_H_
11#define _LOGICVC_REGS_H_
12
13#define LOGICVC_DIMENSIONS_MAX (BIT(16) - 1)
14
15#define LOGICVC_HSYNC_FRONT_PORCH_REG 0x00
16#define LOGICVC_HSYNC_REG 0x08
17#define LOGICVC_HSYNC_BACK_PORCH_REG 0x10
18#define LOGICVC_HRES_REG 0x18
19#define LOGICVC_VSYNC_FRONT_PORCH_REG 0x20
20#define LOGICVC_VSYNC_REG 0x28
21#define LOGICVC_VSYNC_BACK_PORCH_REG 0x30
22#define LOGICVC_VRES_REG 0x38
23
24#define LOGICVC_CTRL_REG 0x40
25#define LOGICVC_CTRL_CLOCK_INVERT BIT(8)
26#define LOGICVC_CTRL_PIXEL_INVERT BIT(7)
27#define LOGICVC_CTRL_DE_INVERT BIT(5)
28#define LOGICVC_CTRL_DE_ENABLE BIT(4)
29#define LOGICVC_CTRL_VSYNC_INVERT BIT(3)
30#define LOGICVC_CTRL_VSYNC_ENABLE BIT(2)
31#define LOGICVC_CTRL_HSYNC_INVERT BIT(1)
32#define LOGICVC_CTRL_HSYNC_ENABLE BIT(0)
33
34#define LOGICVC_DTYPE_REG 0x48
35#define LOGICVC_BACKGROUND_COLOR_REG 0x50
36
37#define LOGICVC_BUFFER_SEL_REG 0x58
38#define LOGICVC_BUFFER_SEL_VALUE(i, v) \
39 (BIT(10 + (i)) | ((v) << (2 * (i))))
40#define LOGICVC_BUFFER_SEL_MAX 2
41
42#define LOGICVC_DOUBLE_CLUT_REG 0x60
43
44#define LOGICVC_INT_STAT_REG 0x68
45#define LOGICVC_INT_STAT_V_SYNC BIT(5)
46
47#define LOGICVC_INT_MASK_REG 0x70
48#define LOGICVC_INT_MASK_V_SYNC BIT(5)
49
50#define LOGICVC_POWER_CTRL_REG 0x78
51#define LOGICVC_POWER_CTRL_BACKLIGHT_ENABLE BIT(0)
52#define LOGICVC_POWER_CTRL_VDD_ENABLE BIT(1)
53#define LOGICVC_POWER_CTRL_VEE_ENABLE BIT(2)
54#define LOGICVC_POWER_CTRL_VIDEO_ENABLE BIT(3)
55
56#define LOGICVC_IP_VERSION_REG 0xf8
57#define LOGICVC_IP_VERSION_MAJOR_MASK GENMASK(16, 11)
58#define LOGICVC_IP_VERSION_MINOR_MASK GENMASK(10, 5)
59#define LOGICVC_IP_VERSION_LEVEL_MASK GENMASK(4, 0)
60
61#define LOGICVC_LAYER_ADDRESS_REG(i) (0x100 + (i) * 0x80)
62#define LOGICVC_LAYER_HOFFSET_REG(i) (0x100 + (i) * 0x80)
63
64#define LOGICVC_LAYER_VOFFSET_REG(i) (0x108 + (i) * 0x80)
65#define LOGICVC_LAYER_VOFFSET_MAX 4095
66
67#define LOGICVC_LAYER_HPOSITION_REG(i) (0x110 + (i) * 0x80)
68#define LOGICVC_LAYER_VPOSITION_REG(i) (0x118 + (i) * 0x80)
69#define LOGICVC_LAYER_WIDTH_REG(i) (0x120 + (i) * 0x80)
70#define LOGICVC_LAYER_HEIGHT_REG(i) (0x128 + (i) * 0x80)
71#define LOGICVC_LAYER_ALPHA_REG(i) (0x130 + (i) * 0x80)
72
73#define LOGICVC_LAYER_CTRL_REG(i) (0x138 + (i) * 0x80)
74#define LOGICVC_LAYER_CTRL_ENABLE BIT(0)
75#define LOGICVC_LAYER_CTRL_COLOR_KEY_DISABLE BIT(1)
76#define LOGICVC_LAYER_CTRL_PIXEL_FORMAT_INVERT BIT(4)
77
78#define LOGICVC_LAYER_COLOR_KEY_REG(i) (0x140 + (i) * 0x80)
79
80#endif
81

source code of linux/drivers/gpu/drm/logicvc/logicvc_regs.h