diff options
author | Ben Skeggs <bskeggs@redhat.com> | 2015-08-20 00:54:16 -0400 |
---|---|---|
committer | Ben Skeggs <bskeggs@redhat.com> | 2015-08-27 22:40:32 -0400 |
commit | bf81df9be28657eea4aca8c6ab4ed3e69f8a051c (patch) | |
tree | a4a7e6f3d4e46696584c930bb7d6b4b2fd941337 /drivers/gpu/drm/nouveau/nvkm | |
parent | a01ca78c8f118e5a24f1527ecf078ab56ddd4805 (diff) |
drm/nouveau/nvif: replace path-based object identification
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/nouveau/nvkm')
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/core/client.c | 50 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/core/handle.c | 22 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/core/ioctl.c | 51 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c | 27 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.h | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c | 17 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c | 4 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv10.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c | 4 |
14 files changed, 111 insertions, 77 deletions
diff --git a/drivers/gpu/drm/nouveau/nvkm/core/client.c b/drivers/gpu/drm/nouveau/nvkm/core/client.c index 7615cdd75294..bfe5357d7334 100644 --- a/drivers/gpu/drm/nouveau/nvkm/core/client.c +++ b/drivers/gpu/drm/nouveau/nvkm/core/client.c | |||
@@ -183,6 +183,55 @@ nvkm_client_oclass = { | |||
183 | }, | 183 | }, |
184 | }; | 184 | }; |
185 | 185 | ||
186 | void | ||
187 | nvkm_client_remove(struct nvkm_client *client, struct nvkm_handle *object) | ||
188 | { | ||
189 | if (!RB_EMPTY_NODE(&object->rb)) | ||
190 | rb_erase(&object->rb, &client->objroot); | ||
191 | } | ||
192 | |||
193 | bool | ||
194 | nvkm_client_insert(struct nvkm_client *client, struct nvkm_handle *object) | ||
195 | { | ||
196 | struct rb_node **ptr = &client->objroot.rb_node; | ||
197 | struct rb_node *parent = NULL; | ||
198 | |||
199 | while (*ptr) { | ||
200 | struct nvkm_handle *this = | ||
201 | container_of(*ptr, typeof(*this), rb); | ||
202 | parent = *ptr; | ||
203 | if (object->handle < this->handle) | ||
204 | ptr = &parent->rb_left; | ||
205 | else | ||
206 | if (object->handle > this->handle) | ||
207 | ptr = &parent->rb_right; | ||
208 | else | ||
209 | return false; | ||
210 | } | ||
211 | |||
212 | rb_link_node(&object->rb, parent, ptr); | ||
213 | rb_insert_color(&object->rb, &client->objroot); | ||
214 | return true; | ||
215 | } | ||
216 | |||
217 | struct nvkm_handle * | ||
218 | nvkm_client_search(struct nvkm_client *client, u64 handle) | ||
219 | { | ||
220 | struct rb_node *node = client->objroot.rb_node; | ||
221 | while (node) { | ||
222 | struct nvkm_handle *object = | ||
223 | container_of(node, typeof(*object), rb); | ||
224 | if (handle < object->handle) | ||
225 | node = node->rb_left; | ||
226 | else | ||
227 | if (handle > object->handle) | ||
228 | node = node->rb_right; | ||
229 | else | ||
230 | return object; | ||
231 | } | ||
232 | return NULL; | ||
233 | } | ||
234 | |||
186 | int | 235 | int |
187 | nvkm_client_fini(struct nvkm_client *client, bool suspend) | 236 | nvkm_client_fini(struct nvkm_client *client, bool suspend) |
188 | { | 237 | { |
@@ -256,6 +305,7 @@ nvkm_client_new(const char *name, u64 device, const char *cfg, | |||
256 | client->device = device; | 305 | client->device = device; |
257 | snprintf(client->name, sizeof(client->name), "%s", name); | 306 | snprintf(client->name, sizeof(client->name), "%s", name); |
258 | client->debug = nvkm_dbgopt(dbg, "CLIENT"); | 307 | client->debug = nvkm_dbgopt(dbg, "CLIENT"); |
308 | client->objroot = RB_ROOT; | ||
259 | return 0; | 309 | return 0; |
260 | } | 310 | } |
261 | 311 | ||
diff --git a/drivers/gpu/drm/nouveau/nvkm/core/handle.c b/drivers/gpu/drm/nouveau/nvkm/core/handle.c index 6230eaece64d..a12ab8001701 100644 --- a/drivers/gpu/drm/nouveau/nvkm/core/handle.c +++ b/drivers/gpu/drm/nouveau/nvkm/core/handle.c | |||
@@ -113,6 +113,7 @@ nvkm_handle_create(struct nvkm_object *parent, u32 _parent, u32 _handle, | |||
113 | INIT_LIST_HEAD(&handle->tree); | 113 | INIT_LIST_HEAD(&handle->tree); |
114 | handle->name = _handle; | 114 | handle->name = _handle; |
115 | handle->priv = ~0; | 115 | handle->priv = ~0; |
116 | RB_CLEAR_NODE(&handle->rb); | ||
116 | 117 | ||
117 | ret = nvkm_namedb_insert(nv_namedb(namedb), _handle, object, handle); | 118 | ret = nvkm_namedb_insert(nv_namedb(namedb), _handle, object, handle); |
118 | if (ret) { | 119 | if (ret) { |
@@ -149,12 +150,15 @@ nvkm_handle_create(struct nvkm_object *parent, u32 _parent, u32 _handle, | |||
149 | void | 150 | void |
150 | nvkm_handle_destroy(struct nvkm_handle *handle) | 151 | nvkm_handle_destroy(struct nvkm_handle *handle) |
151 | { | 152 | { |
153 | struct nvkm_client *client = nvkm_client(handle->object); | ||
152 | struct nvkm_handle *item, *temp; | 154 | struct nvkm_handle *item, *temp; |
153 | 155 | ||
154 | hprintk(handle, TRACE, "destroy running\n"); | 156 | hprintk(handle, TRACE, "destroy running\n"); |
155 | list_for_each_entry_safe(item, temp, &handle->tree, head) { | 157 | list_for_each_entry_safe(item, temp, &handle->tree, head) { |
156 | nvkm_handle_destroy(item); | 158 | nvkm_handle_destroy(item); |
157 | } | 159 | } |
160 | |||
161 | nvkm_client_remove(client, handle); | ||
158 | list_del(&handle->head); | 162 | list_del(&handle->head); |
159 | 163 | ||
160 | if (handle->priv != ~0) { | 164 | if (handle->priv != ~0) { |
@@ -167,24 +171,6 @@ nvkm_handle_destroy(struct nvkm_handle *handle) | |||
167 | kfree(handle); | 171 | kfree(handle); |
168 | } | 172 | } |
169 | 173 | ||
170 | struct nvkm_object * | ||
171 | nvkm_handle_ref(struct nvkm_object *parent, u32 name) | ||
172 | { | ||
173 | struct nvkm_object *object = NULL; | ||
174 | struct nvkm_handle *handle; | ||
175 | |||
176 | while (!nv_iclass(parent, NV_NAMEDB_CLASS)) | ||
177 | parent = parent->parent; | ||
178 | |||
179 | handle = nvkm_namedb_get(nv_namedb(parent), name); | ||
180 | if (handle) { | ||
181 | nvkm_object_ref(handle->object, &object); | ||
182 | nvkm_namedb_put(handle); | ||
183 | } | ||
184 | |||
185 | return object; | ||
186 | } | ||
187 | |||
188 | struct nvkm_handle * | 174 | struct nvkm_handle * |
189 | nvkm_handle_get_class(struct nvkm_object *engctx, u16 oclass) | 175 | nvkm_handle_get_class(struct nvkm_object *engctx, u16 oclass) |
190 | { | 176 | { |
diff --git a/drivers/gpu/drm/nouveau/nvkm/core/ioctl.c b/drivers/gpu/drm/nouveau/nvkm/core/ioctl.c index 7434958846f7..7654783e8350 100644 --- a/drivers/gpu/drm/nouveau/nvkm/core/ioctl.c +++ b/drivers/gpu/drm/nouveau/nvkm/core/ioctl.c | |||
@@ -103,9 +103,9 @@ nvkm_ioctl_new(struct nvkm_handle *handle, void *data, u32 size) | |||
103 | return ret; | 103 | return ret; |
104 | 104 | ||
105 | nvif_ioctl(handle->object, "new vers %d handle %08x class %08x " | 105 | nvif_ioctl(handle->object, "new vers %d handle %08x class %08x " |
106 | "route %02x token %llx\n", | 106 | "route %02x token %llx object %016llx\n", |
107 | args->v0.version, _handle, _oclass, | 107 | args->v0.version, _handle, _oclass, |
108 | args->v0.route, args->v0.token); | 108 | args->v0.route, args->v0.token, args->v0.object); |
109 | 109 | ||
110 | if (!nv_iclass(handle->object, NV_PARENT_CLASS)) { | 110 | if (!nv_iclass(handle->object, NV_PARENT_CLASS)) { |
111 | nvif_debug(handle->object, "cannot have children (ctor)\n"); | 111 | nvif_debug(handle->object, "cannot have children (ctor)\n"); |
@@ -166,6 +166,8 @@ nvkm_ioctl_new(struct nvkm_handle *handle, void *data, u32 size) | |||
166 | if (ret) | 166 | if (ret) |
167 | nvkm_handle_destroy(handle); | 167 | nvkm_handle_destroy(handle); |
168 | 168 | ||
169 | handle->handle = args->v0.object; | ||
170 | nvkm_client_insert(client, handle); | ||
169 | fail_handle: | 171 | fail_handle: |
170 | nvkm_object_dec(object, false); | 172 | nvkm_object_dec(object, false); |
171 | fail_init: | 173 | fail_init: |
@@ -438,40 +440,31 @@ nvkm_ioctl_v0[] = { | |||
438 | }; | 440 | }; |
439 | 441 | ||
440 | static int | 442 | static int |
441 | nvkm_ioctl_path(struct nvkm_handle *parent, u32 type, u32 nr, u32 *path, | 443 | nvkm_ioctl_path(struct nvkm_client *client, u64 handle, u32 type, |
442 | void *data, u32 size, u8 owner, u8 *route, u64 *token) | 444 | void *data, u32 size, u8 owner, u8 *route, u64 *token) |
443 | { | 445 | { |
444 | struct nvkm_handle *handle = parent; | 446 | struct nvkm_handle *object; |
445 | struct nvkm_namedb *namedb; | ||
446 | struct nvkm_object *object; | ||
447 | int ret; | 447 | int ret; |
448 | 448 | ||
449 | while ((object = parent->object), nr--) { | 449 | if (handle) |
450 | nvif_ioctl(object, "path 0x%08x\n", path[nr]); | 450 | object = nvkm_client_search(client, handle); |
451 | if (!nv_iclass(object, NV_PARENT_CLASS)) { | 451 | else |
452 | nvif_debug(object, "cannot have children (path)\n"); | 452 | object = client->root; |
453 | return -EINVAL; | 453 | if (unlikely(!object)) { |
454 | } | 454 | nvif_ioctl(&client->namedb.parent.object, "object not found\n"); |
455 | 455 | return -ENOENT; | |
456 | if (!(namedb = (void *)nv_pclass(object, NV_NAMEDB_CLASS)) || | ||
457 | !(handle = nvkm_namedb_get(namedb, path[nr]))) { | ||
458 | nvif_debug(object, "handle 0x%08x not found\n", path[nr]); | ||
459 | return -ENOENT; | ||
460 | } | ||
461 | nvkm_namedb_put(handle); | ||
462 | parent = handle; | ||
463 | } | 456 | } |
464 | 457 | ||
465 | if (owner != NVIF_IOCTL_V0_OWNER_ANY && owner != handle->route) { | 458 | if (owner != NVIF_IOCTL_V0_OWNER_ANY && owner != object->route) { |
466 | nvif_ioctl(object, "object route != owner\n"); | 459 | nvif_ioctl(&client->namedb.parent.object, "route != owner\n"); |
467 | return -EACCES; | 460 | return -EACCES; |
468 | } | 461 | } |
469 | *route = handle->route; | 462 | *route = object->route; |
470 | *token = handle->token; | 463 | *token = object->token; |
471 | 464 | ||
472 | if (ret = -EINVAL, type < ARRAY_SIZE(nvkm_ioctl_v0)) { | 465 | if (ret = -EINVAL, type < ARRAY_SIZE(nvkm_ioctl_v0)) { |
473 | if (nvkm_ioctl_v0[type].version == 0) | 466 | if (nvkm_ioctl_v0[type].version == 0) |
474 | ret = nvkm_ioctl_v0[type].func(handle, data, size); | 467 | ret = nvkm_ioctl_v0[type].func(object, data, size); |
475 | } | 468 | } |
476 | 469 | ||
477 | return ret; | 470 | return ret; |
@@ -491,11 +484,11 @@ nvkm_ioctl(struct nvkm_client *client, bool supervisor, | |||
491 | nvif_ioctl(object, "size %d\n", size); | 484 | nvif_ioctl(object, "size %d\n", size); |
492 | 485 | ||
493 | if (nvif_unpack(args->v0, 0, 0, true)) { | 486 | if (nvif_unpack(args->v0, 0, 0, true)) { |
494 | nvif_ioctl(object, "vers %d type %02x path %d owner %02x\n", | 487 | nvif_ioctl(object, |
495 | args->v0.version, args->v0.type, args->v0.path_nr, | 488 | "vers %d type %02x object %016llx owner %02x\n", |
489 | args->v0.version, args->v0.type, args->v0.object, | ||
496 | args->v0.owner); | 490 | args->v0.owner); |
497 | ret = nvkm_ioctl_path(client->root, args->v0.type, | 491 | ret = nvkm_ioctl_path(client, args->v0.object, args->v0.type, |
498 | args->v0.path_nr, args->v0.path, | ||
499 | data, size, args->v0.owner, | 492 | data, size, args->v0.owner, |
500 | &args->v0.route, &args->v0.token); | 493 | &args->v0.route, &args->v0.token); |
501 | } | 494 | } |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c b/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c index 9d7ac6a15bd7..2568e5d5790e 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.c | |||
@@ -206,9 +206,12 @@ nv50_disp_dmac_object_detach(struct nvkm_object *parent, int cookie) | |||
206 | static int | 206 | static int |
207 | nv50_disp_dmac_create_(struct nvkm_object *parent, | 207 | nv50_disp_dmac_create_(struct nvkm_object *parent, |
208 | struct nvkm_object *engine, | 208 | struct nvkm_object *engine, |
209 | struct nvkm_oclass *oclass, u32 pushbuf, int head, | 209 | struct nvkm_oclass *oclass, u64 pushbuf, int head, |
210 | int length, void **pobject) | 210 | int length, void **pobject) |
211 | { | 211 | { |
212 | struct nvkm_client *client = nvkm_client(parent); | ||
213 | struct nvkm_handle *handle; | ||
214 | struct nvkm_dmaobj *dmaobj; | ||
212 | struct nv50_disp_dmac *dmac; | 215 | struct nv50_disp_dmac *dmac; |
213 | int ret; | 216 | int ret; |
214 | 217 | ||
@@ -218,22 +221,23 @@ nv50_disp_dmac_create_(struct nvkm_object *parent, | |||
218 | if (ret) | 221 | if (ret) |
219 | return ret; | 222 | return ret; |
220 | 223 | ||
221 | dmac->pushdma = (void *)nvkm_handle_ref(parent, pushbuf); | 224 | handle = nvkm_client_search(client, pushbuf); |
222 | if (!dmac->pushdma) | 225 | if (!handle) |
223 | return -ENOENT; | 226 | return -ENOENT; |
227 | dmaobj = (void *)handle->object; | ||
224 | 228 | ||
225 | switch (nv_mclass(dmac->pushdma)) { | 229 | switch (nv_mclass(dmaobj)) { |
226 | case 0x0002: | 230 | case 0x0002: |
227 | case 0x003d: | 231 | case 0x003d: |
228 | if (dmac->pushdma->limit - dmac->pushdma->start != 0xfff) | 232 | if (dmaobj->limit - dmaobj->start != 0xfff) |
229 | return -EINVAL; | 233 | return -EINVAL; |
230 | 234 | ||
231 | switch (dmac->pushdma->target) { | 235 | switch (dmaobj->target) { |
232 | case NV_MEM_TARGET_VRAM: | 236 | case NV_MEM_TARGET_VRAM: |
233 | dmac->push = 0x00000001 | dmac->pushdma->start >> 8; | 237 | dmac->push = 0x00000001 | dmaobj->start >> 8; |
234 | break; | 238 | break; |
235 | case NV_MEM_TARGET_PCI_NOSNOOP: | 239 | case NV_MEM_TARGET_PCI_NOSNOOP: |
236 | dmac->push = 0x00000003 | dmac->pushdma->start >> 8; | 240 | dmac->push = 0x00000003 | dmaobj->start >> 8; |
237 | break; | 241 | break; |
238 | default: | 242 | default: |
239 | return -EINVAL; | 243 | return -EINVAL; |
@@ -250,7 +254,6 @@ void | |||
250 | nv50_disp_dmac_dtor(struct nvkm_object *object) | 254 | nv50_disp_dmac_dtor(struct nvkm_object *object) |
251 | { | 255 | { |
252 | struct nv50_disp_dmac *dmac = (void *)object; | 256 | struct nv50_disp_dmac *dmac = (void *)object; |
253 | nvkm_object_ref(NULL, (struct nvkm_object **)&dmac->pushdma); | ||
254 | nv50_disp_chan_destroy(&dmac->base); | 257 | nv50_disp_chan_destroy(&dmac->base); |
255 | } | 258 | } |
256 | 259 | ||
@@ -513,7 +516,7 @@ nv50_disp_core_ctor(struct nvkm_object *parent, | |||
513 | nvif_ioctl(parent, "create disp core channel dma size %d\n", size); | 516 | nvif_ioctl(parent, "create disp core channel dma size %d\n", size); |
514 | if (nvif_unpack(args->v0, 0, 0, false)) { | 517 | if (nvif_unpack(args->v0, 0, 0, false)) { |
515 | nvif_ioctl(parent, "create disp core channel dma vers %d " | 518 | nvif_ioctl(parent, "create disp core channel dma vers %d " |
516 | "pushbuf %08x\n", | 519 | "pushbuf %016llx\n", |
517 | args->v0.version, args->v0.pushbuf); | 520 | args->v0.version, args->v0.pushbuf); |
518 | } else | 521 | } else |
519 | return ret; | 522 | return ret; |
@@ -682,7 +685,7 @@ nv50_disp_base_ctor(struct nvkm_object *parent, | |||
682 | nvif_ioctl(parent, "create disp base channel dma size %d\n", size); | 685 | nvif_ioctl(parent, "create disp base channel dma size %d\n", size); |
683 | if (nvif_unpack(args->v0, 0, 0, false)) { | 686 | if (nvif_unpack(args->v0, 0, 0, false)) { |
684 | nvif_ioctl(parent, "create disp base channel dma vers %d " | 687 | nvif_ioctl(parent, "create disp base channel dma vers %d " |
685 | "pushbuf %08x head %d\n", | 688 | "pushbuf %016llx head %d\n", |
686 | args->v0.version, args->v0.pushbuf, args->v0.head); | 689 | args->v0.version, args->v0.pushbuf, args->v0.head); |
687 | if (args->v0.head > disp->head.nr) | 690 | if (args->v0.head > disp->head.nr) |
688 | return -EINVAL; | 691 | return -EINVAL; |
@@ -772,7 +775,7 @@ nv50_disp_ovly_ctor(struct nvkm_object *parent, | |||
772 | nvif_ioctl(parent, "create disp overlay channel dma size %d\n", size); | 775 | nvif_ioctl(parent, "create disp overlay channel dma size %d\n", size); |
773 | if (nvif_unpack(args->v0, 0, 0, false)) { | 776 | if (nvif_unpack(args->v0, 0, 0, false)) { |
774 | nvif_ioctl(parent, "create disp overlay channel dma vers %d " | 777 | nvif_ioctl(parent, "create disp overlay channel dma vers %d " |
775 | "pushbuf %08x head %d\n", | 778 | "pushbuf %016llx head %d\n", |
776 | args->v0.version, args->v0.pushbuf, args->v0.head); | 779 | args->v0.version, args->v0.pushbuf, args->v0.head); |
777 | if (args->v0.head > disp->head.nr) | 780 | if (args->v0.head > disp->head.nr) |
778 | return -EINVAL; | 781 | return -EINVAL; |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.h b/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.h index 0d495d274eb3..21dbd3901113 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.h +++ b/drivers/gpu/drm/nouveau/nvkm/engine/disp/nv50.h | |||
@@ -113,7 +113,6 @@ extern const struct nvkm_event_func gf110_disp_chan_uevent; | |||
113 | 113 | ||
114 | struct nv50_disp_dmac { | 114 | struct nv50_disp_dmac { |
115 | struct nv50_disp_chan base; | 115 | struct nv50_disp_chan base; |
116 | struct nvkm_dmaobj *pushdma; | ||
117 | u32 push; | 116 | u32 push; |
118 | }; | 117 | }; |
119 | 118 | ||
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c index e298aef71918..73b8ab4c222e 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/base.c | |||
@@ -54,9 +54,12 @@ int | |||
54 | nvkm_fifo_channel_create_(struct nvkm_object *parent, | 54 | nvkm_fifo_channel_create_(struct nvkm_object *parent, |
55 | struct nvkm_object *engine, | 55 | struct nvkm_object *engine, |
56 | struct nvkm_oclass *oclass, | 56 | struct nvkm_oclass *oclass, |
57 | int bar, u32 addr, u32 size, u32 pushbuf, | 57 | int bar, u32 addr, u32 size, u64 pushbuf, |
58 | u64 engmask, int len, void **ptr) | 58 | u64 engmask, int len, void **ptr) |
59 | { | 59 | { |
60 | struct nvkm_client *client = nvkm_client(parent); | ||
61 | struct nvkm_handle *handle; | ||
62 | struct nvkm_dmaobj *dmaobj; | ||
60 | struct nvkm_fifo *fifo = (void *)engine; | 63 | struct nvkm_fifo *fifo = (void *)engine; |
61 | struct nvkm_fifo_chan *chan; | 64 | struct nvkm_fifo_chan *chan; |
62 | struct nvkm_dmaeng *dmaeng; | 65 | struct nvkm_dmaeng *dmaeng; |
@@ -73,12 +76,13 @@ nvkm_fifo_channel_create_(struct nvkm_object *parent, | |||
73 | return ret; | 76 | return ret; |
74 | 77 | ||
75 | /* validate dma object representing push buffer */ | 78 | /* validate dma object representing push buffer */ |
76 | chan->pushdma = (void *)nvkm_handle_ref(parent, pushbuf); | 79 | handle = nvkm_client_search(client, pushbuf); |
77 | if (!chan->pushdma) | 80 | if (!handle) |
78 | return -ENOENT; | 81 | return -ENOENT; |
82 | dmaobj = (void *)handle->object; | ||
79 | 83 | ||
80 | dmaeng = (void *)chan->pushdma->base.engine; | 84 | dmaeng = (void *)dmaobj->base.engine; |
81 | switch (chan->pushdma->base.oclass->handle) { | 85 | switch (dmaobj->base.oclass->handle) { |
82 | case NV_DMA_FROM_MEMORY: | 86 | case NV_DMA_FROM_MEMORY: |
83 | case NV_DMA_IN_MEMORY: | 87 | case NV_DMA_IN_MEMORY: |
84 | break; | 88 | break; |
@@ -86,7 +90,7 @@ nvkm_fifo_channel_create_(struct nvkm_object *parent, | |||
86 | return -EINVAL; | 90 | return -EINVAL; |
87 | } | 91 | } |
88 | 92 | ||
89 | ret = dmaeng->bind(chan->pushdma, parent, &chan->pushgpu); | 93 | ret = dmaeng->bind(dmaobj, parent, &chan->pushgpu); |
90 | if (ret) | 94 | if (ret) |
91 | return ret; | 95 | return ret; |
92 | 96 | ||
@@ -126,7 +130,6 @@ nvkm_fifo_channel_destroy(struct nvkm_fifo_chan *chan) | |||
126 | spin_unlock_irqrestore(&fifo->lock, flags); | 130 | spin_unlock_irqrestore(&fifo->lock, flags); |
127 | 131 | ||
128 | nvkm_gpuobj_ref(NULL, &chan->pushgpu); | 132 | nvkm_gpuobj_ref(NULL, &chan->pushgpu); |
129 | nvkm_object_ref(NULL, (struct nvkm_object **)&chan->pushdma); | ||
130 | nvkm_namedb_destroy(&chan->namedb); | 133 | nvkm_namedb_destroy(&chan->namedb); |
131 | } | 134 | } |
132 | 135 | ||
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c index c4f48112aa05..575329d3f2bb 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/g84.c | |||
@@ -182,7 +182,7 @@ g84_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine, | |||
182 | 182 | ||
183 | nvif_ioctl(parent, "create channel dma size %d\n", size); | 183 | nvif_ioctl(parent, "create channel dma size %d\n", size); |
184 | if (nvif_unpack(args->v0, 0, 0, false)) { | 184 | if (nvif_unpack(args->v0, 0, 0, false)) { |
185 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %08x " | 185 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %llx " |
186 | "offset %016llx\n", args->v0.version, | 186 | "offset %016llx\n", args->v0.version, |
187 | args->v0.pushbuf, args->v0.offset); | 187 | args->v0.pushbuf, args->v0.offset); |
188 | } else | 188 | } else |
@@ -258,7 +258,7 @@ g84_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine, | |||
258 | 258 | ||
259 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); | 259 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); |
260 | if (nvif_unpack(args->v0, 0, 0, false)) { | 260 | if (nvif_unpack(args->v0, 0, 0, false)) { |
261 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %08x " | 261 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %llx " |
262 | "ioffset %016llx ilength %08x\n", | 262 | "ioffset %016llx ilength %08x\n", |
263 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, | 263 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, |
264 | args->v0.ilength); | 264 | args->v0.ilength); |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c index d940d41d1182..cfaa8aeb2223 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gf100.c | |||
@@ -210,7 +210,7 @@ gf100_fifo_chan_ctor(struct nvkm_object *parent, struct nvkm_object *engine, | |||
210 | 210 | ||
211 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); | 211 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); |
212 | if (nvif_unpack(args->v0, 0, 0, false)) { | 212 | if (nvif_unpack(args->v0, 0, 0, false)) { |
213 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %08x " | 213 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %llx " |
214 | "ioffset %016llx ilength %08x\n", | 214 | "ioffset %016llx ilength %08x\n", |
215 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, | 215 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, |
216 | args->v0.ilength); | 216 | args->v0.ilength); |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c index 9a1ecef24813..9c423514fee7 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/gk104.c | |||
@@ -251,7 +251,7 @@ gk104_fifo_chan_ctor(struct nvkm_object *parent, struct nvkm_object *engine, | |||
251 | 251 | ||
252 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); | 252 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); |
253 | if (nvif_unpack(args->v0, 0, 0, false)) { | 253 | if (nvif_unpack(args->v0, 0, 0, false)) { |
254 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %08x " | 254 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %llx " |
255 | "ioffset %016llx ilength %08x engine %08x\n", | 255 | "ioffset %016llx ilength %08x engine %08x\n", |
256 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, | 256 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, |
257 | args->v0.ilength, args->v0.engine); | 257 | args->v0.ilength, args->v0.engine); |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c index d5346636b7e3..6458fa0dcb95 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv04.c | |||
@@ -120,7 +120,7 @@ nv04_fifo_chan_ctor(struct nvkm_object *parent, | |||
120 | 120 | ||
121 | nvif_ioctl(parent, "create channel dma size %d\n", size); | 121 | nvif_ioctl(parent, "create channel dma size %d\n", size); |
122 | if (nvif_unpack(args->v0, 0, 0, false)) { | 122 | if (nvif_unpack(args->v0, 0, 0, false)) { |
123 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %08x " | 123 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %llx " |
124 | "offset %016llx\n", args->v0.version, | 124 | "offset %016llx\n", args->v0.version, |
125 | args->v0.pushbuf, args->v0.offset); | 125 | args->v0.pushbuf, args->v0.offset); |
126 | } else | 126 | } else |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv10.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv10.c index 5a7b11f92684..c4b5a3002e3c 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv10.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv10.c | |||
@@ -64,7 +64,7 @@ nv10_fifo_chan_ctor(struct nvkm_object *parent, | |||
64 | 64 | ||
65 | nvif_ioctl(parent, "create channel dma size %d\n", size); | 65 | nvif_ioctl(parent, "create channel dma size %d\n", size); |
66 | if (nvif_unpack(args->v0, 0, 0, false)) { | 66 | if (nvif_unpack(args->v0, 0, 0, false)) { |
67 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %08x " | 67 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %llx " |
68 | "offset %016llx\n", args->v0.version, | 68 | "offset %016llx\n", args->v0.version, |
69 | args->v0.pushbuf, args->v0.offset); | 69 | args->v0.pushbuf, args->v0.offset); |
70 | } else | 70 | } else |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c index 537bb7229e3d..ece2715e77ff 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv17.c | |||
@@ -69,7 +69,7 @@ nv17_fifo_chan_ctor(struct nvkm_object *parent, | |||
69 | 69 | ||
70 | nvif_ioctl(parent, "create channel dma size %d\n", size); | 70 | nvif_ioctl(parent, "create channel dma size %d\n", size); |
71 | if (nvif_unpack(args->v0, 0, 0, false)) { | 71 | if (nvif_unpack(args->v0, 0, 0, false)) { |
72 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %08x " | 72 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %llx " |
73 | "offset %016llx\n", args->v0.version, | 73 | "offset %016llx\n", args->v0.version, |
74 | args->v0.pushbuf, args->v0.offset); | 74 | args->v0.pushbuf, args->v0.offset); |
75 | } else | 75 | } else |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c index 27f07d1db85f..a42218a961d4 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv40.c | |||
@@ -192,7 +192,7 @@ nv40_fifo_chan_ctor(struct nvkm_object *parent, struct nvkm_object *engine, | |||
192 | 192 | ||
193 | nvif_ioctl(parent, "create channel dma size %d\n", size); | 193 | nvif_ioctl(parent, "create channel dma size %d\n", size); |
194 | if (nvif_unpack(args->v0, 0, 0, false)) { | 194 | if (nvif_unpack(args->v0, 0, 0, false)) { |
195 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %08x " | 195 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %llx " |
196 | "offset %016llx\n", args->v0.version, | 196 | "offset %016llx\n", args->v0.version, |
197 | args->v0.pushbuf, args->v0.offset); | 197 | args->v0.pushbuf, args->v0.offset); |
198 | } else | 198 | } else |
diff --git a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c index 24154778c01e..1a7ca8e5aecb 100644 --- a/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c +++ b/drivers/gpu/drm/nouveau/nvkm/engine/fifo/nv50.c | |||
@@ -212,7 +212,7 @@ nv50_fifo_chan_ctor_dma(struct nvkm_object *parent, struct nvkm_object *engine, | |||
212 | 212 | ||
213 | nvif_ioctl(parent, "create channel dma size %d\n", size); | 213 | nvif_ioctl(parent, "create channel dma size %d\n", size); |
214 | if (nvif_unpack(args->v0, 0, 0, false)) { | 214 | if (nvif_unpack(args->v0, 0, 0, false)) { |
215 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %08x " | 215 | nvif_ioctl(parent, "create channel dma vers %d pushbuf %llx " |
216 | "offset %016llx\n", args->v0.version, | 216 | "offset %016llx\n", args->v0.version, |
217 | args->v0.pushbuf, args->v0.offset); | 217 | args->v0.pushbuf, args->v0.offset); |
218 | } else | 218 | } else |
@@ -276,7 +276,7 @@ nv50_fifo_chan_ctor_ind(struct nvkm_object *parent, struct nvkm_object *engine, | |||
276 | 276 | ||
277 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); | 277 | nvif_ioctl(parent, "create channel gpfifo size %d\n", size); |
278 | if (nvif_unpack(args->v0, 0, 0, false)) { | 278 | if (nvif_unpack(args->v0, 0, 0, false)) { |
279 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %08x " | 279 | nvif_ioctl(parent, "create channel gpfifo vers %d pushbuf %llx " |
280 | "ioffset %016llx ilength %08x\n", | 280 | "ioffset %016llx ilength %08x\n", |
281 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, | 281 | args->v0.version, args->v0.pushbuf, args->v0.ioffset, |
282 | args->v0.ilength); | 282 | args->v0.ilength); |