00001 /*************************************************************************** 00002 * Copyright (C) 2005-2007 Stefan Schwarzer, Jens Schneider, * 00003 * Matthias Hardt, Guido Madaus * 00004 * * 00005 * Copyright (C) 2007-2008 BerLinux Solutions GbR * 00006 * Stefan Schwarzer & Guido Madaus * 00007 * * 00008 * Copyright (C) 2009-2013 BerLinux Solutions GmbH * 00009 * * 00010 * Authors: * 00011 * Stefan Schwarzer <stefan.schwarzer@diskohq.org>, * 00012 * Matthias Hardt <matthias.hardt@diskohq.org>, * 00013 * Jens Schneider <jens.schneider@diskohq.org>, * 00014 * Guido Madaus <guido.madaus@diskohq.org>, * 00015 * Patrick Helterhoff <patrick.helterhoff@diskohq.org>, * 00016 * René Bählkow <rene.baehlkow@diskohq.org> * 00017 * * 00018 * This library is free software; you can redistribute it and/or * 00019 * modify it under the terms of the GNU Lesser General Public * 00020 * License version 2.1 as published by the Free Software Foundation. * 00021 * * 00022 * This library is distributed in the hope that it will be useful, * 00023 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00024 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00025 * Lesser General Public License for more details. * 00026 * * 00027 * You should have received a copy of the GNU Lesser General Public * 00028 * License along with this library; if not, write to the * 00029 * Free Software Foundation, Inc., * 00030 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * 00031 **************************************************************************/ 00032 00033 #include "mmsgui/fb/mmsfbconv.h" 00034 00035 #ifdef __HAVE_PF_RGB32__ 00036 00037 #include "mmstools/mmstools.h" 00038 00039 void mmsfb_fillrectangle_rgb32(MMSFBSurfacePlanes *dst_planes, int dst_height, 00040 int dx, int dy, int dw, int dh, MMSFBColor color) { 00041 // first time? 00042 static bool firsttime = true; 00043 if (firsttime) { 00044 printf("DISKO: Using accelerated fill rectangle to RGB32.\n"); 00045 firsttime = false; 00046 } 00047 00048 // get the first destination ptr/pitch 00049 unsigned int *dst = (unsigned int *)dst_planes->ptr; 00050 int dst_pitch = dst_planes->pitch; 00051 00052 // prepare... 00053 int dst_pitch_pix = dst_pitch >> 2; 00054 dst+= dx + dy * dst_pitch_pix; 00055 00056 unsigned int *dst_end = dst + dst_pitch_pix * dh; 00057 #ifndef __HAVE_SSE__ 00058 int dst_pitch_diff = dst_pitch_pix - dw; 00059 #endif 00060 00061 // prepare the color 00062 register unsigned int SRC; 00063 SRC = 0xff000000 00064 | (color.r << 16) 00065 | (color.g << 8) 00066 | color.b; 00067 00068 // copy pixel directly to the destination 00069 // for all lines 00070 while (dst < dst_end) { 00071 // for all pixels in the line 00072 #ifdef __HAVE_SSE__ 00073 // fill memory 4-byte-wise (much faster than loop see below) 00074 // __asm__ __volatile__ ( "\trep stosl\n" : : "D" (dst), "a" (SRC), "c" (dw)); 00075 short d0, d1, d2; 00076 __asm__ __volatile__ ( "\tcld\n\trep stosl" \ 00077 : "=&D" (d0), "=&a" (d1), "=&c" (d2) \ 00078 : "0" (dst), "1" (SRC), "2" (dw) \ 00079 : "memory", "cc"); 00080 00081 // go to the next line 00082 dst+= dst_pitch_pix; 00083 #else 00084 unsigned int *line_end = dst + dw; 00085 while (dst < line_end) { 00086 *dst = SRC; 00087 dst++; 00088 } 00089 00090 // go to the next line 00091 dst+= dst_pitch_diff; 00092 #endif 00093 } 00094 } 00095 00096 #endif