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
Kirill Smelkov
linux
Commits
e5c5e4f5
Commit
e5c5e4f5
authored
Aug 20, 2015
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/fifo: switch to subdev printk macros
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
84407824
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
162 additions
and
165 deletions
+162
-165
drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c
+3
-2
drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c
+4
-3
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c
+55
-59
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c
+71
-77
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c
+25
-21
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c
+4
-3
No files found.
drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c
View file @
e5c5e4f5
...
@@ -57,10 +57,11 @@ nvkm_fifo_channel_create_(struct nvkm_object *parent,
...
@@ -57,10 +57,11 @@ nvkm_fifo_channel_create_(struct nvkm_object *parent,
int
bar
,
u32
addr
,
u32
size
,
u32
pushbuf
,
int
bar
,
u32
addr
,
u32
size
,
u32
pushbuf
,
u64
engmask
,
int
len
,
void
**
ptr
)
u64
engmask
,
int
len
,
void
**
ptr
)
{
{
struct
nvkm_device
*
device
=
nv_device
(
engine
);
struct
nvkm_fifo
*
fifo
=
(
void
*
)
engine
;
struct
nvkm_fifo
*
fifo
=
(
void
*
)
engine
;
struct
nvkm_fifo_chan
*
chan
;
struct
nvkm_fifo_chan
*
chan
;
struct
nvkm_dmaeng
*
dmaeng
;
struct
nvkm_dmaeng
*
dmaeng
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
unsigned
long
flags
;
unsigned
long
flags
;
int
ret
;
int
ret
;
...
@@ -100,7 +101,7 @@ nvkm_fifo_channel_create_(struct nvkm_object *parent,
...
@@ -100,7 +101,7 @@ nvkm_fifo_channel_create_(struct nvkm_object *parent,
spin_unlock_irqrestore
(
&
fifo
->
lock
,
flags
);
spin_unlock_irqrestore
(
&
fifo
->
lock
,
flags
);
if
(
chan
->
chid
==
fifo
->
max
)
{
if
(
chan
->
chid
==
fifo
->
max
)
{
nv
_error
(
fifo
,
"no free channels
\n
"
);
nv
km_error
(
subdev
,
"no free channels
\n
"
);
return
-
ENOSPC
;
return
-
ENOSPC
;
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c
View file @
e5c5e4f5
...
@@ -83,7 +83,8 @@ g84_fifo_context_detach(struct nvkm_object *parent, bool suspend,
...
@@ -83,7 +83,8 @@ g84_fifo_context_detach(struct nvkm_object *parent, bool suspend,
struct
nv50_fifo
*
fifo
=
(
void
*
)
parent
->
engine
;
struct
nv50_fifo
*
fifo
=
(
void
*
)
parent
->
engine
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
->
parent
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
->
parent
;
struct
nv50_fifo_chan
*
chan
=
(
void
*
)
parent
;
struct
nv50_fifo_chan
*
chan
=
(
void
*
)
parent
;
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
u32
addr
,
save
,
engn
;
u32
addr
,
save
,
engn
;
bool
done
;
bool
done
;
...
@@ -112,8 +113,8 @@ g84_fifo_context_detach(struct nvkm_object *parent, bool suspend,
...
@@ -112,8 +113,8 @@ g84_fifo_context_detach(struct nvkm_object *parent, bool suspend,
)
>=
0
;
)
>=
0
;
nvkm_wr32
(
device
,
0x002520
,
save
);
nvkm_wr32
(
device
,
0x002520
,
save
);
if
(
!
done
)
{
if
(
!
done
)
{
nv
_error
(
fifo
,
"channel %d [%s] unload timeout
\n
"
,
nv
km_error
(
subdev
,
"channel %d [%s] unload timeout
\n
"
,
chan
->
base
.
chid
,
nvkm_client_name
(
chan
));
chan
->
base
.
chid
,
nvkm_client_name
(
chan
));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c
View file @
e5c5e4f5
...
@@ -76,7 +76,8 @@ struct gf100_fifo_chan {
...
@@ -76,7 +76,8 @@ struct gf100_fifo_chan {
static
void
static
void
gf100_fifo_runlist_update
(
struct
gf100_fifo
*
fifo
)
gf100_fifo_runlist_update
(
struct
gf100_fifo
*
fifo
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
struct
nvkm_gpuobj
*
cur
;
struct
nvkm_gpuobj
*
cur
;
int
i
,
p
;
int
i
,
p
;
...
@@ -101,7 +102,7 @@ gf100_fifo_runlist_update(struct gf100_fifo *fifo)
...
@@ -101,7 +102,7 @@ gf100_fifo_runlist_update(struct gf100_fifo *fifo)
if
(
wait_event_timeout
(
fifo
->
runlist
.
wait
,
if
(
wait_event_timeout
(
fifo
->
runlist
.
wait
,
!
(
nvkm_rd32
(
device
,
0x00227c
)
&
0x00100000
),
!
(
nvkm_rd32
(
device
,
0x00227c
)
&
0x00100000
),
msecs_to_jiffies
(
2000
))
==
0
)
msecs_to_jiffies
(
2000
))
==
0
)
nv
_error
(
fifo
,
"runlist update timeout
\n
"
);
nv
km_error
(
subdev
,
"runlist update timeout
\n
"
);
mutex_unlock
(
&
nv_subdev
(
fifo
)
->
mutex
);
mutex_unlock
(
&
nv_subdev
(
fifo
)
->
mutex
);
}
}
...
@@ -149,7 +150,8 @@ gf100_fifo_context_detach(struct nvkm_object *parent, bool suspend,
...
@@ -149,7 +150,8 @@ gf100_fifo_context_detach(struct nvkm_object *parent, bool suspend,
struct
gf100_fifo
*
fifo
=
(
void
*
)
parent
->
engine
;
struct
gf100_fifo
*
fifo
=
(
void
*
)
parent
->
engine
;
struct
gf100_fifo_base
*
base
=
(
void
*
)
parent
->
parent
;
struct
gf100_fifo_base
*
base
=
(
void
*
)
parent
->
parent
;
struct
gf100_fifo_chan
*
chan
=
(
void
*
)
parent
;
struct
gf100_fifo_chan
*
chan
=
(
void
*
)
parent
;
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
u32
addr
;
u32
addr
;
...
@@ -170,8 +172,8 @@ gf100_fifo_context_detach(struct nvkm_object *parent, bool suspend,
...
@@ -170,8 +172,8 @@ gf100_fifo_context_detach(struct nvkm_object *parent, bool suspend,
if
(
nvkm_rd32
(
device
,
0x002634
)
==
chan
->
base
.
chid
)
if
(
nvkm_rd32
(
device
,
0x002634
)
==
chan
->
base
.
chid
)
break
;
break
;
)
<
0
)
{
)
<
0
)
{
nv
_error
(
fifo
,
"channel %d [%s] kick timeout
\n
"
,
nv
km_error
(
subdev
,
"channel %d [%s] kick timeout
\n
"
,
chan
->
base
.
chid
,
nvkm_client_name
(
chan
));
chan
->
base
.
chid
,
nvkm_client_name
(
chan
));
if
(
suspend
)
if
(
suspend
)
return
-
EBUSY
;
return
-
EBUSY
;
}
}
...
@@ -446,12 +448,13 @@ static void
...
@@ -446,12 +448,13 @@ static void
gf100_fifo_recover
(
struct
gf100_fifo
*
fifo
,
struct
nvkm_engine
*
engine
,
gf100_fifo_recover
(
struct
gf100_fifo
*
fifo
,
struct
nvkm_engine
*
engine
,
struct
gf100_fifo_chan
*
chan
)
struct
gf100_fifo_chan
*
chan
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
chid
=
chan
->
base
.
chid
;
u32
chid
=
chan
->
base
.
chid
;
unsigned
long
flags
;
unsigned
long
flags
;
nv
_error
(
fifo
,
"%s engine fault on channel %d, recovering...
\n
"
,
nv
km_error
(
subdev
,
"%s engine fault on channel %d, recovering...
\n
"
,
nv_subdev
(
engine
)
->
name
,
chid
);
engine
->
subdev
.
name
,
chid
);
nvkm_mask
(
device
,
0x003004
+
(
chid
*
0x08
),
0x00000001
,
0x00000000
);
nvkm_mask
(
device
,
0x003004
+
(
chid
*
0x08
),
0x00000001
,
0x00000000
);
chan
->
state
=
KILLED
;
chan
->
state
=
KILLED
;
...
@@ -524,17 +527,15 @@ gf100_fifo_intr_sched_ctxsw(struct gf100_fifo *fifo)
...
@@ -524,17 +527,15 @@ gf100_fifo_intr_sched_ctxsw(struct gf100_fifo *fifo)
static
void
static
void
gf100_fifo_intr_sched
(
struct
gf100_fifo
*
fifo
)
gf100_fifo_intr_sched
(
struct
gf100_fifo
*
fifo
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
intr
=
nvkm_rd32
(
device
,
0x00254c
);
u32
intr
=
nvkm_rd32
(
device
,
0x00254c
);
u32
code
=
intr
&
0x000000ff
;
u32
code
=
intr
&
0x000000ff
;
const
struct
nvkm_enum
*
en
;
const
struct
nvkm_enum
*
en
;
char
enunk
[
6
]
=
""
;
en
=
nvkm_enum_find
(
gf100_fifo_sched_reason
,
code
);
en
=
nvkm_enum_find
(
gf100_fifo_sched_reason
,
code
);
if
(
!
en
)
snprintf
(
enunk
,
sizeof
(
enunk
),
"UNK%02x"
,
code
);
nv
_error
(
fifo
,
"SCHED_ERROR [ %s ]
\n
"
,
en
?
en
->
name
:
enunk
);
nv
km_error
(
subdev
,
"SCHED_ERROR %02x [%s]
\n
"
,
code
,
en
?
en
->
name
:
""
);
switch
(
code
)
{
switch
(
code
)
{
case
0x0a
:
case
0x0a
:
...
@@ -607,7 +608,8 @@ gf100_fifo_fault_gpcclient[] = {
...
@@ -607,7 +608,8 @@ gf100_fifo_fault_gpcclient[] = {
static
void
static
void
gf100_fifo_intr_fault
(
struct
gf100_fifo
*
fifo
,
int
unit
)
gf100_fifo_intr_fault
(
struct
gf100_fifo
*
fifo
,
int
unit
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
inst
=
nvkm_rd32
(
device
,
0x002800
+
(
unit
*
0x10
));
u32
inst
=
nvkm_rd32
(
device
,
0x002800
+
(
unit
*
0x10
));
u32
valo
=
nvkm_rd32
(
device
,
0x002804
+
(
unit
*
0x10
));
u32
valo
=
nvkm_rd32
(
device
,
0x002804
+
(
unit
*
0x10
));
u32
vahi
=
nvkm_rd32
(
device
,
0x002808
+
(
unit
*
0x10
));
u32
vahi
=
nvkm_rd32
(
device
,
0x002808
+
(
unit
*
0x10
));
...
@@ -620,16 +622,17 @@ gf100_fifo_intr_fault(struct gf100_fifo *fifo, int unit)
...
@@ -620,16 +622,17 @@ gf100_fifo_intr_fault(struct gf100_fifo *fifo, int unit)
struct
nvkm_object
*
engctx
=
NULL
,
*
object
;
struct
nvkm_object
*
engctx
=
NULL
,
*
object
;
struct
nvkm_engine
*
engine
=
NULL
;
struct
nvkm_engine
*
engine
=
NULL
;
const
struct
nvkm_enum
*
er
,
*
eu
,
*
ec
;
const
struct
nvkm_enum
*
er
,
*
eu
,
*
ec
;
char
erunk
[
6
]
=
""
;
char
gpcid
[
8
]
=
""
;
char
euunk
[
6
]
=
""
;
char
ecunk
[
6
]
=
""
;
char
gpcid
[
3
]
=
""
;
er
=
nvkm_enum_find
(
gf100_fifo_fault_reason
,
reason
);
er
=
nvkm_enum_find
(
gf100_fifo_fault_reason
,
reason
);
if
(
!
er
)
snprintf
(
erunk
,
sizeof
(
erunk
),
"UNK%02X"
,
reason
);
eu
=
nvkm_enum_find
(
gf100_fifo_fault_engine
,
unit
);
eu
=
nvkm_enum_find
(
gf100_fifo_fault_engine
,
unit
);
if
(
hub
)
{
ec
=
nvkm_enum_find
(
gf100_fifo_fault_hubclient
,
client
);
}
else
{
ec
=
nvkm_enum_find
(
gf100_fifo_fault_gpcclient
,
client
);
snprintf
(
gpcid
,
sizeof
(
gpcid
),
"GPC%d/"
,
gpc
);
}
if
(
eu
)
{
if
(
eu
)
{
switch
(
eu
->
data2
)
{
switch
(
eu
->
data2
)
{
case
NVDEV_SUBDEV_BAR
:
case
NVDEV_SUBDEV_BAR
:
...
@@ -647,26 +650,15 @@ gf100_fifo_intr_fault(struct gf100_fifo *fifo, int unit)
...
@@ -647,26 +650,15 @@ gf100_fifo_intr_fault(struct gf100_fifo *fifo, int unit)
engctx
=
nvkm_engctx_get
(
engine
,
inst
);
engctx
=
nvkm_engctx_get
(
engine
,
inst
);
break
;
break
;
}
}
}
else
{
snprintf
(
euunk
,
sizeof
(
euunk
),
"UNK%02x"
,
unit
);
}
if
(
hub
)
{
ec
=
nvkm_enum_find
(
gf100_fifo_fault_hubclient
,
client
);
}
else
{
ec
=
nvkm_enum_find
(
gf100_fifo_fault_gpcclient
,
client
);
snprintf
(
gpcid
,
sizeof
(
gpcid
),
"%d"
,
gpc
);
}
}
if
(
!
ec
)
nvkm_error
(
subdev
,
snprintf
(
ecunk
,
sizeof
(
ecunk
),
"UNK%02x"
,
client
);
"%s fault at %010llx engine %02x [%s] client %02x [%s%s] "
"reason %02x [%s] on channel %d [%010llx %s]
\n
"
,
nv_error
(
fifo
,
"%s fault at 0x%010llx [%s] from %s/%s%s%s%s on "
write
?
"write"
:
"read"
,
(
u64
)
vahi
<<
32
|
valo
,
"channel 0x%010llx [%s]
\n
"
,
write
?
"write"
:
"read"
,
unit
,
eu
?
eu
->
name
:
""
,
client
,
gpcid
,
ec
?
ec
->
name
:
""
,
(
u64
)
vahi
<<
32
|
valo
,
er
?
er
->
name
:
erunk
,
reason
,
er
?
er
->
name
:
""
,
-
1
,
(
u64
)
inst
<<
12
,
eu
?
eu
->
name
:
euunk
,
hub
?
""
:
"GPC"
,
gpcid
,
hub
?
""
:
"/"
,
nvkm_client_name
(
engctx
));
ec
?
ec
->
name
:
ecunk
,
(
u64
)
inst
<<
12
,
nvkm_client_name
(
engctx
));
object
=
engctx
;
object
=
engctx
;
while
(
object
)
{
while
(
object
)
{
...
@@ -692,14 +684,16 @@ gf100_fifo_pbdma_intr[] = {
...
@@ -692,14 +684,16 @@ gf100_fifo_pbdma_intr[] = {
static
void
static
void
gf100_fifo_intr_pbdma
(
struct
gf100_fifo
*
fifo
,
int
unit
)
gf100_fifo_intr_pbdma
(
struct
gf100_fifo
*
fifo
,
int
unit
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
stat
=
nvkm_rd32
(
device
,
0x040108
+
(
unit
*
0x2000
));
u32
stat
=
nvkm_rd32
(
device
,
0x040108
+
(
unit
*
0x2000
));
u32
addr
=
nvkm_rd32
(
device
,
0x0400c0
+
(
unit
*
0x2000
));
u32
addr
=
nvkm_rd32
(
device
,
0x0400c0
+
(
unit
*
0x2000
));
u32
data
=
nvkm_rd32
(
device
,
0x0400c4
+
(
unit
*
0x2000
));
u32
data
=
nvkm_rd32
(
device
,
0x0400c4
+
(
unit
*
0x2000
));
u32
chid
=
nvkm_rd32
(
device
,
0x040120
+
(
unit
*
0x2000
))
&
0x7f
;
u32
chid
=
nvkm_rd32
(
device
,
0x040120
+
(
unit
*
0x2000
))
&
0x7f
;
u32
subc
=
(
addr
&
0x00070000
)
>>
16
;
u32
subc
=
(
addr
&
0x00070000
)
>>
16
;
u32
mthd
=
(
addr
&
0x00003ffc
);
u32
mthd
=
(
addr
&
0x00003ffc
);
u32
show
=
stat
;
u32
show
=
stat
;
char
msg
[
128
];
if
(
stat
&
0x00800000
)
{
if
(
stat
&
0x00800000
)
{
if
(
!
gf100_fifo_swmthd
(
fifo
,
chid
,
mthd
,
data
))
if
(
!
gf100_fifo_swmthd
(
fifo
,
chid
,
mthd
,
data
))
...
@@ -707,14 +701,12 @@ gf100_fifo_intr_pbdma(struct gf100_fifo *fifo, int unit)
...
@@ -707,14 +701,12 @@ gf100_fifo_intr_pbdma(struct gf100_fifo *fifo, int unit)
}
}
if
(
show
)
{
if
(
show
)
{
nv_error
(
fifo
,
"PBDMA%d:"
,
unit
);
nvkm_snprintbf
(
msg
,
sizeof
(
msg
),
gf100_fifo_pbdma_intr
,
show
);
nvkm_bitfield_print
(
gf100_fifo_pbdma_intr
,
show
);
nvkm_error
(
subdev
,
"PBDMA%d: %08x [%s] ch %d [%s] subc %d "
pr_cont
(
"
\n
"
);
"mthd %04x data %08x
\n
"
,
nv_error
(
fifo
,
unit
,
show
,
msg
,
chid
,
"PBDMA%d: ch %d [%s] subc %d mthd 0x%04x data 0x%08x
\n
"
,
nvkm_client_name_for_fifo_chid
(
&
fifo
->
base
,
chid
),
unit
,
chid
,
subc
,
mthd
,
data
);
nvkm_client_name_for_fifo_chid
(
&
fifo
->
base
,
chid
),
subc
,
mthd
,
data
);
}
}
nvkm_wr32
(
device
,
0x0400c0
+
(
unit
*
0x2000
),
0x80600008
);
nvkm_wr32
(
device
,
0x0400c0
+
(
unit
*
0x2000
),
0x80600008
);
...
@@ -724,7 +716,8 @@ gf100_fifo_intr_pbdma(struct gf100_fifo *fifo, int unit)
...
@@ -724,7 +716,8 @@ gf100_fifo_intr_pbdma(struct gf100_fifo *fifo, int unit)
static
void
static
void
gf100_fifo_intr_runlist
(
struct
gf100_fifo
*
fifo
)
gf100_fifo_intr_runlist
(
struct
gf100_fifo
*
fifo
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
intr
=
nvkm_rd32
(
device
,
0x002a00
);
u32
intr
=
nvkm_rd32
(
device
,
0x002a00
);
if
(
intr
&
0x10000000
)
{
if
(
intr
&
0x10000000
)
{
...
@@ -734,7 +727,7 @@ gf100_fifo_intr_runlist(struct gf100_fifo *fifo)
...
@@ -734,7 +727,7 @@ gf100_fifo_intr_runlist(struct gf100_fifo *fifo)
}
}
if
(
intr
)
{
if
(
intr
)
{
nv
_error
(
fifo
,
"RUNLIST 0x
%08x
\n
"
,
intr
);
nv
km_error
(
subdev
,
"RUNLIST
%08x
\n
"
,
intr
);
nvkm_wr32
(
device
,
0x002a00
,
intr
);
nvkm_wr32
(
device
,
0x002a00
,
intr
);
}
}
}
}
...
@@ -742,7 +735,8 @@ gf100_fifo_intr_runlist(struct gf100_fifo *fifo)
...
@@ -742,7 +735,8 @@ gf100_fifo_intr_runlist(struct gf100_fifo *fifo)
static
void
static
void
gf100_fifo_intr_engine_unit
(
struct
gf100_fifo
*
fifo
,
int
engn
)
gf100_fifo_intr_engine_unit
(
struct
gf100_fifo
*
fifo
,
int
engn
)
{
{
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
intr
=
nvkm_rd32
(
device
,
0x0025a8
+
(
engn
*
0x04
));
u32
intr
=
nvkm_rd32
(
device
,
0x0025a8
+
(
engn
*
0x04
));
u32
inte
=
nvkm_rd32
(
device
,
0x002628
);
u32
inte
=
nvkm_rd32
(
device
,
0x002628
);
u32
unkn
;
u32
unkn
;
...
@@ -756,7 +750,8 @@ gf100_fifo_intr_engine_unit(struct gf100_fifo *fifo, int engn)
...
@@ -756,7 +750,8 @@ gf100_fifo_intr_engine_unit(struct gf100_fifo *fifo, int engn)
ints
&=
~
1
;
ints
&=
~
1
;
}
}
if
(
ints
)
{
if
(
ints
)
{
nv_error
(
fifo
,
"ENGINE %d %d %01x"
,
engn
,
unkn
,
ints
);
nvkm_error
(
subdev
,
"ENGINE %d %d %01x"
,
engn
,
unkn
,
ints
);
nvkm_mask
(
device
,
0x002628
,
ints
,
0
);
nvkm_mask
(
device
,
0x002628
,
ints
,
0
);
}
}
}
}
...
@@ -784,7 +779,7 @@ gf100_fifo_intr(struct nvkm_subdev *subdev)
...
@@ -784,7 +779,7 @@ gf100_fifo_intr(struct nvkm_subdev *subdev)
if
(
stat
&
0x00000001
)
{
if
(
stat
&
0x00000001
)
{
u32
intr
=
nvkm_rd32
(
device
,
0x00252c
);
u32
intr
=
nvkm_rd32
(
device
,
0x00252c
);
nv
_warn
(
fifo
,
"INTR 0x00000001: 0x
%08x
\n
"
,
intr
);
nv
km_warn
(
subdev
,
"INTR 00000001:
%08x
\n
"
,
intr
);
nvkm_wr32
(
device
,
0x002100
,
0x00000001
);
nvkm_wr32
(
device
,
0x002100
,
0x00000001
);
stat
&=
~
0x00000001
;
stat
&=
~
0x00000001
;
}
}
...
@@ -797,14 +792,14 @@ gf100_fifo_intr(struct nvkm_subdev *subdev)
...
@@ -797,14 +792,14 @@ gf100_fifo_intr(struct nvkm_subdev *subdev)
if
(
stat
&
0x00010000
)
{
if
(
stat
&
0x00010000
)
{
u32
intr
=
nvkm_rd32
(
device
,
0x00256c
);
u32
intr
=
nvkm_rd32
(
device
,
0x00256c
);
nv
_warn
(
fifo
,
"INTR 0x00010000: 0x
%08x
\n
"
,
intr
);
nv
km_warn
(
subdev
,
"INTR 00010000:
%08x
\n
"
,
intr
);
nvkm_wr32
(
device
,
0x002100
,
0x00010000
);
nvkm_wr32
(
device
,
0x002100
,
0x00010000
);
stat
&=
~
0x00010000
;
stat
&=
~
0x00010000
;
}
}
if
(
stat
&
0x01000000
)
{
if
(
stat
&
0x01000000
)
{
u32
intr
=
nvkm_rd32
(
device
,
0x00258c
);
u32
intr
=
nvkm_rd32
(
device
,
0x00258c
);
nv
_warn
(
fifo
,
"INTR 0x01000000: 0x
%08x
\n
"
,
intr
);
nv
km_warn
(
subdev
,
"INTR 01000000:
%08x
\n
"
,
intr
);
nvkm_wr32
(
device
,
0x002100
,
0x01000000
);
nvkm_wr32
(
device
,
0x002100
,
0x01000000
);
stat
&=
~
0x01000000
;
stat
&=
~
0x01000000
;
}
}
...
@@ -842,7 +837,7 @@ gf100_fifo_intr(struct nvkm_subdev *subdev)
...
@@ -842,7 +837,7 @@ gf100_fifo_intr(struct nvkm_subdev *subdev)
}
}
if
(
stat
)
{
if
(
stat
)
{
nv
_error
(
fifo
,
"INTR 0x
%08x
\n
"
,
stat
);
nv
km_error
(
subdev
,
"INTR
%08x
\n
"
,
stat
);
nvkm_mask
(
device
,
0x002140
,
stat
,
0x00000000
);
nvkm_mask
(
device
,
0x002140
,
stat
,
0x00000000
);
nvkm_wr32
(
device
,
0x002100
,
stat
);
nvkm_wr32
(
device
,
0x002100
,
stat
);
}
}
...
@@ -936,7 +931,8 @@ static int
...
@@ -936,7 +931,8 @@ static int
gf100_fifo_init
(
struct
nvkm_object
*
object
)
gf100_fifo_init
(
struct
nvkm_object
*
object
)
{
{
struct
gf100_fifo
*
fifo
=
(
void
*
)
object
;
struct
gf100_fifo
*
fifo
=
(
void
*
)
object
;
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
int
ret
,
i
;
int
ret
,
i
;
ret
=
nvkm_fifo_init
(
&
fifo
->
base
);
ret
=
nvkm_fifo_init
(
&
fifo
->
base
);
...
@@ -947,7 +943,7 @@ gf100_fifo_init(struct nvkm_object *object)
...
@@ -947,7 +943,7 @@ gf100_fifo_init(struct nvkm_object *object)
nvkm_wr32
(
device
,
0x002204
,
0xffffffff
);
nvkm_wr32
(
device
,
0x002204
,
0xffffffff
);
fifo
->
spoon_nr
=
hweight32
(
nvkm_rd32
(
device
,
0x002204
));
fifo
->
spoon_nr
=
hweight32
(
nvkm_rd32
(
device
,
0x002204
));
nv
_debug
(
fifo
,
"%d PBDMA unit(s)
\n
"
,
fifo
->
spoon_nr
);
nv
km_debug
(
subdev
,
"%d PBDMA unit(s)
\n
"
,
fifo
->
spoon_nr
);
/* assign engines to PBDMAs */
/* assign engines to PBDMAs */
if
(
fifo
->
spoon_nr
>=
3
)
{
if
(
fifo
->
spoon_nr
>=
3
)
{
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c
View file @
e5c5e4f5
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c
View file @
e5c5e4f5
...
@@ -412,9 +412,10 @@ nv04_fifo_swmthd(struct nv04_fifo *fifo, u32 chid, u32 addr, u32 data)
...
@@ -412,9 +412,10 @@ nv04_fifo_swmthd(struct nv04_fifo *fifo, u32 chid, u32 addr, u32 data)
}
}
static
void
static
void
nv04_fifo_cache_error
(
struct
nvkm_device
*
device
,
nv04_fifo_cache_error
(
struct
nv04_fifo
*
fifo
,
u32
chid
,
u32
get
)
struct
nv04_fifo
*
fifo
,
u32
chid
,
u32
get
)
{
{
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
mthd
,
data
;
u32
mthd
,
data
;
int
ptr
;
int
ptr
;
...
@@ -436,10 +437,10 @@ nv04_fifo_cache_error(struct nvkm_device *device,
...
@@ -436,10 +437,10 @@ nv04_fifo_cache_error(struct nvkm_device *device,
if
(
!
nv04_fifo_swmthd
(
fifo
,
chid
,
mthd
,
data
))
{
if
(
!
nv04_fifo_swmthd
(
fifo
,
chid
,
mthd
,
data
))
{
const
char
*
client_name
=
const
char
*
client_name
=
nvkm_client_name_for_fifo_chid
(
&
fifo
->
base
,
chid
);
nvkm_client_name_for_fifo_chid
(
&
fifo
->
base
,
chid
);
nv
_error
(
fifo
,
nv
km_error
(
subdev
,
"CACHE_ERROR - "
"CACHE_ERROR - ch %d [%s] subc %d mthd 0x%04x data 0x
%08x
\n
"
,
"ch %d [%s] subc %d mthd %04x data
%08x
\n
"
,
chid
,
client_name
,
(
mthd
>>
13
)
&
7
,
mthd
&
0x1ffc
,
chid
,
client_name
,
(
mthd
>>
13
)
&
7
,
mthd
&
0x1ffc
,
data
);
data
);
}
}
nvkm_wr32
(
device
,
NV04_PFIFO_CACHE1_DMA_PUSH
,
0
);
nvkm_wr32
(
device
,
NV04_PFIFO_CACHE1_DMA_PUSH
,
0
);
...
@@ -458,14 +459,15 @@ nv04_fifo_cache_error(struct nvkm_device *device,
...
@@ -458,14 +459,15 @@ nv04_fifo_cache_error(struct nvkm_device *device,
}
}
static
void
static
void
nv04_fifo_dma_pusher
(
struct
nvkm_device
*
device
,
nv04_fifo_dma_pusher
(
struct
nv04_fifo
*
fifo
,
u32
chid
)
struct
nv04_fifo
*
fifo
,
u32
chid
)
{
{
const
char
*
client_name
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
u32
dma_get
=
nvkm_rd32
(
device
,
0x003244
);
u32
dma_get
=
nvkm_rd32
(
device
,
0x003244
);
u32
dma_put
=
nvkm_rd32
(
device
,
0x003240
);
u32
dma_put
=
nvkm_rd32
(
device
,
0x003240
);
u32
push
=
nvkm_rd32
(
device
,
0x003220
);
u32
push
=
nvkm_rd32
(
device
,
0x003220
);
u32
state
=
nvkm_rd32
(
device
,
0x003228
);
u32
state
=
nvkm_rd32
(
device
,
0x003228
);
const
char
*
client_name
;
client_name
=
nvkm_client_name_for_fifo_chid
(
&
fifo
->
base
,
chid
);
client_name
=
nvkm_client_name_for_fifo_chid
(
&
fifo
->
base
,
chid
);
...
@@ -475,10 +477,12 @@ nv04_fifo_dma_pusher(struct nvkm_device *device,
...
@@ -475,10 +477,12 @@ nv04_fifo_dma_pusher(struct nvkm_device *device,
u32
ib_get
=
nvkm_rd32
(
device
,
0x003334
);
u32
ib_get
=
nvkm_rd32
(
device
,
0x003334
);
u32
ib_put
=
nvkm_rd32
(
device
,
0x003330
);
u32
ib_put
=
nvkm_rd32
(
device
,
0x003330
);
nv_error
(
fifo
,
nvkm_error
(
subdev
,
"DMA_PUSHER - "
"DMA_PUSHER - ch %d [%s] get 0x%02x%08x put 0x%02x%08x ib_get 0x%08x ib_put 0x%08x state 0x%08x (err: %s) push 0x%08x
\n
"
,
"ch %d [%s] get %02x%08x put %02x%08x ib_get %08x "
chid
,
client_name
,
ho_get
,
dma_get
,
ho_put
,
dma_put
,
"ib_put %08x state %08x (err: %s) push %08x
\n
"
,
ib_get
,
ib_put
,
state
,
nv_dma_state_err
(
state
),
push
);
chid
,
client_name
,
ho_get
,
dma_get
,
ho_put
,
dma_put
,
ib_get
,
ib_put
,
state
,
nv_dma_state_err
(
state
),
push
);
/* METHOD_COUNT, in DMA_STATE on earlier chipsets */
/* METHOD_COUNT, in DMA_STATE on earlier chipsets */
nvkm_wr32
(
device
,
0x003364
,
0x00000000
);
nvkm_wr32
(
device
,
0x003364
,
0x00000000
);
...
@@ -489,10 +493,10 @@ nv04_fifo_dma_pusher(struct nvkm_device *device,
...
@@ -489,10 +493,10 @@ nv04_fifo_dma_pusher(struct nvkm_device *device,
if
(
ib_get
!=
ib_put
)
if
(
ib_get
!=
ib_put
)
nvkm_wr32
(
device
,
0x003334
,
ib_put
);
nvkm_wr32
(
device
,
0x003334
,
ib_put
);
}
else
{
}
else
{
nv
_error
(
fifo
,
nv
km_error
(
subdev
,
"DMA_PUSHER - ch %d [%s] get %08x put %08x "
"DMA_PUSHER - ch %d [%s] get 0x%08x put 0x%08x state 0x%08x (err: %s) push 0x
%08x
\n
"
,
"state %08x (err: %s) push
%08x
\n
"
,
chid
,
client_name
,
dma_get
,
dma_put
,
state
,
chid
,
client_name
,
dma_get
,
dma_put
,
state
,
nv_dma_state_err
(
state
),
push
);
nv_dma_state_err
(
state
),
push
);
if
(
dma_get
!=
dma_put
)
if
(
dma_get
!=
dma_put
)
nvkm_wr32
(
device
,
0x003244
,
dma_put
);
nvkm_wr32
(
device
,
0x003244
,
dma_put
);
...
@@ -506,7 +510,7 @@ nv04_fifo_dma_pusher(struct nvkm_device *device,
...
@@ -506,7 +510,7 @@ nv04_fifo_dma_pusher(struct nvkm_device *device,
void
void
nv04_fifo_intr
(
struct
nvkm_subdev
*
subdev
)
nv04_fifo_intr
(
struct
nvkm_subdev
*
subdev
)
{
{
struct
nvkm_device
*
device
=
nv_device
(
subdev
)
;
struct
nvkm_device
*
device
=
subdev
->
device
;
struct
nv04_fifo
*
fifo
=
(
void
*
)
subdev
;
struct
nv04_fifo
*
fifo
=
(
void
*
)
subdev
;
u32
mask
=
nvkm_rd32
(
device
,
NV03_PFIFO_INTR_EN_0
);
u32
mask
=
nvkm_rd32
(
device
,
NV03_PFIFO_INTR_EN_0
);
u32
stat
=
nvkm_rd32
(
device
,
NV03_PFIFO_INTR_0
)
&
mask
;
u32
stat
=
nvkm_rd32
(
device
,
NV03_PFIFO_INTR_0
)
&
mask
;
...
@@ -519,12 +523,12 @@ nv04_fifo_intr(struct nvkm_subdev *subdev)
...
@@ -519,12 +523,12 @@ nv04_fifo_intr(struct nvkm_subdev *subdev)
get
=
nvkm_rd32
(
device
,
NV03_PFIFO_CACHE1_GET
);
get
=
nvkm_rd32
(
device
,
NV03_PFIFO_CACHE1_GET
);
if
(
stat
&
NV_PFIFO_INTR_CACHE_ERROR
)
{
if
(
stat
&
NV_PFIFO_INTR_CACHE_ERROR
)
{
nv04_fifo_cache_error
(
device
,
fifo
,
chid
,
get
);
nv04_fifo_cache_error
(
fifo
,
chid
,
get
);
stat
&=
~
NV_PFIFO_INTR_CACHE_ERROR
;
stat
&=
~
NV_PFIFO_INTR_CACHE_ERROR
;
}
}
if
(
stat
&
NV_PFIFO_INTR_DMA_PUSHER
)
{
if
(
stat
&
NV_PFIFO_INTR_DMA_PUSHER
)
{
nv04_fifo_dma_pusher
(
device
,
fifo
,
chid
);
nv04_fifo_dma_pusher
(
fifo
,
chid
);
stat
&=
~
NV_PFIFO_INTR_DMA_PUSHER
;
stat
&=
~
NV_PFIFO_INTR_DMA_PUSHER
;
}
}
...
@@ -553,7 +557,7 @@ nv04_fifo_intr(struct nvkm_subdev *subdev)
...
@@ -553,7 +557,7 @@ nv04_fifo_intr(struct nvkm_subdev *subdev)
}
}
if
(
stat
)
{
if
(
stat
)
{
nv
_warn
(
fifo
,
"unknown intr 0x
%08x
\n
"
,
stat
);
nv
km_warn
(
subdev
,
"intr
%08x
\n
"
,
stat
);
nvkm_mask
(
device
,
NV03_PFIFO_INTR_EN_0
,
stat
,
0x00000000
);
nvkm_mask
(
device
,
NV03_PFIFO_INTR_EN_0
,
stat
,
0x00000000
);
nvkm_wr32
(
device
,
NV03_PFIFO_INTR_0
,
stat
);
nvkm_wr32
(
device
,
NV03_PFIFO_INTR_0
,
stat
);
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c
View file @
e5c5e4f5
...
@@ -106,7 +106,8 @@ nv50_fifo_context_detach(struct nvkm_object *parent, bool suspend,
...
@@ -106,7 +106,8 @@ nv50_fifo_context_detach(struct nvkm_object *parent, bool suspend,
struct
nv50_fifo
*
fifo
=
(
void
*
)
parent
->
engine
;
struct
nv50_fifo
*
fifo
=
(
void
*
)
parent
->
engine
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
->
parent
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
->
parent
;
struct
nv50_fifo_chan
*
chan
=
(
void
*
)
parent
;
struct
nv50_fifo_chan
*
chan
=
(
void
*
)
parent
;
struct
nvkm_device
*
device
=
fifo
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_subdev
*
subdev
=
&
fifo
->
base
.
engine
.
subdev
;
struct
nvkm_device
*
device
=
subdev
->
device
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
struct
nvkm_bar
*
bar
=
device
->
bar
;
u32
addr
,
me
;
u32
addr
,
me
;
int
ret
=
0
;
int
ret
=
0
;
...
@@ -139,8 +140,8 @@ nv50_fifo_context_detach(struct nvkm_object *parent, bool suspend,
...
@@ -139,8 +140,8 @@ nv50_fifo_context_detach(struct nvkm_object *parent, bool suspend,
if
(
nvkm_rd32
(
device
,
0x0032fc
)
!=
0xffffffff
)
if
(
nvkm_rd32
(
device
,
0x0032fc
)
!=
0xffffffff
)
break
;
break
;
)
<
0
)
{
)
<
0
)
{
nv
_error
(
fifo
,
"channel %d [%s] unload timeout
\n
"
,
nv
km_error
(
subdev
,
"channel %d [%s] unload timeout
\n
"
,
chan
->
base
.
chid
,
nvkm_client_name
(
chan
));
chan
->
base
.
chid
,
nvkm_client_name
(
chan
));
if
(
suspend
)
if
(
suspend
)
ret
=
-
EBUSY
;
ret
=
-
EBUSY
;
}
}
...
...
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