summaryrefslogtreecommitdiffstats
path: root/drivers/media/platform/nxp/dw100/dw100_regs.h
blob: e85dfeff90568b735a0b54e441c3345e28c474dc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/* SPDX-License-Identifier: GPL-2.0+ */
/*
 * DW100 Hardware dewarper
 *
 * Copyright 2022 NXP
 * Author: Xavier Roumegue (xavier.roumegue@oss.nxp.com)
 */

#ifndef _DW100_REGS_H_
#define _DW100_REGS_H_

/* AHB register offset */
#define DW100_DEWARP_ID			0x00
#define DW100_DEWARP_CTRL		0x04
#define DW100_DEWARP_CTRL_ENABLE			BIT(0)
#define DW100_DEWARP_CTRL_START				BIT(1)
#define DW100_DEWARP_CTRL_SOFT_RESET			BIT(2)
#define DW100_DEWARP_CTRL_FORMAT_YUV422_SP		0UL
#define DW100_DEWARP_CTRL_FORMAT_YUV422_PACKED		1UL
#define DW100_DEWARP_CTRL_FORMAT_YUV420_SP		2UL
#define DW100_DEWARP_CTRL_INPUT_FORMAT_MASK		GENMASK(5, 4)
#define DW100_DEWARP_CTRL_INPUT_FORMAT(x)		((x) << 4)
#define DW100_DEWARP_CTRL_OUTPUT_FORMAT(x)		((x) << 6)
#define DW100_DEWARP_CTRL_OUTPUT_FORMAT_MASK		GENMASK(7, 6)
#define DW100_DEWARP_CTRL_SRC_AUTO_SHADOW		BIT(8)
#define DW100_DEWARP_CTRL_HW_HANDSHAKE			BIT(9)
#define DW100_DEWARP_CTRL_DST_AUTO_SHADOW		BIT(10)
#define DW100_DEWARP_CTRL_SPLIT_LINE			BIT(11)
#define DW100_DEWARP_CTRL_PREFETCH_MODE_MASK		GENMASK(17, 16)
#define DW100_DEWARP_CTRL_PREFETCH_MODE_TRAVERSAL	(0UL << 16)
#define DW100_DEWARP_CTRL_PREFETCH_MODE_CALCULATION	(1UL << 16)
#define DW100_DEWARP_CTRL_PREFETCH_MODE_AUTO		(2UL << 16)
#define DW100_DEWARP_CTRL_PREFETCH_THRESHOLD_MASK	GENMASK(24, 18)
#define DW100_DEWARP_CTRL_PREFETCH_THRESHOLD(x)		((x) << 18)

#define DW100_MAP_LUT_ADDR		0x08
#define DW100_MAP_LUT_ADDR_ADDR(addr)	(((addr) >> 4) & GENMASK(29, 0))
#define DW100_MAP_LUT_SIZE		0x0c
#define DW100_MAP_LUT_SIZE_WIDTH(w)	(((w) & GENMASK(10, 0)) << 0)
#define DW100_MAP_LUT_SIZE_HEIGHT(h)	(((h) & GENMASK(10, 0)) << 16)
#define DW100_SRC_IMG_Y_BASE		0x10
#define DW100_IMG_Y_BASE(base)		(((base) >> 4) & GENMASK(29, 0))
#define DW100_SRC_IMG_UV_BASE		0x14
#define DW100_IMG_UV_BASE(base)		(((base) >> 4) & GENMASK(29, 0))
#define DW100_SRC_IMG_SIZE		0x18
#define DW100_IMG_SIZE_WIDTH(w)		(((w) & GENMASK(12, 0)) << 0)
#define DW100_IMG_SIZE_HEIGHT(h)	(((h) & GENMASK(12, 0)) << 16)

