提交 e94654e2 编写于 作者: B Ben Skeggs

drm/nouveau/bar: ioremap only the areas that we're actually using

Signed-off-by: NBen Skeggs <bskeggs@redhat.com>
上级 98faa78c
...@@ -12,7 +12,6 @@ struct nouveau_bar { ...@@ -12,7 +12,6 @@ struct nouveau_bar {
int (*alloc)(struct nouveau_bar *, struct nouveau_object *, int (*alloc)(struct nouveau_bar *, struct nouveau_object *,
struct nouveau_mem *, struct nouveau_object **); struct nouveau_mem *, struct nouveau_object **);
void __iomem *iomem;
int (*kmap)(struct nouveau_bar *, struct nouveau_mem *, int (*kmap)(struct nouveau_bar *, struct nouveau_mem *,
u32 flags, struct nouveau_vma *); u32 flags, struct nouveau_vma *);
......
...@@ -38,10 +38,12 @@ struct nouveau_barobj { ...@@ -38,10 +38,12 @@ struct nouveau_barobj {
static int static int
nouveau_barobj_ctor(struct nouveau_object *parent, nouveau_barobj_ctor(struct nouveau_object *parent,
struct nouveau_object *engine, struct nouveau_object *engine,
struct nouveau_oclass *oclass, void *mem, u32 size, struct nouveau_oclass *oclass, void *data, u32 size,
struct nouveau_object **pobject) struct nouveau_object **pobject)
{ {
struct nouveau_device *device = nv_device(parent);
struct nouveau_bar *bar = (void *)engine; struct nouveau_bar *bar = (void *)engine;
struct nouveau_mem *mem = data;
struct nouveau_barobj *barobj; struct nouveau_barobj *barobj;
int ret; int ret;
...@@ -54,7 +56,13 @@ nouveau_barobj_ctor(struct nouveau_object *parent, ...@@ -54,7 +56,13 @@ nouveau_barobj_ctor(struct nouveau_object *parent,
if (ret) if (ret)
return ret; return ret;
barobj->iomem = bar->iomem + (u32)barobj->vma.offset; barobj->iomem = ioremap(nv_device_resource_start(device, 3) +
(u32)barobj->vma.offset, mem->size << 12);
if (!barobj->iomem) {
nv_warn(bar, "PRAMIN ioremap failed\n");
return -ENOMEM;
}
return 0; return 0;
} }
...@@ -63,8 +71,11 @@ nouveau_barobj_dtor(struct nouveau_object *object) ...@@ -63,8 +71,11 @@ nouveau_barobj_dtor(struct nouveau_object *object)
{ {
struct nouveau_bar *bar = (void *)object->engine; struct nouveau_bar *bar = (void *)object->engine;
struct nouveau_barobj *barobj = (void *)object; struct nouveau_barobj *barobj = (void *)object;
if (barobj->vma.node) if (barobj->vma.node) {
if (barobj->iomem)
iounmap(barobj->iomem);
bar->unmap(bar, &barobj->vma); bar->unmap(bar, &barobj->vma);
}
nouveau_object_destroy(&barobj->base); nouveau_object_destroy(&barobj->base);
} }
...@@ -99,12 +110,11 @@ nouveau_bar_alloc(struct nouveau_bar *bar, struct nouveau_object *parent, ...@@ -99,12 +110,11 @@ nouveau_bar_alloc(struct nouveau_bar *bar, struct nouveau_object *parent,
struct nouveau_mem *mem, struct nouveau_object **pobject) struct nouveau_mem *mem, struct nouveau_object **pobject)
{ {
struct nouveau_object *engine = nv_object(bar); struct nouveau_object *engine = nv_object(bar);
int ret = -ENOMEM; struct nouveau_object *gpuobj;
if (bar->iomem) { int ret = nouveau_object_ctor(parent, engine, &nouveau_barobj_oclass,
ret = nouveau_object_ctor(parent, engine, mem, 0, &gpuobj);
&nouveau_barobj_oclass, if (ret == 0)
mem, 0, pobject); *pobject = gpuobj;
}
return ret; return ret;
} }
...@@ -113,7 +123,6 @@ nouveau_bar_create_(struct nouveau_object *parent, ...@@ -113,7 +123,6 @@ nouveau_bar_create_(struct nouveau_object *parent,
struct nouveau_object *engine, struct nouveau_object *engine,
struct nouveau_oclass *oclass, int length, void **pobject) struct nouveau_oclass *oclass, int length, void **pobject)
{ {
struct nouveau_device *device = nv_device(parent);
struct nouveau_bar *bar; struct nouveau_bar *bar;
int ret; int ret;
...@@ -123,21 +132,12 @@ nouveau_bar_create_(struct nouveau_object *parent, ...@@ -123,21 +132,12 @@ nouveau_bar_create_(struct nouveau_object *parent,
if (ret) if (ret)
return ret; return ret;
if (nv_device_resource_len(device, 3) != 0) {
bar->iomem = ioremap(nv_device_resource_start(device, 3),
nv_device_resource_len(device, 3));
if (!bar->iomem)
nv_warn(bar, "PRAMIN ioremap failed\n");
}
return 0; return 0;
} }
void void
nouveau_bar_destroy(struct nouveau_bar *bar) nouveau_bar_destroy(struct nouveau_bar *bar)
{ {
if (bar->iomem)
iounmap(bar->iomem);
nouveau_subdev_destroy(&bar->base); nouveau_subdev_destroy(&bar->base);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册