diff options
author | Ben Skeggs <bskeggs@redhat.com> | 2012-10-31 01:51:00 +0100 |
---|---|---|
committer | Ben Skeggs <bskeggs@redhat.com> | 2012-10-31 02:23:23 +0100 |
commit | 5cad16acd25b16681a060d28d10eeacf98d07701 (patch) | |
tree | d00389a956a6809d392ce95d20331ed6122bc675 | |
parent | drm/nouveau: allow creation of zero-sized mm (diff) | |
download | linux-5cad16acd25b16681a060d28d10eeacf98d07701.tar.xz linux-5cad16acd25b16681a060d28d10eeacf98d07701.zip |
drm/nv50/fb: prevent oops on chipsets without compression tags
Unconditionally create the tagram mm, even if there's zero tags.
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
-rw-r--r-- | drivers/gpu/drm/nouveau/core/subdev/fb/nv50.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/drivers/gpu/drm/nouveau/core/subdev/fb/nv50.c b/drivers/gpu/drm/nouveau/core/subdev/fb/nv50.c index 27fb1af7a779..5f570806143a 100644 --- a/drivers/gpu/drm/nouveau/core/subdev/fb/nv50.c +++ b/drivers/gpu/drm/nouveau/core/subdev/fb/nv50.c @@ -219,13 +219,11 @@ nv50_fb_ctor(struct nouveau_object *parent, struct nouveau_object *engine, ((priv->base.ram.size & 0x000000ff) << 32); tags = nv_rd32(priv, 0x100320); - if (tags) { - ret = nouveau_mm_init(&priv->base.tags, 0, tags, 1); - if (ret) - return ret; + ret = nouveau_mm_init(&priv->base.tags, 0, tags, 1); + if (ret) + return ret; - nv_debug(priv, "%d compression tags\n", tags); - } + nv_debug(priv, "%d compression tags\n", tags); size = (priv->base.ram.size >> 12) - rsvd_head - rsvd_tail; switch (device->chipset) { |