Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
2735977b
Commit
2735977b
authored
May 28, 2008
by
Alex Deucher
Committed by
Dave Airlie
Jun 19, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/radeon: IGP clean up register and magic numbers.
Signed-off-by:
Dave Airlie
<
airlied@redhat.com
>
parent
3722bfc6
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
110 additions
and
82 deletions
+110
-82
drivers/char/drm/radeon_cp.c
drivers/char/drm/radeon_cp.c
+44
-35
drivers/char/drm/radeon_drv.h
drivers/char/drm/radeon_drv.h
+66
-47
No files found.
drivers/char/drm/radeon_cp.c
View file @
2735977b
...
...
@@ -109,9 +109,9 @@ static u32 RADEON_READ_PCIE(drm_radeon_private_t *dev_priv, int addr)
static
u32
RADEON_READ_IGPGART
(
drm_radeon_private_t
*
dev_priv
,
int
addr
)
{
u32
ret
;
RADEON_WRITE
(
R
ADEON_IGPGART
_INDEX
,
addr
&
0x7f
);
ret
=
RADEON_READ
(
R
ADEON_IGPGART
_DATA
);
RADEON_WRITE
(
R
ADEON_IGPGART
_INDEX
,
0x7f
);
RADEON_WRITE
(
R
S400_NB_MC
_INDEX
,
addr
&
0x7f
);
ret
=
RADEON_READ
(
R
S400_NB_MC
_DATA
);
RADEON_WRITE
(
R
S400_NB_MC
_INDEX
,
0x7f
);
return
ret
;
}
...
...
@@ -613,14 +613,18 @@ static void radeon_set_igpgart(drm_radeon_private_t * dev_priv, int on)
(
long
)
dev_priv
->
gart_info
.
bus_addr
,
dev_priv
->
gart_size
);
RADEON_WRITE_IGPGART
(
RADEON_IGPGART_UNK_18
,
0x1000
);
RADEON_WRITE_IGPGART
(
RADEON_IGPGART_ENABLE
,
0x1
);
RADEON_WRITE_IGPGART
(
RADEON_IGPGART_CTRL
,
0x42040800
);
RADEON_WRITE_IGPGART
(
RADEON_IGPGART_BASE_ADDR
,
RADEON_WRITE_IGPGART
(
RS400_MC_MISC_CNTL
,
RS400_GART_INDEX_REG_EN
);
RADEON_WRITE_IGPGART
(
RS400_AGP_ADDRESS_SPACE_SIZE
,
(
RS400_GART_EN
|
RS400_VA_SIZE_32MB
));
RADEON_WRITE_IGPGART
(
RS400_GART_FEATURE_ID
,
(
RS400_HANG_EN
|
RS400_TLB_ENABLE
|
RS400_GTW_LAC_EN
|
RS400_1LEVEL_GART
));
RADEON_WRITE_IGPGART
(
RS400_GART_BASE
,
dev_priv
->
gart_info
.
bus_addr
);
temp
=
RADEON_READ_IGPGART
(
dev_priv
,
R
ADEON_IGPGART_UNK_39
);
RADEON_WRITE_IGPGART
(
R
ADEON_IGPGART_UNK_39
,
temp
);
temp
=
RADEON_READ_IGPGART
(
dev_priv
,
R
S400_AGP_MODE_CNTL
);
RADEON_WRITE_IGPGART
(
R
S400_AGP_MODE_CNTL
,
temp
);
RADEON_WRITE
(
RADEON_AGP_BASE
,
(
unsigned
int
)
dev_priv
->
gart_vm_start
);
dev_priv
->
gart_size
=
32
*
1024
*
1024
;
...
...
@@ -629,13 +633,13 @@ static void radeon_set_igpgart(drm_radeon_private_t * dev_priv, int on)
dev_priv
->
gart_size
)
&
0xffff0000
)
|
(
dev_priv
->
gart_vm_start
>>
16
)));
temp
=
RADEON_READ_IGPGART
(
dev_priv
,
R
ADEON_IGPGART_ENABL
E
);
RADEON_WRITE_IGPGART
(
R
ADEON_IGPGART_ENABL
E
,
temp
);
temp
=
RADEON_READ_IGPGART
(
dev_priv
,
R
S400_AGP_ADDRESS_SPACE_SIZ
E
);
RADEON_WRITE_IGPGART
(
R
S400_AGP_ADDRESS_SPACE_SIZ
E
,
temp
);
RADEON_READ_IGPGART
(
dev_priv
,
R
ADEON_IGPGART_FLUSH
);
RADEON_WRITE_IGPGART
(
R
ADEON_IGPGART_FLUSH
,
0x1
);
RADEON_READ_IGPGART
(
dev_priv
,
R
ADEON_IGPGART_FLUSH
);
RADEON_WRITE_IGPGART
(
R
ADEON_IGPGART_FLUSH
,
0x
0
);
RADEON_READ_IGPGART
(
dev_priv
,
R
S400_GART_CACHE_CNTRL
);
RADEON_WRITE_IGPGART
(
R
S400_GART_CACHE_CNTRL
,
RS400_GART_CACHE_INVALIDATE
);
RADEON_READ_IGPGART
(
dev_priv
,
R
S400_GART_CACHE_CNTRL
);
RADEON_WRITE_IGPGART
(
R
S400_GART_CACHE_CNTRL
,
0
);
}
}
...
...
@@ -650,21 +654,26 @@ static void radeon_set_rs690gart(drm_radeon_private_t *dev_priv, int on)
(
long
)
dev_priv
->
gart_info
.
bus_addr
,
dev_priv
->
gart_size
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS690_MC_MISC_CNTL
);
RS690_WRITE_MCIND
(
RS690_MC_MISC_CNTL
,
0x5000
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS400_MC_MISC_CNTL
);
RS690_WRITE_MCIND
(
RS400_MC_MISC_CNTL
,
(
RS400_GART_INDEX_REG_EN
|
RS690_BLOCK_GFX_D3_EN
));
RS690_WRITE_MCIND
(
RS
690_MC_AGP_SIZE
,
RS690_MC_GART_EN
|
RS690_MC_AGP_SIZE_32MB
);
RS690_WRITE_MCIND
(
RS
400_AGP_ADDRESS_SPACE_SIZE
,
(
RS400_GART_EN
|
RS400_VA_SIZE_32MB
)
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS690_MC_GART_FEATURE_ID
);
RS690_WRITE_MCIND
(
RS690_MC_GART_FEATURE_ID
,
0x42040800
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS400_GART_FEATURE_ID
);
RS690_WRITE_MCIND
(
RS400_GART_FEATURE_ID
,
(
RS400_HANG_EN
|
RS400_TLB_ENABLE
|
RS400_GTW_LAC_EN
|
RS400_1LEVEL_GART
));
temp
=
dev_priv
->
gart_info
.
bus_addr
&
0xfffff000
;
temp
|=
(
upper_32_bits
(
dev_priv
->
gart_info
.
bus_addr
)
&
0xff
)
<<
4
;
RS690_WRITE_MCIND
(
RS
690_MC
_GART_BASE
,
temp
);
RS690_WRITE_MCIND
(
RS
400
_GART_BASE
,
temp
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS690_MC_AGP_MODE_CONTROL
);
RS690_WRITE_MCIND
(
RS690_MC_AGP_MODE_CONTROL
,
0x01400000
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS400_AGP_MODE_CNTL
);
RS690_WRITE_MCIND
(
RS400_AGP_MODE_CNTL
,
((
1
<<
RS400_REQ_TYPE_SNOOP_SHIFT
)
|
RS400_REQ_TYPE_SNOOP_DIS
));
RS690_WRITE_MCIND
(
RS690_MC_AGP_BASE
,
(
unsigned
int
)
dev_priv
->
gart_vm_start
);
...
...
@@ -677,32 +686,32 @@ static void radeon_set_rs690gart(drm_radeon_private_t *dev_priv, int on)
RS690_WRITE_MCIND
(
RS690_MC_AGP_LOCATION
,
temp
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS
690_MC_AGP
_SIZE
);
RS690_WRITE_MCIND
(
RS
690_MC_AGP_SIZE
,
RS690_MC_GART_EN
|
RS690_MC_AGP_SIZE_32MB
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS
400_AGP_ADDRESS_SPACE
_SIZE
);
RS690_WRITE_MCIND
(
RS
400_AGP_ADDRESS_SPACE_SIZE
,
(
RS400_GART_EN
|
RS400_VA_SIZE_32MB
)
);
do
{
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS
690_MC_GART_CACHE_CNT
L
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS
400_GART_CACHE_CNTR
L
);
if
((
temp
&
RS690_MC_GART_CLEAR_STATUS
)
==
RS690_MC_GART_CLEAR_DONE
)
break
;
DRM_UDELAY
(
1
);
}
while
(
1
);
RS690_WRITE_MCIND
(
RS690_MC_GART_CACHE_CNTL
,
RS690_MC_GART_CC_CLEAR
);
RS690_WRITE_MCIND
(
RS400_GART_CACHE_CNTRL
,
RS400_GART_CACHE_INVALIDATE
);
do
{
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS
690_MC_GART_CACHE_CNT
L
);
temp
=
RS690_READ_MCIND
(
dev_priv
,
RS
400_GART_CACHE_CNTR
L
);
if
((
temp
&
RS690_MC_GART_CLEAR_STATUS
)
==
RS690_MC_GART_CLEAR_DONE
)
break
;
DRM_UDELAY
(
1
);
}
while
(
1
);
RS690_WRITE_MCIND
(
RS690_MC_GART_CACHE_CNTL
,
RS690_MC_GART_CC_NO_CHANGE
);
RS690_WRITE_MCIND
(
RS400_GART_CACHE_CNTRL
,
0
);
}
else
{
RS690_WRITE_MCIND
(
RS
690_MC_AGP_SIZE
,
RS690_MC_GART_DIS
);
RS690_WRITE_MCIND
(
RS
400_AGP_ADDRESS_SPACE_SIZE
,
0
);
}
}
...
...
drivers/char/drm/radeon_drv.h
View file @
2735977b
...
...
@@ -444,13 +444,13 @@ extern int r300_do_cp_cmdbuf(struct drm_device * dev,
#define RADEON_PCIE_DATA 0x0034
#define RADEON_PCIE_TX_GART_CNTL 0x10
# define RADEON_PCIE_TX_GART_EN (1 << 0)
# define RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_PASS_THRU (0
<<
1)
# define RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_CLAMP_LO (1
<<
1)
# define RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_DISCARD (3
<<
1)
# define RADEON_PCIE_TX_GART_MODE_32_128_CACHE (0
<<
3)
# define RADEON_PCIE_TX_GART_MODE_8_4_128_CACHE (1
<<
3)
# define RADEON_PCIE_TX_GART_CHK_RW_VALID_EN (1
<<
5)
# define RADEON_PCIE_TX_GART_INVALIDATE_TLB (1
<<
8)
# define RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_PASS_THRU (0
<<
1)
# define RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_CLAMP_LO (1
<<
1)
# define RADEON_PCIE_TX_GART_UNMAPPED_ACCESS_DISCARD (3
<<
1)
# define RADEON_PCIE_TX_GART_MODE_32_128_CACHE (0
<<
3)
# define RADEON_PCIE_TX_GART_MODE_8_4_128_CACHE (1
<<
3)
# define RADEON_PCIE_TX_GART_CHK_RW_VALID_EN (1
<<
5)
# define RADEON_PCIE_TX_GART_INVALIDATE_TLB (1
<<
8)
#define RADEON_PCIE_TX_DISCARD_RD_ADDR_LO 0x11
#define RADEON_PCIE_TX_DISCARD_RD_ADDR_HI 0x12
#define RADEON_PCIE_TX_GART_BASE 0x13
...
...
@@ -459,14 +459,9 @@ extern int r300_do_cp_cmdbuf(struct drm_device * dev,
#define RADEON_PCIE_TX_GART_END_LO 0x16
#define RADEON_PCIE_TX_GART_END_HI 0x17
#define RADEON_IGPGART_INDEX 0x168
#define RADEON_IGPGART_DATA 0x16c
#define RADEON_IGPGART_UNK_18 0x18
#define RADEON_IGPGART_CTRL 0x2b
#define RADEON_IGPGART_BASE_ADDR 0x2c
#define RADEON_IGPGART_FLUSH 0x2e
#define RADEON_IGPGART_ENABLE 0x38
#define RADEON_IGPGART_UNK_39 0x39
#define RS400_NB_MC_INDEX 0x168
# define RS400_NB_MC_IND_WR_EN (1 << 8)
#define RS400_NB_MC_DATA 0x16c
#define RS690_MC_INDEX 0x78
# define RS690_MC_INDEX_MASK 0x1ff
...
...
@@ -474,33 +469,55 @@ extern int r300_do_cp_cmdbuf(struct drm_device * dev,
# define RS690_MC_INDEX_WR_ACK 0x7f
#define RS690_MC_DATA 0x7c
#define RS690_MC_MISC_CNTL 0x18
#define RS690_MC_GART_FEATURE_ID 0x2b
#define RS690_MC_GART_BASE 0x2c
#define RS690_MC_GART_CACHE_CNTL 0x2e
# define RS690_MC_GART_CC_NO_CHANGE 0x0
# define RS690_MC_GART_CC_CLEAR 0x1
/* MC indirect registers */
#define RS400_MC_MISC_CNTL 0x18
# define RS400_DISABLE_GTW (1 << 1)
/* switch between MCIND GART and MM GART registers. 0 = mmgart, 1 = mcind gart */
# define RS400_GART_INDEX_REG_EN (1 << 12)
# define RS690_BLOCK_GFX_D3_EN (1 << 14)
#define RS400_K8_FB_LOCATION 0x1e
#define RS400_GART_FEATURE_ID 0x2b
# define RS400_HANG_EN (1 << 11)
# define RS400_TLB_ENABLE (1 << 18)
# define RS400_P2P_ENABLE (1 << 19)
# define RS400_GTW_LAC_EN (1 << 25)
# define RS400_2LEVEL_GART (0 << 30)
# define RS400_1LEVEL_GART (1 << 30)
# define RS400_PDC_EN (1 << 31)
#define RS400_GART_BASE 0x2c
#define RS400_GART_CACHE_CNTRL 0x2e
# define RS400_GART_CACHE_INVALIDATE (1 << 0)
/* wait for it to clear */
/* ??? */
# define RS690_MC_GART_CLEAR_STATUS (1 << 1)
# define RS690_MC_GART_CLEAR_DONE (0 << 1)
# define RS690_MC_GART_CLEAR_PENDING (1 << 1)
#define RS690_MC_AGP_SIZE 0x38
# define RS690_MC_GART_DIS 0x0
# define RS690_MC_GART_EN 0x1
# define RS690_MC_AGP_SIZE_32MB (0 << 1)
# define RS690_MC_AGP_SIZE_64MB (1 << 1)
# define RS690_MC_AGP_SIZE_128MB (2 << 1)
# define RS690_MC_AGP_SIZE_256MB (3 << 1)
# define RS690_MC_AGP_SIZE_512MB (4 << 1)
# define RS690_MC_AGP_SIZE_1GB (5 << 1)
# define RS690_MC_AGP_SIZE_2GB (6 << 1)
#define RS690_MC_AGP_MODE_CONTROL 0x39
#define RS400_AGP_ADDRESS_SPACE_SIZE 0x38
# define RS400_GART_EN (1 << 0)
# define RS400_VA_SIZE_32MB (0 << 1)
# define RS400_VA_SIZE_64MB (1 << 1)
# define RS400_VA_SIZE_128MB (2 << 1)
# define RS400_VA_SIZE_256MB (3 << 1)
# define RS400_VA_SIZE_512MB (4 << 1)
# define RS400_VA_SIZE_1GB (5 << 1)
# define RS400_VA_SIZE_2GB (6 << 1)
#define RS400_AGP_MODE_CNTL 0x39
# define RS400_POST_GART_Q_SIZE (1 << 18)
# define RS400_NONGART_SNOOP (1 << 19)
# define RS400_AGP_RD_BUF_SIZE (1 << 20)
# define RS400_REQ_TYPE_SNOOP_SHIFT 22
# define RS400_REQ_TYPE_SNOOP_MASK 0x3
# define RS400_REQ_TYPE_SNOOP_DIS (1 << 24)
#define RS400_MC_MISC_UMA_CNTL 0x5f
#define RS400_MC_MCLK_CNTL 0x7a
#define RS400_MC_UMA_DUALCH_CNTL 0x86
#define RS690_MC_FB_LOCATION 0x100
#define RS690_MC_AGP_LOCATION 0x101
#define RS690_MC_AGP_BASE 0x102
#define RS690_MC_AGP_BASE_2 0x103
#define R520_MC_IND_INDEX 0x70
#define R520_MC_IND_WR_EN (1
<<
24)
#define R520_MC_IND_WR_EN (1
<<
24)
#define R520_MC_IND_DATA 0x74
#define RV515_MC_FB_LOCATION 0x01
...
...
@@ -512,6 +529,8 @@ extern int r300_do_cp_cmdbuf(struct drm_device * dev,
#define RADEON_MPP_TB_CONFIG 0x01c0
#define RADEON_MEM_CNTL 0x0140
#define RADEON_MEM_SDRAM_MODE_REG 0x0158
#define RADEON_AGP_BASE_2 0x015c
#define RS400_AGP_BASE_2 0x0164
#define RADEON_AGP_BASE 0x0170
#define RADEON_RB3D_COLOROFFSET 0x1c40
...
...
@@ -1079,36 +1098,36 @@ extern int r300_do_cp_cmdbuf(struct drm_device * dev,
#define RADEON_READ8(reg) DRM_READ8( dev_priv->mmio, (reg) )
#define RADEON_WRITE8(reg,val) DRM_WRITE8( dev_priv->mmio, (reg), (val) )
#define RADEON_WRITE_PLL(
addr, val
) \
#define RADEON_WRITE_PLL(
addr, val
) \
do { \
RADEON_WRITE8(
RADEON_CLOCK_CNTL_INDEX, \
RADEON_WRITE8(RADEON_CLOCK_CNTL_INDEX, \
((addr) & 0x1f) | RADEON_PLL_WR_EN ); \
RADEON_WRITE(
RADEON_CLOCK_CNTL_DATA, (val)
); \
RADEON_WRITE(
RADEON_CLOCK_CNTL_DATA, (val)
); \
} while (0)
#define RADEON_WRITE_IGPGART(
addr, val
) \
#define RADEON_WRITE_IGPGART(
addr, val
) \
do { \
RADEON_WRITE(
RADEON_IGPGART
_INDEX, \
((addr) & 0x7f) |
(1 << 8));
\
RADEON_WRITE(
RADEON_IGPGART_DATA, (val)
); \
RADEON_WRITE(
RADEON_IGPGART_INDEX, 0x7f
); \
RADEON_WRITE(
RS400_NB_MC
_INDEX, \
((addr) & 0x7f) |
RS400_NB_MC_IND_WR_EN);
\
RADEON_WRITE(
RS400_NB_MC_DATA, (val)
); \
RADEON_WRITE(
RS400_NB_MC_INDEX, 0x7f
); \
} while (0)
#define RADEON_WRITE_PCIE(
addr, val
) \
#define RADEON_WRITE_PCIE(
addr, val
) \
do { \
RADEON_WRITE8(
RADEON_PCIE_INDEX, \
RADEON_WRITE8(RADEON_PCIE_INDEX, \
((addr) & 0xff)); \
RADEON_WRITE(
RADEON_PCIE_DATA, (val)
); \
RADEON_WRITE(
RADEON_PCIE_DATA, (val)
); \
} while (0)
#define RADEON_WRITE_MCIND(
addr, val
) \
#define RADEON_WRITE_MCIND(
addr, val
) \
do { \
RADEON_WRITE(R520_MC_IND_INDEX, 0xff0000 | ((addr) & 0xff)); \
RADEON_WRITE(R520_MC_IND_DATA, (val)); \
RADEON_WRITE(R520_MC_IND_INDEX, 0); \
} while (0)
#define RS690_WRITE_MCIND(
addr, val
) \
#define RS690_WRITE_MCIND(
addr, val
) \
do { \
RADEON_WRITE(RS690_MC_INDEX, RS690_MC_INDEX_WR_EN | ((addr) & RS690_MC_INDEX_MASK)); \
RADEON_WRITE(RS690_MC_DATA, val); \
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment