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
1d2a1e53
Commit
1d2a1e53
authored
Aug 20, 2015
by
Ben Skeggs
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
drm/nouveau/ramht: remove dependence on namedb
Signed-off-by:
Ben Skeggs
<
bskeggs@redhat.com
>
parent
f027f491
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
162 additions
and
82 deletions
+162
-82
drivers/gpu/drm/nouveau/include/nvkm/core/ramht.h
drivers/gpu/drm/nouveau/include/nvkm/core/ramht.h
+18
-10
drivers/gpu/drm/nouveau/nvkm/core/ramht.c
drivers/gpu/drm/nouveau/nvkm/core/ramht.c
+113
-44
drivers/gpu/drm/nouveau/nvkm/engine/disp/gf110.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/gf110.c
+1
-1
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c
+6
-5
drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c
+7
-5
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c
+2
-2
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c
+1
-1
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c
+2
-2
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c
+8
-6
drivers/gpu/drm/nouveau/nvkm/subdev/instmem/nv04.c
drivers/gpu/drm/nouveau/nvkm/subdev/instmem/nv04.c
+2
-3
drivers/gpu/drm/nouveau/nvkm/subdev/instmem/nv40.c
drivers/gpu/drm/nouveau/nvkm/subdev/instmem/nv40.c
+2
-3
No files found.
drivers/gpu/drm/nouveau/include/nvkm/core/ramht.h
View file @
1d2a1e53
...
@@ -2,19 +2,27 @@
...
@@ -2,19 +2,27 @@
#define __NVKM_RAMHT_H__
#define __NVKM_RAMHT_H__
#include <core/gpuobj.h>
#include <core/gpuobj.h>
struct
nvkm_ramht_data
{
struct
nvkm_gpuobj
*
inst
;
int
chid
;
u32
handle
;
};
struct
nvkm_ramht
{
struct
nvkm_ramht
{
struct
nvkm_gpuobj
gpuobj
;
struct
nvkm_device
*
device
;
struct
nvkm_gpuobj
*
parent
;
struct
nvkm_gpuobj
*
gpuobj
;
int
size
;
int
bits
;
int
bits
;
struct
nvkm_ramht_data
data
[];
};
};
int
nvkm_ramht_insert
(
struct
nvkm_ramht
*
,
int
chid
,
u32
handle
,
u32
context
);
int
nvkm_ramht_new
(
struct
nvkm_device
*
,
u32
size
,
u32
align
,
struct
nvkm_gpuobj
*
,
struct
nvkm_ramht
**
);
void
nvkm_ramht_del
(
struct
nvkm_ramht
**
);
int
nvkm_ramht_insert
(
struct
nvkm_ramht
*
,
struct
nvkm_object
*
,
int
chid
,
int
addr
,
u32
handle
,
u32
context
);
void
nvkm_ramht_remove
(
struct
nvkm_ramht
*
,
int
cookie
);
void
nvkm_ramht_remove
(
struct
nvkm_ramht
*
,
int
cookie
);
int
nvkm_ramht_new
(
struct
nvkm_object
*
,
struct
nvkm_object
*
,
u32
size
,
struct
nvkm_gpuobj
*
u32
align
,
struct
nvkm_ramht
**
);
nvkm_ramht_search
(
struct
nvkm_ramht
*
,
int
chid
,
u32
handle
);
static
inline
void
nvkm_ramht_ref
(
struct
nvkm_ramht
*
obj
,
struct
nvkm_ramht
**
ref
)
{
nvkm_gpuobj_ref
(
&
obj
->
gpuobj
,
(
struct
nvkm_gpuobj
**
)
ref
);
}
#endif
#endif
drivers/gpu/drm/nouveau/nvkm/core/ramht.c
View file @
1d2a1e53
...
@@ -33,74 +33,143 @@ nvkm_ramht_hash(struct nvkm_ramht *ramht, int chid, u32 handle)
...
@@ -33,74 +33,143 @@ nvkm_ramht_hash(struct nvkm_ramht *ramht, int chid, u32 handle)
}
}
hash
^=
chid
<<
(
ramht
->
bits
-
4
);
hash
^=
chid
<<
(
ramht
->
bits
-
4
);
hash
=
hash
<<
3
;
return
hash
;
return
hash
;
}
}
int
struct
nvkm_gpuobj
*
nvkm_ramht_
insert
(
struct
nvkm_ramht
*
ramht
,
int
chid
,
u32
handle
,
u32
context
)
nvkm_ramht_
search
(
struct
nvkm_ramht
*
ramht
,
int
chid
,
u32
handle
)
{
{
struct
nvkm_gpuobj
*
gpuobj
=
&
ramht
->
gpuobj
;
int
ret
=
-
ENOSPC
;
u32
co
,
ho
;
u32
co
,
ho
;
co
=
ho
=
nvkm_ramht_hash
(
ramht
,
chid
,
handle
);
co
=
ho
=
nvkm_ramht_hash
(
ramht
,
chid
,
handle
);
nvkm_kmap
(
gpuobj
);
do
{
do
{
if
(
!
nvkm_ro32
(
gpuobj
,
co
+
4
))
{
if
(
ramht
->
data
[
co
].
chid
==
chid
)
{
nvkm_wo32
(
gpuobj
,
co
+
0
,
handle
);
if
(
ramht
->
data
[
co
].
handle
==
handle
)
nvkm_wo32
(
gpuobj
,
co
+
4
,
context
);
return
ramht
->
data
[
co
].
inst
;
ret
=
co
;
break
;
}
}
co
+=
8
;
if
(
++
co
>=
ramht
->
size
)
if
(
co
>=
nv_gpuobj
(
ramht
)
->
size
)
co
=
0
;
co
=
0
;
}
while
(
co
!=
ho
);
}
while
(
co
!=
ho
);
nvkm_done
(
gpuobj
);
return
ret
;
return
NULL
;
}
static
int
nvkm_ramht_update
(
struct
nvkm_ramht
*
ramht
,
int
co
,
struct
nvkm_object
*
object
,
int
chid
,
int
addr
,
u32
handle
,
u32
context
)
{
struct
nvkm_ramht_data
*
data
=
&
ramht
->
data
[
co
];
u64
inst
=
0x00000040
;
/* just non-zero for <=g8x fifo ramht */
int
ret
;
nvkm_gpuobj_del
(
&
data
->
inst
);
data
->
chid
=
chid
;
data
->
handle
=
handle
;
if
(
!
object
)
{
inst
=
0
;
goto
done
;
}
if
(
nv_iclass
(
object
,
NV_GPUOBJ_CLASS
))
{
struct
nvkm_gpuobj
*
gpuobj
=
nv_gpuobj
(
object
);
if
(
ramht
->
device
->
card_type
>=
NV_50
)
inst
=
gpuobj
->
node
->
offset
;
else
inst
=
gpuobj
->
addr
;
goto
done
;
}
ret
=
nvkm_object_bind
(
object
,
ramht
->
parent
,
16
,
&
data
->
inst
);
if
(
ret
)
{
if
(
ret
!=
-
ENODEV
)
{
data
->
chid
=
-
1
;
return
ret
;
}
data
->
inst
=
NULL
;
}
if
(
data
->
inst
)
{
if
(
ramht
->
device
->
card_type
>=
NV_50
)
inst
=
data
->
inst
->
node
->
offset
;
else
inst
=
data
->
inst
->
addr
;
}
done:
if
(
addr
<
0
)
context
|=
inst
<<
-
addr
;
else
context
|=
inst
>>
addr
;
nvkm_kmap
(
ramht
->
gpuobj
);
nvkm_wo32
(
ramht
->
gpuobj
,
(
co
<<
3
)
+
0
,
handle
);
nvkm_wo32
(
ramht
->
gpuobj
,
(
co
<<
3
)
+
4
,
context
);
nvkm_done
(
ramht
->
gpuobj
);
return
co
+
1
;
}
}
void
void
nvkm_ramht_remove
(
struct
nvkm_ramht
*
ramht
,
int
cookie
)
nvkm_ramht_remove
(
struct
nvkm_ramht
*
ramht
,
int
cookie
)
{
{
struct
nvkm_gpuobj
*
gpuobj
=
&
ramht
->
gpuobj
;
if
(
--
cookie
>=
0
)
nvkm_kmap
(
gpuobj
);
nvkm_ramht_update
(
ramht
,
cookie
,
NULL
,
-
1
,
0
,
0
,
0
);
nvkm_wo32
(
gpuobj
,
cookie
+
0
,
0x00000000
);
nvkm_wo32
(
gpuobj
,
cookie
+
4
,
0x00000000
);
nvkm_done
(
gpuobj
);
}
}
static
struct
nvkm_oclass
int
nvkm_ramht_oclass
=
{
nvkm_ramht_insert
(
struct
nvkm_ramht
*
ramht
,
struct
nvkm_object
*
object
,
.
handle
=
0x0000abcd
,
int
chid
,
int
addr
,
u32
handle
,
u32
context
)
.
ofuncs
=
&
(
struct
nvkm_ofuncs
)
{
{
.
ctor
=
NULL
,
u32
co
,
ho
;
.
dtor
=
_nvkm_gpuobj_dtor
,
.
init
=
_nvkm_gpuobj_init
,
if
(
nvkm_ramht_search
(
ramht
,
chid
,
handle
))
.
fini
=
_nvkm_gpuobj_fini
,
return
-
EEXIST
;
.
rd32
=
_nvkm_gpuobj_rd32
,
.
wr32
=
_nvkm_gpuobj_wr32
,
co
=
ho
=
nvkm_ramht_hash
(
ramht
,
chid
,
handle
);
},
do
{
};
if
(
ramht
->
data
[
co
].
chid
<
0
)
{
return
nvkm_ramht_update
(
ramht
,
co
,
object
,
chid
,
addr
,
handle
,
context
);
}
if
(
++
co
>=
ramht
->
size
)
co
=
0
;
}
while
(
co
!=
ho
);
return
-
ENOSPC
;
}
void
nvkm_ramht_del
(
struct
nvkm_ramht
**
pramht
)
{
struct
nvkm_ramht
*
ramht
=
*
pramht
;
if
(
ramht
)
{
nvkm_gpuobj_del
(
&
ramht
->
gpuobj
);
kfree
(
*
pramht
);
*
pramht
=
NULL
;
}
}
int
int
nvkm_ramht_new
(
struct
nvkm_
object
*
parent
,
struct
nvkm_object
*
pargpu
,
nvkm_ramht_new
(
struct
nvkm_
device
*
device
,
u32
size
,
u32
align
,
u32
size
,
u32
align
,
struct
nvkm_ramht
**
pramht
)
struct
nvkm_gpuobj
*
parent
,
struct
nvkm_ramht
**
pramht
)
{
{
struct
nvkm_ramht
*
ramht
;
struct
nvkm_ramht
*
ramht
;
int
ret
;
int
ret
,
i
;
ret
=
nvkm_gpuobj_create
(
parent
,
parent
->
engine
?
if
(
!
(
ramht
=
*
pramht
=
kzalloc
(
sizeof
(
*
ramht
)
+
(
size
>>
3
)
*
&
parent
->
engine
->
subdev
.
object
:
NULL
,
/* <nv50 ramht */
sizeof
(
*
ramht
->
data
),
GFP_KERNEL
)))
&
nvkm_ramht_oclass
,
0
,
pargpu
,
size
,
return
-
ENOMEM
;
align
,
NVOBJ_FLAG_ZERO_ALLOC
,
&
ramht
);
*
pramht
=
ramht
;
ramht
->
device
=
device
;
if
(
ret
)
ramht
->
parent
=
parent
;
return
ret
;
ramht
->
size
=
size
>>
3
;
ramht
->
bits
=
order_base_2
(
ramht
->
size
);
for
(
i
=
0
;
i
<
ramht
->
size
;
i
++
)
ramht
->
data
[
i
].
chid
=
-
1
;
ramht
->
bits
=
order_base_2
(
nv_gpuobj
(
ramht
)
->
size
>>
3
);
ret
=
nvkm_gpuobj_new
(
ramht
->
device
,
size
,
align
,
true
,
return
0
;
ramht
->
parent
,
&
ramht
->
gpuobj
);
if
(
ret
)
nvkm_ramht_del
(
pramht
);
return
ret
;
}
}
drivers/gpu/drm/nouveau/nvkm/engine/disp/gf110.c
View file @
1d2a1e53
...
@@ -80,7 +80,7 @@ gf110_disp_dmac_object_attach(struct nvkm_object *parent,
...
@@ -80,7 +80,7 @@ gf110_disp_dmac_object_attach(struct nvkm_object *parent,
struct
nv50_disp_chan
*
chan
=
(
void
*
)
parent
;
struct
nv50_disp_chan
*
chan
=
(
void
*
)
parent
;
u32
addr
=
nv_gpuobj
(
object
)
->
node
->
offset
;
u32
addr
=
nv_gpuobj
(
object
)
->
node
->
offset
;
u32
data
=
(
chan
->
chid
<<
27
)
|
(
addr
<<
9
)
|
0x00000001
;
u32
data
=
(
chan
->
chid
<<
27
)
|
(
addr
<<
9
)
|
0x00000001
;
return
nvkm_ramht_insert
(
base
->
ramht
,
chan
->
chid
,
name
,
data
);
return
nvkm_ramht_insert
(
base
->
ramht
,
NULL
,
chan
->
chid
,
0
,
name
,
data
);
}
}
static
void
static
void
...
...
drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c
View file @
1d2a1e53
...
@@ -193,7 +193,7 @@ nv50_disp_dmac_object_attach(struct nvkm_object *parent,
...
@@ -193,7 +193,7 @@ nv50_disp_dmac_object_attach(struct nvkm_object *parent,
u32
addr
=
nv_gpuobj
(
object
)
->
node
->
offset
;
u32
addr
=
nv_gpuobj
(
object
)
->
node
->
offset
;
u32
chid
=
chan
->
chid
;
u32
chid
=
chan
->
chid
;
u32
data
=
(
chid
<<
28
)
|
(
addr
<<
10
)
|
chid
;
u32
data
=
(
chid
<<
28
)
|
(
addr
<<
10
)
|
chid
;
return
nvkm_ramht_insert
(
base
->
ramht
,
chid
,
name
,
data
);
return
nvkm_ramht_insert
(
base
->
ramht
,
NULL
,
chid
,
0
,
name
,
data
);
}
}
static
void
static
void
...
@@ -1153,6 +1153,8 @@ nv50_disp_main_ctor(struct nvkm_object *parent,
...
@@ -1153,6 +1153,8 @@ nv50_disp_main_ctor(struct nvkm_object *parent,
{
{
struct
nv50_disp
*
disp
=
(
void
*
)
engine
;
struct
nv50_disp
*
disp
=
(
void
*
)
engine
;
struct
nv50_disp_base
*
base
;
struct
nv50_disp_base
*
base
;
struct
nvkm_device
*
device
=
disp
->
base
.
engine
.
subdev
.
device
;
struct
nvkm_gpuobj
*
instmem
=
(
void
*
)
parent
;
int
ret
;
int
ret
;
ret
=
nvkm_parent_create
(
parent
,
engine
,
oclass
,
0
,
ret
=
nvkm_parent_create
(
parent
,
engine
,
oclass
,
0
,
...
@@ -1161,15 +1163,14 @@ nv50_disp_main_ctor(struct nvkm_object *parent,
...
@@ -1161,15 +1163,14 @@ nv50_disp_main_ctor(struct nvkm_object *parent,
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
return
nvkm_ramht_new
(
nv_object
(
base
),
nv_object
(
base
),
0x1000
,
0
,
return
nvkm_ramht_new
(
device
,
0x1000
,
0
,
instmem
,
&
base
->
ramht
);
&
base
->
ramht
);
}
}
void
void
nv50_disp_main_dtor
(
struct
nvkm_object
*
object
)
nv50_disp_main_dtor
(
struct
nvkm_object
*
object
)
{
{
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
struct
nv50_disp_base
*
base
=
(
void
*
)
object
;
nvkm_ramht_
ref
(
NULL
,
&
base
->
ramht
);
nvkm_ramht_
del
(
&
base
->
ramht
);
nvkm_parent_destroy
(
&
base
->
base
);
nvkm_parent_destroy
(
&
base
->
base
);
}
}
...
@@ -1235,7 +1236,7 @@ nv50_disp_main_init(struct nvkm_object *object)
...
@@ -1235,7 +1236,7 @@ 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) */
nvkm_wr32
(
device
,
0x610010
,
(
nv_gpuobj
(
base
->
ramht
)
->
addr
>>
8
)
|
9
);
nvkm_wr32
(
device
,
0x610010
,
(
base
->
ramht
->
gpuobj
->
addr
>>
8
)
|
9
);
/* enable supervisor interrupts, disable everything else */
/* enable supervisor interrupts, disable everything else */
nvkm_wr32
(
device
,
0x61002c
,
0x00000370
);
nvkm_wr32
(
device
,
0x61002c
,
0x00000370
);
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c
View file @
1d2a1e53
...
@@ -161,7 +161,7 @@ g84_fifo_object_attach(struct nvkm_object *parent,
...
@@ -161,7 +161,7 @@ g84_fifo_object_attach(struct nvkm_object *parent,
}
}
}
}
return
nvkm_ramht_insert
(
chan
->
ramht
,
0
,
handle
,
context
);
return
nvkm_ramht_insert
(
chan
->
ramht
,
NULL
,
0
,
0
,
handle
,
context
);
}
}
static
int
static
int
...
@@ -172,6 +172,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -172,6 +172,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
union
{
union
{
struct
nv50_channel_dma_v0
v0
;
struct
nv50_channel_dma_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
struct
nvkm_device
*
device
=
parent
->
engine
->
subdev
.
device
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_chan
*
chan
;
struct
nv50_fifo_chan
*
chan
;
int
ret
;
int
ret
;
...
@@ -208,7 +209,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -208,7 +209,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
args
->
v0
.
chid
=
chan
->
base
.
chid
;
args
->
v0
.
chid
=
chan
->
base
.
chid
;
ret
=
nvkm_ramht_new
(
nv_object
(
chan
),
nv_object
(
chan
),
0x8000
,
16
,
ret
=
nvkm_ramht_new
(
device
,
0x8000
,
16
,
&
base
->
base
.
gpuobj
,
&
chan
->
ramht
);
&
chan
->
ramht
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -232,7 +233,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -232,7 +233,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
chan
->
ramht
->
gpuobj
.
node
->
offset
>>
4
));
(
chan
->
ramht
->
gpuobj
->
node
->
offset
>>
4
));
nvkm_wo32
(
base
->
ramfc
,
0x88
,
base
->
cache
->
addr
>>
10
);
nvkm_wo32
(
base
->
ramfc
,
0x88
,
base
->
cache
->
addr
>>
10
);
nvkm_wo32
(
base
->
ramfc
,
0x98
,
nv_gpuobj
(
base
)
->
addr
>>
12
);
nvkm_wo32
(
base
->
ramfc
,
0x98
,
nv_gpuobj
(
base
)
->
addr
>>
12
);
nvkm_done
(
base
->
ramfc
);
nvkm_done
(
base
->
ramfc
);
...
@@ -247,6 +248,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -247,6 +248,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
union
{
union
{
struct
nv50_channel_gpfifo_v0
v0
;
struct
nv50_channel_gpfifo_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
struct
nvkm_device
*
device
=
parent
->
engine
->
subdev
.
device
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_chan
*
chan
;
struct
nv50_fifo_chan
*
chan
;
u64
ioffset
,
ilength
;
u64
ioffset
,
ilength
;
...
@@ -285,7 +287,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -285,7 +287,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
args
->
v0
.
chid
=
chan
->
base
.
chid
;
args
->
v0
.
chid
=
chan
->
base
.
chid
;
ret
=
nvkm_ramht_new
(
nv_object
(
chan
),
nv_object
(
chan
),
0x8000
,
16
,
ret
=
nvkm_ramht_new
(
device
,
0x8000
,
16
,
&
base
->
base
.
gpuobj
,
&
chan
->
ramht
);
&
chan
->
ramht
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -309,7 +311,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -309,7 +311,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
chan
->
ramht
->
gpuobj
.
node
->
offset
>>
4
));
(
chan
->
ramht
->
gpuobj
->
node
->
offset
>>
4
));
nvkm_wo32
(
base
->
ramfc
,
0x88
,
base
->
cache
->
addr
>>
10
);
nvkm_wo32
(
base
->
ramfc
,
0x88
,
base
->
cache
->
addr
>>
10
);
nvkm_wo32
(
base
->
ramfc
,
0x98
,
nv_gpuobj
(
base
)
->
addr
>>
12
);
nvkm_wo32
(
base
->
ramfc
,
0x98
,
nv_gpuobj
(
base
)
->
addr
>>
12
);
nvkm_done
(
base
->
ramfc
);
nvkm_done
(
base
->
ramfc
);
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c
View file @
1d2a1e53
...
@@ -86,7 +86,7 @@ nv04_fifo_object_attach(struct nvkm_object *parent,
...
@@ -86,7 +86,7 @@ nv04_fifo_object_attach(struct nvkm_object *parent,
context
|=
chid
<<
24
;
context
|=
chid
<<
24
;
mutex_lock
(
&
nv_subdev
(
fifo
)
->
mutex
);
mutex_lock
(
&
nv_subdev
(
fifo
)
->
mutex
);
ret
=
nvkm_ramht_insert
(
imem
->
ramht
,
chid
,
handle
,
context
);
ret
=
nvkm_ramht_insert
(
imem
->
ramht
,
NULL
,
chid
,
0
,
handle
,
context
);
mutex_unlock
(
&
nv_subdev
(
fifo
)
->
mutex
);
mutex_unlock
(
&
nv_subdev
(
fifo
)
->
mutex
);
return
ret
;
return
ret
;
}
}
...
@@ -625,7 +625,7 @@ nv04_fifo_init(struct nvkm_object *object)
...
@@ -625,7 +625,7 @@ nv04_fifo_init(struct nvkm_object *object)
nvkm_wr32
(
device
,
NV03_PFIFO_RAMHT
,
(
0x03
<<
24
)
/* search 128 */
|
nvkm_wr32
(
device
,
NV03_PFIFO_RAMHT
,
(
0x03
<<
24
)
/* search 128 */
|
((
ramht
->
bits
-
9
)
<<
16
)
|
((
ramht
->
bits
-
9
)
<<
16
)
|
(
ramht
->
gpuobj
.
addr
>>
8
));
(
ramht
->
gpuobj
->
addr
>>
8
));
nvkm_wr32
(
device
,
NV03_PFIFO_RAMRO
,
nvkm_memory_addr
(
ramro
)
>>
8
);
nvkm_wr32
(
device
,
NV03_PFIFO_RAMRO
,
nvkm_memory_addr
(
ramro
)
>>
8
);
nvkm_wr32
(
device
,
NV03_PFIFO_RAMFC
,
nvkm_memory_addr
(
ramfc
)
>>
8
);
nvkm_wr32
(
device
,
NV03_PFIFO_RAMFC
,
nvkm_memory_addr
(
ramfc
)
>>
8
);
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c
View file @
1d2a1e53
...
@@ -191,7 +191,7 @@ nv17_fifo_init(struct nvkm_object *object)
...
@@ -191,7 +191,7 @@ nv17_fifo_init(struct nvkm_object *object)
nvkm_wr32
(
device
,
NV03_PFIFO_RAMHT
,
(
0x03
<<
24
)
/* search 128 */
|
nvkm_wr32
(
device
,
NV03_PFIFO_RAMHT
,
(
0x03
<<
24
)
/* search 128 */
|
((
ramht
->
bits
-
9
)
<<
16
)
|
((
ramht
->
bits
-
9
)
<<
16
)
|
(
ramht
->
gpuobj
.
addr
>>
8
));
(
ramht
->
gpuobj
->
addr
>>
8
));
nvkm_wr32
(
device
,
NV03_PFIFO_RAMRO
,
nvkm_memory_addr
(
ramro
)
>>
8
);
nvkm_wr32
(
device
,
NV03_PFIFO_RAMRO
,
nvkm_memory_addr
(
ramro
)
>>
8
);
nvkm_wr32
(
device
,
NV03_PFIFO_RAMFC
,
nvkm_memory_addr
(
ramfc
)
>>
8
|
nvkm_wr32
(
device
,
NV03_PFIFO_RAMFC
,
nvkm_memory_addr
(
ramfc
)
>>
8
|
0x00010000
);
0x00010000
);
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c
View file @
1d2a1e53
...
@@ -98,7 +98,7 @@ nv40_fifo_object_attach(struct nvkm_object *parent,
...
@@ -98,7 +98,7 @@ nv40_fifo_object_attach(struct nvkm_object *parent,
context
|=
chid
<<
23
;
context
|=
chid
<<
23
;
mutex_lock
(
&
nv_subdev
(
fifo
)
->
mutex
);
mutex_lock
(
&
nv_subdev
(
fifo
)
->
mutex
);
ret
=
nvkm_ramht_insert
(
imem
->
ramht
,
chid
,
handle
,
context
);
ret
=
nvkm_ramht_insert
(
imem
->
ramht
,
NULL
,
chid
,
0
,
handle
,
context
);
mutex_unlock
(
&
nv_subdev
(
fifo
)
->
mutex
);
mutex_unlock
(
&
nv_subdev
(
fifo
)
->
mutex
);
return
ret
;
return
ret
;
}
}
...
@@ -322,7 +322,7 @@ nv40_fifo_init(struct nvkm_object *object)
...
@@ -322,7 +322,7 @@ nv40_fifo_init(struct nvkm_object *object)
nvkm_wr32
(
device
,
NV03_PFIFO_RAMHT
,
(
0x03
<<
24
)
/* search 128 */
|
nvkm_wr32
(
device
,
NV03_PFIFO_RAMHT
,
(
0x03
<<
24
)
/* search 128 */
|
((
ramht
->
bits
-
9
)
<<
16
)
|
((
ramht
->
bits
-
9
)
<<
16
)
|
(
ramht
->
gpuobj
.
addr
>>
8
));
(
ramht
->
gpuobj
->
addr
>>
8
));
nvkm_wr32
(
device
,
NV03_PFIFO_RAMRO
,
nvkm_memory_addr
(
ramro
)
>>
8
);
nvkm_wr32
(
device
,
NV03_PFIFO_RAMRO
,
nvkm_memory_addr
(
ramro
)
>>
8
);
switch
(
nv_device
(
fifo
)
->
chipset
)
{
switch
(
nv_device
(
fifo
)
->
chipset
)
{
...
...
drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c
View file @
1d2a1e53
...
@@ -182,7 +182,7 @@ nv50_fifo_object_attach(struct nvkm_object *parent,
...
@@ -182,7 +182,7 @@ nv50_fifo_object_attach(struct nvkm_object *parent,
}
}
}
}
return
nvkm_ramht_insert
(
chan
->
ramht
,
0
,
handle
,
context
);
return
nvkm_ramht_insert
(
chan
->
ramht
,
NULL
,
0
,
0
,
handle
,
context
);
}
}
void
void
...
@@ -200,6 +200,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -200,6 +200,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
union
{
union
{
struct
nv50_channel_dma_v0
v0
;
struct
nv50_channel_dma_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
struct
nvkm_device
*
device
=
parent
->
engine
->
subdev
.
device
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_chan
*
chan
;
struct
nv50_fifo_chan
*
chan
;
int
ret
;
int
ret
;
...
@@ -231,7 +232,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -231,7 +232,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
nv_parent
(
chan
)
->
object_attach
=
nv50_fifo_object_attach
;
nv_parent
(
chan
)
->
object_attach
=
nv50_fifo_object_attach
;
nv_parent
(
chan
)
->
object_detach
=
nv50_fifo_object_detach
;
nv_parent
(
chan
)
->
object_detach
=
nv50_fifo_object_detach
;
ret
=
nvkm_ramht_new
(
nv_object
(
chan
),
nv_object
(
chan
),
0x8000
,
16
,
ret
=
nvkm_ramht_new
(
device
,
0x8000
,
16
,
&
base
->
base
.
gpuobj
,
&
chan
->
ramht
);
&
chan
->
ramht
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -250,7 +251,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -250,7 +251,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine,
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
chan
->
ramht
->
gpuobj
.
node
->
offset
>>
4
));
(
chan
->
ramht
->
gpuobj
->
node
->
offset
>>
4
));
nvkm_done
(
base
->
ramfc
);
nvkm_done
(
base
->
ramfc
);
return
0
;
return
0
;
}
}
...
@@ -263,6 +264,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -263,6 +264,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
union
{
union
{
struct
nv50_channel_gpfifo_v0
v0
;
struct
nv50_channel_gpfifo_v0
v0
;
}
*
args
=
data
;
}
*
args
=
data
;
struct
nvkm_device
*
device
=
parent
->
engine
->
subdev
.
device
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_base
*
base
=
(
void
*
)
parent
;
struct
nv50_fifo_chan
*
chan
;
struct
nv50_fifo_chan
*
chan
;
u64
ioffset
,
ilength
;
u64
ioffset
,
ilength
;
...
@@ -296,7 +298,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -296,7 +298,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
nv_parent
(
chan
)
->
object_attach
=
nv50_fifo_object_attach
;
nv_parent
(
chan
)
->
object_attach
=
nv50_fifo_object_attach
;
nv_parent
(
chan
)
->
object_detach
=
nv50_fifo_object_detach
;
nv_parent
(
chan
)
->
object_detach
=
nv50_fifo_object_detach
;
ret
=
nvkm_ramht_new
(
nv_object
(
chan
),
nv_object
(
chan
),
0x8000
,
16
,
ret
=
nvkm_ramht_new
(
device
,
0x8000
,
16
,
&
base
->
base
.
gpuobj
,
&
chan
->
ramht
);
&
chan
->
ramht
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
@@ -315,7 +317,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -315,7 +317,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine,
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x7c
,
0x30000001
);
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
nvkm_wo32
(
base
->
ramfc
,
0x80
,
((
chan
->
ramht
->
bits
-
9
)
<<
27
)
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
4
<<
24
)
/* SEARCH_FULL */
|
(
chan
->
ramht
->
gpuobj
.
node
->
offset
>>
4
));
(
chan
->
ramht
->
gpuobj
->
node
->
offset
>>
4
));
nvkm_done
(
base
->
ramfc
);
nvkm_done
(
base
->
ramfc
);
return
0
;
return
0
;
}
}
...
@@ -324,7 +326,7 @@ void
...
@@ -324,7 +326,7 @@ void
nv50_fifo_chan_dtor
(
struct
nvkm_object
*
object
)
nv50_fifo_chan_dtor
(
struct
nvkm_object
*
object
)
{
{
struct
nv50_fifo_chan
*
chan
=
(
void
*
)
object
;
struct
nv50_fifo_chan
*
chan
=
(
void
*
)
object
;
nvkm_ramht_
ref
(
NULL
,
&
chan
->
ramht
);
nvkm_ramht_
del
(
&
chan
->
ramht
);
nvkm_fifo_channel_destroy
(
&
chan
->
base
);
nvkm_fifo_channel_destroy
(
&
chan
->
base
);
}
}
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/instmem/nv04.c
View file @
1d2a1e53
...
@@ -156,7 +156,7 @@ nv04_instmem_dtor(struct nvkm_object *object)
...
@@ -156,7 +156,7 @@ nv04_instmem_dtor(struct nvkm_object *object)
struct
nv04_instmem
*
imem
=
(
void
*
)
object
;
struct
nv04_instmem
*
imem
=
(
void
*
)
object
;
nvkm_memory_del
(
&
imem
->
base
.
ramfc
);
nvkm_memory_del
(
&
imem
->
base
.
ramfc
);
nvkm_memory_del
(
&
imem
->
base
.
ramro
);
nvkm_memory_del
(
&
imem
->
base
.
ramro
);
nvkm_ramht_
ref
(
NULL
,
&
imem
->
base
.
ramht
);
nvkm_ramht_
del
(
&
imem
->
base
.
ramht
);
nvkm_memory_del
(
&
imem
->
base
.
vbios
);
nvkm_memory_del
(
&
imem
->
base
.
vbios
);
nvkm_mm_fini
(
&
imem
->
heap
);
nvkm_mm_fini
(
&
imem
->
heap
);
nvkm_instmem_destroy
(
&
imem
->
base
);
nvkm_instmem_destroy
(
&
imem
->
base
);
...
@@ -198,8 +198,7 @@ nv04_instmem_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -198,8 +198,7 @@ nv04_instmem_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
return
ret
;
return
ret
;
/* 0x10000-0x18000: reserve for RAMHT */
/* 0x10000-0x18000: reserve for RAMHT */
ret
=
nvkm_ramht_new
(
nv_object
(
imem
),
NULL
,
0x08000
,
0
,
ret
=
nvkm_ramht_new
(
device
,
0x08000
,
0
,
NULL
,
&
imem
->
base
.
ramht
);
&
imem
->
base
.
ramht
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
...
drivers/gpu/drm/nouveau/nvkm/subdev/instmem/nv40.c
View file @
1d2a1e53
...
@@ -157,7 +157,7 @@ nv40_instmem_dtor(struct nvkm_object *object)
...
@@ -157,7 +157,7 @@ nv40_instmem_dtor(struct nvkm_object *object)
struct
nv40_instmem
*
imem
=
(
void
*
)
object
;
struct
nv40_instmem
*
imem
=
(
void
*
)
object
;
nvkm_memory_del
(
&
imem
->
base
.
ramfc
);
nvkm_memory_del
(
&
imem
->
base
.
ramfc
);
nvkm_memory_del
(
&
imem
->
base
.
ramro
);
nvkm_memory_del
(
&
imem
->
base
.
ramro
);
nvkm_ramht_
ref
(
NULL
,
&
imem
->
base
.
ramht
);
nvkm_ramht_
del
(
&
imem
->
base
.
ramht
);
nvkm_memory_del
(
&
imem
->
base
.
vbios
);
nvkm_memory_del
(
&
imem
->
base
.
vbios
);
nvkm_mm_fini
(
&
imem
->
heap
);
nvkm_mm_fini
(
&
imem
->
heap
);
if
(
imem
->
iomem
)
if
(
imem
->
iomem
)
...
@@ -227,8 +227,7 @@ nv40_instmem_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
...
@@ -227,8 +227,7 @@ nv40_instmem_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
return
ret
;
return
ret
;
/* 0x10000-0x18000: reserve for RAMHT */
/* 0x10000-0x18000: reserve for RAMHT */
ret
=
nvkm_ramht_new
(
nv_object
(
imem
),
NULL
,
0x08000
,
0
,
ret
=
nvkm_ramht_new
(
device
,
0x08000
,
0
,
NULL
,
&
imem
->
base
.
ramht
);
&
imem
->
base
.
ramht
);
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
...
...
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