Commit e94654e2 authored by Ben Skeggs's avatar Ben Skeggs
Browse files

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



Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent 98faa78c
Loading
Loading
Loading
Loading
+0 −1
Original line number Diff line number Diff line
@@ -12,7 +12,6 @@ struct nouveau_bar {

	int (*alloc)(struct nouveau_bar *, struct nouveau_object *,
		     struct nouveau_mem *, struct nouveau_object **);
	void __iomem *iomem;

	int (*kmap)(struct nouveau_bar *, struct nouveau_mem *,
		    u32 flags, struct nouveau_vma *);
+19 −19
Original line number Diff line number Diff line
@@ -38,10 +38,12 @@ struct nouveau_barobj {
static int
nouveau_barobj_ctor(struct nouveau_object *parent,
		    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_device *device = nv_device(parent);
	struct nouveau_bar *bar = (void *)engine;
	struct nouveau_mem *mem = data;
	struct nouveau_barobj *barobj;
	int ret;

@@ -54,7 +56,13 @@ nouveau_barobj_ctor(struct nouveau_object *parent,
	if (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;
}

@@ -63,8 +71,11 @@ nouveau_barobj_dtor(struct nouveau_object *object)
{
	struct nouveau_bar *bar = (void *)object->engine;
	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);
	}
	nouveau_object_destroy(&barobj->base);
}

@@ -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_object *engine = nv_object(bar);
	int ret = -ENOMEM;
	if (bar->iomem) {
		ret = nouveau_object_ctor(parent, engine,
					  &nouveau_barobj_oclass,
					  mem, 0, pobject);
	}
	struct nouveau_object *gpuobj;
	int ret = nouveau_object_ctor(parent, engine, &nouveau_barobj_oclass,
				      mem, 0, &gpuobj);
	if (ret == 0)
		*pobject = gpuobj;
	return ret;
}

@@ -113,7 +123,6 @@ nouveau_bar_create_(struct nouveau_object *parent,
		    struct nouveau_object *engine,
		    struct nouveau_oclass *oclass, int length, void **pobject)
{
	struct nouveau_device *device = nv_device(parent);
	struct nouveau_bar *bar;
	int ret;

@@ -123,21 +132,12 @@ nouveau_bar_create_(struct nouveau_object *parent,
	if (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;
}

void
nouveau_bar_destroy(struct nouveau_bar *bar)
{
	if (bar->iomem)
		iounmap(bar->iomem);
	nouveau_subdev_destroy(&bar->base);
}