Mercurial > sdl-ios-xcode
view src/video/ps3/spulibs/spu_common.h @ 5043:da347bfed240
Florian Forster to sdl
in SDL 1.3 (revision 5508 from SVN), the method used to calculate the
bits per pixel from a “int format” differ between “SDL_ListModes” (which
always uses the “SDL_BITSPERPIXEL” macro) and “SDL_PixelFormatEnumTo-
Masks” (which uses either “SDL_BITSPERPIXEL” or “SDL_BYTESPERPIXEL * 8”,
depending on the value of “SDL_BYTESPERPIXEL”).
Because the values are later compared in “SDL_ListModes” this may lead
to some valid video modes not being returned. In my case the only mode
returned by “SDL_GetNumDisplayModes” was dismissed and NULL was
returned. (This led to the calling application sticking its head in the
sand.)
The attached patch copies the method used within “SDL_PixelFormatEnumTo-
Masks” to “SDL_ListModes”. This solved the problem for me though I don't
fully understand the method used by “SDL_PixelFormatEnumToMasks”.
author | Sam Lantinga <slouken@libsdl.org> |
---|---|
date | Wed, 19 Jan 2011 16:06:47 -0800 |
parents | 94fb40a4a9a7 |
children |
line wrap: on
line source
/* * SDL - Simple DirectMedia Layer * CELL BE Support for PS3 Framebuffer * Copyright (C) 2008, 2009 International Business Machines Corporation * * This library is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published * by the Free Software Foundation; either version 2.1 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 * USA * * Martin Lowinski <lowinski [at] de [dot] ibm [ibm] com> * Dirk Herrendoerfer <d.herrendoerfer [at] de [dot] ibm [dot] com> * SPE code based on research by: * Rene Becker * Thimo Emmerich */ /* Common definitions/makros for SPUs */ #ifndef _SPU_COMMON_H #define _SPU_COMMON_H #include <stdio.h> #include <stdint.h> #include <string.h> /* Tag management */ #define DMA_WAIT_TAG(_tag) \ mfc_write_tag_mask(1<<(_tag)); \ mfc_read_tag_status_all(); /* SPU mailbox messages */ #define SPU_READY 0 #define SPU_START 1 #define SPU_FIN 2 #define SPU_EXIT 3 /* Tags */ #define RETR_BUF 0 #define STR_BUF 1 #define TAG_INIT 2 /* Buffersizes */ #define MAX_HDTV_WIDTH 1920 #define MAX_HDTV_HEIGHT 1080 /* One stride of HDTV */ #define BUFFER_SIZE 7680 /* fb_writer ppu/spu exchange parms */ struct fb_writer_parms_t { uint8_t *data; uint8_t *center; uint32_t out_line_stride; uint32_t in_line_stride; uint32_t bounded_input_height; uint32_t bounded_input_width; uint32_t fb_pixel_size; /* This padding is to fulfill the need for 16 byte alignment. On parm change, update! */ char padding[4]; } __attribute__((aligned(128))); /* yuv2rgb ppu/spu exchange parms */ struct yuv2rgb_parms_t { uint8_t* y_plane; uint8_t* v_plane; uint8_t* u_plane; uint8_t* dstBuffer; unsigned int src_pixel_width; unsigned int src_pixel_height; /* This padding is to fulfill the need for 16 byte alignment. On parm change, update! */ char padding[128 - ((4 * sizeof(uint8_t *) + 2 * sizeof(unsigned int)) & 0x7F)]; } __attribute__((aligned(128))); /* bilin_scaler ppu/spu exchange parms */ struct scale_parms_t { uint8_t* y_plane; uint8_t* v_plane; uint8_t* u_plane; uint8_t* dstBuffer; unsigned int src_pixel_width; unsigned int src_pixel_height; unsigned int dst_pixel_width; unsigned int dst_pixel_height; /* This padding is to fulfill the need for 16 byte alignment. On parm change, update! */ char padding[128 - ((4 * sizeof(uint8_t *) + 4 * sizeof(unsigned int)) & 0x7F)]; } __attribute__((aligned(128))); #endif /* _SPU_COMMON_H */