aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBen Skeggs <bskeggs@redhat.com>2011-07-11 01:46:01 -0400
committerBen Skeggs <bskeggs@redhat.com>2011-09-20 02:08:02 -0400
commite432d48f87543731fff2b19563420877d8a0c4cc (patch)
tree2438f7fdc935695cf4551fb5060a91b17bf559b5
parent658e86ee2db9500aea529a04008cce10972416bc (diff)
drm/nvd0: lets not attempt to dereference a nv50_display pointer
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
-rw-r--r--drivers/gpu/drm/nouveau/nouveau_object.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_object.c b/drivers/gpu/drm/nouveau/nouveau_object.c
index 4406c1751069..02222c540aee 100644
--- a/drivers/gpu/drm/nouveau/nouveau_object.c
+++ b/drivers/gpu/drm/nouveau/nouveau_object.c
@@ -693,6 +693,7 @@ nouveau_gpuobj_channel_init_pramin(struct nouveau_channel *chan)
693static int 693static int
694nvc0_gpuobj_channel_init(struct nouveau_channel *chan, struct nouveau_vm *vm) 694nvc0_gpuobj_channel_init(struct nouveau_channel *chan, struct nouveau_vm *vm)
695{ 695{
696 struct drm_nouveau_private *dev_priv = chan->dev->dev_private;
696 struct drm_device *dev = chan->dev; 697 struct drm_device *dev = chan->dev;
697 struct nouveau_gpuobj *pgd = NULL; 698 struct nouveau_gpuobj *pgd = NULL;
698 struct nouveau_vm_pgd *vpgd; 699 struct nouveau_vm_pgd *vpgd;
@@ -722,6 +723,9 @@ nvc0_gpuobj_channel_init(struct nouveau_channel *chan, struct nouveau_vm *vm)
722 nv_wo32(chan->ramin, 0x020c, 0x000000ff); 723 nv_wo32(chan->ramin, 0x020c, 0x000000ff);
723 724
724 /* map display semaphore buffers into channel's vm */ 725 /* map display semaphore buffers into channel's vm */
726 if (dev_priv->card_type >= NV_D0)
727 return 0;
728
725 for (i = 0; i < 2; i++) { 729 for (i = 0; i < 2; i++) {
726 struct nv50_display_crtc *dispc = &nv50_display(dev)->crtc[i]; 730 struct nv50_display_crtc *dispc = &nv50_display(dev)->crtc[i];
727 731
@@ -875,18 +879,18 @@ nouveau_gpuobj_channel_takedown(struct nouveau_channel *chan)
875 879
876 NV_DEBUG(dev, "ch%d\n", chan->id); 880 NV_DEBUG(dev, "ch%d\n", chan->id);
877 881
878 if (dev_priv->card_type >= NV_50) { 882 if (dev_priv->card_type >= NV_50 && dev_priv->card_type <= NV_C0) {
879 struct nv50_display *disp = nv50_display(dev); 883 struct nv50_display *disp = nv50_display(dev);
880 884
881 for (i = 0; i < dev->mode_config.num_crtc; i++) { 885 for (i = 0; i < dev->mode_config.num_crtc; i++) {
882 struct nv50_display_crtc *dispc = &disp->crtc[i]; 886 struct nv50_display_crtc *dispc = &disp->crtc[i];
883 nouveau_bo_vma_del(dispc->sem.bo, &chan->dispc_vma[i]); 887 nouveau_bo_vma_del(dispc->sem.bo, &chan->dispc_vma[i]);
884 } 888 }
885
886 nouveau_vm_ref(NULL, &chan->vm, chan->vm_pd);
887 nouveau_gpuobj_ref(NULL, &chan->vm_pd);
888 } 889 }
889 890
891 nouveau_vm_ref(NULL, &chan->vm, chan->vm_pd);
892 nouveau_gpuobj_ref(NULL, &chan->vm_pd);
893
890 if (drm_mm_initialized(&chan->ramin_heap)) 894 if (drm_mm_initialized(&chan->ramin_heap))
891 drm_mm_takedown(&chan->ramin_heap); 895 drm_mm_takedown(&chan->ramin_heap);
892 nouveau_gpuobj_ref(NULL, &chan->ramin); 896 nouveau_gpuobj_ref(NULL, &chan->ramin);