changeset 4327:9bdf337bd078

upgraded to newest vidix interface
author alex
date Wed, 23 Jan 2002 19:37:28 +0000
parents 870cec859f92
children 2936f5445e0c
files vidix/drivers/nvidia_vid.c vidix/drivers/radeon_vid.c
diffstat 2 files changed, 150 insertions(+), 11 deletions(-) [+]
line wrap: on
line diff
--- a/vidix/drivers/nvidia_vid.c	Wed Jan 23 19:34:33 2002 +0000
+++ b/vidix/drivers/nvidia_vid.c	Wed Jan 23 19:37:28 2002 +0000
@@ -11,13 +11,34 @@
 #include "../../libdha/pci_ids.h"
 #include "../../libdha/pci_names.h"
 
-//#include "nvidia.h"
+#include "nvidia.h"
 
-static void *mmio_base = 0;
-static void *mem_base = 0;
+static void *ctrl_base = 0;
+static void *fb_base = 0;
 static int32_t overlay_offset = 0;
 static uint32_t ram_size = 0;
 
+static unsigned int *PFB;
+static unsigned int *PCIO;
+static unsigned int *PGRAPH;
+static unsigned int *PRAMIN;
+static unsigned int *FIFO;
+static unsigned int *PMC;
+
+typedef unsigned char U008;
+
+#define NV_WR08(p,i,d)	(((U008 *)(p))[i]=(d))
+
+unsigned int nv_fifo_space = 0;
+
+void CRTCout(unsigned char index, unsigned char val)
+{
+    NV_WR08(PCIO, 0x3d4, index);
+    NV_WR08(PCIO, 0x3d5, val);
+}
+
+volatile RivaScaledImage *ScaledImage;
+
 #define CARD_FLAGS_NONE		0x00
 #define CARD_FLAGS_NOTSUPPORTED	0x01
 
@@ -29,6 +50,8 @@
     const int flags;
 };
 