#define DW100_SRC_IMG_STRIDE		0x1c
#define DW100_MAP_LUT_ADDR2		0x20
#define DW100_MAP_LUT_SIZE2		0x24
#define DW100_SRC_IMG_Y_BASE2		0x28
#define DW100_SRC_IMG_UV_BASE2		0x2c
#define DW100_SRC_IMG_SIZE2		0x30
#define DW100_SRC_IMG_STRIDE2		0x34
#define DW100_DST_IMG_Y_BASE		0x38
#define DW100_DST_IMG_UV_BASE		0x3c
#define DW100_DST_IMG_SIZE		0x40
#define DW100_DST_IMG_STRIDE		0x44
#define DW100_DST_IMG_Y_BASE2		0x48
#define DW100_DST_IMG_UV_BASE2		0x4c
#define DW100_DST_IMG_SIZE2		0x50
#define DW100_DST_IMG_STRIDE2		0x54
#define DW100_SWAP_CONTROL		0x58
#define DW100_SWAP_CONTROL_BYTE		BIT(0)
#define DW100_SWAP_CONTROL_SHORT	BIT(1)
#define DW100_SWAP_CONTROL_WORD		BIT(2)
#define DW100_SWAP_CONTROL_LONG		BIT(3)
#define DW100_SWAP_CONTROL_Y(x)		(((x) & GENMASK(3, 0)) << 0)
#define DW100_SWAP_CONTROL_UV(x)	(((x) & GENMASK(3, 0)) << 4)
#define DW100_SWAP_CONTROL_SRC(x)	(((x) & GENMASK(7, 0)) << 0)
#define DW100_SWAP_CONTROL_DST(x)	(((x) & GENMASK(7, 0)) << 8)
#define DW100_SWAP_CONTROL_SRC2(x)	(((x) & GENMASK(7, 0)) << 16)
#define DW100_SWAP_CONTROL_DST2(x)	(((x) & GENMASK(7, 0)) << 24)
#define DW100_SWAP_CONTROL_SRC_MASK	GENMASK(7, 0)
#define DW100_SWAP_CONTROL_DST_MASK	GENMASK(15, 8)
#define DW100_SWAP_CONTROL_SRC2_MASK	GENMASK(23, 16)
#define DW100_SWAP_CONTROL_DST2_MASK	GENMASK(31, 24)
#define DW100_VERTICAL_SPLIT_LINE	0x5c
#define DW100_HORIZON_SPLIT_LINE	0x60
#define DW100_SCALE_FACTOR		0x64
#define DW100_ROI_START			0x68
#define DW100_ROI_START_X(x)		(((x) & GENMASK(12, 0)) << 0)
#define DW100_ROI_START_Y(y)		(((y) & GENMASK(12, 0)) << 16)
#define DW100_BOUNDARY_PIXEL		0x6c
#define DW100_BOUNDARY_PIXEL_V(v)	(((v) & GENMASK(7, 0)) << 0)
#define DW100_BOUNDARY_PIXEL_U(u)	(((u) & GENMASK(7, 0)) << 8)
#define DW100_BOUNDARY_PIXEL_Y(y)	(((y) & GENMASK(7, 0)) << 16)

#define DW100_INTERRUPT_STATUS		0x70
#define DW100_INTERRUPT_STATUS_INT_FRAME_DONE		BIT(0)
#define DW100_INTERRUPT_STATUS_INT_ERR_TIME_OUT		BIT(1)
#define DW100_INTERRUPT_STATUS_INT_ERR_AXI_RESP		BIT(2)
#define DW100_INTERRUPT_STATUS_INT_ERR_X		BIT(3)
#define DW100_INTERRUPT_STATUS_INT_ERR_MB_FETCH		BIT(4)
#define DW100_INTERRUPT_STATUS_INT_ERR_FRAME2		BIT(5)
#define DW100_INTERRUPT_STATUS_INT_ERR_FRAME3		BIT(6)
#define DW100_INTERRUPT_STATUS_INT_ERR_FRAME_DONE	BIT(7)
#define DW100_INTERRUPT_STATUS_INT_ERR_STATUS(x)	(((x) >> 1) & 0x7f)
#define DW100_INTERRUPT_STATUS_INT_STATUS(x)		((x) & 0xff)

#define DW100_INTERRUPT_STATUS_INT_ENABLE_MASK		GENMASK(15, 8)
#define DW100_INTERRUPT_STATUS_INT_ENABLE(x)		(((x) & GENMASK(7, 0)) << 8)
#define DW100_INTERRUPT_STATUS_FRAME_BUSY		BIT(16)
#define DW100_INTERRUPT_STATUS_INT_CLEAR(x)		(((x) & GENMASK(7, 0)) << 24)
#define DW100_BUS_CTRL			0x74
#define DW100_BUS_CTRL_AXI_MASTER_ENABLE	BIT(31)
#define DW100_BUS_CTRL1			0x78
#define DW100_BUS_TIME_OUT_CYCLE	0x7c
#define DW100_DST_IMG_Y_SIZE1		0x80
#define DW100_DST_IMG_Y_SIZE(sz)	(((sz) >> 4) & GENMASK(29, 0))
#define DW100_DST_IMG_UV_SIZE(sz)	(((sz) >> 4) & GENMASK(29, 0))
#define DW100_DST_IMG_UV_SIZE1		0x84
#define DW100_DST_IMG_Y_SIZE2		0x88
#define DW100_DST_IMG_UV_SIZE2		0x8c

#endif /* _DW100_REGS_H_ */