diff src/video/ps3/SDL_ps3render.c @ 3143:8fdabaa064c3 gsoc2009_ps3

Fixed centering. Added debug msgs for RenderCopy().
author Martin Lowinski <martin@goldtopf.org>
date Sat, 06 Jun 2009 06:40:23 +0000
parents c146645a770e
children 0d8d1f870964
line wrap: on
line diff
--- a/src/video/ps3/SDL_ps3render.c	Thu Jun 04 07:02:15 2009 +0000
+++ b/src/video/ps3/SDL_ps3render.c	Sat Jun 06 06:40:23 2009 +0000
@@ -38,28 +38,6 @@
 
 #include <asm/ps3fb.h>
 
-/* Debugging
- * 0: No debug messages
- * 1: Video debug messages
- * 2: SPE debug messages
- * 3: Memory adresses
- */
-#define DEBUG_LEVEL 2
-
-#ifdef DEBUG_LEVEL
-#define deprintf( level, fmt, args... ) \
-    do \
-{ \
-    if ( (unsigned)(level) <= DEBUG_LEVEL ) \
-    { \
-        fprintf( stdout, fmt, ##args ); \
-        fflush( stdout ); \
-    } \
-} while ( 0 )
-#else
-#define deprintf( level, fmt, args... )
-#endif
-
 /* SDL surface based renderer implementation */
 
 static SDL_Renderer *SDL_PS3_CreateRenderer(SDL_Window * window,
@@ -158,8 +136,8 @@
     }
     SDL_zerop(data);
 
-    renderer->CreateTexture = PS3_CreateTexture;
-    renderer->DestroyTexture = PS3_DestroyTexture;
+    //renderer->CreateTexture = PS3_CreateTexture;
+    //renderer->DestroyTexture = PS3_DestroyTexture;
     renderer->RenderPoint = SDL_PS3_RenderPoint;
     renderer->RenderLine = SDL_PS3_RenderLine;
     renderer->RenderFill = SDL_PS3_RenderFill;
@@ -172,6 +150,9 @@
     renderer->driverdata = data;
     Setup_SoftwareRenderer(renderer);
 
+    deprintf(1, "window->w = %u\n", window->w);
+    deprintf(1, "window->h = %u\n", window->h);
+
     data->double_buffering = 0;
 
     if (flags & SDL_RENDERER_PRESENTFLIP2) {
@@ -341,11 +322,20 @@
         SDL_Rect real_srcrect = *srcrect;
         SDL_Rect real_dstrect = *dstrect;
 
-        /* For testing */
-        int width = 1280;
-        int height = 720;
-        void *pixels = (void *)memalign(16, height * data->screens[0]->pitch);
-        SDL_memset(pixels, 0x42, height * data->screens[0]->pitch);
+        deprintf(1, "surface->w = %u\n", surface->w); // FIXME: surface->w changes to 32
+        deprintf(1, "surface->h = %u\n", surface->h);
+
+        deprintf(1, "srcrect->w = %u\n", srcrect->w);
+        deprintf(1, "srcrect->h = %u\n", srcrect->h);
+        deprintf(1, "dstrect->w = %u\n", dstrect->w);
+        deprintf(1, "dstrect->h = %u\n", dstrect->h);
+
+        deprintf(1, "txdata->bpp = %u\n", txdata->bpp);
+        deprintf(1, "texture->format (bpp) = %u\n", SDL_BYTESPERPIXEL(texture->format));
+
+        /* For testing, align pixels */
+        void *pixels = (void *)memalign(16, dstrect->h * data->screens[0]->pitch);
+        SDL_memcpy(pixels, surface->pixels, dstrect->h * data->screens[0]->pitch);
 
         /* Get screeninfo */
         struct fb_fix_screeninfo fb_finfo;
@@ -364,19 +354,22 @@
             txdata->bpp = fb_vinfo.red.length + fb_vinfo.green.length + fb_vinfo.blue.length;
 
         /* Adjust centering */
-        data->bounded_width = width < fb_vinfo.xres ? width : fb_vinfo.xres;
-        data->bounded_height = height < fb_vinfo.yres ? height : fb_vinfo.yres;
+        data->bounded_width = window->w < fb_vinfo.xres ? window->w : fb_vinfo.xres;
+        data->bounded_height = window->h < fb_vinfo.yres ? window->h : fb_vinfo.yres;
         data->offset_left = (fb_vinfo.xres - data->bounded_width) >> 1;
         data->offset_top = (fb_vinfo.yres - data->bounded_height) >> 1;
-        data->center[0] = devdata->frame_buffer + data->offset_left * txdata->bpp/8 +
+        data->center[0] = devdata->frame_buffer + data->offset_left * /*txdata->bpp/8*/ 4 +
                     data->offset_top * fb_finfo.line_length;
         data->center[1] = data->center[0] + fb_vinfo.yres * fb_finfo.line_length;
 
+        deprintf(1, "offset_left = %u\n", data->offset_left);
+        deprintf(1, "offset_top = %u\n", data->offset_top);
+
         /* Set SPU parms for copying the surface to framebuffer */
         devdata->fb_parms->data = (unsigned char *)pixels;
         devdata->fb_parms->center = data->center[data->current_screen];
         devdata->fb_parms->out_line_stride = fb_finfo.line_length;
-        devdata->fb_parms->in_line_stride = surface->w * txdata->bpp / 8;
+        devdata->fb_parms->in_line_stride = dstrect->w * /*txdata->bpp / 8*/4;
         devdata->fb_parms->bounded_input_height = data->bounded_height;
         devdata->fb_parms->bounded_input_width = data->bounded_width;
         devdata->fb_parms->fb_pixel_size = txdata->bpp / 8;
@@ -390,7 +383,8 @@
         SPE_WaitForMsg(devdata->fb_thread_data, SPU_FIN);
         free(pixels);
 
-        return SDL_LowerBlit(surface, &real_srcrect, target, &real_dstrect);
+        return 0;
+        //return SDL_LowerBlit(surface, &real_srcrect, target, &real_dstrect);
     }
 }