+static const struct nv_card_id_s nv_card_id;
+
 static const struct nv_card_id_s nv_card_ids[]=
 {
     { DEVICE_NVIDIA_RIVA_TNT2_NV5, "nVidia TNT2 (NV5) ", 5, CARD_FLAGS_NOTSUPPORTED},
@@ -54,10 +77,11 @@
 static vidix_capability_t nvidia_cap =
 {
     "NVIDIA driver for VIDIX",
+    "alex",
     TYPE_OUTPUT,
     { 0, 0, 0, 0 },
-    1024,
-    768,
+    2046,
+    2047,
     4,
     4,
     -1,
@@ -108,6 +132,8 @@
 		else
 		
 		    printf("Found chip: %s\n", nv_card_ids[idx].name);
+		
+		memcpy(&nv_card_id, &nv_card_ids[idx], sizeof(struct nv_card_id_s));
 		nvidia_cap.device_id = nv_card_ids[idx].id;
 		err = 0;
 		memcpy(&pci_info, &lst[i], sizeof(pciinfo_t));
@@ -132,20 +158,99 @@
 
 int vixInit(void)
 {
+    int card_option;
+    
     printf("[nvidia] init\n");
     
+    pci_config_read(pci_info.bus, pci_info.card, pci_info.func, 0x40,
+	4, &card_option);
+    printf("card_option: %x\n", card_option);
+    
     if (!probed)
     {
 	printf("Driver was not probed but is being initialized\n");
 	return(EINTR);
     }
     
-    mmio_base = map_phys_mem(pci_info.base0, 0xFFFF);
-    if (mmio_base == (void *)-1)
+    ctrl_base = map_phys_mem(pci_info.base0, 0x00800000);
+    if (ctrl_base == (void *)-1)
+	return(ENOMEM);
+    fb_base = map_phys_mem(pci_info.base1, 0x01000000);
+    if (fb_base == (void *)-1)
 	return(ENOMEM);
 
-    printf("mmio_base: %p\n", mmio_base);
-    return ENXIO;
+    printf("ctrl_base: %p, fb_base: %p\n", ctrl_base, fb_base);
+
+    PFB = 	ctrl_base+0x00100000;
+    PGRAPH =	ctrl_base+0x00400000;
+    PRAMIN =	ctrl_base+0x00710000;
+    FIFO =	ctrl_base+0x00800000;
+    PCIO =	ctrl_base+0x00601000;
+    PMC = 	ctrl_base+0x00000000;
+    printf("pfb: %p, pgraph: %p, pramin: %p, fifo: %p, pcio: %p\n",
+	PFB, PGRAPH, PRAMIN, FIFO, PCIO);
+    
+    ScaledImage = FIFO+0x8000/4;
+    printf("ScaledImage: %p\n", ScaledImage);
+
+    /* unlock */
+    CRTCout(0x11, 0xff);
+
+    printf("fifo_free: %d\n", ScaledImage->fifo_free);
+
+    RIVA_FIFO_FREE(ScaledImage, 10);
+    
+    dump_scaledimage(ScaledImage);
+    
+    /* create scaled image object */
+    *(PRAMIN+0x518) = 0x0100A037;
+    *(PRAMIN+0x519) = 0x00000C02;
+    
+    /* put scaled image object into subchannel */
+    *(FIFO+0x2000) = 0x80000011;
+
+    /* ram size detection */
+    switch(nv_card_id.core)
+    {
+	case 5:
+	{
+	    if (*(PFB+0x0) & 0x00000100)
+	    {
+		printf("first ver\n");
+		ram_size = ((*(PFB+0x0) >> 12) & 0x0f) * 1024 * 2 + 1024 * 2;
+	    }
+	    else
+	    {
+		printf("second ver (code: %d)\n",
+		    *(PFB+0x0) & 0x00000003);
+		switch(*(PFB+0x0) & 0x00000003)
+		{
+		    case 0:
+			ram_size = 1024*32;
+			break;
+		    case 1:
+			ram_size = 1024*4;
+			break;
+		    case 2:
+			ram_size = 1024*8;
+			break;
+		    case 3:
+			ram_size = 1024*16;
+			break;
+		    default:
+			printf("Unknown ram size code: %d\n",
+			    *(PFB+0x0) & 0x00000003);
+			break;
+		}
+	    }
+	    break;
+	}
+	default:
+	    printf("Unknown core: %d\n", nv_card_id.core);
+    }
+
+    printf("ram_size: %d\n", ram_size);
+    return 0;
 }
 
 void vixDestroy(void)
@@ -162,16 +267,49 @@
 int vixQueryFourcc(vidix_fourcc_t *to)
 {
     printf("[nvidia] query fourcc (%x)\n", to->fourcc);
+    to->flags = 0;
+    to->depth = VID_DEPTH_32BPP;
     return 0;
 }
 
 int vixConfigPlayback(vidix_playback_t *info)
 {
+    int fb_pixel_size = 32/8;
+    int fb_line_len = 1280*4;
+    char buffer = 0;
+    int offset = 0;
+    int x,y,h,w;
+    int bpp = 32 >> 3;
+    int size;
+
     printf("[nvidia] config playback\n");
     
-    info->num_frames = 2;
+    x = info->src.x;
+    y = info->src.y;
+    h = info->src.h;
+    w = info->src.w;
+    
+    w = (w + 1) & ~1;
+    
+    size = h * (((w << 1) + 63) & ~63) / bpp;
+    
+    
+    PMC[(0x8900/4)+buffer] = offset;
+    PMC[(0x8928/4)+buffer] = (h << 16) | w;
+    PMC[(0x8930/4)+buffer] = ((y << 4) & 0xffff0000) | (x >> 12);
+    PMC[(0x8938/4)+buffer] = (w << 20) / info->dest.w;
+    PMC[(0x8938/4)+buffer] = (h << 20) / info->dest.h;
+    
+    info->dga_addr = fb_base + (info->dest.w - info->src.w) * fb_pixel_size /
+		    2 + (info->dest.h - info->src.h) * fb_line_len / 2;
+    
+    info->num_frames = 1;
     info->frame_size = info->src.w*info->src.h+(info->src.w*info->src.h)/2;
-    info->dga_addr = malloc(info->num_frames*info->frame_size);
+    info->offsets[0] = 0;
+    info->offset.y = 0;
+    info->offset.v = ((info->src.w + 31) & ~31) * info->src.h;
+    info->offset.u = info->offset.v+((info->src.w + 31) & ~31) * info->src.h / 4;
+//    info->dga_addr = malloc(info->num_frames*info->frame_size);
     return 0;
 }
 
--- a/vidix/drivers/radeon_vid.c	Wed Jan 23 19:34:33 2002 +0000
+++ b/vidix/drivers/radeon_vid.c	Wed Jan 23 19:37:28 2002 +0000
@@ -609,6 +609,7 @@
 #else
     "BES driver for radeon cards",
 #endif
+    "Nick Kurshev",
     TYPE_OUTPUT | TYPE_FX,
     { 0, 0, 0, 0 },
     2048,