xref: /haiku/headers/private/graphics/radeon_hd/r600_reg.h (revision 5cf44dda39962b528f9791e7bfc2f98a9e882478)
12613175eSAlexander von Gluck IV /*
2*5cf44ddaSAlexander von Gluck IV  * Copyright 2008 Advanced Micro Devices, Inc.
3*5cf44ddaSAlexander von Gluck IV  * Copyright 2008 Red Hat Inc.
4*5cf44ddaSAlexander von Gluck IV  * Copyright 2009 Jerome Glisse.
52613175eSAlexander von Gluck IV  *
62613175eSAlexander von Gluck IV  * Permission is hereby granted, free of charge, to any person obtaining a
72613175eSAlexander von Gluck IV  * copy of this software and associated documentation files (the "Software"),
82613175eSAlexander von Gluck IV  * to deal in the Software without restriction, including without limitation
92613175eSAlexander von Gluck IV  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
102613175eSAlexander von Gluck IV  * and/or sell copies of the Software, and to permit persons to whom the
112613175eSAlexander von Gluck IV  * Software is furnished to do so, subject to the following conditions:
122613175eSAlexander von Gluck IV  *
13*5cf44ddaSAlexander von Gluck IV  * The above copyright notice and this permission notice shall be included in
14*5cf44ddaSAlexander von Gluck IV  * all copies or substantial portions of the Software.
152613175eSAlexander von Gluck IV  *
16*5cf44ddaSAlexander von Gluck IV  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*5cf44ddaSAlexander von Gluck IV  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
182613175eSAlexander von Gluck IV  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
19*5cf44ddaSAlexander von Gluck IV  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
20*5cf44ddaSAlexander von Gluck IV  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21*5cf44ddaSAlexander von Gluck IV  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22*5cf44ddaSAlexander von Gluck IV  * OTHER DEALINGS IN THE SOFTWARE.
23*5cf44ddaSAlexander von Gluck IV  *
24*5cf44ddaSAlexander von Gluck IV  * Authors: Dave Airlie
25*5cf44ddaSAlexander von Gluck IV  *          Alex Deucher
26*5cf44ddaSAlexander von Gluck IV  *          Jerome Glisse
272613175eSAlexander von Gluck IV  */
28*5cf44ddaSAlexander von Gluck IV #ifndef __R600_REG_H__
29*5cf44ddaSAlexander von Gluck IV #define __R600_REG_H__
302613175eSAlexander von Gluck IV 
312613175eSAlexander von Gluck IV 
322613175eSAlexander von Gluck IV #include "r600_reg_auto_r6xx.h"
332613175eSAlexander von Gluck IV #include "r600_reg_r6xx.h"
342613175eSAlexander von Gluck IV #include "r600_reg_r7xx.h"
352613175eSAlexander von Gluck IV 
362613175eSAlexander von Gluck IV 
37*5cf44ddaSAlexander von Gluck IV #define R600_PCIE_PORT_INDEX                0x0038
38*5cf44ddaSAlexander von Gluck IV #define R600_PCIE_PORT_DATA                 0x003c
391d5cfc64SAlexander von Gluck IV 
40*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_FB_LOCATION			0x2180
41*5cf44ddaSAlexander von Gluck IV #define		R600_MC_FB_BASE_MASK			0x0000FFFF
42*5cf44ddaSAlexander von Gluck IV #define		R600_MC_FB_BASE_SHIFT			0
43*5cf44ddaSAlexander von Gluck IV #define		R600_MC_FB_TOP_MASK			0xFFFF0000
44*5cf44ddaSAlexander von Gluck IV #define		R600_MC_FB_TOP_SHIFT			16
45*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_AGP_TOP			0x2184
46*5cf44ddaSAlexander von Gluck IV #define		R600_MC_AGP_TOP_MASK			0x0003FFFF
47*5cf44ddaSAlexander von Gluck IV #define		R600_MC_AGP_TOP_SHIFT			0
48*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_AGP_BOT			0x2188
49*5cf44ddaSAlexander von Gluck IV #define		R600_MC_AGP_BOT_MASK			0x0003FFFF
50*5cf44ddaSAlexander von Gluck IV #define		R600_MC_AGP_BOT_SHIFT			0
51*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_AGP_BASE			0x218c
52*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_SYSTEM_APERTURE_LOW_ADDR	0x2190
53*5cf44ddaSAlexander von Gluck IV #define		R600_LOGICAL_PAGE_NUMBER_MASK		0x000FFFFF
54*5cf44ddaSAlexander von Gluck IV #define		R600_LOGICAL_PAGE_NUMBER_SHIFT		0
55*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_SYSTEM_APERTURE_HIGH_ADDR	0x2194
56*5cf44ddaSAlexander von Gluck IV #define R600_MC_VM_SYSTEM_APERTURE_DEFAULT_ADDR	0x2198
571d5cfc64SAlexander von Gluck IV 
58*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_FB_LOCATION			0x2024
59*5cf44ddaSAlexander von Gluck IV #define		R700_MC_FB_BASE_MASK			0x0000FFFF
60*5cf44ddaSAlexander von Gluck IV #define		R700_MC_FB_BASE_SHIFT			0
61*5cf44ddaSAlexander von Gluck IV #define		R700_MC_FB_TOP_MASK			0xFFFF0000
62*5cf44ddaSAlexander von Gluck IV #define		R700_MC_FB_TOP_SHIFT			16
63*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_AGP_TOP			0x2028
64*5cf44ddaSAlexander von Gluck IV #define		R700_MC_AGP_TOP_MASK			0x0003FFFF
65*5cf44ddaSAlexander von Gluck IV #define		R700_MC_AGP_TOP_SHIFT			0
66*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_AGP_BOT			0x202c
67*5cf44ddaSAlexander von Gluck IV #define		R700_MC_AGP_BOT_MASK			0x0003FFFF
68*5cf44ddaSAlexander von Gluck IV #define		R700_MC_AGP_BOT_SHIFT			0
69*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_AGP_BASE			0x2030
70*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_SYSTEM_APERTURE_LOW_ADDR	0x2034
71*5cf44ddaSAlexander von Gluck IV #define		R700_LOGICAL_PAGE_NUMBER_MASK		0x000FFFFF
72*5cf44ddaSAlexander von Gluck IV #define		R700_LOGICAL_PAGE_NUMBER_SHIFT		0
73*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_SYSTEM_APERTURE_HIGH_ADDR	0x2038
74*5cf44ddaSAlexander von Gluck IV #define R700_MC_VM_SYSTEM_APERTURE_DEFAULT_ADDR	0x203c
751d5cfc64SAlexander von Gluck IV 
76*5cf44ddaSAlexander von Gluck IV #define R600_RAMCFG				       0x2408
77*5cf44ddaSAlexander von Gluck IV #       define R600_CHANSIZE                           (1 << 7)
78*5cf44ddaSAlexander von Gluck IV #       define R600_CHANSIZE_OVERRIDE                  (1 << 10)
79*5cf44ddaSAlexander von Gluck IV 
80*5cf44ddaSAlexander von Gluck IV 
81*5cf44ddaSAlexander von Gluck IV #define R600_GENERAL_PWRMGT                                        0x618
82*5cf44ddaSAlexander von Gluck IV #	define R600_OPEN_DRAIN_PADS				   (1 << 11)
83*5cf44ddaSAlexander von Gluck IV 
84*5cf44ddaSAlexander von Gluck IV #define R600_LOWER_GPIO_ENABLE                                     0x710
85*5cf44ddaSAlexander von Gluck IV #define R600_CTXSW_VID_LOWER_GPIO_CNTL                             0x718
86*5cf44ddaSAlexander von Gluck IV #define R600_HIGH_VID_LOWER_GPIO_CNTL                              0x71c
87*5cf44ddaSAlexander von Gluck IV #define R600_MEDIUM_VID_LOWER_GPIO_CNTL                            0x720
88*5cf44ddaSAlexander von Gluck IV #define R600_LOW_VID_LOWER_GPIO_CNTL                               0x724
89*5cf44ddaSAlexander von Gluck IV 
90*5cf44ddaSAlexander von Gluck IV #define R600_D1GRPH_SWAP_CONTROL                               0x610C
91*5cf44ddaSAlexander von Gluck IV #       define R600_D1GRPH_SWAP_ENDIAN_NONE                    (0 << 0)
92*5cf44ddaSAlexander von Gluck IV #       define R600_D1GRPH_SWAP_ENDIAN_16BIT                   (1 << 0)
93*5cf44ddaSAlexander von Gluck IV #       define R600_D1GRPH_SWAP_ENDIAN_32BIT                   (2 << 0)
94*5cf44ddaSAlexander von Gluck IV #       define R600_D1GRPH_SWAP_ENDIAN_64BIT                   (3 << 0)
95*5cf44ddaSAlexander von Gluck IV 
96*5cf44ddaSAlexander von Gluck IV #define R600_HDP_NONSURFACE_BASE                                0x2c04
97*5cf44ddaSAlexander von Gluck IV 
98*5cf44ddaSAlexander von Gluck IV #define R600_BUS_CNTL                                           0x5420
99*5cf44ddaSAlexander von Gluck IV #       define R600_BIOS_ROM_DIS                                (1 << 1)
100*5cf44ddaSAlexander von Gluck IV #define R600_CONFIG_CNTL                                        0x5424
101*5cf44ddaSAlexander von Gluck IV #define R600_CONFIG_MEMSIZE                                     0x5428
102*5cf44ddaSAlexander von Gluck IV #define R600_CONFIG_F0_BASE                                     0x542C
103*5cf44ddaSAlexander von Gluck IV #define R600_CONFIG_APER_SIZE                                   0x5430
104*5cf44ddaSAlexander von Gluck IV 
105*5cf44ddaSAlexander von Gluck IV #define R600_ROM_CNTL                              0x1600
106*5cf44ddaSAlexander von Gluck IV #       define R600_SCK_OVERWRITE                  (1 << 1)
107*5cf44ddaSAlexander von Gluck IV #       define R600_SCK_PRESCALE_CRYSTAL_CLK_SHIFT 28
108*5cf44ddaSAlexander von Gluck IV #       define R600_SCK_PRESCALE_CRYSTAL_CLK_MASK  (0xf << 28)
1091d5cfc64SAlexander von Gluck IV 
1101d5cfc64SAlexander von Gluck IV #define R600_CG_SPLL_FUNC_CNTL                     0x600
1111d5cfc64SAlexander von Gluck IV #       define R600_SPLL_BYPASS_EN                 (1 << 3)
112*5cf44ddaSAlexander von Gluck IV #define R600_CG_SPLL_STATUS                        0x60c
113*5cf44ddaSAlexander von Gluck IV #       define R600_SPLL_CHG_STATUS                (1 << 1)
11452aeea24SAlexander von Gluck IV 
115*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_0_SCRATCH               0x1724
116*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_1_SCRATCH               0x1728
117*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_2_SCRATCH               0x172c
118*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_3_SCRATCH               0x1730
119*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_4_SCRATCH               0x1734
120*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_5_SCRATCH               0x1738
121*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_6_SCRATCH               0x173c
122*5cf44ddaSAlexander von Gluck IV #define R600_BIOS_7_SCRATCH               0x1740
1231d5cfc64SAlexander von Gluck IV 
124*5cf44ddaSAlexander von Gluck IV /* Audio, these regs were reverse enginered,
125*5cf44ddaSAlexander von Gluck IV  * so the chance is high that the naming is wrong
126*5cf44ddaSAlexander von Gluck IV  * R6xx+ ??? */
1272613175eSAlexander von Gluck IV 
128*5cf44ddaSAlexander von Gluck IV /* Audio clocks */
129*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PLL1_MUL               0x0514
130*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PLL1_DIV               0x0518
131*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PLL2_MUL               0x0524
132*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PLL2_DIV               0x0528
133*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_CLK_SRCSEL             0x0534
1342613175eSAlexander von Gluck IV 
135*5cf44ddaSAlexander von Gluck IV /* Audio general */
136*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_ENABLE                 0x7300
137*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_TIMING                 0x7344
1382613175eSAlexander von Gluck IV 
139*5cf44ddaSAlexander von Gluck IV /* Audio params */
140*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_VENDOR_ID              0x7380
141*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_REVISION_ID            0x7384
142*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_ROOT_NODE_COUNT        0x7388
143*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_NID1_NODE_COUNT        0x738c
144*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_NID1_TYPE              0x7390
145*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_SUPPORTED_SIZE_RATE    0x7394
146*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_SUPPORTED_CODEC        0x7398
147*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_SUPPORTED_POWER_STATES 0x739c
148*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_NID2_CAPS              0x73a0
149*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_NID3_CAPS              0x73a4
150*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_NID3_PIN_CAPS          0x73a8
1512613175eSAlexander von Gluck IV 
152*5cf44ddaSAlexander von Gluck IV /* Audio conn list */
153*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_CONN_LIST_LEN          0x73ac
154*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_CONN_LIST              0x73b0
155*5cf44ddaSAlexander von Gluck IV 
156*5cf44ddaSAlexander von Gluck IV /* Audio verbs */
157*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_RATE_BPS_CHANNEL       0x73c0
158*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PLAYING                0x73c4
159*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_IMPLEMENTATION_ID      0x73c8
160*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_CONFIG_DEFAULT         0x73cc
161*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PIN_SENSE              0x73d0
162*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_PIN_WIDGET_CNTL        0x73d4
163*5cf44ddaSAlexander von Gluck IV #define R600_AUDIO_STATUS_BITS            0x73d8
164*5cf44ddaSAlexander von Gluck IV 
165*5cf44ddaSAlexander von Gluck IV /* HDMI base register addresses */
166*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_BLOCK1                  0x7400
167*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_BLOCK2                  0x7700
168*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_BLOCK3                  0x7800
169*5cf44ddaSAlexander von Gluck IV 
170*5cf44ddaSAlexander von Gluck IV /* HDMI registers */
171*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_ENABLE                0x00
172*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_STATUS                0x04
173*5cf44ddaSAlexander von Gluck IV #       define R600_HDMI_INT_PENDING    (1 << 29)
174*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_CNTL                  0x08
175*5cf44ddaSAlexander von Gluck IV #       define R600_HDMI_INT_EN         (1 << 28)
176*5cf44ddaSAlexander von Gluck IV #       define R600_HDMI_INT_ACK        (1 << 29)
177*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_UNKNOWN_0             0x0C
178*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIOCNTL             0x10
179*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_VIDEOCNTL             0x14
180*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_VERSION               0x18
181*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_UNKNOWN_1             0x28
182*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_VIDEOINFOFRAME_0      0x54
183*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_VIDEOINFOFRAME_1      0x58
184*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_VIDEOINFOFRAME_2      0x5c
185*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_VIDEOINFOFRAME_3      0x60
186*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_32kHz_CTS             0xac
187*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_32kHz_N               0xb0
188*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_44_1kHz_CTS           0xb4
189*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_44_1kHz_N             0xb8
190*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_48kHz_CTS             0xbc
191*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_48kHz_N               0xc0
192*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIOINFOFRAME_0      0xcc
193*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIOINFOFRAME_1      0xd0
194*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_IEC60958_1            0xd4
195*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_IEC60958_2            0xd8
196*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_UNKNOWN_2             0xdc
197*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIO_DEBUG_0         0xe0
198*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIO_DEBUG_1         0xe4
199*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIO_DEBUG_2         0xe8
200*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_AUDIO_DEBUG_3         0xec
201*5cf44ddaSAlexander von Gluck IV 
202*5cf44ddaSAlexander von Gluck IV /* HDMI additional config base register addresses */
203*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_CONFIG1                 0x7600
204*5cf44ddaSAlexander von Gluck IV #define R600_HDMI_CONFIG2                 0x7a00
2052613175eSAlexander von Gluck IV 
2062613175eSAlexander von Gluck IV #endif
207