xref: /netbsd-src/sys/arch/arm/sunxi/sunxi_debereg.h (revision a4d537b2c9ef29102e01f528495ea5788433285c)
1 /* $NetBSD: sunxi_debereg.h,v 1.1 2018/04/03 12:52:16 bouyer Exp $ */
2 
3 /*-
4  * Copyright (c) 2013 The NetBSD Foundation, Inc.
5  * All rights reserved.
6  *
7  * This code is derived from software contributed to The NetBSD Foundation
8  * by Matt Thomas of 3am Software Foundry.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  */
31 
32 #define SUNXI_DEBE_MODCTL_REG		0x0800
33 #define SUNXI_DEBE_BACKCOLOR_REG	0x0804
34 #define SUNXI_DEBE_DISSIZE_REG		0x0808
35 #define SUNXI_DEBE_LAYSIZE_REG		0x0810
36 #define SUNXI_DEBE_LAYCOOR_REG		0x0820
37 #define SUNXI_DEBE_LAYLINEWIDTH_REG	0x0840
38 #define SUNXI_DEBE_LAYFB_L32ADD_REG	0x0850
39 #define SUNXI_DEBE_LAYFB_H4ADD_REG	0x0860
40 #define SUNXI_DEBE_REGBUFFCTL_REG	0x0870
41 #define SUNXI_DEBE_CKMAX_REG		0x0880
42 #define SUNXI_DEBE_CKMIN_REG		0x0884
43 #define SUNXI_DEBE_CKCFG_REG		0x0888
44 #define SUNXI_DEBE_ATTCTL0_REG		0x0890
45 #define SUNXI_DEBE_ATTCTL1_REG		0x08A0
46 #define SUNXI_DEBE_HWCCTL_REG		0x08D8
47 #define SUNXI_DEBE_HWCFBCTL_REG		0x08E0
48 #define SUNXI_DEBE_WBCTL_REG		0x08F0
49 #define SUNXI_DEBE_WBADD_REG		0x08F4
50 #define SUNXI_DEBE_WBLINEWIDTH_REG	0x08F8
51 #define SUNXI_DEBE_IYUVCTL_REG		0x0920
52 #define SUNXI_DEBE_IYUVADD_REG		0x0930
53 #define SUNXI_DEBE_IYUVLINEWIDTH_REG	0x0940
54 #define SUNXI_DEBE_YGCOEF_REG		0x0950
55 #define SUNXI_DEBE_YGCONS_REG		0x095C
56 #define SUNXI_DEBE_URCOEF_REG		0x0960
57 #define SUNXI_DEBE_URCONS_REG		0x096C
58 #define SUNXI_DEBE_VBCOEF_REG		0x0970
59 #define SUNXI_DEBE_VBCONS_REG		0x097C
60 #define SUNXI_DEBE_OCCTL_REG		0x09C0
61 #define SUNXI_DEBE_OCRCOEF_REG		0x09D0
62 #define SUNXI_DEBE_OCRCONS_REG		0x09DC
63 #define SUNXI_DEBE_OCGCOEF_REG		0x09E0
64 #define SUNXI_DEBE_OCGCONS_REG		0x09EC
65 #define SUNXI_DEBE_OCBCOEF_REG		0x09F0
66 #define SUNXI_DEBE_OCBCONS_REG		0x09FC
67 #define SUNXI_DEBE_HWC_PATTERN_BLOCK	0x4800
68 #define SUNXI_DEBE_HWC_PALETTE_TABLE	0x4C00
69 
70 #define SUNXI_DEBE_MODCTL_LINE_SEL	__BIT(29)
71 #define SUNXI_DEBE_MODCTL_ITLMOD_EN	__BIT(28)
72 #define SUNXI_DEBE_MODCTL_OUT_SEL	__BITS(22,20)
73 #define SUNXI_DEBE_MODCTL_OUT_SEL_LCD0	0
74 #define SUNXI_DEBE_MODCTL_OUT_SEL_LCD1	1
75 #define SUNXI_DEBE_MODCTL_OUT_SEL_FE0	6
76 #define SUNXI_DEBE_MODCTL_OUT_SEL_FE1	7
77 #define SUNXI_DEBE_MODCTL_OSCA_EN	__BIT(17)
78 #define SUNXI_DEBE_MODCTL_HWC_EN	__BIT(16)
79 #define SUNXI_DEBE_MODCTL_LAY3_EN	__BIT(11)
80 #define SUNXI_DEBE_MODCTL_LAY2_EN	__BIT(10)
81 #define SUNXI_DEBE_MODCTL_LAY1_EN	__BIT(9)
82 #define SUNXI_DEBE_MODCTL_LAY0_EN	__BIT(8)
83 #define SUNXI_DEBE_MODCTL_START_CTL	__BIT(1)
84 #define SUNXI_DEBE_MODCTL_EN		__BIT(0)
85 
86 #define SUNXI_DEBE_ATTCTL0_LAY_GLBALPHA	__BITS(31,24)
87 #define SUNXI_DEBE_ATTCTL0_LAY_WORKMOD	__BITS(23,22)
88 #define SUNXI_DEBE_ATTCTL0_PREMUL	__BIT(21,20)
89 #define SUNXI_DEBE_ATTCTL0_CKEN		__BITS(19,18)
90 #define SUNXI_DEBE_ATTCTL0_LAY_PIPESEL	__BIT(15)
91 #define SUNXI_DEBE_ATTCTL0_LAY_PRISEL	__BITS(11,10)
92 #define SUNXI_DEBE_ATTCTL0_LAY_VDOSEL	__BIT(4)
93 #define SUNXI_DEBE_ATTCTL0_LAY_YUVEN	__BIT(2)
94 #define SUNXI_DEBE_ATTCTL0_LAY_VDOEN	__BIT(1)
95 #define SUNXI_DEBE_ATTCTL0_LAY_GLBALPHAEN __BIT(0)
96 
97 #define SUNXI_DEBE_ATTCTL1_LAY_HSCAFCT	__BITS(15,14)
98 #define SUNXI_DEBE_ATTCTL1_LAY_WSCAFCT	__BITS(13,12)
99 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT	__BITS(11,8)
100 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_MONO_1BPP	0
101 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_MONO_2BPP	1
102 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_MONO_4BPP	2
103 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_MONO_8BPP	3
104 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_RGB655	4
105 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_RGB565	5
106 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_RGB556	6
107 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_ARGB1555	7
108 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_RGBA5551	8
109 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_XRGB8888	9
110 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_ARGB8888	10
111 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_RGB888	11
112 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_ARGB4444	12
113 #define SUNXI_DEBE_ATTCTL1_LAY_FBFMT_RGBA4444	13
114 #define SUNXI_DEBE_ATTCTL1_LAY_BRSWAPEN	__BIT(2)
115 #define SUNXI_DEBE_ATTCTL1_LAY_FBPS	__BITS(1,0)
116 #define SUNXI_DEBE_ATTCTL1_LAY_FBPS_32BPP_ARGB	0
117 #define SUNXI_DEBE_ATTCTL1_LAY_FBPS_32BPP_BGRA	2
118 
119 #define SUNXI_DEBE_REGBUFFCTL_REGAUTOLOAD_DIS __BIT(1)
120 #define SUNXI_DEBE_REGBUFFCTL_REGLOADCTL	__BIT(0)
121 
122 #define SUNXI_DEBE_HWCCTL_YCOOR		__BITS(31,16)
123 #define SUNXI_DEBE_HWCCTL_XCOOR		__BITS(15,0)
124 
125 #define SUNXI_DEBE_HWCFBCTL_YCOOROFF	__BITS(31,24)
126 #define SUNXI_DEBE_HWCFBCTL_XCOOROFF	__BITS(23,16)
127 #define SUNXI_DEBE_HWCFBCTL_YSIZE	__BITS(5,4)
128 #define SUNXI_DEBE_HWCFBCTL_YSIZE_32	0
129 #define SUNXI_DEBE_HWCFBCTL_YSIZE_64	1
130 #define SUNXI_DEBE_HWCFBCTL_XSIZE	__BITS(3,2)
131 #define SUNXI_DEBE_HWCFBCTL_XSIZE_32	0
132 #define SUNXI_DEBE_HWCFBCTL_XSIZE_64	1
133 #define SUNXI_DEBE_HWCFBCTL_FBFMT	__BITS(1,0)
134 #define SUNXI_DEBE_HWCFBCTL_FBFMT_1BPP	0
135 #define SUNXI_DEBE_HWCFBCTL_FBFMT_2BPP	1
136 #define SUNXI_DEBE_HWCFBCTL_FBFMT_4BPP	2
137 #define SUNXI_DEBE_HWCFBCTL_FBFMT_8BPP	3
138 
139