135c4bbdfSmrg/* 235c4bbdfSmrg * Copyright © 2013 Geert Uytterhoeven 335c4bbdfSmrg * 435c4bbdfSmrg * Permission is hereby granted, free of charge, to any person obtaining a 535c4bbdfSmrg * copy of this software and associated documentation files (the "Software"), 635c4bbdfSmrg * to deal in the Software without restriction, including without limitation 735c4bbdfSmrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 835c4bbdfSmrg * and/or sell copies of the Software, and to permit persons to whom the 935c4bbdfSmrg * Software is furnished to do so, subject to the following conditions: 1035c4bbdfSmrg * 1135c4bbdfSmrg * The above copyright notice and this permission notice (including the next 1235c4bbdfSmrg * paragraph) shall be included in all copies or substantial portions of the 1335c4bbdfSmrg * Software. 1435c4bbdfSmrg * 1535c4bbdfSmrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1635c4bbdfSmrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 1735c4bbdfSmrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 1835c4bbdfSmrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 1935c4bbdfSmrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 2035c4bbdfSmrg * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 2135c4bbdfSmrg * DEALINGS IN THE SOFTWARE. 2235c4bbdfSmrg * 2335c4bbdfSmrg * Based on shpacked.c, which is Copyright © 2000 Keith Packard 2435c4bbdfSmrg */ 2535c4bbdfSmrg 2635c4bbdfSmrg#ifdef HAVE_DIX_CONFIG_H 2735c4bbdfSmrg#include <dix-config.h> 2835c4bbdfSmrg#endif 2935c4bbdfSmrg 3035c4bbdfSmrg#include <stdlib.h> 3135c4bbdfSmrg 3235c4bbdfSmrg#include <X11/X.h> 3335c4bbdfSmrg#include "scrnintstr.h" 3435c4bbdfSmrg#include "windowstr.h" 3535c4bbdfSmrg#include <X11/fonts/font.h> 3635c4bbdfSmrg#include "dixfontstr.h" 3735c4bbdfSmrg#include <X11/fonts/fontstruct.h> 3835c4bbdfSmrg#include "mi.h" 3935c4bbdfSmrg#include "regionstr.h" 4035c4bbdfSmrg#include "globals.h" 4135c4bbdfSmrg#include "gcstruct.h" 4235c4bbdfSmrg#include "shadow.h" 4335c4bbdfSmrg#include "fb.h" 4435c4bbdfSmrg#include "c2p_core.h" 4535c4bbdfSmrg 4635c4bbdfSmrg 4735c4bbdfSmrg /* 4835c4bbdfSmrg * Perform a full C2P step on 16 4-bit pixels, stored in 2 32-bit words 4935c4bbdfSmrg * containing 5035c4bbdfSmrg * - 16 4-bit chunky pixels on input 5135c4bbdfSmrg * - permutated planar data (2 planes per 32-bit word) on output 5235c4bbdfSmrg */ 5335c4bbdfSmrg 5435c4bbdfSmrgstatic void c2p_16x4(CARD32 d[2]) 5535c4bbdfSmrg{ 5635c4bbdfSmrg transp2(d, 8); 5735c4bbdfSmrg transp2(d, 2); 5835c4bbdfSmrg transp2x(d, 1); 5935c4bbdfSmrg transp2(d, 16); 6035c4bbdfSmrg transp2(d, 4); 6135c4bbdfSmrg transp2(d, 1); 6235c4bbdfSmrg} 6335c4bbdfSmrg 6435c4bbdfSmrg 6535c4bbdfSmrg /* 6635c4bbdfSmrg * Store a full block of iplan2p4 data after c2p conversion 6735c4bbdfSmrg */ 6835c4bbdfSmrg 6935c4bbdfSmrgstatic inline void store_iplan2p4(void *dst, const CARD32 d[2]) 7035c4bbdfSmrg{ 7135c4bbdfSmrg CARD32 *p = dst; 7235c4bbdfSmrg 7335c4bbdfSmrg *p++ = d[0]; 7435c4bbdfSmrg *p++ = d[1]; 7535c4bbdfSmrg} 7635c4bbdfSmrg 7735c4bbdfSmrg 7835c4bbdfSmrgvoid 7935c4bbdfSmrgshadowUpdateIplan2p4(ScreenPtr pScreen, shadowBufPtr pBuf) 8035c4bbdfSmrg{ 811b5d61b8Smrg RegionPtr damage = DamageRegion(pBuf->pDamage); 8235c4bbdfSmrg PixmapPtr pShadow = pBuf->pPixmap; 8335c4bbdfSmrg int nbox = RegionNumRects(damage); 8435c4bbdfSmrg BoxPtr pbox = RegionRects(damage); 8535c4bbdfSmrg FbBits *shaBase; 8635c4bbdfSmrg CARD16 *shaLine, *sha; 8735c4bbdfSmrg FbStride shaStride; 8835c4bbdfSmrg int scrLine; 8935c4bbdfSmrg _X_UNUSED int shaBpp, shaXoff, shaYoff; 9035c4bbdfSmrg int x, y, w, h; 9135c4bbdfSmrg int i, n; 9235c4bbdfSmrg CARD16 *win; 9335c4bbdfSmrg _X_UNUSED CARD32 winSize; 9435c4bbdfSmrg union { 9535c4bbdfSmrg CARD8 bytes[8]; 9635c4bbdfSmrg CARD32 words[2]; 9735c4bbdfSmrg } d; 9835c4bbdfSmrg 9935c4bbdfSmrg fbGetDrawable(&pShadow->drawable, shaBase, shaStride, shaBpp, shaXoff, 10035c4bbdfSmrg shaYoff); 10135c4bbdfSmrg shaStride *= sizeof(FbBits) / sizeof(CARD16); 10235c4bbdfSmrg 10335c4bbdfSmrg while (nbox--) { 10435c4bbdfSmrg x = pbox->x1; 10535c4bbdfSmrg y = pbox->y1; 10635c4bbdfSmrg w = pbox->x2 - pbox->x1; 10735c4bbdfSmrg h = pbox->y2 - pbox->y1; 10835c4bbdfSmrg 10935c4bbdfSmrg scrLine = (x & -16) / 2; 11035c4bbdfSmrg shaLine = (CARD16 *)shaBase + y * shaStride + scrLine / sizeof(CARD16); 11135c4bbdfSmrg 11235c4bbdfSmrg n = ((x & 15) + w + 15) / 16; /* number of c2p units in scanline */ 11335c4bbdfSmrg 11435c4bbdfSmrg while (h--) { 11535c4bbdfSmrg sha = shaLine; 11635c4bbdfSmrg win = (CARD16 *) (*pBuf->window) (pScreen, 11735c4bbdfSmrg y, 11835c4bbdfSmrg scrLine, 11935c4bbdfSmrg SHADOW_WINDOW_WRITE, 12035c4bbdfSmrg &winSize, 12135c4bbdfSmrg pBuf->closure); 12235c4bbdfSmrg if (!win) 12335c4bbdfSmrg return; 12435c4bbdfSmrg for (i = 0; i < n; i++) { 12535c4bbdfSmrg memcpy(d.bytes, sha, sizeof(d.bytes)); 12635c4bbdfSmrg c2p_16x4(d.words); 12735c4bbdfSmrg store_iplan2p4(win, d.words); 12835c4bbdfSmrg sha += sizeof(d.bytes) / sizeof(*sha); 12935c4bbdfSmrg win += sizeof(d.bytes) / sizeof(*win); 13035c4bbdfSmrg } 13135c4bbdfSmrg shaLine += shaStride; 13235c4bbdfSmrg y++; 13335c4bbdfSmrg } 13435c4bbdfSmrg pbox++; 13535c4bbdfSmrg } 13635c4bbdfSmrg} 137