Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
37b034a6
Commit
37b034a6
authored
Jul 08, 2011
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nvd0/disp: tidy up what we have so far
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
ee41779e
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
39 additions
and
64 deletions
+39
-64
drivers/gpu/drm/nouveau/Makefile
drivers/gpu/drm/nouveau/Makefile
+3
-3
drivers/gpu/drm/nouveau/nvd0_display.c
drivers/gpu/drm/nouveau/nvd0_display.c
+36
-61
No files found.
drivers/gpu/drm/nouveau/Makefile
View file @
37b034a6
...
@@ -23,12 +23,12 @@ nouveau-y := nouveau_drv.o nouveau_state.o nouveau_channel.o nouveau_mem.o \
...
@@ -23,12 +23,12 @@ nouveau-y := nouveau_drv.o nouveau_state.o nouveau_channel.o nouveau_mem.o \
nva3_copy.o nvc0_copy.o
\
nva3_copy.o nvc0_copy.o
\
nv31_mpeg.o nv50_mpeg.o
\
nv31_mpeg.o nv50_mpeg.o
\
nv04_instmem.o nv50_instmem.o nvc0_instmem.o
\
nv04_instmem.o nv50_instmem.o nvc0_instmem.o
\
nv50_evo.o nv50_crtc.o nv50_dac.o nv50_sor.o
\
nv50_cursor.o nv50_display.o
\
nv04_dac.o nv04_dfp.o nv04_tv.o nv17_tv.o nv17_tv_modes.o
\
nv04_dac.o nv04_dfp.o nv04_tv.o nv17_tv.o nv17_tv_modes.o
\
nv04_crtc.o nv04_display.o nv04_cursor.o
\
nv04_crtc.o nv04_display.o nv04_cursor.o
\
nv04_fbcon.o nv50_fbcon.o nvc0_fbcon.o
\
nv50_evo.o nv50_crtc.o nv50_dac.o nv50_sor.o
\
nv50_cursor.o nv50_display.o
\
nvd0_display.o
\
nvd0_display.o
\
nv04_fbcon.o nv50_fbcon.o nvc0_fbcon.o
\
nv10_gpio.o nv50_gpio.o
\
nv10_gpio.o nv50_gpio.o
\
nv50_calc.o
\
nv50_calc.o
\
nv04_pm.o nv50_pm.o nva3_pm.o nvc0_pm.o
\
nv04_pm.o nv50_pm.o nva3_pm.o nvc0_pm.o
\
...
...
drivers/gpu/drm/nouveau/nvd0_display.c
View file @
37b034a6
...
@@ -31,13 +31,10 @@
...
@@ -31,13 +31,10 @@
#include "nouveau_connector.h"
#include "nouveau_connector.h"
#include "nouveau_encoder.h"
#include "nouveau_encoder.h"
#include "nouveau_crtc.h"
#include "nouveau_crtc.h"
#include "nouveau_dma.h"
#include "nouveau_fb.h"
#include "nouveau_fb.h"
#include "nv50_display.h"
#include "nv50_display.h"
#define MEM_SYNC 0xe0000001
#define MEM_VRAM 0xe0010000
#include "nouveau_dma.h"
struct
nvd0_display
{
struct
nvd0_display
{
struct
nouveau_gpuobj
*
mem
;
struct
nouveau_gpuobj
*
mem
;
struct
{
struct
{
...
@@ -56,7 +53,7 @@ nvd0_display(struct drm_device *dev)
...
@@ -56,7 +53,7 @@ nvd0_display(struct drm_device *dev)
return
dev_priv
->
engine
.
display
.
priv
;
return
dev_priv
->
engine
.
display
.
priv
;
}
}
static
int
static
in
line
in
t
evo_icmd
(
struct
drm_device
*
dev
,
int
id
,
u32
mthd
,
u32
data
)
evo_icmd
(
struct
drm_device
*
dev
,
int
id
,
u32
mthd
,
u32
data
)
{
{
int
ret
=
0
;
int
ret
=
0
;
...
@@ -237,7 +234,7 @@ nvd0_crtc_cursor_show(struct nouveau_crtc *nv_crtc, bool show, bool update)
...
@@ -237,7 +234,7 @@ nvd0_crtc_cursor_show(struct nouveau_crtc *nv_crtc, bool show, bool update)
evo_data
(
push
,
0x85000000
);
evo_data
(
push
,
0x85000000
);
evo_data
(
push
,
nv_crtc
->
cursor
.
nvbo
->
bo
.
offset
>>
8
);
evo_data
(
push
,
nv_crtc
->
cursor
.
nvbo
->
bo
.
offset
>>
8
);
evo_mthd
(
push
,
0x048c
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_mthd
(
push
,
0x048c
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_data
(
push
,
MEM_
VRAM
);
evo_data
(
push
,
NvEvo
VRAM
);
}
else
{
}
else
{
evo_mthd
(
push
,
0x0480
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_mthd
(
push
,
0x0480
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_data
(
push
,
0x05000000
);
evo_data
(
push
,
0x05000000
);
...
@@ -295,7 +292,7 @@ nvd0_crtc_commit(struct drm_crtc *crtc)
...
@@ -295,7 +292,7 @@ nvd0_crtc_commit(struct drm_crtc *crtc)
evo_data
(
push
,
0x00000000
);
evo_data
(
push
,
0x00000000
);
evo_data
(
push
,
0x00000000
);
evo_data
(
push
,
0x00000000
);
evo_mthd
(
push
,
0x045c
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_mthd
(
push
,
0x045c
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_data
(
push
,
MEM_
VRAM
);
evo_data
(
push
,
NvEvo
VRAM
);
evo_mthd
(
push
,
0x0430
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_mthd
(
push
,
0x0430
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_data
(
push
,
0xffffff00
);
evo_data
(
push
,
0xffffff00
);
evo_kick
(
push
,
crtc
->
dev
,
0
);
evo_kick
(
push
,
crtc
->
dev
,
0
);
...
@@ -958,23 +955,6 @@ nvd0_sor_create(struct drm_connector *connector, struct dcb_entry *dcbe)
...
@@ -958,23 +955,6 @@ nvd0_sor_create(struct drm_connector *connector, struct dcb_entry *dcbe)
/******************************************************************************
/******************************************************************************
* IRQ
* IRQ
*****************************************************************************/
*****************************************************************************/
static
void
debug_irq
(
struct
drm_device
*
dev
,
int
i
)
{
if
(
drm_debug
&
(
DRM_UT_DRIVER
|
DRM_UT_KMS
))
{
NV_INFO
(
dev
,
"PDISP: modeset req %d
\n
"
,
i
);
NV_INFO
(
dev
,
" STAT: 0x%08x 0x%08x 0x%08x
\n
"
,
nv_rd32
(
dev
,
0x6101d0
),
nv_rd32
(
dev
,
0x6101d4
),
nv_rd32
(
dev
,
0x6109d4
));
for
(
i
=
0
;
i
<
8
;
i
++
)
{
NV_INFO
(
dev
,
" %s%d: 0x%08x 0x%08x
\n
"
,
i
<
4
?
"DAC"
:
"SOR"
,
i
,
nv_rd32
(
dev
,
0x640180
+
(
i
*
0x20
)),
nv_rd32
(
dev
,
0x660180
+
(
i
*
0x20
)));
}
}
}
static
struct
dcb_entry
*
static
struct
dcb_entry
*
lookup_dcb
(
struct
drm_device
*
dev
,
int
id
,
u32
mc
)
lookup_dcb
(
struct
drm_device
*
dev
,
int
id
,
u32
mc
)
{
{
...
@@ -1009,20 +989,11 @@ lookup_dcb(struct drm_device *dev, int id, u32 mc)
...
@@ -1009,20 +989,11 @@ lookup_dcb(struct drm_device *dev, int id, u32 mc)
}
}
static
void
static
void
nvd0_display_unk1_handler
(
struct
drm_device
*
dev
)
nvd0_display_unk1_handler
(
struct
drm_device
*
dev
,
u32
crtc
,
u32
mask
)
{
{
struct
dcb_entry
*
dcb
;
struct
dcb_entry
*
dcb
;
u32
mask
,
crtc
;
int
i
;
int
i
;
mask
=
nv_rd32
(
dev
,
0x6101d4
);
crtc
=
0
;
if
(
!
mask
)
{
mask
=
nv_rd32
(
dev
,
0x6109d4
);
crtc
=
1
;
}
debug_irq
(
dev
,
1
);
for
(
i
=
0
;
mask
&&
i
<
8
;
i
++
)
{
for
(
i
=
0
;
mask
&&
i
<
8
;
i
++
)
{
u32
mcc
=
nv_rd32
(
dev
,
0x640180
+
(
i
*
0x20
));
u32
mcc
=
nv_rd32
(
dev
,
0x640180
+
(
i
*
0x20
));
if
(
!
(
mcc
&
(
1
<<
crtc
)))
if
(
!
(
mcc
&
(
1
<<
crtc
)))
...
@@ -1041,21 +1012,12 @@ nvd0_display_unk1_handler(struct drm_device *dev)
...
@@ -1041,21 +1012,12 @@ nvd0_display_unk1_handler(struct drm_device *dev)
}
}
static
void
static
void
nvd0_display_unk2_handler
(
struct
drm_device
*
dev
)
nvd0_display_unk2_handler
(
struct
drm_device
*
dev
,
u32
crtc
,
u32
mask
)
{
{
struct
dcb_entry
*
dcb
;
struct
dcb_entry
*
dcb
;
u32
mask
,
crtc
,
pclk
;
u32
or
,
tmp
,
pclk
;
u32
or
,
tmp
;
int
i
;
int
i
;
mask
=
nv_rd32
(
dev
,
0x6101d4
);
crtc
=
0
;
if
(
!
mask
)
{
mask
=
nv_rd32
(
dev
,
0x6109d4
);
crtc
=
1
;
}
debug_irq
(
dev
,
2
);
for
(
i
=
0
;
mask
&&
i
<
8
;
i
++
)
{
for
(
i
=
0
;
mask
&&
i
<
8
;
i
++
)
{
u32
mcc
=
nv_rd32
(
dev
,
0x640180
+
(
i
*
0x20
));
u32
mcc
=
nv_rd32
(
dev
,
0x640180
+
(
i
*
0x20
));
if
(
!
(
mcc
&
(
1
<<
crtc
)))
if
(
!
(
mcc
&
(
1
<<
crtc
)))
...
@@ -1113,20 +1075,11 @@ nvd0_display_unk2_handler(struct drm_device *dev)
...
@@ -1113,20 +1075,11 @@ nvd0_display_unk2_handler(struct drm_device *dev)
}
}
static
void
static
void
nvd0_display_unk4_handler
(
struct
drm_device
*
dev
)
nvd0_display_unk4_handler
(
struct
drm_device
*
dev
,
u32
crtc
,
u32
mask
)
{
{
struct
dcb_entry
*
dcb
;
struct
dcb_entry
*
dcb
;
u32
mask
,
crtc
;
int
pclk
,
i
;
int
pclk
,
i
;
mask
=
nv_rd32
(
dev
,
0x6101d4
);
crtc
=
0
;
if
(
!
mask
)
{
mask
=
nv_rd32
(
dev
,
0x6109d4
);
crtc
=
1
;
}
debug_irq
(
dev
,
4
);
pclk
=
nv_rd32
(
dev
,
0x660450
+
(
crtc
*
0x300
))
/
1000
;
pclk
=
nv_rd32
(
dev
,
0x660450
+
(
crtc
*
0x300
))
/
1000
;
for
(
i
=
0
;
mask
&&
i
<
8
;
i
++
)
{
for
(
i
=
0
;
mask
&&
i
<
8
;
i
++
)
{
...
@@ -1152,13 +1105,35 @@ nvd0_display_bh(unsigned long data)
...
@@ -1152,13 +1105,35 @@ nvd0_display_bh(unsigned long data)
{
{
struct
drm_device
*
dev
=
(
struct
drm_device
*
)
data
;
struct
drm_device
*
dev
=
(
struct
drm_device
*
)
data
;
struct
nvd0_display
*
disp
=
nvd0_display
(
dev
);
struct
nvd0_display
*
disp
=
nvd0_display
(
dev
);
u32
mask
,
crtc
;
int
i
;
if
(
drm_debug
&
(
DRM_UT_DRIVER
|
DRM_UT_KMS
))
{
NV_INFO
(
dev
,
"PDISP: modeset req %d
\n
"
,
disp
->
modeset
);
NV_INFO
(
dev
,
" STAT: 0x%08x 0x%08x 0x%08x
\n
"
,
nv_rd32
(
dev
,
0x6101d0
),
nv_rd32
(
dev
,
0x6101d4
),
nv_rd32
(
dev
,
0x6109d4
));
for
(
i
=
0
;
i
<
8
;
i
++
)
{
NV_INFO
(
dev
,
" %s%d: 0x%08x 0x%08x
\n
"
,
i
<
4
?
"DAC"
:
"SOR"
,
i
,
nv_rd32
(
dev
,
0x640180
+
(
i
*
0x20
)),
nv_rd32
(
dev
,
0x660180
+
(
i
*
0x20
)));
}
}
mask
=
nv_rd32
(
dev
,
0x6101d4
);
crtc
=
0
;
if
(
!
mask
)
{
mask
=
nv_rd32
(
dev
,
0x6109d4
);
crtc
=
1
;
}
if
(
disp
->
modeset
&
0x00000001
)
if
(
disp
->
modeset
&
0x00000001
)
nvd0_display_unk1_handler
(
dev
);
nvd0_display_unk1_handler
(
dev
,
crtc
,
mask
);
if
(
disp
->
modeset
&
0x00000002
)
if
(
disp
->
modeset
&
0x00000002
)
nvd0_display_unk2_handler
(
dev
);
nvd0_display_unk2_handler
(
dev
,
crtc
,
mask
);
if
(
disp
->
modeset
&
0x00000004
)
if
(
disp
->
modeset
&
0x00000004
)
nvd0_display_unk4_handler
(
dev
);
nvd0_display_unk4_handler
(
dev
,
crtc
,
mask
);
}
}
static
void
static
void
...
@@ -1324,7 +1299,7 @@ nvd0_display_init(struct drm_device *dev)
...
@@ -1324,7 +1299,7 @@ nvd0_display_init(struct drm_device *dev)
if
(
!
push
)
if
(
!
push
)
return
-
EBUSY
;
return
-
EBUSY
;
evo_mthd
(
push
,
0x0088
,
1
);
evo_mthd
(
push
,
0x0088
,
1
);
evo_data
(
push
,
MEM_SYNC
);
evo_data
(
push
,
NvEvoSync
);
evo_mthd
(
push
,
0x0084
,
1
);
evo_mthd
(
push
,
0x0084
,
1
);
evo_data
(
push
,
0x00000000
);
evo_data
(
push
,
0x00000000
);
evo_mthd
(
push
,
0x0084
,
1
);
evo_mthd
(
push
,
0x0084
,
1
);
...
@@ -1430,7 +1405,7 @@ nvd0_display_create(struct drm_device *dev)
...
@@ -1430,7 +1405,7 @@ nvd0_display_create(struct drm_device *dev)
nv_wo32
(
disp
->
mem
,
0x100c
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x100c
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1010
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1010
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1014
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1014
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x0000
,
MEM_SYNC
);
nv_wo32
(
disp
->
mem
,
0x0000
,
NvEvoSync
);
nv_wo32
(
disp
->
mem
,
0x0004
,
(
0x1000
<<
9
)
|
0x00000001
);
nv_wo32
(
disp
->
mem
,
0x0004
,
(
0x1000
<<
9
)
|
0x00000001
);
nv_wo32
(
disp
->
mem
,
0x1020
,
0x00000049
);
nv_wo32
(
disp
->
mem
,
0x1020
,
0x00000049
);
...
@@ -1439,7 +1414,7 @@ nvd0_display_create(struct drm_device *dev)
...
@@ -1439,7 +1414,7 @@ nvd0_display_create(struct drm_device *dev)
nv_wo32
(
disp
->
mem
,
0x102c
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x102c
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1030
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1030
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1034
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x1034
,
0x00000000
);
nv_wo32
(
disp
->
mem
,
0x0008
,
MEM_
VRAM
);
nv_wo32
(
disp
->
mem
,
0x0008
,
NvEvo
VRAM
);
nv_wo32
(
disp
->
mem
,
0x000c
,
(
0x1020
<<
9
)
|
0x00000001
);
nv_wo32
(
disp
->
mem
,
0x000c
,
(
0x1020
<<
9
)
|
0x00000001
);
nv_wo32
(
disp
->
mem
,
0x1040
,
0x00000009
);
nv_wo32
(
disp
->
mem
,
0x1040
,
0x00000009
);
...
...
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