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
2fde1f1c
Commit
2fde1f1c
authored
Aug 20, 2015
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/disp: switch to device pri macros
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
f9793bb7
Changes
20
Hide whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
457 additions
and
380 deletions
+457
-380
drivers/gpu/drm/nouveau/nvkm/engine/disp/dacnv50.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/dacnv50.c
+7
-5
drivers/gpu/drm/nouveau/nvkm/engine/disp/gf110.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/gf110.c
+128
-105
drivers/gpu/drm/nouveau/nvkm/engine/disp/gk104.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/gk104.c
+2
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/gk110.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/gk110.c
+2
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/gm107.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/gm107.c
+2
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/gm204.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/gm204.c
+2
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagf110.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagf110.c
+8
-7
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagt215.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagt215.c
+7
-6
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmig84.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmig84.c
+23
-22
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigf110.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigf110.c
+15
-14
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigk104.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigk104.c
+16
-15
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigt215.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigt215.c
+23
-22
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv04.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv04.c
+17
-13
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c
+138
-114
drivers/gpu/drm/nouveau/nvkm/engine/disp/piornv50.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/piornv50.c
+2
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorg94.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorg94.c
+16
-12
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgf110.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgf110.c
+15
-12
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgm204.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgm204.c
+19
-15
drivers/gpu/drm/nouveau/nvkm/engine/disp/sornv50.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/sornv50.c
+2
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/vga.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/vga.c
+13
-12
No files found.
drivers/gpu/drm/nouveau/nvkm/engine/disp/dacnv50.c
View file @
2fde1f1c
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
int
int
nv50_dac_power
(
NV50_DISP_MTHD_V1
)
nv50_dac_power
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
doff
=
outp
->
or
*
0x800
;
const
u32
doff
=
outp
->
or
*
0x800
;
union
{
union
{
struct
nv50_disp_dac_pwr_v0
v0
;
struct
nv50_disp_dac_pwr_v0
v0
;
...
@@ -54,7 +55,7 @@ nv50_dac_power(NV50_DISP_MTHD_V1)
...
@@ -54,7 +55,7 @@ nv50_dac_power(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv
_mask
(
disp
,
0x61a004
+
doff
,
0xc000007f
,
0x80000000
|
stat
);
nv
km_mask
(
device
,
0x61a004
+
doff
,
0xc000007f
,
0x80000000
|
stat
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
return
0
;
return
0
;
}
}
...
@@ -62,6 +63,7 @@ nv50_dac_power(NV50_DISP_MTHD_V1)
...
@@ -62,6 +63,7 @@ nv50_dac_power(NV50_DISP_MTHD_V1)
int
int
nv50_dac_sense
(
NV50_DISP_MTHD_V1
)
nv50_dac_sense
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
union
{
union
{
struct
nv50_disp_dac_load_v0
v0
;
struct
nv50_disp_dac_load_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
...
@@ -79,15 +81,15 @@ nv50_dac_sense(NV50_DISP_MTHD_V1)
...
@@ -79,15 +81,15 @@ nv50_dac_sense(NV50_DISP_MTHD_V1)
}
else
}
else
return
ret
;
return
ret
;
nv
_mask
(
disp
,
0x61a004
+
doff
,
0x807f0000
,
0x80150000
);
nv
km_mask
(
device
,
0x61a004
+
doff
,
0x807f0000
,
0x80150000
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv
_wr32
(
disp
,
0x61a00c
+
doff
,
0x00100000
|
loadval
);
nv
km_wr32
(
device
,
0x61a00c
+
doff
,
0x00100000
|
loadval
);
mdelay
(
9
);
mdelay
(
9
);
udelay
(
500
);
udelay
(
500
);
loadval
=
nv
_mask
(
disp
,
0x61a00c
+
doff
,
0xffffffff
,
0x00000000
);
loadval
=
nv
km_mask
(
device
,
0x61a00c
+
doff
,
0xffffffff
,
0x00000000
);
nv
_mask
(
disp
,
0x61a004
+
doff
,
0x807f0000
,
0x80550000
);
nv
km_mask
(
device
,
0x61a004
+
doff
,
0x807f0000
,
0x80550000
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61a004
+
doff
,
0x80000000
,
0x00000000
);
nv_debug
(
disp
,
"DAC%d sense: 0x%08x
\n
"
,
outp
->
or
,
loadval
);
nv_debug
(
disp
,
"DAC%d sense: 0x%08x
\n
"
,
outp
->
or
,
loadval
);
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/gf110.c
View file @
2fde1f1c
...
@@ -47,16 +47,18 @@ static void
...
@@ -47,16 +47,18 @@ static void
gf110_disp_chan_uevent_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
gf110_disp_chan_uevent_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
{
{
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
nv_mask
(
disp
,
0x610090
,
0x00000001
<<
index
,
0x00000000
<<
index
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
nv_wr32
(
disp
,
0x61008c
,
0x00000001
<<
index
);
nvkm_mask
(
device
,
0x610090
,
0x00000001
<<
index
,
0x00000000
<<
index
);
nvkm_wr32
(
device
,
0x61008c
,
0x00000001
<<
index
);
}
}
static
void
static
void
gf110_disp_chan_uevent_init
(
struct
nvkm_event
*
event
,
int
types
,
int
index
)
gf110_disp_chan_uevent_init
(
struct
nvkm_event
*
event
,
int
types
,
int
index
)
{
{
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
nv_wr32
(
disp
,
0x61008c
,
0x00000001
<<
index
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
nv_mask
(
disp
,
0x610090
,
0x00000001
<<
index
,
0x00000001
<<
index
);
nvkm_wr32
(
device
,
0x61008c
,
0x00000001
<<
index
);
nvkm_mask
(
device
,
0x610090
,
0x00000001
<<
index
,
0x00000001
<<
index
);
}
}
const
struct
nvkm_event_func
const
struct
nvkm_event_func
...
@@ -93,6 +95,7 @@ gf110_disp_dmac_init(struct nvkm_object *object)
...
@@ -93,6 +95,7 @@ gf110_disp_dmac_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
dmac
->
base
.
chid
;
int
chid
=
dmac
->
base
.
chid
;
int
ret
;
int
ret
;
...
@@ -101,20 +104,20 @@ gf110_disp_dmac_init(struct nvkm_object *object)
...
@@ -101,20 +104,20 @@ gf110_disp_dmac_init(struct nvkm_object *object)
return
ret
;
return
ret
;
/* enable error reporting */
/* enable error reporting */
nv
_mask
(
disp
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000001
<<
chid
);
nv
km_mask
(
device
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000001
<<
chid
);
/* initialise channel for dma command submission */
/* initialise channel for dma command submission */
nv
_wr32
(
disp
,
0x610494
+
(
chid
*
0x0010
),
dmac
->
push
);
nv
km_wr32
(
device
,
0x610494
+
(
chid
*
0x0010
),
dmac
->
push
);
nv
_wr32
(
disp
,
0x610498
+
(
chid
*
0x0010
),
0x00010000
);
nv
km_wr32
(
device
,
0x610498
+
(
chid
*
0x0010
),
0x00010000
);
nv
_wr32
(
disp
,
0x61049c
+
(
chid
*
0x0010
),
0x00000001
);
nv
km_wr32
(
device
,
0x61049c
+
(
chid
*
0x0010
),
0x00000001
);
nv
_mask
(
disp
,
0x610490
+
(
chid
*
0x0010
),
0x00000010
,
0x00000010
);
nv
km_mask
(
device
,
0x610490
+
(
chid
*
0x0010
),
0x00000010
,
0x00000010
);
nv
_wr32
(
disp
,
0x640000
+
(
chid
*
0x1000
),
0x00000000
);
nv
km_wr32
(
device
,
0x640000
+
(
chid
*
0x1000
),
0x00000000
);
nv
_wr32
(
disp
,
0x610490
+
(
chid
*
0x0010
),
0x00000013
);
nv
km_wr32
(
device
,
0x610490
+
(
chid
*
0x0010
),
0x00000013
);
/* wait for it to go inactive */
/* wait for it to go inactive */
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x80000000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x80000000
,
0x00000000
))
{
nv_error
(
dmac
,
"init: 0x%08x
\n
"
,
nv_error
(
dmac
,
"init: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610490
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610490
+
(
chid
*
0x10
)));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -126,21 +129,22 @@ gf110_disp_dmac_fini(struct nvkm_object *object, bool suspend)
...
@@ -126,21 +129,22 @@ gf110_disp_dmac_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
dmac
->
base
.
chid
;
int
chid
=
dmac
->
base
.
chid
;
/* deactivate channel */
/* deactivate channel */
nv
_mask
(
disp
,
0x610490
+
(
chid
*
0x0010
),
0x00001010
,
0x00001000
);
nv
km_mask
(
device
,
0x610490
+
(
chid
*
0x0010
),
0x00001010
,
0x00001000
);
nv
_mask
(
disp
,
0x610490
+
(
chid
*
0x0010
),
0x00000003
,
0x00000000
);
nv
km_mask
(
device
,
0x610490
+
(
chid
*
0x0010
),
0x00000003
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x001e0000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x001e0000
,
0x00000000
))
{
nv_error
(
dmac
,
"fini: 0x%08x
\n
"
,
nv_error
(
dmac
,
"fini: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610490
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610490
+
(
chid
*
0x10
)));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
/* disable error reporting and completion notification */
/* disable error reporting and completion notification */
nv
_mask
(
disp
,
0x610090
,
0x00000001
<<
chid
,
0x00000000
);
nv
km_mask
(
device
,
0x610090
,
0x00000001
<<
chid
,
0x00000000
);
nv
_mask
(
disp
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000000
);
nv
km_mask
(
device
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000000
);
return
nv50_disp_chan_fini
(
&
dmac
->
base
,
suspend
);
return
nv50_disp_chan_fini
(
&
dmac
->
base
,
suspend
);
}
}
...
@@ -294,6 +298,7 @@ gf110_disp_core_init(struct nvkm_object *object)
...
@@ -294,6 +298,7 @@ gf110_disp_core_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
ret
;
int
ret
;
ret
=
nv50_disp_chan_init
(
&
mast
->
base
);
ret
=
nv50_disp_chan_init
(
&
mast
->
base
);
...
@@ -301,19 +306,19 @@ gf110_disp_core_init(struct nvkm_object *object)
...
@@ -301,19 +306,19 @@ gf110_disp_core_init(struct nvkm_object *object)
return
ret
;
return
ret
;
/* enable error reporting */
/* enable error reporting */
nv
_mask
(
disp
,
0x6100a0
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x6100a0
,
0x00000001
,
0x00000001
);
/* initialise channel for dma command submission */
/* initialise channel for dma command submission */
nv
_wr32
(
disp
,
0x610494
,
mast
->
push
);
nv
km_wr32
(
device
,
0x610494
,
mast
->
push
);
nv
_wr32
(
disp
,
0x610498
,
0x00010000
);
nv
km_wr32
(
device
,
0x610498
,
0x00010000
);
nv
_wr32
(
disp
,
0x61049c
,
0x00000001
);
nv
km_wr32
(
device
,
0x61049c
,
0x00000001
);
nv
_mask
(
disp
,
0x610490
,
0x00000010
,
0x00000010
);
nv
km_mask
(
device
,
0x610490
,
0x00000010
,
0x00000010
);
nv
_wr32
(
disp
,
0x640000
,
0x00000000
);
nv
km_wr32
(
device
,
0x640000
,
0x00000000
);
nv
_wr32
(
disp
,
0x610490
,
0x01000013
);
nv
km_wr32
(
device
,
0x610490
,
0x01000013
);
/* wait for it to go inactive */
/* wait for it to go inactive */
if
(
!
nv_wait
(
disp
,
0x610490
,
0x80000000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610490
,
0x80000000
,
0x00000000
))
{
nv_error
(
mast
,
"init: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610490
));
nv_error
(
mast
,
"init: 0x%08x
\n
"
,
nv
km_rd32
(
device
,
0x610490
));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -325,19 +330,20 @@ gf110_disp_core_fini(struct nvkm_object *object, bool suspend)
...
@@ -325,19 +330,20 @@ gf110_disp_core_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
/* deactivate channel */
/* deactivate channel */
nv
_mask
(
disp
,
0x610490
,
0x00000010
,
0x00000000
);
nv
km_mask
(
device
,
0x610490
,
0x00000010
,
0x00000000
);
nv
_mask
(
disp
,
0x610490
,
0x00000003
,
0x00000000
);
nv
km_mask
(
device
,
0x610490
,
0x00000003
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x610490
,
0x001e0000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610490
,
0x001e0000
,
0x00000000
))
{
nv_error
(
mast
,
"fini: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610490
));
nv_error
(
mast
,
"fini: 0x%08x
\n
"
,
nv
km_rd32
(
device
,
0x610490
));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
/* disable error reporting and completion notification */
/* disable error reporting and completion notification */
nv
_mask
(
disp
,
0x610090
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x610090
,
0x00000001
,
0x00000000
);
nv
_mask
(
disp
,
0x6100a0
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6100a0
,
0x00000001
,
0x00000000
);
return
nv50_disp_chan_fini
(
&
mast
->
base
,
suspend
);
return
nv50_disp_chan_fini
(
&
mast
->
base
,
suspend
);
}
}
...
@@ -541,6 +547,7 @@ gf110_disp_pioc_init(struct nvkm_object *object)
...
@@ -541,6 +547,7 @@ gf110_disp_pioc_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
pioc
->
base
.
chid
;
int
chid
=
pioc
->
base
.
chid
;
int
ret
;
int
ret
;
...
@@ -549,13 +556,13 @@ gf110_disp_pioc_init(struct nvkm_object *object)
...
@@ -549,13 +556,13 @@ gf110_disp_pioc_init(struct nvkm_object *object)
return
ret
;
return
ret
;
/* enable error reporting */
/* enable error reporting */
nv
_mask
(
disp
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000001
<<
chid
);
nv
km_mask
(
device
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000001
<<
chid
);
/* activate channel */
/* activate channel */
nv
_wr32
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x00000001
);
nv
km_wr32
(
device
,
0x610490
+
(
chid
*
0x10
),
0x00000001
);
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x00030000
,
0x00010000
))
{
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x00030000
,
0x00010000
))
{
nv_error
(
pioc
,
"init: 0x%08x
\n
"
,
nv_error
(
pioc
,
"init: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610490
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610490
+
(
chid
*
0x10
)));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -567,19 +574,20 @@ gf110_disp_pioc_fini(struct nvkm_object *object, bool suspend)
...
@@ -567,19 +574,20 @@ gf110_disp_pioc_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
pioc
->
base
.
chid
;
int
chid
=
pioc
->
base
.
chid
;
nv
_mask
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x610490
+
(
chid
*
0x10
),
0x00000001
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x00030000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610490
+
(
chid
*
0x10
),
0x00030000
,
0x00000000
))
{
nv_error
(
pioc
,
"timeout: 0x%08x
\n
"
,
nv_error
(
pioc
,
"timeout: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610490
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610490
+
(
chid
*
0x10
)));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
/* disable error reporting and completion notification */
/* disable error reporting and completion notification */
nv
_mask
(
disp
,
0x610090
,
0x00000001
<<
chid
,
0x00000000
);
nv
km_mask
(
device
,
0x610090
,
0x00000001
<<
chid
,
0x00000000
);
nv
_mask
(
disp
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000000
);
nv
km_mask
(
device
,
0x6100a0
,
0x00000001
<<
chid
,
0x00000000
);
return
nv50_disp_chan_fini
(
&
pioc
->
base
,
suspend
);
return
nv50_disp_chan_fini
(
&
pioc
->
base
,
suspend
);
}
}
...
@@ -625,9 +633,10 @@ gf110_disp_curs_ofuncs = {
...
@@ -625,9 +633,10 @@ gf110_disp_curs_ofuncs = {
int
int
gf110_disp_main_scanoutpos
(
NV50_DISP_MTHD_V0
)
gf110_disp_main_scanoutpos
(
NV50_DISP_MTHD_V0
)
{
{
const
u32
total
=
nv_rd32
(
disp
,
0x640414
+
(
head
*
0x300
));
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
blanke
=
nv_rd32
(
disp
,
0x64041c
+
(
head
*
0x300
));
const
u32
total
=
nvkm_rd32
(
device
,
0x640414
+
(
head
*
0x300
));
const
u32
blanks
=
nv_rd32
(
disp
,
0x640420
+
(
head
*
0x300
));
const
u32
blanke
=
nvkm_rd32
(
device
,
0x64041c
+
(
head
*
0x300
));
const
u32
blanks
=
nvkm_rd32
(
device
,
0x640420
+
(
head
*
0x300
));
union
{
union
{
struct
nv04_disp_scanoutpos_v0
v0
;
struct
nv04_disp_scanoutpos_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
...
@@ -644,10 +653,10 @@ gf110_disp_main_scanoutpos(NV50_DISP_MTHD_V0)
...
@@ -644,10 +653,10 @@ gf110_disp_main_scanoutpos(NV50_DISP_MTHD_V0)
args
->
v0
.
htotal
=
(
total
&
0x0000ffff
);
args
->
v0
.
htotal
=
(
total
&
0x0000ffff
);
args
->
v0
.
time
[
0
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
time
[
0
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
vline
=
/* vline read locks hline */
args
->
v0
.
vline
=
/* vline read locks hline */
nv
_rd32
(
disp
,
0x616340
+
(
head
*
0x800
))
&
0xffff
;
nv
km_rd32
(
device
,
0x616340
+
(
head
*
0x800
))
&
0xffff
;
args
->
v0
.
time
[
1
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
time
[
1
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
hline
=
args
->
v0
.
hline
=
nv
_rd32
(
disp
,
0x616344
+
(
head
*
0x800
))
&
0xffff
;
nv
km_rd32
(
device
,
0x616344
+
(
head
*
0x800
))
&
0xffff
;
}
else
}
else
return
ret
;
return
ret
;
...
@@ -659,6 +668,7 @@ gf110_disp_main_init(struct nvkm_object *object)
...
@@ -659,6 +668,7 @@ gf110_disp_main_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
ret
,
i
;
int
ret
,
i
;
u32
tmp
;
u32
tmp
;
...
@@ -673,30 +683,30 @@ gf110_disp_main_init(struct nvkm_object *object)
...
@@ -673,30 +683,30 @@ gf110_disp_main_init(struct nvkm_object *object)
/* ... CRTC caps */
/* ... CRTC caps */
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x616104
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x616104
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101b4
+
(
i
*
0x800
),
tmp
);
nv
km_wr32
(
device
,
0x6101b4
+
(
i
*
0x800
),
tmp
);
tmp
=
nv
_rd32
(
disp
,
0x616108
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x616108
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101b8
+
(
i
*
0x800
),
tmp
);
nv
km_wr32
(
device
,
0x6101b8
+
(
i
*
0x800
),
tmp
);
tmp
=
nv
_rd32
(
disp
,
0x61610c
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61610c
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101bc
+
(
i
*
0x800
),
tmp
);
nv
km_wr32
(
device
,
0x6101bc
+
(
i
*
0x800
),
tmp
);
}
}
/* ... DAC caps */
/* ... DAC caps */
for
(
i
=
0
;
i
<
disp
->
dac
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
dac
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x61a000
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61a000
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101c0
+
(
i
*
0x800
),
tmp
);
nv
km_wr32
(
device
,
0x6101c0
+
(
i
*
0x800
),
tmp
);
}
}
/* ... SOR caps */
/* ... SOR caps */
for
(
i
=
0
;
i
<
disp
->
sor
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
sor
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x61c000
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61c000
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6301c4
+
(
i
*
0x800
),
tmp
);
nv
km_wr32
(
device
,
0x6301c4
+
(
i
*
0x800
),
tmp
);
}
}
/* steal display away from vbios, or something like that */
/* steal display away from vbios, or something like that */
if
(
nv
_rd32
(
disp
,
0x6100ac
)
&
0x00000100
)
{
if
(
nv
km_rd32
(
device
,
0x6100ac
)
&
0x00000100
)
{
nv
_wr32
(
disp
,
0x6100ac
,
0x00000100
);
nv
km_wr32
(
device
,
0x6100ac
,
0x00000100
);
nv
_mask
(
disp
,
0x6194e8
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6194e8
,
0x00000001
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x6194e8
,
0x00000002
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x6194e8
,
0x00000002
,
0x00000000
))
{
nv_error
(
disp
,
"timeout acquiring display
\n
"
);
nv_error
(
disp
,
"timeout acquiring display
\n
"
);
return
-
EBUSY
;
return
-
EBUSY
;
...
@@ -704,12 +714,12 @@ gf110_disp_main_init(struct nvkm_object *object)
...
@@ -704,12 +714,12 @@ gf110_disp_main_init(struct nvkm_object *object)
}
}
/* point at display engine memory area (hash table, objects) */
/* point at display engine memory area (hash table, objects) */
nv
_wr32
(
disp
,
0x610010
,
(
nv_gpuobj
(
object
->
parent
)
->
addr
>>
8
)
|
9
);
nv
km_wr32
(
device
,
0x610010
,
(
nv_gpuobj
(
object
->
parent
)
->
addr
>>
8
)
|
9
);
/* enable supervisor interrupts, disable everything else */
/* enable supervisor interrupts, disable everything else */
nv
_wr32
(
disp
,
0x610090
,
0x00000000
);
nv
km_wr32
(
device
,
0x610090
,
0x00000000
);
nv
_wr32
(
disp
,
0x6100a0
,
0x00000000
);
nv
km_wr32
(
device
,
0x6100a0
,
0x00000000
);
nv
_wr32
(
disp
,
0x6100b0
,
0x00000307
);
nv
km_wr32
(
device
,
0x6100b0
,
0x00000307
);
/* disable underflow reporting, preventing an intermittent issue
/* disable underflow reporting, preventing an intermittent issue
* on some gk104 boards where the production vbios left this
* on some gk104 boards where the production vbios left this
...
@@ -718,7 +728,7 @@ gf110_disp_main_init(struct nvkm_object *object)
...
@@ -718,7 +728,7 @@ gf110_disp_main_init(struct nvkm_object *object)
* ftp://download.nvidia.com/open-gpu-doc/gk104-disable-underflow-reporting/1/gk104-disable-underflow-reporting.txt
* ftp://download.nvidia.com/open-gpu-doc/gk104-disable-underflow-reporting/1/gk104-disable-underflow-reporting.txt
*/
*/
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
nv
_mask
(
disp
,
0x616308
+
(
i
*
0x800
),
0x00000111
,
0x00000010
);
nv
km_mask
(
device
,
0x616308
+
(
i
*
0x800
),
0x00000111
,
0x00000010
);
return
0
;
return
0
;
}
}
...
@@ -728,9 +738,10 @@ gf110_disp_main_fini(struct nvkm_object *object, bool suspend)
...
@@ -728,9 +738,10 @@ gf110_disp_main_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
/* disable all interrupts */
/* disable all interrupts */
nv
_wr32
(
disp
,
0x6100b0
,
0x00000000
);
nv
km_wr32
(
device
,
0x6100b0
,
0x00000000
);
return
nvkm_parent_fini
(
&
base
->
base
,
suspend
);
return
nvkm_parent_fini
(
&
base
->
base
,
suspend
);
}
}
...
@@ -769,14 +780,16 @@ static void
...
@@ -769,14 +780,16 @@ static void
gf110_disp_vblank_init
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
gf110_disp_vblank_init
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
{
{
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
nv_mask
(
disp
,
0x6100c0
+
(
head
*
0x800
),
0x00000001
,
0x00000001
);
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
nvkm_mask
(
device
,
0x6100c0
+
(
head
*
0x800
),
0x00000001
,
0x00000001
);
}
}
static
void
static
void
gf110_disp_vblank_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
gf110_disp_vblank_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
{
{
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
nv_mask
(
disp
,
0x6100c0
+
(
head
*
0x800
),
0x00000001
,
0x00000000
);
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
nvkm_mask
(
device
,
0x6100c0
+
(
head
*
0x800
),
0x00000001
,
0x00000000
);
}
}
const
struct
nvkm_event_func
const
struct
nvkm_event_func
...
@@ -835,7 +848,8 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl,
...
@@ -835,7 +848,8 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl,
static
struct
nvkm_output
*
static
struct
nvkm_output
*
exec_script
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
)
exec_script
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
)
{
{
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
struct
nvbios_outp
info
;
struct
nvbios_outp
info
;
u8
ver
,
hdr
,
cnt
,
len
;
u8
ver
,
hdr
,
cnt
,
len
;
...
@@ -843,7 +857,7 @@ exec_script(struct nv50_disp *disp, int head, int id)
...
@@ -843,7 +857,7 @@ exec_script(struct nv50_disp *disp, int head, int id)
int
or
;
int
or
;
for
(
or
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
or
<
8
;
or
++
)
{
for
(
or
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
or
<
8
;
or
++
)
{
ctrl
=
nv
_rd32
(
disp
,
0x640180
+
(
or
*
0x20
));
ctrl
=
nv
km_rd32
(
device
,
0x640180
+
(
or
*
0x20
));
if
(
ctrl
&
(
1
<<
head
))
if
(
ctrl
&
(
1
<<
head
))
break
;
break
;
}
}
...
@@ -871,7 +885,8 @@ exec_script(struct nv50_disp *disp, int head, int id)
...
@@ -871,7 +885,8 @@ exec_script(struct nv50_disp *disp, int head, int id)
static
struct
nvkm_output
*
static
struct
nvkm_output
*
exec_clkcmp
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
,
u32
pclk
,
u32
*
conf
)
exec_clkcmp
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
,
u32
pclk
,
u32
*
conf
)
{
{
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
struct
nvbios_outp
info1
;
struct
nvbios_outp
info1
;
struct
nvbios_ocfg
info2
;
struct
nvbios_ocfg
info2
;
...
@@ -880,7 +895,7 @@ exec_clkcmp(struct nv50_disp *disp, int head, int id, u32 pclk, u32 *conf)
...
@@ -880,7 +895,7 @@ exec_clkcmp(struct nv50_disp *disp, int head, int id, u32 pclk, u32 *conf)
int
or
;
int
or
;
for
(
or
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
or
<
8
;
or
++
)
{
for
(
or
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
or
<
8
;
or
++
)
{
ctrl
=
nv
_rd32
(
disp
,
0x660180
+
(
or
*
0x20
));
ctrl
=
nv
km_rd32
(
device
,
0x660180
+
(
or
*
0x20
));
if
(
ctrl
&
(
1
<<
head
))
if
(
ctrl
&
(
1
<<
head
))
break
;
break
;
}
}
...
@@ -961,32 +976,34 @@ gf110_disp_intr_unk2_0(struct nv50_disp *disp, int head)
...
@@ -961,32 +976,34 @@ gf110_disp_intr_unk2_0(struct nv50_disp *disp, int head)
static
void
static
void
gf110_disp_intr_unk2_1
(
struct
nv50_disp
*
disp
,
int
head
)
gf110_disp_intr_unk2_1
(
struct
nv50_disp
*
disp
,
int
head
)
{
{
struct
nvkm_devinit
*
devinit
=
nvkm_devinit
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
pclk
=
nv_rd32
(
disp
,
0x660450
+
(
head
*
0x300
))
/
1000
;
struct
nvkm_devinit
*
devinit
=
device
->
devinit
;
u32
pclk
=
nvkm_rd32
(
device
,
0x660450
+
(
head
*
0x300
))
/
1000
;
if
(
pclk
)
if
(
pclk
)
devinit
->
pll_set
(
devinit
,
PLL_VPLL0
+
head
,
pclk
);
devinit
->
pll_set
(
devinit
,
PLL_VPLL0
+
head
,
pclk
);
nv
_wr32
(
disp
,
0x612200
+
(
head
*
0x800
),
0x00000000
);
nv
km_wr32
(
device
,
0x612200
+
(
head
*
0x800
),
0x00000000
);
}
}
static
void
static
void
gf110_disp_intr_unk2_2_tu
(
struct
nv50_disp
*
disp
,
int
head
,
gf110_disp_intr_unk2_2_tu
(
struct
nv50_disp
*
disp
,
int
head
,
struct
dcb_output
*
outp
)
struct
dcb_output
*
outp
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
int
or
=
ffs
(
outp
->
or
)
-
1
;
const
int
or
=
ffs
(
outp
->
or
)
-
1
;
const
u32
ctrl
=
nv
_rd32
(
disp
,
0x660200
+
(
or
*
0x020
));
const
u32
ctrl
=
nv
km_rd32
(
device
,
0x660200
+
(
or
*
0x020
));
const
u32
conf
=
nv
_rd32
(
disp
,
0x660404
+
(
head
*
0x300
));
const
u32
conf
=
nv
km_rd32
(
device
,
0x660404
+
(
head
*
0x300
));
const
s32
vactive
=
nv
_rd32
(
disp
,
0x660414
+
(
head
*
0x300
))
&
0xffff
;
const
s32
vactive
=
nv
km_rd32
(
device
,
0x660414
+
(
head
*
0x300
))
&
0xffff
;
const
s32
vblanke
=
nv
_rd32
(
disp
,
0x66041c
+
(
head
*
0x300
))
&
0xffff
;
const
s32
vblanke
=
nv
km_rd32
(
device
,
0x66041c
+
(
head
*
0x300
))
&
0xffff
;
const
s32
vblanks
=
nv
_rd32
(
disp
,
0x660420
+
(
head
*
0x300
))
&
0xffff
;
const
s32
vblanks
=
nv
km_rd32
(
device
,
0x660420
+
(
head
*
0x300
))
&
0xffff
;
const
u32
pclk
=
nv
_rd32
(
disp
,
0x660450
+
(
head
*
0x300
))
/
1000
;
const
u32
pclk
=
nv
km_rd32
(
device
,
0x660450
+
(
head
*
0x300
))
/
1000
;
const
u32
link
=
((
ctrl
&
0xf00
)
==
0x800
)
?
0
:
1
;
const
u32
link
=
((
ctrl
&
0xf00
)
==
0x800
)
?
0
:
1
;
const
u32
hoff
=
(
head
*
0x800
);
const
u32
hoff
=
(
head
*
0x800
);
const
u32
soff
=
(
or
*
0x800
);
const
u32
soff
=
(
or
*
0x800
);
const
u32
loff
=
(
link
*
0x080
)
+
soff
;
const
u32
loff
=
(
link
*
0x080
)
+
soff
;
const
u32
symbol
=
100000
;
const
u32
symbol
=
100000
;
const
u32
TU
=
64
;
const
u32
TU
=
64
;
u32
dpctrl
=
nv
_rd32
(
disp
,
0x61c10c
+
loff
);
u32
dpctrl
=
nv
km_rd32
(
device
,
0x61c10c
+
loff
);
u32
clksor
=
nv
_rd32
(
disp
,
0x612300
+
soff
);
u32
clksor
=
nv
km_rd32
(
device
,
0x612300
+
soff
);
u32
datarate
,
link_nr
,
link_bw
,
bits
;
u32
datarate
,
link_nr
,
link_bw
,
bits
;
u64
ratio
,
value
;
u64
ratio
,
value
;
...
@@ -999,14 +1016,14 @@ gf110_disp_intr_unk2_2_tu(struct nv50_disp *disp, int head,
...
@@ -999,14 +1016,14 @@ gf110_disp_intr_unk2_2_tu(struct nv50_disp *disp, int head,
value
=
value
*
link_bw
;
value
=
value
*
link_bw
;
do_div
(
value
,
pclk
);
do_div
(
value
,
pclk
);
value
=
value
-
(
3
*
!!
(
dpctrl
&
0x00004000
))
-
(
12
/
link_nr
);
value
=
value
-
(
3
*
!!
(
dpctrl
&
0x00004000
))
-
(
12
/
link_nr
);
nv
_mask
(
disp
,
0x616620
+
hoff
,
0x0000ffff
,
value
);
nv
km_mask
(
device
,
0x616620
+
hoff
,
0x0000ffff
,
value
);
/* symbols/vblank - algorithm taken from comments in tegra driver */
/* symbols/vblank - algorithm taken from comments in tegra driver */
value
=
vblanks
-
vblanke
-
25
;
value
=
vblanks
-
vblanke
-
25
;
value
=
value
*
link_bw
;
value
=
value
*
link_bw
;
do_div
(
value
,
pclk
);
do_div
(
value
,
pclk
);
value
=
value
-
((
36
/
link_nr
)
+
3
)
-
1
;
value
=
value
-
((
36
/
link_nr
)
+
3
)
-
1
;
nv
_mask
(
disp
,
0x616624
+
hoff
,
0x00ffffff
,
value
);
nv
km_mask
(
device
,
0x616624
+
hoff
,
0x00ffffff
,
value
);
/* watermark */
/* watermark */
if
((
conf
&
0x3c0
)
==
0x180
)
bits
=
30
;
if
((
conf
&
0x3c0
)
==
0x180
)
bits
=
30
;
...
@@ -1026,14 +1043,15 @@ gf110_disp_intr_unk2_2_tu(struct nv50_disp *disp, int head,
...
@@ -1026,14 +1043,15 @@ gf110_disp_intr_unk2_2_tu(struct nv50_disp *disp, int head,
value
+=
5
;
value
+=
5
;
value
|=
0x08000000
;
value
|=
0x08000000
;
nv
_wr32
(
disp
,
0x616610
+
hoff
,
value
);
nv
km_wr32
(
device
,
0x616610
+
hoff
,
value
);
}
}
static
void
static
void
gf110_disp_intr_unk2_2
(
struct
nv50_disp
*
disp
,
int
head
)
gf110_disp_intr_unk2_2
(
struct
nv50_disp
*
disp
,
int
head
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
u32
pclk
=
nv
_rd32
(
disp
,
0x660450
+
(
head
*
0x300
))
/
1000
;
u32
pclk
=
nv
km_rd32
(
device
,
0x660450
+
(
head
*
0x300
))
/
1000
;
u32
conf
,
addr
,
data
;
u32
conf
,
addr
,
data
;
outp
=
exec_clkcmp
(
disp
,
head
,
0xff
,
pclk
,
&
conf
);
outp
=
exec_clkcmp
(
disp
,
head
,
0xff
,
pclk
,
&
conf
);
...
@@ -1042,7 +1060,7 @@ gf110_disp_intr_unk2_2(struct nv50_disp *disp, int head)
...
@@ -1042,7 +1060,7 @@ gf110_disp_intr_unk2_2(struct nv50_disp *disp, int head)
/* see note in nv50_disp_intr_unk20_2() */
/* see note in nv50_disp_intr_unk20_2() */
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
u32
sync
=
nv
_rd32
(
disp
,
0x660404
+
(
head
*
0x300
));
u32
sync
=
nv
km_rd32
(
device
,
0x660404
+
(
head
*
0x300
));
switch
((
sync
&
0x000003c0
)
>>
6
)
{
switch
((
sync
&
0x000003c0
)
>>
6
)
{
case
6
:
pclk
=
pclk
*
30
;
break
;
case
6
:
pclk
=
pclk
*
30
;
break
;
case
5
:
pclk
=
pclk
*
24
;
break
;
case
5
:
pclk
=
pclk
*
24
;
break
;
...
@@ -1069,7 +1087,7 @@ gf110_disp_intr_unk2_2(struct nv50_disp *disp, int head)
...
@@ -1069,7 +1087,7 @@ gf110_disp_intr_unk2_2(struct nv50_disp *disp, int head)
data
=
(
conf
&
0x0100
)
?
0x00000101
:
0x00000000
;
data
=
(
conf
&
0x0100
)
?
0x00000101
:
0x00000000
;
switch
(
outp
->
info
.
type
)
{
switch
(
outp
->
info
.
type
)
{
case
DCB_OUTPUT_TMDS
:
case
DCB_OUTPUT_TMDS
:
nv
_mask
(
disp
,
addr
,
0x007c0000
,
0x00280000
);
nv
km_mask
(
device
,
addr
,
0x007c0000
,
0x00280000
);
break
;
break
;
case
DCB_OUTPUT_DP
:
case
DCB_OUTPUT_DP
:
gf110_disp_intr_unk2_2_tu
(
disp
,
head
,
&
outp
->
info
);
gf110_disp_intr_unk2_2_tu
(
disp
,
head
,
&
outp
->
info
);
...
@@ -1079,13 +1097,14 @@ gf110_disp_intr_unk2_2(struct nv50_disp *disp, int head)
...
@@ -1079,13 +1097,14 @@ gf110_disp_intr_unk2_2(struct nv50_disp *disp, int head)
}
}
}
}
nv
_mask
(
disp
,
addr
,
0x00000707
,
data
);
nv
km_mask
(
device
,
addr
,
0x00000707
,
data
);
}
}
static
void
static
void
gf110_disp_intr_unk4_0
(
struct
nv50_disp
*
disp
,
int
head
)
gf110_disp_intr_unk4_0
(
struct
nv50_disp
*
disp
,
int
head
)
{
{
u32
pclk
=
nv_rd32
(
disp
,
0x660450
+
(
head
*
0x300
))
/
1000
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
pclk
=
nvkm_rd32
(
device
,
0x660450
+
(
head
*
0x300
))
/
1000
;
u32
conf
;
u32
conf
;
exec_clkcmp
(
disp
,
head
,
1
,
pclk
,
&
conf
);
exec_clkcmp
(
disp
,
head
,
1
,
pclk
,
&
conf
);
...
@@ -1097,12 +1116,13 @@ gf110_disp_intr_supervisor(struct work_struct *work)
...
@@ -1097,12 +1116,13 @@ gf110_disp_intr_supervisor(struct work_struct *work)
struct
nv50_disp
*
disp
=
struct
nv50_disp
*
disp
=
container_of
(
work
,
struct
nv50_disp
,
supervisor
);
container_of
(
work
,
struct
nv50_disp
,
supervisor
);
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
mask
[
4
];
u32
mask
[
4
];
int
head
;
int
head
;
nv_debug
(
disp
,
"supervisor %d
\n
"
,
ffs
(
disp
->
super
));
nv_debug
(
disp
,
"supervisor %d
\n
"
,
ffs
(
disp
->
super
));
for
(
head
=
0
;
head
<
disp
->
head
.
nr
;
head
++
)
{
for
(
head
=
0
;
head
<
disp
->
head
.
nr
;
head
++
)
{
mask
[
head
]
=
nv
_rd32
(
disp
,
0x6101d4
+
(
head
*
0x800
));
mask
[
head
]
=
nv
km_rd32
(
device
,
0x6101d4
+
(
head
*
0x800
));
nv_debug
(
disp
,
"head %d: 0x%08x
\n
"
,
head
,
mask
[
head
]);
nv_debug
(
disp
,
"head %d: 0x%08x
\n
"
,
head
,
mask
[
head
]);
}
}
...
@@ -1145,17 +1165,18 @@ gf110_disp_intr_supervisor(struct work_struct *work)
...
@@ -1145,17 +1165,18 @@ gf110_disp_intr_supervisor(struct work_struct *work)
}
}
for
(
head
=
0
;
head
<
disp
->
head
.
nr
;
head
++
)
for
(
head
=
0
;
head
<
disp
->
head
.
nr
;
head
++
)
nv
_wr32
(
disp
,
0x6101d4
+
(
head
*
0x800
),
0x00000000
);
nv
km_wr32
(
device
,
0x6101d4
+
(
head
*
0x800
),
0x00000000
);
nv
_wr32
(
disp
,
0x6101d0
,
0x80000000
);
nv
km_wr32
(
device
,
0x6101d0
,
0x80000000
);
}
}
static
void
static
void
gf110_disp_intr_error
(
struct
nv50_disp
*
disp
,
int
chid
)
gf110_disp_intr_error
(
struct
nv50_disp
*
disp
,
int
chid
)
{
{
const
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
const
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
u32
mthd
=
nv_rd32
(
disp
,
0x6101f0
+
(
chid
*
12
));
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
data
=
nv_rd32
(
disp
,
0x6101f4
+
(
chid
*
12
));
u32
mthd
=
nvkm_rd32
(
device
,
0x6101f0
+
(
chid
*
12
));
u32
unkn
=
nv_rd32
(
disp
,
0x6101f8
+
(
chid
*
12
));
u32
data
=
nvkm_rd32
(
device
,
0x6101f4
+
(
chid
*
12
));
u32
unkn
=
nvkm_rd32
(
device
,
0x6101f8
+
(
chid
*
12
));
nv_error
(
disp
,
"chid %d mthd 0x%04x data 0x%08x "
nv_error
(
disp
,
"chid %d mthd 0x%04x data 0x%08x "
"0x%08x 0x%08x
\n
"
,
"0x%08x 0x%08x
\n
"
,
...
@@ -1192,29 +1213,30 @@ gf110_disp_intr_error(struct nv50_disp *disp, int chid)
...
@@ -1192,29 +1213,30 @@ gf110_disp_intr_error(struct nv50_disp *disp, int chid)
}
}
}
}
nv
_wr32
(
disp
,
0x61009c
,
(
1
<<
chid
));
nv
km_wr32
(
device
,
0x61009c
,
(
1
<<
chid
));
nv
_wr32
(
disp
,
0x6101f0
+
(
chid
*
12
),
0x90000000
);
nv
km_wr32
(
device
,
0x6101f0
+
(
chid
*
12
),
0x90000000
);
}
}
void
void
gf110_disp_intr
(
struct
nvkm_subdev
*
subdev
)
gf110_disp_intr
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
subdev
;
struct
nv50_disp
*
disp
=
(
void
*
)
subdev
;
u32
intr
=
nv_rd32
(
disp
,
0x610088
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
intr
=
nvkm_rd32
(
device
,
0x610088
);
int
i
;
int
i
;
if
(
intr
&
0x00000001
)
{
if
(
intr
&
0x00000001
)
{
u32
stat
=
nv
_rd32
(
disp
,
0x61008c
);
u32
stat
=
nv
km_rd32
(
device
,
0x61008c
);
while
(
stat
)
{
while
(
stat
)
{
int
chid
=
__ffs
(
stat
);
stat
&=
~
(
1
<<
chid
);
int
chid
=
__ffs
(
stat
);
stat
&=
~
(
1
<<
chid
);
nv50_disp_chan_uevent_send
(
disp
,
chid
);
nv50_disp_chan_uevent_send
(
disp
,
chid
);
nv
_wr32
(
disp
,
0x61008c
,
1
<<
chid
);
nv
km_wr32
(
device
,
0x61008c
,
1
<<
chid
);
}
}
intr
&=
~
0x00000001
;
intr
&=
~
0x00000001
;
}
}
if
(
intr
&
0x00000002
)
{
if
(
intr
&
0x00000002
)
{
u32
stat
=
nv
_rd32
(
disp
,
0x61009c
);
u32
stat
=
nv
km_rd32
(
device
,
0x61009c
);
int
chid
=
ffs
(
stat
)
-
1
;
int
chid
=
ffs
(
stat
)
-
1
;
if
(
chid
>=
0
)
if
(
chid
>=
0
)
gf110_disp_intr_error
(
disp
,
chid
);
gf110_disp_intr_error
(
disp
,
chid
);
...
@@ -1222,17 +1244,17 @@ gf110_disp_intr(struct nvkm_subdev *subdev)
...
@@ -1222,17 +1244,17 @@ gf110_disp_intr(struct nvkm_subdev *subdev)
}
}
if
(
intr
&
0x00100000
)
{
if
(
intr
&
0x00100000
)
{
u32
stat
=
nv
_rd32
(
disp
,
0x6100ac
);
u32
stat
=
nv
km_rd32
(
device
,
0x6100ac
);
if
(
stat
&
0x00000007
)
{
if
(
stat
&
0x00000007
)
{
disp
->
super
=
(
stat
&
0x00000007
);
disp
->
super
=
(
stat
&
0x00000007
);
schedule_work
(
&
disp
->
supervisor
);
schedule_work
(
&
disp
->
supervisor
);
nv
_wr32
(
disp
,
0x6100ac
,
disp
->
super
);
nv
km_wr32
(
device
,
0x6100ac
,
disp
->
super
);
stat
&=
~
0x00000007
;
stat
&=
~
0x00000007
;
}
}
if
(
stat
)
{
if
(
stat
)
{
nv_info
(
disp
,
"unknown intr24 0x%08x
\n
"
,
stat
);
nv_info
(
disp
,
"unknown intr24 0x%08x
\n
"
,
stat
);
nv
_wr32
(
disp
,
0x6100ac
,
stat
);
nv
km_wr32
(
device
,
0x6100ac
,
stat
);
}
}
intr
&=
~
0x00100000
;
intr
&=
~
0x00100000
;
...
@@ -1241,11 +1263,11 @@ gf110_disp_intr(struct nvkm_subdev *subdev)
...
@@ -1241,11 +1263,11 @@ gf110_disp_intr(struct nvkm_subdev *subdev)
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
{
u32
mask
=
0x01000000
<<
i
;
u32
mask
=
0x01000000
<<
i
;
if
(
mask
&
intr
)
{
if
(
mask
&
intr
)
{
u32
stat
=
nv
_rd32
(
disp
,
0x6100bc
+
(
i
*
0x800
));
u32
stat
=
nv
km_rd32
(
device
,
0x6100bc
+
(
i
*
0x800
));
if
(
stat
&
0x00000001
)
if
(
stat
&
0x00000001
)
nvkm_disp_vblank
(
&
disp
->
base
,
i
);
nvkm_disp_vblank
(
&
disp
->
base
,
i
);
nv
_mask
(
disp
,
0x6100bc
+
(
i
*
0x800
),
0
,
0
);
nv
km_mask
(
device
,
0x6100bc
+
(
i
*
0x800
),
0
,
0
);
nv
_rd32
(
disp
,
0x6100c0
+
(
i
*
0x800
));
nv
km_rd32
(
device
,
0x6100c0
+
(
i
*
0x800
));
}
}
}
}
}
}
...
@@ -1255,8 +1277,9 @@ gf110_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -1255,8 +1277,9 @@ gf110_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_object
**
pobject
)
struct
nvkm_object
**
pobject
)
{
{
struct
nvkm_device
*
device
=
(
void
*
)
parent
;
struct
nv50_disp
*
disp
;
struct
nv50_disp
*
disp
;
int
heads
=
nv
_rd32
(
parent
,
0x022448
);
int
heads
=
nv
km_rd32
(
device
,
0x022448
);
int
ret
;
int
ret
;
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/gk104.c
View file @
2fde1f1c
...
@@ -219,8 +219,9 @@ gk104_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -219,8 +219,9 @@ gk104_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_object
**
pobject
)
struct
nvkm_object
**
pobject
)
{
{
struct
nvkm_device
*
device
=
(
void
*
)
parent
;
struct
nv50_disp
*
disp
;
struct
nv50_disp
*
disp
;
int
heads
=
nv
_rd32
(
parent
,
0x022448
);
int
heads
=
nv
km_rd32
(
device
,
0x022448
);
int
ret
;
int
ret
;
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/gk110.c
View file @
2fde1f1c
...
@@ -54,8 +54,9 @@ gk110_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -54,8 +54,9 @@ gk110_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_object
**
pobject
)
struct
nvkm_object
**
pobject
)
{
{
struct
nvkm_device
*
device
=
(
void
*
)
parent
;
struct
nv50_disp
*
disp
;
struct
nv50_disp
*
disp
;
int
heads
=
nv
_rd32
(
parent
,
0x022448
);
int
heads
=
nv
km_rd32
(
device
,
0x022448
);
int
ret
;
int
ret
;
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/gm107.c
View file @
2fde1f1c
...
@@ -54,8 +54,9 @@ gm107_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -54,8 +54,9 @@ gm107_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_object
**
pobject
)
struct
nvkm_object
**
pobject
)
{
{
struct
nvkm_device
*
device
=
(
void
*
)
parent
;
struct
nv50_disp
*
disp
;
struct
nv50_disp
*
disp
;
int
heads
=
nv
_rd32
(
parent
,
0x022448
);
int
heads
=
nv
km_rd32
(
device
,
0x022448
);
int
ret
;
int
ret
;
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/gm204.c
View file @
2fde1f1c
...
@@ -55,8 +55,9 @@ gm204_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -55,8 +55,9 @@ gm204_disp_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_oclass
*
oclass
,
void
*
data
,
u32
size
,
struct
nvkm_object
**
pobject
)
struct
nvkm_object
**
pobject
)
{
{
struct
nvkm_device
*
device
=
(
void
*
)
parent
;
struct
nv50_disp
*
disp
;
struct
nv50_disp
*
disp
;
int
heads
=
nv
_rd32
(
parent
,
0x022448
);
int
heads
=
nv
km_rd32
(
device
,
0x022448
);
int
ret
;
int
ret
;
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
ret
=
nvkm_disp_create
(
parent
,
engine
,
oclass
,
heads
,
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagf110.c
View file @
2fde1f1c
...
@@ -35,6 +35,7 @@
...
@@ -35,6 +35,7 @@
int
int
gf110_hda_eld
(
NV50_DISP_MTHD_V1
)
gf110_hda_eld
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
union
{
union
{
struct
nv50_disp_sor_hda_eld_v0
v0
;
struct
nv50_disp_sor_hda_eld_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
...
@@ -52,21 +53,21 @@ gf110_hda_eld(NV50_DISP_MTHD_V1)
...
@@ -52,21 +53,21 @@ gf110_hda_eld(NV50_DISP_MTHD_V1)
if
(
size
&&
args
->
v0
.
data
[
0
])
{
if
(
size
&&
args
->
v0
.
data
[
0
])
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
nv
_mask
(
disp
,
0x616618
+
hoff
,
0x8000000c
,
0x80000001
);
nv
km_mask
(
device
,
0x616618
+
hoff
,
0x8000000c
,
0x80000001
);
nv_wait
(
disp
,
0x616618
+
hoff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x616618
+
hoff
,
0x80000000
,
0x00000000
);
}
}
nv
_mask
(
disp
,
0x616548
+
hoff
,
0x00000070
,
0x00000000
);
nv
km_mask
(
device
,
0x616548
+
hoff
,
0x00000070
,
0x00000000
);
for
(
i
=
0
;
i
<
size
;
i
++
)
for
(
i
=
0
;
i
<
size
;
i
++
)
nv
_wr32
(
disp
,
0x10ec00
+
soff
,
(
i
<<
8
)
|
args
->
v0
.
data
[
i
]);
nv
km_wr32
(
device
,
0x10ec00
+
soff
,
(
i
<<
8
)
|
args
->
v0
.
data
[
i
]);
for
(;
i
<
0x60
;
i
++
)
for
(;
i
<
0x60
;
i
++
)
nv
_wr32
(
disp
,
0x10ec00
+
soff
,
(
i
<<
8
));
nv
km_wr32
(
device
,
0x10ec00
+
soff
,
(
i
<<
8
));
nv
_mask
(
disp
,
0x10ec10
+
soff
,
0x80000003
,
0x80000003
);
nv
km_mask
(
device
,
0x10ec10
+
soff
,
0x80000003
,
0x80000003
);
}
else
{
}
else
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
nv
_mask
(
disp
,
0x616618
+
hoff
,
0x80000001
,
0x80000000
);
nv
km_mask
(
device
,
0x616618
+
hoff
,
0x80000001
,
0x80000000
);
nv_wait
(
disp
,
0x616618
+
hoff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x616618
+
hoff
,
0x80000000
,
0x00000000
);
}
}
nv
_mask
(
disp
,
0x10ec10
+
soff
,
0x80000003
,
0x80000000
|
!!
size
);
nv
km_mask
(
device
,
0x10ec10
+
soff
,
0x80000003
,
0x80000000
|
!!
size
);
}
}
return
0
;
return
0
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdagt215.c
View file @
2fde1f1c
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
int
int
gt215_hda_eld
(
NV50_DISP_MTHD_V1
)
gt215_hda_eld
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
union
{
union
{
struct
nv50_disp_sor_hda_eld_v0
v0
;
struct
nv50_disp_sor_hda_eld_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
...
@@ -49,20 +50,20 @@ gt215_hda_eld(NV50_DISP_MTHD_V1)
...
@@ -49,20 +50,20 @@ gt215_hda_eld(NV50_DISP_MTHD_V1)
if
(
size
&&
args
->
v0
.
data
[
0
])
{
if
(
size
&&
args
->
v0
.
data
[
0
])
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
nv
_mask
(
disp
,
0x61c1e0
+
soff
,
0x8000000d
,
0x80000001
);
nv
km_mask
(
device
,
0x61c1e0
+
soff
,
0x8000000d
,
0x80000001
);
nv_wait
(
disp
,
0x61c1e0
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c1e0
+
soff
,
0x80000000
,
0x00000000
);
}
}
for
(
i
=
0
;
i
<
size
;
i
++
)
for
(
i
=
0
;
i
<
size
;
i
++
)
nv
_wr32
(
disp
,
0x61c440
+
soff
,
(
i
<<
8
)
|
args
->
v0
.
data
[
0
]);
nv
km_wr32
(
device
,
0x61c440
+
soff
,
(
i
<<
8
)
|
args
->
v0
.
data
[
0
]);
for
(;
i
<
0x60
;
i
++
)
for
(;
i
<
0x60
;
i
++
)
nv
_wr32
(
disp
,
0x61c440
+
soff
,
(
i
<<
8
));
nv
km_wr32
(
device
,
0x61c440
+
soff
,
(
i
<<
8
));
nv
_mask
(
disp
,
0x61c448
+
soff
,
0x80000003
,
0x80000003
);
nv
km_mask
(
device
,
0x61c448
+
soff
,
0x80000003
,
0x80000003
);
}
else
{
}
else
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
if
(
outp
->
info
.
type
==
DCB_OUTPUT_DP
)
{
nv
_mask
(
disp
,
0x61c1e0
+
soff
,
0x80000001
,
0x80000000
);
nv
km_mask
(
device
,
0x61c1e0
+
soff
,
0x80000001
,
0x80000000
);
nv_wait
(
disp
,
0x61c1e0
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c1e0
+
soff
,
0x80000000
,
0x00000000
);
}
}
nv
_mask
(
disp
,
0x61c448
+
soff
,
0x80000003
,
0x80000000
|
!!
size
);
nv
km_mask
(
device
,
0x61c448
+
soff
,
0x80000003
,
0x80000000
|
!!
size
);
}
}
return
0
;
return
0
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmig84.c
View file @
2fde1f1c
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
int
int
g84_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
g84_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
hoff
=
(
head
*
0x800
);
const
u32
hoff
=
(
head
*
0x800
);
union
{
union
{
struct
nv50_disp_sor_hdmi_pwr_v0
v0
;
struct
nv50_disp_sor_hdmi_pwr_v0
v0
;
...
@@ -54,38 +55,38 @@ g84_hdmi_ctrl(NV50_DISP_MTHD_V1)
...
@@ -54,38 +55,38 @@ g84_hdmi_ctrl(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
if
(
!
(
ctrl
&
0x40000000
))
{
if
(
!
(
ctrl
&
0x40000000
))
{
nv
_mask
(
disp
,
0x6165a4
+
hoff
,
0x40000000
,
0x00000000
);
nv
km_mask
(
device
,
0x6165a4
+
hoff
,
0x40000000
,
0x00000000
);
nv
_mask
(
disp
,
0x616520
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x616520
+
hoff
,
0x00000001
,
0x00000000
);
nv
_mask
(
disp
,
0x616500
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x616500
+
hoff
,
0x00000001
,
0x00000000
);
return
0
;
return
0
;
}
}
/* AVI InfoFrame */
/* AVI InfoFrame */
nv
_mask
(
disp
,
0x616520
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x616520
+
hoff
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x616528
+
hoff
,
0x000d0282
);
nv
km_wr32
(
device
,
0x616528
+
hoff
,
0x000d0282
);
nv
_wr32
(
disp
,
0x61652c
+
hoff
,
0x0000006f
);
nv
km_wr32
(
device
,
0x61652c
+
hoff
,
0x0000006f
);
nv
_wr32
(
disp
,
0x616530
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x616530
+
hoff
,
0x00000000
);
nv
_wr32
(
disp
,
0x616534
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x616534
+
hoff
,
0x00000000
);
nv
_wr32
(
disp
,
0x616538
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x616538
+
hoff
,
0x00000000
);
nv
_mask
(
disp
,
0x616520
+
hoff
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x616520
+
hoff
,
0x00000001
,
0x00000001
);
/* Audio InfoFrame */
/* Audio InfoFrame */
nv
_mask
(
disp
,
0x616500
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x616500
+
hoff
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x616508
+
hoff
,
0x000a0184
);
nv
km_wr32
(
device
,
0x616508
+
hoff
,
0x000a0184
);
nv
_wr32
(
disp
,
0x61650c
+
hoff
,
0x00000071
);
nv
km_wr32
(
device
,
0x61650c
+
hoff
,
0x00000071
);
nv
_wr32
(
disp
,
0x616510
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x616510
+
hoff
,
0x00000000
);
nv
_mask
(
disp
,
0x616500
+
hoff
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x616500
+
hoff
,
0x00000001
,
0x00000001
);
nv
_mask
(
disp
,
0x6165d0
+
hoff
,
0x00070001
,
0x00010001
);
/* SPARE, HW_CTS */
nv
km_mask
(
device
,
0x6165d0
+
hoff
,
0x00070001
,
0x00010001
);
/* SPARE, HW_CTS */
nv
_mask
(
disp
,
0x616568
+
hoff
,
0x00010101
,
0x00000000
);
/* ACR_CTRL, ?? */
nv
km_mask
(
device
,
0x616568
+
hoff
,
0x00010101
,
0x00000000
);
/* ACR_CTRL, ?? */
nv
_mask
(
disp
,
0x616578
+
hoff
,
0x80000000
,
0x80000000
);
/* ACR_0441_ENABLE */
nv
km_mask
(
device
,
0x616578
+
hoff
,
0x80000000
,
0x80000000
);
/* ACR_0441_ENABLE */
/* ??? */
/* ??? */
nv
_mask
(
disp
,
0x61733c
,
0x00100000
,
0x00100000
);
/* RESETF */
nv
km_mask
(
device
,
0x61733c
,
0x00100000
,
0x00100000
);
/* RESETF */
nv
_mask
(
disp
,
0x61733c
,
0x10000000
,
0x10000000
);
/* LOOKUP_EN */
nv
km_mask
(
device
,
0x61733c
,
0x10000000
,
0x10000000
);
/* LOOKUP_EN */
nv
_mask
(
disp
,
0x61733c
,
0x00100000
,
0x00000000
);
/* !RESETF */
nv
km_mask
(
device
,
0x61733c
,
0x00100000
,
0x00000000
);
/* !RESETF */
/* HDMI_CTRL */
/* HDMI_CTRL */
nv
_mask
(
disp
,
0x6165a4
+
hoff
,
0x5f1f007f
,
ctrl
);
nv
km_mask
(
device
,
0x6165a4
+
hoff
,
0x5f1f007f
,
ctrl
);
return
0
;
return
0
;
}
}
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigf110.c
View file @
2fde1f1c
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
int
int
gf110_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
gf110_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
hoff
=
(
head
*
0x800
);
const
u32
hoff
=
(
head
*
0x800
);
union
{
union
{
struct
nv50_disp_sor_hdmi_pwr_v0
v0
;
struct
nv50_disp_sor_hdmi_pwr_v0
v0
;
...
@@ -53,27 +54,27 @@ gf110_hdmi_ctrl(NV50_DISP_MTHD_V1)
...
@@ -53,27 +54,27 @@ gf110_hdmi_ctrl(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
if
(
!
(
ctrl
&
0x40000000
))
{
if
(
!
(
ctrl
&
0x40000000
))
{
nv
_mask
(
disp
,
0x616798
+
hoff
,
0x40000000
,
0x00000000
);
nv
km_mask
(
device
,
0x616798
+
hoff
,
0x40000000
,
0x00000000
);
nv
_mask
(
disp
,
0x6167a4
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6167a4
+
hoff
,
0x00000001
,
0x00000000
);
nv
_mask
(
disp
,
0x616714
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x616714
+
hoff
,
0x00000001
,
0x00000000
);
return
0
;
return
0
;
}
}
/* AVI InfoFrame */
/* AVI InfoFrame */
nv
_mask
(
disp
,
0x616714
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x616714
+
hoff
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x61671c
+
hoff
,
0x000d0282
);
nv
km_wr32
(
device
,
0x61671c
+
hoff
,
0x000d0282
);
nv
_wr32
(
disp
,
0x616720
+
hoff
,
0x0000006f
);
nv
km_wr32
(
device
,
0x616720
+
hoff
,
0x0000006f
);
nv
_wr32
(
disp
,
0x616724
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x616724
+
hoff
,
0x00000000
);
nv
_wr32
(
disp
,
0x616728
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x616728
+
hoff
,
0x00000000
);
nv
_wr32
(
disp
,
0x61672c
+
hoff
,
0x00000000
);
nv
km_wr32
(
device
,
0x61672c
+
hoff
,
0x00000000
);
nv
_mask
(
disp
,
0x616714
+
hoff
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x616714
+
hoff
,
0x00000001
,
0x00000001
);
/* ??? InfoFrame? */
/* ??? InfoFrame? */
nv
_mask
(
disp
,
0x6167a4
+
hoff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6167a4
+
hoff
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x6167ac
+
hoff
,
0x00000010
);
nv
km_wr32
(
device
,
0x6167ac
+
hoff
,
0x00000010
);
nv
_mask
(
disp
,
0x6167a4
+
hoff
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x6167a4
+
hoff
,
0x00000001
,
0x00000001
);
/* HDMI_CTRL */
/* HDMI_CTRL */
nv
_mask
(
disp
,
0x616798
+
hoff
,
0x401f007f
,
ctrl
);
nv
km_mask
(
device
,
0x616798
+
hoff
,
0x401f007f
,
ctrl
);
return
0
;
return
0
;
}
}
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigk104.c
View file @
2fde1f1c
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
int
int
gk104_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
gk104_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
hoff
=
(
head
*
0x800
);
const
u32
hoff
=
(
head
*
0x800
);
const
u32
hdmi
=
(
head
*
0x400
);
const
u32
hdmi
=
(
head
*
0x400
);
union
{
union
{
...
@@ -54,30 +55,30 @@ gk104_hdmi_ctrl(NV50_DISP_MTHD_V1)
...
@@ -54,30 +55,30 @@ gk104_hdmi_ctrl(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
if
(
!
(
ctrl
&
0x40000000
))
{
if
(
!
(
ctrl
&
0x40000000
))
{
nv
_mask
(
disp
,
0x616798
+
hoff
,
0x40000000
,
0x00000000
);
nv
km_mask
(
device
,
0x616798
+
hoff
,
0x40000000
,
0x00000000
);
nv
_mask
(
disp
,
0x6900c0
+
hdmi
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6900c0
+
hdmi
,
0x00000001
,
0x00000000
);
nv
_mask
(
disp
,
0x690000
+
hdmi
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x690000
+
hdmi
,
0x00000001
,
0x00000000
);
return
0
;
return
0
;
}
}
/* AVI InfoFrame */
/* AVI InfoFrame */
nv
_mask
(
disp
,
0x690000
+
hdmi
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x690000
+
hdmi
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x690008
+
hdmi
,
0x000d0282
);
nv
km_wr32
(
device
,
0x690008
+
hdmi
,
0x000d0282
);
nv
_wr32
(
disp
,
0x69000c
+
hdmi
,
0x0000006f
);
nv
km_wr32
(
device
,
0x69000c
+
hdmi
,
0x0000006f
);
nv
_wr32
(
disp
,
0x690010
+
hdmi
,
0x00000000
);
nv
km_wr32
(
device
,
0x690010
+
hdmi
,
0x00000000
);
nv
_wr32
(
disp
,
0x690014
+
hdmi
,
0x00000000
);
nv
km_wr32
(
device
,
0x690014
+
hdmi
,
0x00000000
);
nv
_wr32
(
disp
,
0x690018
+
hdmi
,
0x00000000
);
nv
km_wr32
(
device
,
0x690018
+
hdmi
,
0x00000000
);
nv
_mask
(
disp
,
0x690000
+
hdmi
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x690000
+
hdmi
,
0x00000001
,
0x00000001
);
/* ??? InfoFrame? */
/* ??? InfoFrame? */
nv
_mask
(
disp
,
0x6900c0
+
hdmi
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6900c0
+
hdmi
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x6900cc
+
hdmi
,
0x00000010
);
nv
km_wr32
(
device
,
0x6900cc
+
hdmi
,
0x00000010
);
nv
_mask
(
disp
,
0x6900c0
+
hdmi
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x6900c0
+
hdmi
,
0x00000001
,
0x00000001
);
/* ??? */
/* ??? */
nv
_wr32
(
disp
,
0x690080
+
hdmi
,
0x82000000
);
nv
km_wr32
(
device
,
0x690080
+
hdmi
,
0x82000000
);
/* HDMI_CTRL */
/* HDMI_CTRL */
nv
_mask
(
disp
,
0x616798
+
hoff
,
0x401f007f
,
ctrl
);
nv
km_mask
(
device
,
0x616798
+
hoff
,
0x401f007f
,
ctrl
);
return
0
;
return
0
;
}
}
drivers/gpu/drm/nouveau/nvkm/engine/disp/hdmigt215.c
View file @
2fde1f1c
...
@@ -32,6 +32,7 @@
...
@@ -32,6 +32,7 @@
int
int
gt215_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
gt215_hdmi_ctrl
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
outp
->
or
*
0x800
;
const
u32
soff
=
outp
->
or
*
0x800
;
union
{
union
{
struct
nv50_disp_sor_hdmi_pwr_v0
v0
;
struct
nv50_disp_sor_hdmi_pwr_v0
v0
;
...
@@ -55,38 +56,38 @@ gt215_hdmi_ctrl(NV50_DISP_MTHD_V1)
...
@@ -55,38 +56,38 @@ gt215_hdmi_ctrl(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
if
(
!
(
ctrl
&
0x40000000
))
{
if
(
!
(
ctrl
&
0x40000000
))
{
nv
_mask
(
disp
,
0x61c5a4
+
soff
,
0x40000000
,
0x00000000
);
nv
km_mask
(
device
,
0x61c5a4
+
soff
,
0x40000000
,
0x00000000
);
nv
_mask
(
disp
,
0x61c520
+
soff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x61c520
+
soff
,
0x00000001
,
0x00000000
);
nv
_mask
(
disp
,
0x61c500
+
soff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x61c500
+
soff
,
0x00000001
,
0x00000000
);
return
0
;
return
0
;
}
}
/* AVI InfoFrame */
/* AVI InfoFrame */
nv
_mask
(
disp
,
0x61c520
+
soff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x61c520
+
soff
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x61c528
+
soff
,
0x000d0282
);
nv
km_wr32
(
device
,
0x61c528
+
soff
,
0x000d0282
);
nv
_wr32
(
disp
,
0x61c52c
+
soff
,
0x0000006f
);
nv
km_wr32
(
device
,
0x61c52c
+
soff
,
0x0000006f
);
nv
_wr32
(
disp
,
0x61c530
+
soff
,
0x00000000
);
nv
km_wr32
(
device
,
0x61c530
+
soff
,
0x00000000
);
nv
_wr32
(
disp
,
0x61c534
+
soff
,
0x00000000
);
nv
km_wr32
(
device
,
0x61c534
+
soff
,
0x00000000
);
nv
_wr32
(
disp
,
0x61c538
+
soff
,
0x00000000
);
nv
km_wr32
(
device
,
0x61c538
+
soff
,
0x00000000
);
nv
_mask
(
disp
,
0x61c520
+
soff
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x61c520
+
soff
,
0x00000001
,
0x00000001
);
/* Audio InfoFrame */
/* Audio InfoFrame */
nv
_mask
(
disp
,
0x61c500
+
soff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x61c500
+
soff
,
0x00000001
,
0x00000000
);
nv
_wr32
(
disp
,
0x61c508
+
soff
,
0x000a0184
);
nv
km_wr32
(
device
,
0x61c508
+
soff
,
0x000a0184
);
nv
_wr32
(
disp
,
0x61c50c
+
soff
,
0x00000071
);
nv
km_wr32
(
device
,
0x61c50c
+
soff
,
0x00000071
);
nv
_wr32
(
disp
,
0x61c510
+
soff
,
0x00000000
);
nv
km_wr32
(
device
,
0x61c510
+
soff
,
0x00000000
);
nv
_mask
(
disp
,
0x61c500
+
soff
,
0x00000001
,
0x00000001
);
nv
km_mask
(
device
,
0x61c500
+
soff
,
0x00000001
,
0x00000001
);
nv
_mask
(
disp
,
0x61c5d0
+
soff
,
0x00070001
,
0x00010001
);
/* SPARE, HW_CTS */
nv
km_mask
(
device
,
0x61c5d0
+
soff
,
0x00070001
,
0x00010001
);
/* SPARE, HW_CTS */
nv
_mask
(
disp
,
0x61c568
+
soff
,
0x00010101
,
0x00000000
);
/* ACR_CTRL, ?? */
nv
km_mask
(
device
,
0x61c568
+
soff
,
0x00010101
,
0x00000000
);
/* ACR_CTRL, ?? */
nv
_mask
(
disp
,
0x61c578
+
soff
,
0x80000000
,
0x80000000
);
/* ACR_0441_ENABLE */
nv
km_mask
(
device
,
0x61c578
+
soff
,
0x80000000
,
0x80000000
);
/* ACR_0441_ENABLE */
/* ??? */
/* ??? */
nv
_mask
(
disp
,
0x61733c
,
0x00100000
,
0x00100000
);
/* RESETF */
nv
km_mask
(
device
,
0x61733c
,
0x00100000
,
0x00100000
);
/* RESETF */
nv
_mask
(
disp
,
0x61733c
,
0x10000000
,
0x10000000
);
/* LOOKUP_EN */
nv
km_mask
(
device
,
0x61733c
,
0x10000000
,
0x10000000
);
/* LOOKUP_EN */
nv
_mask
(
disp
,
0x61733c
,
0x00100000
,
0x00000000
);
/* !RESETF */
nv
km_mask
(
device
,
0x61733c
,
0x00100000
,
0x00000000
);
/* !RESETF */
/* HDMI_CTRL */
/* HDMI_CTRL */
nv
_mask
(
disp
,
0x61c5a4
+
soff
,
0x5f1f007f
,
ctrl
);
nv
km_mask
(
device
,
0x61c5a4
+
soff
,
0x5f1f007f
,
ctrl
);
return
0
;
return
0
;
}
}
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv04.c
View file @
2fde1f1c
...
@@ -32,6 +32,7 @@ static int
...
@@ -32,6 +32,7 @@ static int
nv04_disp_scanoutpos
(
struct
nvkm_object
*
object
,
struct
nvkm_disp
*
disp
,
nv04_disp_scanoutpos
(
struct
nvkm_object
*
object
,
struct
nvkm_disp
*
disp
,
void
*
data
,
u32
size
,
int
head
)
void
*
data
,
u32
size
,
int
head
)
{
{
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
const
u32
hoff
=
head
*
0x2000
;
const
u32
hoff
=
head
*
0x2000
;
union
{
union
{
struct
nv04_disp_scanoutpos_v0
v0
;
struct
nv04_disp_scanoutpos_v0
v0
;
...
@@ -42,12 +43,12 @@ nv04_disp_scanoutpos(struct nvkm_object *object, struct nvkm_disp *disp,
...
@@ -42,12 +43,12 @@ nv04_disp_scanoutpos(struct nvkm_object *object, struct nvkm_disp *disp,
nv_ioctl
(
object
,
"disp scanoutpos size %d
\n
"
,
size
);
nv_ioctl
(
object
,
"disp scanoutpos size %d
\n
"
,
size
);
if
(
nvif_unpack
(
args
->
v0
,
0
,
0
,
false
))
{
if
(
nvif_unpack
(
args
->
v0
,
0
,
0
,
false
))
{
nv_ioctl
(
object
,
"disp scanoutpos vers %d
\n
"
,
args
->
v0
.
version
);
nv_ioctl
(
object
,
"disp scanoutpos vers %d
\n
"
,
args
->
v0
.
version
);
args
->
v0
.
vblanks
=
nv
_rd32
(
disp
,
0x680800
+
hoff
)
&
0xffff
;
args
->
v0
.
vblanks
=
nv
km_rd32
(
device
,
0x680800
+
hoff
)
&
0xffff
;
args
->
v0
.
vtotal
=
nv
_rd32
(
disp
,
0x680804
+
hoff
)
&
0xffff
;
args
->
v0
.
vtotal
=
nv
km_rd32
(
device
,
0x680804
+
hoff
)
&
0xffff
;
args
->
v0
.
vblanke
=
args
->
v0
.
vtotal
-
1
;
args
->
v0
.
vblanke
=
args
->
v0
.
vtotal
-
1
;
args
->
v0
.
hblanks
=
nv
_rd32
(
disp
,
0x680820
+
hoff
)
&
0xffff
;
args
->
v0
.
hblanks
=
nv
km_rd32
(
device
,
0x680820
+
hoff
)
&
0xffff
;
args
->
v0
.
htotal
=
nv
_rd32
(
disp
,
0x680824
+
hoff
)
&
0xffff
;
args
->
v0
.
htotal
=
nv
km_rd32
(
device
,
0x680824
+
hoff
)
&
0xffff
;
args
->
v0
.
hblanke
=
args
->
v0
.
htotal
-
1
;
args
->
v0
.
hblanke
=
args
->
v0
.
htotal
-
1
;
/*
/*
...
@@ -59,7 +60,7 @@ nv04_disp_scanoutpos(struct nvkm_object *object, struct nvkm_disp *disp,
...
@@ -59,7 +60,7 @@ nv04_disp_scanoutpos(struct nvkm_object *object, struct nvkm_disp *disp,
return
-
ENOTSUPP
;
return
-
ENOTSUPP
;
args
->
v0
.
time
[
0
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
time
[
0
]
=
ktime_to_ns
(
ktime_get
());
line
=
nv
_rd32
(
disp
,
0x600868
+
hoff
);
line
=
nv
km_rd32
(
device
,
0x600868
+
hoff
);
args
->
v0
.
time
[
1
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
time
[
1
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
hline
=
(
line
&
0xffff0000
)
>>
16
;
args
->
v0
.
hline
=
(
line
&
0xffff0000
)
>>
16
;
args
->
v0
.
vline
=
(
line
&
0x0000ffff
);
args
->
v0
.
vline
=
(
line
&
0x0000ffff
);
...
@@ -124,14 +125,16 @@ static void
...
@@ -124,14 +125,16 @@ static void
nv04_disp_vblank_init
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
nv04_disp_vblank_init
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
{
{
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
nv_wr32
(
disp
,
0x600140
+
(
head
*
0x2000
)
,
0x00000001
);
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
nvkm_wr32
(
device
,
0x600140
+
(
head
*
0x2000
)
,
0x00000001
);
}
}
static
void
static
void
nv04_disp_vblank_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
nv04_disp_vblank_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
{
{
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
nv_wr32
(
disp
,
0x600140
+
(
head
*
0x2000
)
,
0x00000000
);
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
nvkm_wr32
(
device
,
0x600140
+
(
head
*
0x2000
)
,
0x00000000
);
}
}
static
const
struct
nvkm_event_func
static
const
struct
nvkm_event_func
...
@@ -145,26 +148,27 @@ static void
...
@@ -145,26 +148,27 @@ static void
nv04_disp_intr
(
struct
nvkm_subdev
*
subdev
)
nv04_disp_intr
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nvkm_disp
*
disp
=
(
void
*
)
subdev
;
struct
nvkm_disp
*
disp
=
(
void
*
)
subdev
;
u32
crtc0
=
nv_rd32
(
disp
,
0x600100
);
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
u32
crtc1
=
nv_rd32
(
disp
,
0x602100
);
u32
crtc0
=
nvkm_rd32
(
device
,
0x600100
);
u32
crtc1
=
nvkm_rd32
(
device
,
0x602100
);
u32
pvideo
;
u32
pvideo
;
if
(
crtc0
&
0x00000001
)
{
if
(
crtc0
&
0x00000001
)
{
nvkm_disp_vblank
(
disp
,
0
);
nvkm_disp_vblank
(
disp
,
0
);
nv
_wr32
(
disp
,
0x600100
,
0x00000001
);
nv
km_wr32
(
device
,
0x600100
,
0x00000001
);
}
}
if
(
crtc1
&
0x00000001
)
{
if
(
crtc1
&
0x00000001
)
{
nvkm_disp_vblank
(
disp
,
1
);
nvkm_disp_vblank
(
disp
,
1
);
nv
_wr32
(
disp
,
0x602100
,
0x00000001
);
nv
km_wr32
(
device
,
0x602100
,
0x00000001
);
}
}
if
(
nv_device
(
disp
)
->
chipset
>=
0x10
&&
if
(
nv_device
(
disp
)
->
chipset
>=
0x10
&&
nv_device
(
disp
)
->
chipset
<=
0x40
)
{
nv_device
(
disp
)
->
chipset
<=
0x40
)
{
pvideo
=
nv
_rd32
(
disp
,
0x8100
);
pvideo
=
nv
km_rd32
(
device
,
0x8100
);
if
(
pvideo
&
~
0x11
)
if
(
pvideo
&
~
0x11
)
nv_info
(
disp
,
"PVIDEO intr: %08x
\n
"
,
pvideo
);
nv_info
(
disp
,
"PVIDEO intr: %08x
\n
"
,
pvideo
);
nv
_wr32
(
disp
,
0x8100
,
pvideo
);
nv
km_wr32
(
device
,
0x8100
,
pvideo
);
}
}
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c
View file @
2fde1f1c
...
@@ -89,16 +89,18 @@ static void
...
@@ -89,16 +89,18 @@ static void
nv50_disp_chan_uevent_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
nv50_disp_chan_uevent_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
index
)
{
{
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
nv_mask
(
disp
,
0x610028
,
0x00000001
<<
index
,
0x00000000
<<
index
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
nv_wr32
(
disp
,
0x610020
,
0x00000001
<<
index
);
nvkm_mask
(
device
,
0x610028
,
0x00000001
<<
index
,
0x00000000
<<
index
);
nvkm_wr32
(
device
,
0x610020
,
0x00000001
<<
index
);
}
}
static
void
static
void
nv50_disp_chan_uevent_init
(
struct
nvkm_event
*
event
,
int
types
,
int
index
)
nv50_disp_chan_uevent_init
(
struct
nvkm_event
*
event
,
int
types
,
int
index
)
{
{
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
struct
nv50_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
uevent
);
nv_wr32
(
disp
,
0x610020
,
0x00000001
<<
index
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
nv_mask
(
disp
,
0x610028
,
0x00000001
<<
index
,
0x00000001
<<
index
);
nvkm_wr32
(
device
,
0x610020
,
0x00000001
<<
index
);
nvkm_mask
(
device
,
0x610028
,
0x00000001
<<
index
,
0x00000001
<<
index
);
}
}
void
void
...
@@ -165,17 +167,17 @@ nv50_disp_chan_map(struct nvkm_object *object, u64 *addr, u32 *size)
...
@@ -165,17 +167,17 @@ nv50_disp_chan_map(struct nvkm_object *object, u64 *addr, u32 *size)
u32
u32
nv50_disp_chan_rd32
(
struct
nvkm_object
*
object
,
u64
addr
)
nv50_disp_chan_rd32
(
struct
nvkm_object
*
object
,
u64
addr
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_chan
*
chan
=
(
void
*
)
object
;
struct
nv50_disp_chan
*
chan
=
(
void
*
)
object
;
return
nv_rd32
(
disp
,
0x640000
+
(
chan
->
chid
*
0x1000
)
+
addr
);
struct
nvkm_device
*
device
=
object
->
engine
->
subdev
.
device
;
return
nvkm_rd32
(
device
,
0x640000
+
(
chan
->
chid
*
0x1000
)
+
addr
);
}
}
void
void
nv50_disp_chan_wr32
(
struct
nvkm_object
*
object
,
u64
addr
,
u32
data
)
nv50_disp_chan_wr32
(
struct
nvkm_object
*
object
,
u64
addr
,
u32
data
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_chan
*
chan
=
(
void
*
)
object
;
struct
nv50_disp_chan
*
chan
=
(
void
*
)
object
;
nv_wr32
(
disp
,
0x640000
+
(
chan
->
chid
*
0x1000
)
+
addr
,
data
);
struct
nvkm_device
*
device
=
object
->
engine
->
subdev
.
device
;
nvkm_wr32
(
device
,
0x640000
+
(
chan
->
chid
*
0x1000
)
+
addr
,
data
);
}
}
/*******************************************************************************
/*******************************************************************************
...
@@ -257,6 +259,7 @@ nv50_disp_dmac_init(struct nvkm_object *object)
...
@@ -257,6 +259,7 @@ nv50_disp_dmac_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
dmac
->
base
.
chid
;
int
chid
=
dmac
->
base
.
chid
;
int
ret
;
int
ret
;
...
@@ -265,20 +268,20 @@ nv50_disp_dmac_init(struct nvkm_object *object)
...
@@ -265,20 +268,20 @@ nv50_disp_dmac_init(struct nvkm_object *object)
return
ret
;
return
ret
;
/* enable error reporting */
/* enable error reporting */
nv
_mask
(
disp
,
0x610028
,
0x00010000
<<
chid
,
0x00010000
<<
chid
);
nv
km_mask
(
device
,
0x610028
,
0x00010000
<<
chid
,
0x00010000
<<
chid
);
/* initialise channel for dma command submission */
/* initialise channel for dma command submission */
nv
_wr32
(
disp
,
0x610204
+
(
chid
*
0x0010
),
dmac
->
push
);
nv
km_wr32
(
device
,
0x610204
+
(
chid
*
0x0010
),
dmac
->
push
);
nv
_wr32
(
disp
,
0x610208
+
(
chid
*
0x0010
),
0x00010000
);
nv
km_wr32
(
device
,
0x610208
+
(
chid
*
0x0010
),
0x00010000
);
nv
_wr32
(
disp
,
0x61020c
+
(
chid
*
0x0010
),
chid
);
nv
km_wr32
(
device
,
0x61020c
+
(
chid
*
0x0010
),
chid
);
nv
_mask
(
disp
,
0x610200
+
(
chid
*
0x0010
),
0x00000010
,
0x00000010
);
nv
km_mask
(
device
,
0x610200
+
(
chid
*
0x0010
),
0x00000010
,
0x00000010
);
nv
_wr32
(
disp
,
0x640000
+
(
chid
*
0x1000
),
0x00000000
);
nv
km_wr32
(
device
,
0x640000
+
(
chid
*
0x1000
),
0x00000000
);
nv
_wr32
(
disp
,
0x610200
+
(
chid
*
0x0010
),
0x00000013
);
nv
km_wr32
(
device
,
0x610200
+
(
chid
*
0x0010
),
0x00000013
);
/* wait for it to go inactive */
/* wait for it to go inactive */
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x80000000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x80000000
,
0x00000000
))
{
nv_error
(
dmac
,
"init timeout, 0x%08x
\n
"
,
nv_error
(
dmac
,
"init timeout, 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610200
+
(
chid
*
0x10
)));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -290,20 +293,21 @@ nv50_disp_dmac_fini(struct nvkm_object *object, bool suspend)
...
@@ -290,20 +293,21 @@ nv50_disp_dmac_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
dmac
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
dmac
->
base
.
chid
;
int
chid
=
dmac
->
base
.
chid
;
/* deactivate channel */
/* deactivate channel */
nv
_mask
(
disp
,
0x610200
+
(
chid
*
0x0010
),
0x00001010
,
0x00001000
);
nv
km_mask
(
device
,
0x610200
+
(
chid
*
0x0010
),
0x00001010
,
0x00001000
);
nv
_mask
(
disp
,
0x610200
+
(
chid
*
0x0010
),
0x00000003
,
0x00000000
);
nv
km_mask
(
device
,
0x610200
+
(
chid
*
0x0010
),
0x00000003
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x001e0000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x001e0000
,
0x00000000
))
{
nv_error
(
dmac
,
"fini timeout, 0x%08x
\n
"
,
nv_error
(
dmac
,
"fini timeout, 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610200
+
(
chid
*
0x10
)));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
/* disable error reporting and completion notifications */
/* disable error reporting and completion notifications */
nv
_mask
(
disp
,
0x610028
,
0x00010001
<<
chid
,
0x00000000
<<
chid
);
nv
km_mask
(
device
,
0x610028
,
0x00010001
<<
chid
,
0x00000000
<<
chid
);
return
nv50_disp_chan_fini
(
&
dmac
->
base
,
suspend
);
return
nv50_disp_chan_fini
(
&
dmac
->
base
,
suspend
);
}
}
...
@@ -316,13 +320,14 @@ static void
...
@@ -316,13 +320,14 @@ static void
nv50_disp_mthd_list
(
struct
nv50_disp
*
disp
,
int
debug
,
u32
base
,
int
c
,
nv50_disp_mthd_list
(
struct
nv50_disp
*
disp
,
int
debug
,
u32
base
,
int
c
,
const
struct
nv50_disp_mthd_list
*
list
,
int
inst
)
const
struct
nv50_disp_mthd_list
*
list
,
int
inst
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_object
*
object
=
nv_object
(
disp
);
struct
nvkm_object
*
object
=
nv_object
(
disp
);
int
i
;
int
i
;
for
(
i
=
0
;
list
->
data
[
i
].
mthd
;
i
++
)
{
for
(
i
=
0
;
list
->
data
[
i
].
mthd
;
i
++
)
{
if
(
list
->
data
[
i
].
addr
)
{
if
(
list
->
data
[
i
].
addr
)
{
u32
next
=
nv
_rd32
(
disp
,
list
->
data
[
i
].
addr
+
base
+
0
);
u32
next
=
nv
km_rd32
(
device
,
list
->
data
[
i
].
addr
+
base
+
0
);
u32
prev
=
nv
_rd32
(
disp
,
list
->
data
[
i
].
addr
+
base
+
c
);
u32
prev
=
nv
km_rd32
(
device
,
list
->
data
[
i
].
addr
+
base
+
c
);
u32
mthd
=
list
->
data
[
i
].
mthd
+
(
list
->
mthd
*
inst
);
u32
mthd
=
list
->
data
[
i
].
mthd
+
(
list
->
mthd
*
inst
);
const
char
*
name
=
list
->
data
[
i
].
name
;
const
char
*
name
=
list
->
data
[
i
].
name
;
char
mods
[
16
];
char
mods
[
16
];
...
@@ -517,6 +522,7 @@ nv50_disp_core_init(struct nvkm_object *object)
...
@@ -517,6 +522,7 @@ nv50_disp_core_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
ret
;
int
ret
;
ret
=
nv50_disp_chan_init
(
&
mast
->
base
);
ret
=
nv50_disp_chan_init
(
&
mast
->
base
);
...
@@ -524,25 +530,25 @@ nv50_disp_core_init(struct nvkm_object *object)
...
@@ -524,25 +530,25 @@ nv50_disp_core_init(struct nvkm_object *object)
return
ret
;
return
ret
;
/* enable error reporting */
/* enable error reporting */
nv
_mask
(
disp
,
0x610028
,
0x00010000
,
0x00010000
);
nv
km_mask
(
device
,
0x610028
,
0x00010000
,
0x00010000
);
/* attempt to unstick channel from some unknown state */
/* attempt to unstick channel from some unknown state */
if
((
nv
_rd32
(
disp
,
0x610200
)
&
0x009f0000
)
==
0x00020000
)
if
((
nv
km_rd32
(
device
,
0x610200
)
&
0x009f0000
)
==
0x00020000
)
nv
_mask
(
disp
,
0x610200
,
0x00800000
,
0x00800000
);
nv
km_mask
(
device
,
0x610200
,
0x00800000
,
0x00800000
);
if
((
nv
_rd32
(
disp
,
0x610200
)
&
0x003f0000
)
==
0x00030000
)
if
((
nv
km_rd32
(
device
,
0x610200
)
&
0x003f0000
)
==
0x00030000
)
nv
_mask
(
disp
,
0x610200
,
0x00600000
,
0x00600000
);
nv
km_mask
(
device
,
0x610200
,
0x00600000
,
0x00600000
);
/* initialise channel for dma command submission */
/* initialise channel for dma command submission */
nv
_wr32
(
disp
,
0x610204
,
mast
->
push
);
nv
km_wr32
(
device
,
0x610204
,
mast
->
push
);
nv
_wr32
(
disp
,
0x610208
,
0x00010000
);
nv
km_wr32
(
device
,
0x610208
,
0x00010000
);
nv
_wr32
(
disp
,
0x61020c
,
0x00000000
);
nv
km_wr32
(
device
,
0x61020c
,
0x00000000
);
nv
_mask
(
disp
,
0x610200
,
0x00000010
,
0x00000010
);
nv
km_mask
(
device
,
0x610200
,
0x00000010
,
0x00000010
);
nv
_wr32
(
disp
,
0x640000
,
0x00000000
);
nv
km_wr32
(
device
,
0x640000
,
0x00000000
);
nv
_wr32
(
disp
,
0x610200
,
0x01000013
);
nv
km_wr32
(
device
,
0x610200
,
0x01000013
);
/* wait for it to go inactive */
/* wait for it to go inactive */
if
(
!
nv_wait
(
disp
,
0x610200
,
0x80000000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
,
0x80000000
,
0x00000000
))
{
nv_error
(
mast
,
"init: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
));
nv_error
(
mast
,
"init: 0x%08x
\n
"
,
nv
km_rd32
(
device
,
0x610200
));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -554,18 +560,19 @@ nv50_disp_core_fini(struct nvkm_object *object, bool suspend)
...
@@ -554,18 +560,19 @@ nv50_disp_core_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nv50_disp_dmac
*
mast
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
/* deactivate channel */
/* deactivate channel */
nv
_mask
(
disp
,
0x610200
,
0x00000010
,
0x00000000
);
nv
km_mask
(
device
,
0x610200
,
0x00000010
,
0x00000000
);
nv
_mask
(
disp
,
0x610200
,
0x00000003
,
0x00000000
);
nv
km_mask
(
device
,
0x610200
,
0x00000003
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x610200
,
0x001e0000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
,
0x001e0000
,
0x00000000
))
{
nv_error
(
mast
,
"fini: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
));
nv_error
(
mast
,
"fini: 0x%08x
\n
"
,
nv
km_rd32
(
device
,
0x610200
));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
/* disable error reporting and completion notifications */
/* disable error reporting and completion notifications */
nv
_mask
(
disp
,
0x610028
,
0x00010001
,
0x00000000
);
nv
km_mask
(
device
,
0x610028
,
0x00010001
,
0x00000000
);
return
nv50_disp_chan_fini
(
&
mast
->
base
,
suspend
);
return
nv50_disp_chan_fini
(
&
mast
->
base
,
suspend
);
}
}
...
@@ -803,6 +810,7 @@ nv50_disp_pioc_init(struct nvkm_object *object)
...
@@ -803,6 +810,7 @@ nv50_disp_pioc_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
pioc
->
base
.
chid
;
int
chid
=
pioc
->
base
.
chid
;
int
ret
;
int
ret
;
...
@@ -810,17 +818,17 @@ nv50_disp_pioc_init(struct nvkm_object *object)
...
@@ -810,17 +818,17 @@ nv50_disp_pioc_init(struct nvkm_object *object)
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
nv
_wr32
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00002000
);
nv
km_wr32
(
device
,
0x610200
+
(
chid
*
0x10
),
0x00002000
);
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00000000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00000000
,
0x00000000
))
{
nv_error
(
pioc
,
"timeout0: 0x%08x
\n
"
,
nv_error
(
pioc
,
"timeout0: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610200
+
(
chid
*
0x10
)));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
nv
_wr32
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00000001
);
nv
km_wr32
(
device
,
0x610200
+
(
chid
*
0x10
),
0x00000001
);
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00030000
,
0x00010000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00030000
,
0x00010000
))
{
nv_error
(
pioc
,
"timeout1: 0x%08x
\n
"
,
nv_error
(
pioc
,
"timeout1: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610200
+
(
chid
*
0x10
)));
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -832,12 +840,13 @@ nv50_disp_pioc_fini(struct nvkm_object *object, bool suspend)
...
@@ -832,12 +840,13 @@ nv50_disp_pioc_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nv50_disp_pioc
*
pioc
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
chid
=
pioc
->
base
.
chid
;
int
chid
=
pioc
->
base
.
chid
;
nv
_mask
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x610200
+
(
chid
*
0x10
),
0x00000001
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00030000
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x610200
+
(
chid
*
0x10
),
0x00030000
,
0x00000000
))
{
nv_error
(
pioc
,
"timeout: 0x%08x
\n
"
,
nv_error
(
pioc
,
"timeout: 0x%08x
\n
"
,
nv
_rd32
(
disp
,
0x610200
+
(
chid
*
0x10
)));
nv
km_rd32
(
device
,
0x610200
+
(
chid
*
0x10
)));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -948,9 +957,10 @@ nv50_disp_curs_ofuncs = {
...
@@ -948,9 +957,10 @@ nv50_disp_curs_ofuncs = {
int
int
nv50_disp_main_scanoutpos
(
NV50_DISP_MTHD_V0
)
nv50_disp_main_scanoutpos
(
NV50_DISP_MTHD_V0
)
{
{
const
u32
blanke
=
nv_rd32
(
disp
,
0x610aec
+
(
head
*
0x540
));
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
blanks
=
nv_rd32
(
disp
,
0x610af4
+
(
head
*
0x540
));
const
u32
blanke
=
nvkm_rd32
(
device
,
0x610aec
+
(
head
*
0x540
));
const
u32
total
=
nv_rd32
(
disp
,
0x610afc
+
(
head
*
0x540
));
const
u32
blanks
=
nvkm_rd32
(
device
,
0x610af4
+
(
head
*
0x540
));
const
u32
total
=
nvkm_rd32
(
device
,
0x610afc
+
(
head
*
0x540
));
union
{
union
{
struct
nv04_disp_scanoutpos_v0
v0
;
struct
nv04_disp_scanoutpos_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
...
@@ -967,10 +977,10 @@ nv50_disp_main_scanoutpos(NV50_DISP_MTHD_V0)
...
@@ -967,10 +977,10 @@ nv50_disp_main_scanoutpos(NV50_DISP_MTHD_V0)
args
->
v0
.
htotal
=
(
total
&
0x0000ffff
);
args
->
v0
.
htotal
=
(
total
&
0x0000ffff
);
args
->
v0
.
time
[
0
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
time
[
0
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
vline
=
/* vline read locks hline */
args
->
v0
.
vline
=
/* vline read locks hline */
nv
_rd32
(
disp
,
0x616340
+
(
head
*
0x800
))
&
0xffff
;
nv
km_rd32
(
device
,
0x616340
+
(
head
*
0x800
))
&
0xffff
;
args
->
v0
.
time
[
1
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
time
[
1
]
=
ktime_to_ns
(
ktime_get
());
args
->
v0
.
hline
=
args
->
v0
.
hline
=
nv
_rd32
(
disp
,
0x616344
+
(
head
*
0x800
))
&
0xffff
;
nv
km_rd32
(
device
,
0x616344
+
(
head
*
0x800
))
&
0xffff
;
}
else
}
else
return
ret
;
return
ret
;
...
@@ -1133,6 +1143,7 @@ nv50_disp_main_init(struct nvkm_object *object)
...
@@ -1133,6 +1143,7 @@ nv50_disp_main_init(struct nvkm_object *object)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
int
ret
,
i
;
int
ret
,
i
;
u32
tmp
;
u32
tmp
;
...
@@ -1144,43 +1155,43 @@ nv50_disp_main_init(struct nvkm_object *object)
...
@@ -1144,43 +1155,43 @@ nv50_disp_main_init(struct nvkm_object *object)
* another appear to inform EVO of the display capabilities or
* another appear to inform EVO of the display capabilities or
* something similar. NFI what the 0x614004 caps are for..
* something similar. NFI what the 0x614004 caps are for..
*/
*/
tmp
=
nv
_rd32
(
disp
,
0x614004
);
tmp
=
nv
km_rd32
(
device
,
0x614004
);
nv
_wr32
(
disp
,
0x610184
,
tmp
);
nv
km_wr32
(
device
,
0x610184
,
tmp
);
/* ... CRTC caps */
/* ... CRTC caps */
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
head
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x616100
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x616100
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x610190
+
(
i
*
0x10
),
tmp
);
nv
km_wr32
(
device
,
0x610190
+
(
i
*
0x10
),
tmp
);
tmp
=
nv
_rd32
(
disp
,
0x616104
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x616104
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x610194
+
(
i
*
0x10
),
tmp
);
nv
km_wr32
(
device
,
0x610194
+
(
i
*
0x10
),
tmp
);
tmp
=
nv
_rd32
(
disp
,
0x616108
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x616108
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x610198
+
(
i
*
0x10
),
tmp
);
nv
km_wr32
(
device
,
0x610198
+
(
i
*
0x10
),
tmp
);
tmp
=
nv
_rd32
(
disp
,
0x61610c
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61610c
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x61019c
+
(
i
*
0x10
),
tmp
);
nv
km_wr32
(
device
,
0x61019c
+
(
i
*
0x10
),
tmp
);
}
}
/* ... DAC caps */
/* ... DAC caps */
for
(
i
=
0
;
i
<
disp
->
dac
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
dac
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x61a000
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61a000
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101d0
+
(
i
*
0x04
),
tmp
);
nv
km_wr32
(
device
,
0x6101d0
+
(
i
*
0x04
),
tmp
);
}
}
/* ... SOR caps */
/* ... SOR caps */
for
(
i
=
0
;
i
<
disp
->
sor
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
sor
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x61c000
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61c000
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101e0
+
(
i
*
0x04
),
tmp
);
nv
km_wr32
(
device
,
0x6101e0
+
(
i
*
0x04
),
tmp
);
}
}
/* ... PIOR caps */
/* ... PIOR caps */
for
(
i
=
0
;
i
<
disp
->
pior
.
nr
;
i
++
)
{
for
(
i
=
0
;
i
<
disp
->
pior
.
nr
;
i
++
)
{
tmp
=
nv
_rd32
(
disp
,
0x61e000
+
(
i
*
0x800
));
tmp
=
nv
km_rd32
(
device
,
0x61e000
+
(
i
*
0x800
));
nv
_wr32
(
disp
,
0x6101f0
+
(
i
*
0x04
),
tmp
);
nv
km_wr32
(
device
,
0x6101f0
+
(
i
*
0x04
),
tmp
);
}
}
/* steal display away from vbios, or something like that */
/* steal display away from vbios, or something like that */
if
(
nv
_rd32
(
disp
,
0x610024
)
&
0x00000100
)
{
if
(
nv
km_rd32
(
device
,
0x610024
)
&
0x00000100
)
{
nv
_wr32
(
disp
,
0x610024
,
0x00000100
);
nv
km_wr32
(
device
,
0x610024
,
0x00000100
);
nv
_mask
(
disp
,
0x6194e8
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x6194e8
,
0x00000001
,
0x00000000
);
if
(
!
nv_wait
(
disp
,
0x6194e8
,
0x00000002
,
0x00000000
))
{
if
(
!
nv_wait
(
disp
,
0x6194e8
,
0x00000002
,
0x00000000
))
{
nv_error
(
disp
,
"timeout acquiring display
\n
"
);
nv_error
(
disp
,
"timeout acquiring display
\n
"
);
return
-
EBUSY
;
return
-
EBUSY
;
...
@@ -1188,11 +1199,11 @@ nv50_disp_main_init(struct nvkm_object *object)
...
@@ -1188,11 +1199,11 @@ nv50_disp_main_init(struct nvkm_object *object)
}
}
/* point at display engine memory area (hash table, objects) */
/* point at display engine memory area (hash table, objects) */
nv
_wr32
(
disp
,
0x610010
,
(
nv_gpuobj
(
base
->
ramht
)
->
addr
>>
8
)
|
9
);
nv
km_wr32
(
device
,
0x610010
,
(
nv_gpuobj
(
base
->
ramht
)
->
addr
>>
8
)
|
9
);
/* enable supervisor interrupts, disable everything else */
/* enable supervisor interrupts, disable everything else */
nv
_wr32
(
disp
,
0x61002c
,
0x00000370
);
nv
km_wr32
(
device
,
0x61002c
,
0x00000370
);
nv
_wr32
(
disp
,
0x610028
,
0x00000000
);
nv
km_wr32
(
device
,
0x610028
,
0x00000000
);
return
0
;
return
0
;
}
}
...
@@ -1201,10 +1212,11 @@ nv50_disp_main_fini(struct nvkm_object *object, bool suspend)
...
@@ -1201,10 +1212,11 @@ nv50_disp_main_fini(struct nvkm_object *object, bool suspend)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
object
->
engine
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
/* disable all interrupts */
/* disable all interrupts */
nv
_wr32
(
disp
,
0x610024
,
0x00000000
);
nv
km_wr32
(
device
,
0x610024
,
0x00000000
);
nv
_wr32
(
disp
,
0x610020
,
0x00000000
);
nv
km_wr32
(
device
,
0x610020
,
0x00000000
);
return
nvkm_parent_fini
(
&
base
->
base
,
suspend
);
return
nvkm_parent_fini
(
&
base
->
base
,
suspend
);
}
}
...
@@ -1289,14 +1301,16 @@ static void
...
@@ -1289,14 +1301,16 @@ static void
nv50_disp_vblank_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
nv50_disp_vblank_fini
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
{
{
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
nv_mask
(
disp
,
0x61002c
,
(
4
<<
head
),
0
);
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
nvkm_mask
(
device
,
0x61002c
,
(
4
<<
head
),
0
);
}
}
static
void
static
void
nv50_disp_vblank_init
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
nv50_disp_vblank_init
(
struct
nvkm_event
*
event
,
int
type
,
int
head
)
{
{
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
struct
nvkm_disp
*
disp
=
container_of
(
event
,
typeof
(
*
disp
),
vblank
);
nv_mask
(
disp
,
0x61002c
,
(
4
<<
head
),
(
4
<<
head
));
struct
nvkm_device
*
device
=
disp
->
engine
.
subdev
.
device
;
nvkm_mask
(
device
,
0x61002c
,
(
4
<<
head
),
(
4
<<
head
));
}
}
const
struct
nvkm_event_func
const
struct
nvkm_event_func
...
@@ -1325,8 +1339,9 @@ static void
...
@@ -1325,8 +1339,9 @@ static void
nv50_disp_intr_error
(
struct
nv50_disp
*
disp
,
int
chid
)
nv50_disp_intr_error
(
struct
nv50_disp
*
disp
,
int
chid
)
{
{
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
u32
data
=
nv_rd32
(
disp
,
0x610084
+
(
chid
*
0x08
));
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
addr
=
nv_rd32
(
disp
,
0x610080
+
(
chid
*
0x08
));
u32
data
=
nvkm_rd32
(
device
,
0x610084
+
(
chid
*
0x08
));
u32
addr
=
nvkm_rd32
(
device
,
0x610080
+
(
chid
*
0x08
));
u32
code
=
(
addr
&
0x00ff0000
)
>>
16
;
u32
code
=
(
addr
&
0x00ff0000
)
>>
16
;
u32
type
=
(
addr
&
0x00007000
)
>>
12
;
u32
type
=
(
addr
&
0x00007000
)
>>
12
;
u32
mthd
=
(
addr
&
0x00000ffc
);
u32
mthd
=
(
addr
&
0x00000ffc
);
...
@@ -1376,8 +1391,8 @@ nv50_disp_intr_error(struct nv50_disp *disp, int chid)
...
@@ -1376,8 +1391,8 @@ nv50_disp_intr_error(struct nv50_disp *disp, int chid)
}
}
}
}
nv
_wr32
(
disp
,
0x610020
,
0x00010000
<<
chid
);
nv
km_wr32
(
device
,
0x610020
,
0x00010000
<<
chid
);
nv
_wr32
(
disp
,
0x610080
+
(
chid
*
0x08
),
0x90000000
);
nv
km_wr32
(
device
,
0x610080
+
(
chid
*
0x08
),
0x90000000
);
}
}
static
struct
nvkm_output
*
static
struct
nvkm_output
*
...
@@ -1440,7 +1455,8 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl,
...
@@ -1440,7 +1455,8 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl,
static
struct
nvkm_output
*
static
struct
nvkm_output
*
exec_script
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
)
exec_script
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
)
{
{
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
struct
nvbios_outp
info
;
struct
nvbios_outp
info
;
u8
ver
,
hdr
,
cnt
,
len
;
u8
ver
,
hdr
,
cnt
,
len
;
...
@@ -1450,7 +1466,7 @@ exec_script(struct nv50_disp *disp, int head, int id)
...
@@ -1450,7 +1466,7 @@ exec_script(struct nv50_disp *disp, int head, int id)
/* DAC */
/* DAC */
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
dac
.
nr
;
i
++
)
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
dac
.
nr
;
i
++
)
ctrl
=
nv
_rd32
(
disp
,
0x610b5c
+
(
i
*
8
));
ctrl
=
nv
km_rd32
(
device
,
0x610b5c
+
(
i
*
8
));
/* SOR */
/* SOR */
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
...
@@ -1462,14 +1478,14 @@ exec_script(struct nv50_disp *disp, int head, int id)
...
@@ -1462,14 +1478,14 @@ exec_script(struct nv50_disp *disp, int head, int id)
reg
=
0x610798
;
reg
=
0x610798
;
}
}
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
sor
.
nr
;
i
++
)
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
sor
.
nr
;
i
++
)
ctrl
=
nv
_rd32
(
disp
,
reg
+
(
i
*
8
));
ctrl
=
nv
km_rd32
(
device
,
reg
+
(
i
*
8
));
i
+=
4
;
i
+=
4
;
}
}
/* PIOR */
/* PIOR */
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
pior
.
nr
;
i
++
)
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
pior
.
nr
;
i
++
)
ctrl
=
nv
_rd32
(
disp
,
0x610b84
+
(
i
*
8
));
ctrl
=
nv
km_rd32
(
device
,
0x610b84
+
(
i
*
8
));
i
+=
8
;
i
+=
8
;
}
}
...
@@ -1497,7 +1513,8 @@ exec_script(struct nv50_disp *disp, int head, int id)
...
@@ -1497,7 +1513,8 @@ exec_script(struct nv50_disp *disp, int head, int id)
static
struct
nvkm_output
*
static
struct
nvkm_output
*
exec_clkcmp
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
,
u32
pclk
,
u32
*
conf
)
exec_clkcmp
(
struct
nv50_disp
*
disp
,
int
head
,
int
id
,
u32
pclk
,
u32
*
conf
)
{
{
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
struct
nvbios_outp
info1
;
struct
nvbios_outp
info1
;
struct
nvbios_ocfg
info2
;
struct
nvbios_ocfg
info2
;
...
@@ -1508,7 +1525,7 @@ exec_clkcmp(struct nv50_disp *disp, int head, int id, u32 pclk, u32 *conf)
...
@@ -1508,7 +1525,7 @@ exec_clkcmp(struct nv50_disp *disp, int head, int id, u32 pclk, u32 *conf)
/* DAC */
/* DAC */
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
dac
.
nr
;
i
++
)
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
dac
.
nr
;
i
++
)
ctrl
=
nv
_rd32
(
disp
,
0x610b58
+
(
i
*
8
));
ctrl
=
nv
km_rd32
(
device
,
0x610b58
+
(
i
*
8
));
/* SOR */
/* SOR */
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
...
@@ -1520,14 +1537,14 @@ exec_clkcmp(struct nv50_disp *disp, int head, int id, u32 pclk, u32 *conf)
...
@@ -1520,14 +1537,14 @@ exec_clkcmp(struct nv50_disp *disp, int head, int id, u32 pclk, u32 *conf)
reg
=
0x610794
;
reg
=
0x610794
;
}
}
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
sor
.
nr
;
i
++
)
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
sor
.
nr
;
i
++
)
ctrl
=
nv
_rd32
(
disp
,
reg
+
(
i
*
8
));
ctrl
=
nv
km_rd32
(
device
,
reg
+
(
i
*
8
));
i
+=
4
;
i
+=
4
;
}
}
/* PIOR */
/* PIOR */
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
if
(
!
(
ctrl
&
(
1
<<
head
)))
{
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
pior
.
nr
;
i
++
)
for
(
i
=
0
;
!
(
ctrl
&
(
1
<<
head
))
&&
i
<
disp
->
pior
.
nr
;
i
++
)
ctrl
=
nv
_rd32
(
disp
,
0x610b80
+
(
i
*
8
));
ctrl
=
nv
km_rd32
(
device
,
0x610b80
+
(
i
*
8
));
i
+=
8
;
i
+=
8
;
}
}
...
@@ -1625,8 +1642,9 @@ nv50_disp_intr_unk20_0(struct nv50_disp *disp, int head)
...
@@ -1625,8 +1642,9 @@ nv50_disp_intr_unk20_0(struct nv50_disp *disp, int head)
static
void
static
void
nv50_disp_intr_unk20_1
(
struct
nv50_disp
*
disp
,
int
head
)
nv50_disp_intr_unk20_1
(
struct
nv50_disp
*
disp
,
int
head
)
{
{
struct
nvkm_devinit
*
devinit
=
nvkm_devinit
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
pclk
=
nv_rd32
(
disp
,
0x610ad0
+
(
head
*
0x540
))
&
0x3fffff
;
struct
nvkm_devinit
*
devinit
=
device
->
devinit
;
u32
pclk
=
nvkm_rd32
(
device
,
0x610ad0
+
(
head
*
0x540
))
&
0x3fffff
;
if
(
pclk
)
if
(
pclk
)
devinit
->
pll_set
(
devinit
,
PLL_VPLL0
+
head
,
pclk
);
devinit
->
pll_set
(
devinit
,
PLL_VPLL0
+
head
,
pclk
);
}
}
...
@@ -1635,17 +1653,18 @@ static void
...
@@ -1635,17 +1653,18 @@ static void
nv50_disp_intr_unk20_2_dp
(
struct
nv50_disp
*
disp
,
int
head
,
nv50_disp_intr_unk20_2_dp
(
struct
nv50_disp
*
disp
,
int
head
,
struct
dcb_output
*
outp
,
u32
pclk
)
struct
dcb_output
*
outp
,
u32
pclk
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
int
link
=
!
(
outp
->
sorconf
.
link
&
1
);
const
int
link
=
!
(
outp
->
sorconf
.
link
&
1
);
const
int
or
=
ffs
(
outp
->
or
)
-
1
;
const
int
or
=
ffs
(
outp
->
or
)
-
1
;
const
u32
soff
=
(
or
*
0x800
);
const
u32
soff
=
(
or
*
0x800
);
const
u32
loff
=
(
link
*
0x080
)
+
soff
;
const
u32
loff
=
(
link
*
0x080
)
+
soff
;
const
u32
ctrl
=
nv
_rd32
(
disp
,
0x610794
+
(
or
*
8
));
const
u32
ctrl
=
nv
km_rd32
(
device
,
0x610794
+
(
or
*
8
));
const
u32
symbol
=
100000
;
const
u32
symbol
=
100000
;
const
s32
vactive
=
nv
_rd32
(
disp
,
0x610af8
+
(
head
*
0x540
))
&
0xffff
;
const
s32
vactive
=
nv
km_rd32
(
device
,
0x610af8
+
(
head
*
0x540
))
&
0xffff
;
const
s32
vblanke
=
nv
_rd32
(
disp
,
0x610ae8
+
(
head
*
0x540
))
&
0xffff
;
const
s32
vblanke
=
nv
km_rd32
(
device
,
0x610ae8
+
(
head
*
0x540
))
&
0xffff
;
const
s32
vblanks
=
nv
_rd32
(
disp
,
0x610af0
+
(
head
*
0x540
))
&
0xffff
;
const
s32
vblanks
=
nv
km_rd32
(
device
,
0x610af0
+
(
head
*
0x540
))
&
0xffff
;
u32
dpctrl
=
nv
_rd32
(
disp
,
0x61c10c
+
loff
);
u32
dpctrl
=
nv
km_rd32
(
device
,
0x61c10c
+
loff
);
u32
clksor
=
nv
_rd32
(
disp
,
0x614300
+
soff
);
u32
clksor
=
nv
km_rd32
(
device
,
0x614300
+
soff
);
int
bestTU
=
0
,
bestVTUi
=
0
,
bestVTUf
=
0
,
bestVTUa
=
0
;
int
bestTU
=
0
,
bestVTUi
=
0
,
bestVTUf
=
0
,
bestVTUa
=
0
;
int
TU
,
VTUi
,
VTUf
,
VTUa
;
int
TU
,
VTUi
,
VTUf
,
VTUa
;
u64
link_data_rate
,
link_ratio
,
unk
;
u64
link_data_rate
,
link_ratio
,
unk
;
...
@@ -1661,14 +1680,14 @@ nv50_disp_intr_unk20_2_dp(struct nv50_disp *disp, int head,
...
@@ -1661,14 +1680,14 @@ nv50_disp_intr_unk20_2_dp(struct nv50_disp *disp, int head,
value
=
value
*
link_bw
;
value
=
value
*
link_bw
;
do_div
(
value
,
pclk
);
do_div
(
value
,
pclk
);
value
=
value
-
(
3
*
!!
(
dpctrl
&
0x00004000
))
-
(
12
/
link_nr
);
value
=
value
-
(
3
*
!!
(
dpctrl
&
0x00004000
))
-
(
12
/
link_nr
);
nv
_mask
(
disp
,
0x61c1e8
+
soff
,
0x0000ffff
,
value
);
nv
km_mask
(
device
,
0x61c1e8
+
soff
,
0x0000ffff
,
value
);
/* symbols/vblank - algorithm taken from comments in tegra driver */
/* symbols/vblank - algorithm taken from comments in tegra driver */
value
=
vblanks
-
vblanke
-
25
;
value
=
vblanks
-
vblanke
-
25
;
value
=
value
*
link_bw
;
value
=
value
*
link_bw
;
do_div
(
value
,
pclk
);
do_div
(
value
,
pclk
);
value
=
value
-
((
36
/
link_nr
)
+
3
)
-
1
;
value
=
value
-
((
36
/
link_nr
)
+
3
)
-
1
;
nv
_mask
(
disp
,
0x61c1ec
+
soff
,
0x00ffffff
,
value
);
nv
km_mask
(
device
,
0x61c1ec
+
soff
,
0x00ffffff
,
value
);
/* watermark / activesym */
/* watermark / activesym */
if
((
ctrl
&
0xf0000
)
==
0x60000
)
bits
=
30
;
if
((
ctrl
&
0xf0000
)
==
0x60000
)
bits
=
30
;
...
@@ -1744,8 +1763,8 @@ nv50_disp_intr_unk20_2_dp(struct nv50_disp *disp, int head,
...
@@ -1744,8 +1763,8 @@ nv50_disp_intr_unk20_2_dp(struct nv50_disp *disp, int head,
do_div
(
unk
,
symbol
);
do_div
(
unk
,
symbol
);
unk
+=
6
;
unk
+=
6
;
nv
_mask
(
disp
,
0x61c10c
+
loff
,
0x000001fc
,
bestTU
<<
2
);
nv
km_mask
(
device
,
0x61c10c
+
loff
,
0x000001fc
,
bestTU
<<
2
);
nv
_mask
(
disp
,
0x61c128
+
loff
,
0x010f7f3f
,
bestVTUa
<<
24
|
nv
km_mask
(
device
,
0x61c128
+
loff
,
0x010f7f3f
,
bestVTUa
<<
24
|
bestVTUf
<<
16
|
bestVTUf
<<
16
|
bestVTUi
<<
8
|
unk
);
bestVTUi
<<
8
|
unk
);
}
}
...
@@ -1753,8 +1772,9 @@ nv50_disp_intr_unk20_2_dp(struct nv50_disp *disp, int head,
...
@@ -1753,8 +1772,9 @@ nv50_disp_intr_unk20_2_dp(struct nv50_disp *disp, int head,
static
void
static
void
nv50_disp_intr_unk20_2
(
struct
nv50_disp
*
disp
,
int
head
)
nv50_disp_intr_unk20_2
(
struct
nv50_disp
*
disp
,
int
head
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
u32
pclk
=
nv
_rd32
(
disp
,
0x610ad0
+
(
head
*
0x540
))
&
0x3fffff
;
u32
pclk
=
nv
km_rd32
(
device
,
0x610ad0
+
(
head
*
0x540
))
&
0x3fffff
;
u32
hval
,
hreg
=
0x614200
+
(
head
*
0x800
);
u32
hval
,
hreg
=
0x614200
+
(
head
*
0x800
);
u32
oval
,
oreg
;
u32
oval
,
oreg
;
u32
mask
,
conf
;
u32
mask
,
conf
;
...
@@ -1786,10 +1806,10 @@ nv50_disp_intr_unk20_2(struct nv50_disp *disp, int head)
...
@@ -1786,10 +1806,10 @@ nv50_disp_intr_unk20_2(struct nv50_disp *disp, int head)
u32
ctrl
,
datarate
;
u32
ctrl
,
datarate
;
if
(
outp
->
info
.
location
==
0
)
{
if
(
outp
->
info
.
location
==
0
)
{
ctrl
=
nv
_rd32
(
disp
,
0x610794
+
soff
);
ctrl
=
nv
km_rd32
(
device
,
0x610794
+
soff
);
soff
=
1
;
soff
=
1
;
}
else
{
}
else
{
ctrl
=
nv
_rd32
(
disp
,
0x610b80
+
soff
);
ctrl
=
nv
km_rd32
(
device
,
0x610b80
+
soff
);
soff
=
2
;
soff
=
2
;
}
}
...
@@ -1828,8 +1848,8 @@ nv50_disp_intr_unk20_2(struct nv50_disp *disp, int head)
...
@@ -1828,8 +1848,8 @@ nv50_disp_intr_unk20_2(struct nv50_disp *disp, int head)
mask
=
0x00000707
;
mask
=
0x00000707
;
}
}
nv
_mask
(
disp
,
hreg
,
0x0000000f
,
hval
);
nv
km_mask
(
device
,
hreg
,
0x0000000f
,
hval
);
nv
_mask
(
disp
,
oreg
,
mask
,
oval
);
nv
km_mask
(
device
,
oreg
,
mask
,
oval
);
}
}
/* If programming a TMDS output on a SOR that can also be configured for
/* If programming a TMDS output on a SOR that can also be configured for
...
@@ -1844,7 +1864,8 @@ static void
...
@@ -1844,7 +1864,8 @@ static void
nv50_disp_intr_unk40_0_tmds
(
struct
nv50_disp
*
disp
,
nv50_disp_intr_unk40_0_tmds
(
struct
nv50_disp
*
disp
,
struct
dcb_output
*
outp
)
struct
dcb_output
*
outp
)
{
{
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
const
int
link
=
!
(
outp
->
sorconf
.
link
&
1
);
const
int
link
=
!
(
outp
->
sorconf
.
link
&
1
);
const
int
or
=
ffs
(
outp
->
or
)
-
1
;
const
int
or
=
ffs
(
outp
->
or
)
-
1
;
const
u32
loff
=
(
or
*
0x800
)
+
(
link
*
0x80
);
const
u32
loff
=
(
or
*
0x800
)
+
(
link
*
0x80
);
...
@@ -1853,14 +1874,15 @@ nv50_disp_intr_unk40_0_tmds(struct nv50_disp *disp,
...
@@ -1853,14 +1874,15 @@ nv50_disp_intr_unk40_0_tmds(struct nv50_disp *disp,
u8
ver
,
hdr
;
u8
ver
,
hdr
;
if
(
dcb_outp_match
(
bios
,
DCB_OUTPUT_DP
,
mask
,
&
ver
,
&
hdr
,
&
match
))
if
(
dcb_outp_match
(
bios
,
DCB_OUTPUT_DP
,
mask
,
&
ver
,
&
hdr
,
&
match
))
nv
_mask
(
disp
,
0x61c10c
+
loff
,
0x00000001
,
0x00000000
);
nv
km_mask
(
device
,
0x61c10c
+
loff
,
0x00000001
,
0x00000000
);
}
}
static
void
static
void
nv50_disp_intr_unk40_0
(
struct
nv50_disp
*
disp
,
int
head
)
nv50_disp_intr_unk40_0
(
struct
nv50_disp
*
disp
,
int
head
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_output
*
outp
;
struct
nvkm_output
*
outp
;
u32
pclk
=
nv
_rd32
(
disp
,
0x610ad0
+
(
head
*
0x540
))
&
0x3fffff
;
u32
pclk
=
nv
km_rd32
(
device
,
0x610ad0
+
(
head
*
0x540
))
&
0x3fffff
;
u32
conf
;
u32
conf
;
outp
=
exec_clkcmp
(
disp
,
head
,
1
,
pclk
,
&
conf
);
outp
=
exec_clkcmp
(
disp
,
head
,
1
,
pclk
,
&
conf
);
...
@@ -1877,7 +1899,8 @@ nv50_disp_intr_supervisor(struct work_struct *work)
...
@@ -1877,7 +1899,8 @@ nv50_disp_intr_supervisor(struct work_struct *work)
struct
nv50_disp
*
disp
=
struct
nv50_disp
*
disp
=
container_of
(
work
,
struct
nv50_disp
,
supervisor
);
container_of
(
work
,
struct
nv50_disp
,
supervisor
);
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
struct
nv50_disp_impl
*
impl
=
(
void
*
)
nv_object
(
disp
)
->
oclass
;
u32
super
=
nv_rd32
(
disp
,
0x610030
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
super
=
nvkm_rd32
(
device
,
0x610030
);
int
head
;
int
head
;
nv_debug
(
disp
,
"supervisor 0x%08x 0x%08x
\n
"
,
disp
->
super
,
super
);
nv_debug
(
disp
,
"supervisor 0x%08x 0x%08x
\n
"
,
disp
->
super
,
super
);
...
@@ -1917,15 +1940,16 @@ nv50_disp_intr_supervisor(struct work_struct *work)
...
@@ -1917,15 +1940,16 @@ nv50_disp_intr_supervisor(struct work_struct *work)
}
}
}
}
nv
_wr32
(
disp
,
0x610030
,
0x80000000
);
nv
km_wr32
(
device
,
0x610030
,
0x80000000
);
}
}
void
void
nv50_disp_intr
(
struct
nvkm_subdev
*
subdev
)
nv50_disp_intr
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
subdev
;
struct
nv50_disp
*
disp
=
(
void
*
)
subdev
;
u32
intr0
=
nv_rd32
(
disp
,
0x610020
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
u32
intr1
=
nv_rd32
(
disp
,
0x610024
);
u32
intr0
=
nvkm_rd32
(
device
,
0x610020
);
u32
intr1
=
nvkm_rd32
(
device
,
0x610024
);
while
(
intr0
&
0x001f0000
)
{
while
(
intr0
&
0x001f0000
)
{
u32
chid
=
__ffs
(
intr0
&
0x001f0000
)
-
16
;
u32
chid
=
__ffs
(
intr0
&
0x001f0000
)
-
16
;
...
@@ -1941,18 +1965,18 @@ nv50_disp_intr(struct nvkm_subdev *subdev)
...
@@ -1941,18 +1965,18 @@ nv50_disp_intr(struct nvkm_subdev *subdev)
if
(
intr1
&
0x00000004
)
{
if
(
intr1
&
0x00000004
)
{
nvkm_disp_vblank
(
&
disp
->
base
,
0
);
nvkm_disp_vblank
(
&
disp
->
base
,
0
);
nv
_wr32
(
disp
,
0x610024
,
0x00000004
);
nv
km_wr32
(
device
,
0x610024
,
0x00000004
);
}
}
if
(
intr1
&
0x00000008
)
{
if
(
intr1
&
0x00000008
)
{
nvkm_disp_vblank
(
&
disp
->
base
,
1
);
nvkm_disp_vblank
(
&
disp
->
base
,
1
);
nv
_wr32
(
disp
,
0x610024
,
0x00000008
);
nv
km_wr32
(
device
,
0x610024
,
0x00000008
);
}
}
if
(
intr1
&
0x00000070
)
{
if
(
intr1
&
0x00000070
)
{
disp
->
super
=
(
intr1
&
0x00000070
);
disp
->
super
=
(
intr1
&
0x00000070
);
schedule_work
(
&
disp
->
supervisor
);
schedule_work
(
&
disp
->
supervisor
);
nv
_wr32
(
disp
,
0x610024
,
disp
->
super
);
nv
km_wr32
(
device
,
0x610024
,
disp
->
super
);
}
}
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/piornv50.c
View file @
2fde1f1c
...
@@ -144,6 +144,7 @@ nv50_pior_dp_impl = {
...
@@ -144,6 +144,7 @@ nv50_pior_dp_impl = {
int
int
nv50_pior_power
(
NV50_DISP_MTHD_V1
)
nv50_pior_power
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
outp
->
or
*
0x800
;
const
u32
soff
=
outp
->
or
*
0x800
;
union
{
union
{
struct
nv50_disp_pior_pwr_v0
v0
;
struct
nv50_disp_pior_pwr_v0
v0
;
...
@@ -163,7 +164,7 @@ nv50_pior_power(NV50_DISP_MTHD_V1)
...
@@ -163,7 +164,7 @@ nv50_pior_power(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
nv_wait
(
disp
,
0x61e004
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61e004
+
soff
,
0x80000000
,
0x00000000
);
nv
_mask
(
disp
,
0x61e004
+
soff
,
0x80000101
,
0x80000000
|
ctrl
);
nv
km_mask
(
device
,
0x61e004
+
soff
,
0x80000101
,
0x80000000
|
ctrl
);
nv_wait
(
disp
,
0x61e004
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61e004
+
soff
,
0x80000000
,
0x00000000
);
disp
->
pior
.
type
[
outp
->
or
]
=
type
;
disp
->
pior
.
type
[
outp
->
or
]
=
type
;
return
0
;
return
0
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorg94.c
View file @
2fde1f1c
...
@@ -55,8 +55,9 @@ static int
...
@@ -55,8 +55,9 @@ static int
g94_sor_dp_pattern
(
struct
nvkm_output_dp
*
outp
,
int
pattern
)
g94_sor_dp_pattern
(
struct
nvkm_output_dp
*
outp
,
int
pattern
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
loff
=
g94_sor_loff
(
outp
);
const
u32
loff
=
g94_sor_loff
(
outp
);
nv
_mask
(
disp
,
0x61c10c
+
loff
,
0x0f000000
,
pattern
<<
24
);
nv
km_mask
(
device
,
0x61c10c
+
loff
,
0x0f000000
,
pattern
<<
24
);
return
0
;
return
0
;
}
}
...
@@ -64,6 +65,7 @@ int
...
@@ -64,6 +65,7 @@ int
g94_sor_dp_lnk_pwr
(
struct
nvkm_output_dp
*
outp
,
int
nr
)
g94_sor_dp_lnk_pwr
(
struct
nvkm_output_dp
*
outp
,
int
nr
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
g94_sor_soff
(
outp
);
const
u32
soff
=
g94_sor_soff
(
outp
);
const
u32
loff
=
g94_sor_loff
(
outp
);
const
u32
loff
=
g94_sor_loff
(
outp
);
u32
mask
=
0
,
i
;
u32
mask
=
0
,
i
;
...
@@ -71,8 +73,8 @@ g94_sor_dp_lnk_pwr(struct nvkm_output_dp *outp, int nr)
...
@@ -71,8 +73,8 @@ g94_sor_dp_lnk_pwr(struct nvkm_output_dp *outp, int nr)
for
(
i
=
0
;
i
<
nr
;
i
++
)
for
(
i
=
0
;
i
<
nr
;
i
++
)
mask
|=
1
<<
(
g94_sor_dp_lane_map
(
disp
,
i
)
>>
3
);
mask
|=
1
<<
(
g94_sor_dp_lane_map
(
disp
,
i
)
>>
3
);
nv
_mask
(
disp
,
0x61c130
+
loff
,
0x0000000f
,
mask
);
nv
km_mask
(
device
,
0x61c130
+
loff
,
0x0000000f
,
mask
);
nv
_mask
(
disp
,
0x61c034
+
soff
,
0x80000000
,
0x80000000
);
nv
km_mask
(
device
,
0x61c034
+
soff
,
0x80000000
,
0x80000000
);
nv_wait
(
disp
,
0x61c034
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c034
+
soff
,
0x80000000
,
0x00000000
);
return
0
;
return
0
;
}
}
...
@@ -81,6 +83,7 @@ static int
...
@@ -81,6 +83,7 @@ static int
g94_sor_dp_lnk_ctl
(
struct
nvkm_output_dp
*
outp
,
int
nr
,
int
bw
,
bool
ef
)
g94_sor_dp_lnk_ctl
(
struct
nvkm_output_dp
*
outp
,
int
nr
,
int
bw
,
bool
ef
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
g94_sor_soff
(
outp
);
const
u32
soff
=
g94_sor_soff
(
outp
);
const
u32
loff
=
g94_sor_loff
(
outp
);
const
u32
loff
=
g94_sor_loff
(
outp
);
u32
dpctrl
=
0x00000000
;
u32
dpctrl
=
0x00000000
;
...
@@ -92,8 +95,8 @@ g94_sor_dp_lnk_ctl(struct nvkm_output_dp *outp, int nr, int bw, bool ef)
...
@@ -92,8 +95,8 @@ g94_sor_dp_lnk_ctl(struct nvkm_output_dp *outp, int nr, int bw, bool ef)
if
(
bw
>
0x06
)
if
(
bw
>
0x06
)
clksor
|=
0x00040000
;
clksor
|=
0x00040000
;
nv
_mask
(
disp
,
0x614300
+
soff
,
0x000c0000
,
clksor
);
nv
km_mask
(
device
,
0x614300
+
soff
,
0x000c0000
,
clksor
);
nv
_mask
(
disp
,
0x61c10c
+
loff
,
0x001f4000
,
dpctrl
);
nv
km_mask
(
device
,
0x61c10c
+
loff
,
0x001f4000
,
dpctrl
);
return
0
;
return
0
;
}
}
...
@@ -101,7 +104,8 @@ static int
...
@@ -101,7 +104,8 @@ static int
g94_sor_dp_drv_ctl
(
struct
nvkm_output_dp
*
outp
,
int
ln
,
int
vs
,
int
pe
,
int
pc
)
g94_sor_dp_drv_ctl
(
struct
nvkm_output_dp
*
outp
,
int
ln
,
int
vs
,
int
pe
,
int
pc
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
const
u32
shift
=
g94_sor_dp_lane_map
(
disp
,
ln
);
const
u32
shift
=
g94_sor_dp_lane_map
(
disp
,
ln
);
const
u32
loff
=
g94_sor_loff
(
outp
);
const
u32
loff
=
g94_sor_loff
(
outp
);
u32
addr
,
data
[
3
];
u32
addr
,
data
[
3
];
...
@@ -120,14 +124,14 @@ g94_sor_dp_drv_ctl(struct nvkm_output_dp *outp, int ln, int vs, int pe, int pc)
...
@@ -120,14 +124,14 @@ g94_sor_dp_drv_ctl(struct nvkm_output_dp *outp, int ln, int vs, int pe, int pc)
if
(
!
addr
)
if
(
!
addr
)
return
-
EINVAL
;
return
-
EINVAL
;
data
[
0
]
=
nv
_rd32
(
disp
,
0x61c118
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
0
]
=
nv
km_rd32
(
device
,
0x61c118
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
1
]
=
nv
_rd32
(
disp
,
0x61c120
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
1
]
=
nv
km_rd32
(
device
,
0x61c120
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
2
]
=
nv
_rd32
(
disp
,
0x61c130
+
loff
);
data
[
2
]
=
nv
km_rd32
(
device
,
0x61c130
+
loff
);
if
((
data
[
2
]
&
0x0000ff00
)
<
(
ocfg
.
tx_pu
<<
8
)
||
ln
==
0
)
if
((
data
[
2
]
&
0x0000ff00
)
<
(
ocfg
.
tx_pu
<<
8
)
||
ln
==
0
)
data
[
2
]
=
(
data
[
2
]
&
~
0x0000ff00
)
|
(
ocfg
.
tx_pu
<<
8
);
data
[
2
]
=
(
data
[
2
]
&
~
0x0000ff00
)
|
(
ocfg
.
tx_pu
<<
8
);
nv
_wr32
(
disp
,
0x61c118
+
loff
,
data
[
0
]
|
(
ocfg
.
dc
<<
shift
));
nv
km_wr32
(
device
,
0x61c118
+
loff
,
data
[
0
]
|
(
ocfg
.
dc
<<
shift
));
nv
_wr32
(
disp
,
0x61c120
+
loff
,
data
[
1
]
|
(
ocfg
.
pe
<<
shift
));
nv
km_wr32
(
device
,
0x61c120
+
loff
,
data
[
1
]
|
(
ocfg
.
pe
<<
shift
));
nv
_wr32
(
disp
,
0x61c130
+
loff
,
data
[
2
]);
nv
km_wr32
(
device
,
0x61c130
+
loff
,
data
[
2
]);
return
0
;
return
0
;
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgf110.c
View file @
2fde1f1c
...
@@ -40,8 +40,9 @@ static int
...
@@ -40,8 +40,9 @@ static int
gf110_sor_dp_pattern
(
struct
nvkm_output_dp
*
outp
,
int
pattern
)
gf110_sor_dp_pattern
(
struct
nvkm_output_dp
*
outp
,
int
pattern
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
loff
=
gf110_sor_loff
(
outp
);
const
u32
loff
=
gf110_sor_loff
(
outp
);
nv
_mask
(
disp
,
0x61c110
+
loff
,
0x0f0f0f0f
,
0x01010101
*
pattern
);
nv
km_mask
(
device
,
0x61c110
+
loff
,
0x0f0f0f0f
,
0x01010101
*
pattern
);
return
0
;
return
0
;
}
}
...
@@ -49,6 +50,7 @@ int
...
@@ -49,6 +50,7 @@ int
gf110_sor_dp_lnk_ctl
(
struct
nvkm_output_dp
*
outp
,
int
nr
,
int
bw
,
bool
ef
)
gf110_sor_dp_lnk_ctl
(
struct
nvkm_output_dp
*
outp
,
int
nr
,
int
bw
,
bool
ef
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
gf110_sor_soff
(
outp
);
const
u32
soff
=
gf110_sor_soff
(
outp
);
const
u32
loff
=
gf110_sor_loff
(
outp
);
const
u32
loff
=
gf110_sor_loff
(
outp
);
u32
dpctrl
=
0x00000000
;
u32
dpctrl
=
0x00000000
;
...
@@ -59,8 +61,8 @@ gf110_sor_dp_lnk_ctl(struct nvkm_output_dp *outp, int nr, int bw, bool ef)
...
@@ -59,8 +61,8 @@ gf110_sor_dp_lnk_ctl(struct nvkm_output_dp *outp, int nr, int bw, bool ef)
if
(
ef
)
if
(
ef
)
dpctrl
|=
0x00004000
;
dpctrl
|=
0x00004000
;
nv
_mask
(
disp
,
0x612300
+
soff
,
0x007c0000
,
clksor
);
nv
km_mask
(
device
,
0x612300
+
soff
,
0x007c0000
,
clksor
);
nv
_mask
(
disp
,
0x61c10c
+
loff
,
0x001f4000
,
dpctrl
);
nv
km_mask
(
device
,
0x61c10c
+
loff
,
0x001f4000
,
dpctrl
);
return
0
;
return
0
;
}
}
...
@@ -69,7 +71,8 @@ gf110_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
...
@@ -69,7 +71,8 @@ gf110_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
int
ln
,
int
vs
,
int
pe
,
int
pc
)
int
ln
,
int
vs
,
int
pe
,
int
pc
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
const
u32
shift
=
g94_sor_dp_lane_map
(
disp
,
ln
);
const
u32
shift
=
g94_sor_dp_lane_map
(
disp
,
ln
);
const
u32
loff
=
gf110_sor_loff
(
outp
);
const
u32
loff
=
gf110_sor_loff
(
outp
);
u32
addr
,
data
[
4
];
u32
addr
,
data
[
4
];
...
@@ -88,16 +91,16 @@ gf110_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
...
@@ -88,16 +91,16 @@ gf110_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
if
(
!
addr
)
if
(
!
addr
)
return
-
EINVAL
;
return
-
EINVAL
;
data
[
0
]
=
nv
_rd32
(
disp
,
0x61c118
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
0
]
=
nv
km_rd32
(
device
,
0x61c118
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
1
]
=
nv
_rd32
(
disp
,
0x61c120
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
1
]
=
nv
km_rd32
(
device
,
0x61c120
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
2
]
=
nv
_rd32
(
disp
,
0x61c130
+
loff
);
data
[
2
]
=
nv
km_rd32
(
device
,
0x61c130
+
loff
);
if
((
data
[
2
]
&
0x0000ff00
)
<
(
ocfg
.
tx_pu
<<
8
)
||
ln
==
0
)
if
((
data
[
2
]
&
0x0000ff00
)
<
(
ocfg
.
tx_pu
<<
8
)
||
ln
==
0
)
data
[
2
]
=
(
data
[
2
]
&
~
0x0000ff00
)
|
(
ocfg
.
tx_pu
<<
8
);
data
[
2
]
=
(
data
[
2
]
&
~
0x0000ff00
)
|
(
ocfg
.
tx_pu
<<
8
);
nv
_wr32
(
disp
,
0x61c118
+
loff
,
data
[
0
]
|
(
ocfg
.
dc
<<
shift
));
nv
km_wr32
(
device
,
0x61c118
+
loff
,
data
[
0
]
|
(
ocfg
.
dc
<<
shift
));
nv
_wr32
(
disp
,
0x61c120
+
loff
,
data
[
1
]
|
(
ocfg
.
pe
<<
shift
));
nv
km_wr32
(
device
,
0x61c120
+
loff
,
data
[
1
]
|
(
ocfg
.
pe
<<
shift
));
nv
_wr32
(
disp
,
0x61c130
+
loff
,
data
[
2
]);
nv
km_wr32
(
device
,
0x61c130
+
loff
,
data
[
2
]);
data
[
3
]
=
nv
_rd32
(
disp
,
0x61c13c
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
3
]
=
nv
km_rd32
(
device
,
0x61c13c
+
loff
)
&
~
(
0x000000ff
<<
shift
);
nv
_wr32
(
disp
,
0x61c13c
+
loff
,
data
[
3
]
|
(
ocfg
.
pc
<<
shift
));
nv
km_wr32
(
device
,
0x61c13c
+
loff
,
data
[
3
]
|
(
ocfg
.
pc
<<
shift
));
return
0
;
return
0
;
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/sorgm204.c
View file @
2fde1f1c
...
@@ -42,12 +42,13 @@ void
...
@@ -42,12 +42,13 @@ void
gm204_sor_magic
(
struct
nvkm_output
*
outp
)
gm204_sor_magic
(
struct
nvkm_output
*
outp
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
outp
->
or
*
0x100
;
const
u32
soff
=
outp
->
or
*
0x100
;
const
u32
data
=
outp
->
or
+
1
;
const
u32
data
=
outp
->
or
+
1
;
if
(
outp
->
info
.
sorconf
.
link
&
1
)
if
(
outp
->
info
.
sorconf
.
link
&
1
)
nv
_mask
(
disp
,
0x612308
+
soff
,
0x0000001f
,
0x00000000
|
data
);
nv
km_mask
(
device
,
0x612308
+
soff
,
0x0000001f
,
0x00000000
|
data
);
if
(
outp
->
info
.
sorconf
.
link
&
2
)
if
(
outp
->
info
.
sorconf
.
link
&
2
)
nv
_mask
(
disp
,
0x612388
+
soff
,
0x0000001f
,
0x00000010
|
data
);
nv
km_mask
(
device
,
0x612388
+
soff
,
0x0000001f
,
0x00000010
|
data
);
}
}
static
inline
u32
static
inline
u32
...
@@ -60,12 +61,13 @@ static int
...
@@ -60,12 +61,13 @@ static int
gm204_sor_dp_pattern
(
struct
nvkm_output_dp
*
outp
,
int
pattern
)
gm204_sor_dp_pattern
(
struct
nvkm_output_dp
*
outp
,
int
pattern
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
gm204_sor_soff
(
outp
);
const
u32
soff
=
gm204_sor_soff
(
outp
);
const
u32
data
=
0x01010101
*
pattern
;
const
u32
data
=
0x01010101
*
pattern
;
if
(
outp
->
base
.
info
.
sorconf
.
link
&
1
)
if
(
outp
->
base
.
info
.
sorconf
.
link
&
1
)
nv
_mask
(
disp
,
0x61c110
+
soff
,
0x0f0f0f0f
,
data
);
nv
km_mask
(
device
,
0x61c110
+
soff
,
0x0f0f0f0f
,
data
);
else
else
nv
_mask
(
disp
,
0x61c12c
+
soff
,
0x0f0f0f0f
,
data
);
nv
km_mask
(
device
,
0x61c12c
+
soff
,
0x0f0f0f0f
,
data
);
return
0
;
return
0
;
}
}
...
@@ -73,6 +75,7 @@ static int
...
@@ -73,6 +75,7 @@ static int
gm204_sor_dp_lnk_pwr
(
struct
nvkm_output_dp
*
outp
,
int
nr
)
gm204_sor_dp_lnk_pwr
(
struct
nvkm_output_dp
*
outp
,
int
nr
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
const
u32
soff
=
gm204_sor_soff
(
outp
);
const
u32
soff
=
gm204_sor_soff
(
outp
);
const
u32
loff
=
gm204_sor_loff
(
outp
);
const
u32
loff
=
gm204_sor_loff
(
outp
);
u32
mask
=
0
,
i
;
u32
mask
=
0
,
i
;
...
@@ -80,8 +83,8 @@ gm204_sor_dp_lnk_pwr(struct nvkm_output_dp *outp, int nr)
...
@@ -80,8 +83,8 @@ gm204_sor_dp_lnk_pwr(struct nvkm_output_dp *outp, int nr)
for
(
i
=
0
;
i
<
nr
;
i
++
)
for
(
i
=
0
;
i
<
nr
;
i
++
)
mask
|=
1
<<
(
gm204_sor_dp_lane_map
(
disp
,
i
)
>>
3
);
mask
|=
1
<<
(
gm204_sor_dp_lane_map
(
disp
,
i
)
>>
3
);
nv
_mask
(
disp
,
0x61c130
+
loff
,
0x0000000f
,
mask
);
nv
km_mask
(
device
,
0x61c130
+
loff
,
0x0000000f
,
mask
);
nv
_mask
(
disp
,
0x61c034
+
soff
,
0x80000000
,
0x80000000
);
nv
km_mask
(
device
,
0x61c034
+
soff
,
0x80000000
,
0x80000000
);
nv_wait
(
disp
,
0x61c034
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c034
+
soff
,
0x80000000
,
0x00000000
);
return
0
;
return
0
;
}
}
...
@@ -91,7 +94,8 @@ gm204_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
...
@@ -91,7 +94,8 @@ gm204_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
int
ln
,
int
vs
,
int
pe
,
int
pc
)
int
ln
,
int
vs
,
int
pe
,
int
pc
)
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nv50_disp
*
disp
=
(
void
*
)
nvkm_disp
(
outp
);
struct
nvkm_bios
*
bios
=
nvkm_bios
(
disp
);
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
const
u32
shift
=
gm204_sor_dp_lane_map
(
disp
,
ln
);
const
u32
shift
=
gm204_sor_dp_lane_map
(
disp
,
ln
);
const
u32
loff
=
gm204_sor_loff
(
outp
);
const
u32
loff
=
gm204_sor_loff
(
outp
);
u32
addr
,
data
[
4
];
u32
addr
,
data
[
4
];
...
@@ -111,16 +115,16 @@ gm204_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
...
@@ -111,16 +115,16 @@ gm204_sor_dp_drv_ctl(struct nvkm_output_dp *outp,
return
-
EINVAL
;
return
-
EINVAL
;
ocfg
.
tx_pu
&=
0x0f
;
ocfg
.
tx_pu
&=
0x0f
;
data
[
0
]
=
nv
_rd32
(
disp
,
0x61c118
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
0
]
=
nv
km_rd32
(
device
,
0x61c118
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
1
]
=
nv
_rd32
(
disp
,
0x61c120
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
1
]
=
nv
km_rd32
(
device
,
0x61c120
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
2
]
=
nv
_rd32
(
disp
,
0x61c130
+
loff
);
data
[
2
]
=
nv
km_rd32
(
device
,
0x61c130
+
loff
);
if
((
data
[
2
]
&
0x00000f00
)
<
(
ocfg
.
tx_pu
<<
8
)
||
ln
==
0
)
if
((
data
[
2
]
&
0x00000f00
)
<
(
ocfg
.
tx_pu
<<
8
)
||
ln
==
0
)
data
[
2
]
=
(
data
[
2
]
&
~
0x00000f00
)
|
(
ocfg
.
tx_pu
<<
8
);
data
[
2
]
=
(
data
[
2
]
&
~
0x00000f00
)
|
(
ocfg
.
tx_pu
<<
8
);
nv
_wr32
(
disp
,
0x61c118
+
loff
,
data
[
0
]
|
(
ocfg
.
dc
<<
shift
));
nv
km_wr32
(
device
,
0x61c118
+
loff
,
data
[
0
]
|
(
ocfg
.
dc
<<
shift
));
nv
_wr32
(
disp
,
0x61c120
+
loff
,
data
[
1
]
|
(
ocfg
.
pe
<<
shift
));
nv
km_wr32
(
device
,
0x61c120
+
loff
,
data
[
1
]
|
(
ocfg
.
pe
<<
shift
));
nv
_wr32
(
disp
,
0x61c130
+
loff
,
data
[
2
]);
nv
km_wr32
(
device
,
0x61c130
+
loff
,
data
[
2
]);
data
[
3
]
=
nv
_rd32
(
disp
,
0x61c13c
+
loff
)
&
~
(
0x000000ff
<<
shift
);
data
[
3
]
=
nv
km_rd32
(
device
,
0x61c13c
+
loff
)
&
~
(
0x000000ff
<<
shift
);
nv
_wr32
(
disp
,
0x61c13c
+
loff
,
data
[
3
]
|
(
ocfg
.
pc
<<
shift
));
nv
km_wr32
(
device
,
0x61c13c
+
loff
,
data
[
3
]
|
(
ocfg
.
pc
<<
shift
));
return
0
;
return
0
;
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/sornv50.c
View file @
2fde1f1c
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
int
int
nv50_sor_power
(
NV50_DISP_MTHD_V1
)
nv50_sor_power
(
NV50_DISP_MTHD_V1
)
{
{
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
union
{
union
{
struct
nv50_disp_sor_pwr_v0
v0
;
struct
nv50_disp_sor_pwr_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
...
@@ -49,7 +50,7 @@ nv50_sor_power(NV50_DISP_MTHD_V1)
...
@@ -49,7 +50,7 @@ nv50_sor_power(NV50_DISP_MTHD_V1)
return
ret
;
return
ret
;
nv_wait
(
disp
,
0x61c004
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c004
+
soff
,
0x80000000
,
0x00000000
);
nv
_mask
(
disp
,
0x61c004
+
soff
,
0x80000001
,
0x80000000
|
stat
);
nv
km_mask
(
device
,
0x61c004
+
soff
,
0x80000001
,
0x80000000
|
stat
);
nv_wait
(
disp
,
0x61c004
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c004
+
soff
,
0x80000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c030
+
soff
,
0x10000000
,
0x00000000
);
nv_wait
(
disp
,
0x61c030
+
soff
,
0x10000000
,
0x00000000
);
return
0
;
return
0
;
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/vga.c
View file @
2fde1f1c
...
@@ -29,19 +29,19 @@ nv_rdport(void *obj, int head, u16 port)
...
@@ -29,19 +29,19 @@ nv_rdport(void *obj, int head, u16 port)
struct
nvkm_device
*
device
=
nv_device
(
obj
);
struct
nvkm_device
*
device
=
nv_device
(
obj
);
if
(
device
->
card_type
>=
NV_50
)
if
(
device
->
card_type
>=
NV_50
)
return
nv
_rd08
(
obj
,
0x601000
+
port
);
return
nv
km_rd08
(
device
,
0x601000
+
port
);
if
(
port
==
0x03c0
||
port
==
0x03c1
||
/* AR */
if
(
port
==
0x03c0
||
port
==
0x03c1
||
/* AR */
port
==
0x03c2
||
port
==
0x03da
||
/* INP0 */
port
==
0x03c2
||
port
==
0x03da
||
/* INP0 */
port
==
0x03d4
||
port
==
0x03d5
)
/* CR */
port
==
0x03d4
||
port
==
0x03d5
)
/* CR */
return
nv
_rd08
(
obj
,
0x601000
+
(
head
*
0x2000
)
+
port
);
return
nv
km_rd08
(
device
,
0x601000
+
(
head
*
0x2000
)
+
port
);
if
(
port
==
0x03c2
||
port
==
0x03cc
||
/* MISC */
if
(
port
==
0x03c2
||
port
==
0x03cc
||
/* MISC */
port
==
0x03c4
||
port
==
0x03c5
||
/* SR */
port
==
0x03c4
||
port
==
0x03c5
||
/* SR */
port
==
0x03ce
||
port
==
0x03cf
)
{
/* GR */
port
==
0x03ce
||
port
==
0x03cf
)
{
/* GR */
if
(
device
->
card_type
<
NV_40
)
if
(
device
->
card_type
<
NV_40
)
head
=
0
;
/* CR44 selects head */
head
=
0
;
/* CR44 selects head */
return
nv
_rd08
(
obj
,
0x0c0000
+
(
head
*
0x2000
)
+
port
);
return
nv
km_rd08
(
device
,
0x0c0000
+
(
head
*
0x2000
)
+
port
);
}
}
nv_error
(
obj
,
"unknown vga port 0x%04x
\n
"
,
port
);
nv_error
(
obj
,
"unknown vga port 0x%04x
\n
"
,
port
);
...
@@ -54,19 +54,19 @@ nv_wrport(void *obj, int head, u16 port, u8 data)
...
@@ -54,19 +54,19 @@ nv_wrport(void *obj, int head, u16 port, u8 data)
struct
nvkm_device
*
device
=
nv_device
(
obj
);
struct
nvkm_device
*
device
=
nv_device
(
obj
);
if
(
device
->
card_type
>=
NV_50
)
if
(
device
->
card_type
>=
NV_50
)
nv
_wr08
(
obj
,
0x601000
+
port
,
data
);
nv
km_wr08
(
device
,
0x601000
+
port
,
data
);
else
else
if
(
port
==
0x03c0
||
port
==
0x03c1
||
/* AR */
if
(
port
==
0x03c0
||
port
==
0x03c1
||
/* AR */
port
==
0x03c2
||
port
==
0x03da
||
/* INP0 */
port
==
0x03c2
||
port
==
0x03da
||
/* INP0 */
port
==
0x03d4
||
port
==
0x03d5
)
/* CR */
port
==
0x03d4
||
port
==
0x03d5
)
/* CR */
nv
_wr08
(
obj
,
0x601000
+
(
head
*
0x2000
)
+
port
,
data
);
nv
km_wr08
(
device
,
0x601000
+
(
head
*
0x2000
)
+
port
,
data
);
else
else
if
(
port
==
0x03c2
||
port
==
0x03cc
||
/* MISC */
if
(
port
==
0x03c2
||
port
==
0x03cc
||
/* MISC */
port
==
0x03c4
||
port
==
0x03c5
||
/* SR */
port
==
0x03c4
||
port
==
0x03c5
||
/* SR */
port
==
0x03ce
||
port
==
0x03cf
)
{
/* GR */
port
==
0x03ce
||
port
==
0x03cf
)
{
/* GR */
if
(
device
->
card_type
<
NV_40
)
if
(
device
->
card_type
<
NV_40
)
head
=
0
;
/* CR44 selects head */
head
=
0
;
/* CR44 selects head */
nv
_wr08
(
obj
,
0x0c0000
+
(
head
*
0x2000
)
+
port
,
data
);
nv
km_wr08
(
device
,
0x0c0000
+
(
head
*
0x2000
)
+
port
,
data
);
}
else
}
else
nv_error
(
obj
,
"unknown vga port 0x%04x
\n
"
,
port
);
nv_error
(
obj
,
"unknown vga port 0x%04x
\n
"
,
port
);
}
}
...
@@ -135,16 +135,16 @@ nv_wrvgai(void *obj, int head, u16 port, u8 index, u8 value)
...
@@ -135,16 +135,16 @@ nv_wrvgai(void *obj, int head, u16 port, u8 index, u8 value)
bool
bool
nv_lockvgac
(
void
*
obj
,
bool
lock
)
nv_lockvgac
(
void
*
obj
,
bool
lock
)
{
{
struct
nvkm_device
*
dev
=
nv_device
(
obj
);
struct
nvkm_device
*
dev
ice
=
nv_device
(
obj
);
bool
locked
=
!
nv_rdvgac
(
obj
,
0
,
0x1f
);
bool
locked
=
!
nv_rdvgac
(
obj
,
0
,
0x1f
);
u8
data
=
lock
?
0x99
:
0x57
;
u8
data
=
lock
?
0x99
:
0x57
;
if
(
dev
->
card_type
<
NV_50
)
if
(
dev
ice
->
card_type
<
NV_50
)
nv_wrvgac
(
obj
,
0
,
0x1f
,
data
);
nv_wrvgac
(
obj
,
0
,
0x1f
,
data
);
else
else
nv_wrvgac
(
obj
,
0
,
0x3f
,
data
);
nv_wrvgac
(
obj
,
0
,
0x3f
,
data
);
if
(
dev
->
chipset
==
0x11
)
{
if
(
dev
ice
->
chipset
==
0x11
)
{
if
(
!
(
nv
_rd32
(
obj
,
0x001084
)
&
0x10000000
))
if
(
!
(
nv
km_rd32
(
device
,
0x001084
)
&
0x10000000
))
nv_wrvgac
(
obj
,
1
,
0x1f
,
data
);
nv_wrvgac
(
obj
,
1
,
0x1f
,
data
);
}
}
return
locked
;
return
locked
;
...
@@ -171,9 +171,10 @@ nv_lockvgac(void *obj, bool lock)
...
@@ -171,9 +171,10 @@ nv_lockvgac(void *obj, bool lock)
u8
u8
nv_rdvgaowner
(
void
*
obj
)
nv_rdvgaowner
(
void
*
obj
)
{
{
if
(
nv_device
(
obj
)
->
card_type
<
NV_50
)
{
struct
nvkm_device
*
device
=
nv_device
(
obj
);
if
(
device
->
card_type
<
NV_50
)
{
if
(
nv_device
(
obj
)
->
chipset
==
0x11
)
{
if
(
nv_device
(
obj
)
->
chipset
==
0x11
)
{
u32
tied
=
nv
_rd32
(
obj
,
0x001084
)
&
0x10000000
;
u32
tied
=
nv
km_rd32
(
device
,
0x001084
)
&
0x10000000
;
if
(
tied
==
0
)
{
if
(
tied
==
0
)
{
u8
slA
=
nv_rdvgac
(
obj
,
0
,
0x28
)
&
0x80
;
u8
slA
=
nv_rdvgac
(
obj
,
0
,
0x28
)
&
0x80
;
u8
tvA
=
nv_rdvgac
(
obj
,
0
,
0x33
)
&
0x01
;
u8
tvA
=
nv_rdvgac
(
obj
,
0
,
0x33
)
&
0x01
;
...
...
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