diff options
| -rw-r--r-- | shared-core/nouveau_drm.h | 2 | ||||
| -rw-r--r-- | shared-core/nouveau_fifo.c | 14 | ||||
| -rw-r--r-- | shared-core/nouveau_irq.c | 1 | ||||
| -rw-r--r-- | shared-core/nouveau_mem.c | 2 | 
4 files changed, 14 insertions, 5 deletions
| diff --git a/shared-core/nouveau_drm.h b/shared-core/nouveau_drm.h index 3ba7e961..1e7322e0 100644 --- a/shared-core/nouveau_drm.h +++ b/shared-core/nouveau_drm.h @@ -114,7 +114,7 @@ enum nouveau_card_type {  	NV_10      =10,  	NV_11      =10,  	NV_15      =10, -	NV_17      =10, +	NV_17      =17,  	NV_20      =20,  	NV_25      =20,  	NV_30      =30, diff --git a/shared-core/nouveau_fifo.c b/shared-core/nouveau_fifo.c index 92166eeb..8e66ca2e 100644 --- a/shared-core/nouveau_fifo.c +++ b/shared-core/nouveau_fifo.c @@ -51,7 +51,7 @@ int nouveau_fifo_ctx_size(drm_device_t* dev)  	if (dev_priv->card_type >= NV_40)  		return 128; -	else if (dev_priv->card_type >= NV_10) +	else if (dev_priv->card_type >= NV_17)  		return 64;  	else  		return 32; @@ -90,10 +90,12 @@ static int nouveau_fifo_instmem_configure(drm_device_t *dev)  			break;  		case NV_30:  		case NV_20: -		case NV_10: +		case NV_17:  			NV_WRITE(NV03_PFIFO_RAMFC, (dev_priv->ramfc_offset>>8) |  					(1 << 16) /* 64 Bytes entry*/); +			/* XXX nvidia blob set bit 18, 21,23 for nv20 & nv30 */  			break; +		case NV_10:  		case NV_04:  		case NV_03:  			NV_WRITE(NV03_PFIFO_RAMFC, dev_priv->ramfc_offset>>8); @@ -269,11 +271,12 @@ static void nouveau_nv10_context_init(drm_device_t *dev, int channel)          drm_nouveau_private_t *dev_priv = dev->dev_private;          struct nouveau_object *cb_obj;          uint32_t fifoctx; +        int ctx_size = nouveau_fifo_ctx_size(dev);          int i;          cb_obj  = dev_priv->fifos[channel].cmdbuf_obj; -        fifoctx = NV_RAMIN + dev_priv->ramfc_offset + channel*64; +        fifoctx = NV_RAMIN + dev_priv->ramfc_offset + channel*ctx_size; -        for (i=0;i<64;i+=4) +        for (i=0;i<ctx_size;i+=4)                  NV_WRITE(fifoctx + i, 0);          /* Fill entries that are seen filled in dumps of nvidia driver just @@ -327,6 +330,7 @@ static void nouveau_nv30_context_init(drm_device_t *dev, int channel)          RAMFC_WR(SEMAPHORE,             NV_READ(NV10_PFIFO_CACHE1_SEMAPHORE));  } +#if 0  static void nouveau_nv10_context_save(drm_device_t *dev)  {  	drm_nouveau_private_t *dev_priv = dev->dev_private; @@ -350,6 +354,7 @@ static void nouveau_nv10_context_save(drm_device_t *dev)  	RAMFC_WR(SEMAPHORE        , NV_READ(NV10_PFIFO_CACHE1_SEMAPHORE));  	RAMFC_WR(DMA_SUBROUTINE   , NV_READ(NV10_PFIFO_CACHE1_DMA_SUBROUTINE));  } +#endif  #undef RAMFC_WR  #define RAMFC_WR(offset, val) NV_WRITE(fifoctx + NV40_RAMFC_##offset, (val)) @@ -507,6 +512,7 @@ static int nouveau_fifo_alloc(drm_device_t* dev, int *chan_ret, DRMFILE filp)  			nouveau_nv04_context_init(dev, channel);  			break;  		case NV_10: +		case NV_17:  			nv10_graph_context_create(dev, channel);  			nouveau_nv10_context_init(dev, channel);  			break; diff --git a/shared-core/nouveau_irq.c b/shared-core/nouveau_irq.c index b7c1d532..8de6e705 100644 --- a/shared-core/nouveau_irq.c +++ b/shared-core/nouveau_irq.c @@ -372,6 +372,7 @@ static void nouveau_pgraph_irq_handler(drm_device_t *dev)  				nouveau_nv04_context_switch(dev);  				break;  			case NV_10: +			case NV_17:  				nouveau_nv10_context_switch(dev);  				break;  			case NV_20: diff --git a/shared-core/nouveau_mem.c b/shared-core/nouveau_mem.c index 541f1545..a5343b99 100644 --- a/shared-core/nouveau_mem.c +++ b/shared-core/nouveau_mem.c @@ -248,6 +248,7 @@ uint64_t nouveau_mem_fb_amount(struct drm_device *dev)  			}  			break;  		case NV_10: +		case NV_17:  		case NV_20:  		case NV_30:  		case NV_40: @@ -521,6 +522,7 @@ nouveau_instmem_configure_fixed_tables(struct drm_device *dev)  			break;  		case NV_30:  		case NV_20: +		case NV_17:  		case NV_10:  		case NV_04:  		case NV_03: | 
