PageRenderTime 50ms CodeModel.GetById 30ms app.highlight 11ms RepoModel.GetById 6ms app.codeStats 0ms

/modules/softcam/FFdecsa/parallel_generic.h

https://bitbucket.org/cesbo/astra
C Header | 102 lines | 77 code | 6 blank | 19 comment | 2 complexity | efeb269111f9cea397570a76dfc3148b MD5 | raw file
Possible License(s): GPL-3.0, GPL-2.0
  1/* FFdecsa -- fast decsa algorithm
  2 *
  3 * Copyright (C) 2003-2004  fatih89r
  4 *
  5 * This program is free software; you can redistribute it and/or modify
  6 * it under the terms of the GNU General Public License as published by
  7 * the Free Software Foundation; either version 2 of the License, or
  8 * (at your option) any later version.
  9 *
 10 * This program is distributed in the hope that it will be useful,
 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 13 * GNU General Public License for more details.
 14 *
 15 * You should have received a copy of the GNU General Public License
 16 * along with this program; if not, write to the Free Software
 17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 18 */
 19
 20
 21
 22#if 0
 23//// generics
 24#define COPY4BY(d,s)     do{ int *pd=(int *)(d), *ps=(int *)(s); \
 25                             *pd = *ps; }while(0)
 26#define COPY8BY(d,s)     do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 27                             *pd = *ps; }while(0)
 28#define COPY16BY(d,s)    do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 29                             *pd = *ps; \
 30			     *(pd+1) = *(ps+1); }while(0)
 31#define COPY32BY(d,s)    do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 32                             *pd = *ps; \
 33			     *(pd+1) = *(ps+1) \
 34			     *(pd+2) = *(ps+2) \
 35			     *(pd+3) = *(ps+3); }while(0)
 36#define XOR4BY(d,s1,s2)  do{ int *pd=(int *)(d), *ps1=(int *)(s1), *ps2=(int *)(s2); \
 37                             *pd = *ps1  ^ *ps2; }while(0)
 38#define XOR8BY(d,s1,s2)  do{ long long int *pd=(long long int *)(d), *ps1=(long long int *)(s1), *ps2=(long long int *)(s2); \
 39                             *pd = *ps1  ^ *ps2; }while(0)
 40#define XOR16BY(d,s1,s2) do{ long long int *pd=(long long int *)(d), *ps1=(long long int *)(s1), *ps2=(long long int *)(s2); \
 41                             *pd = *ps1  ^ *ps2; \
 42                             *(pd+8) = *(ps1+8)  ^ *(ps2+8); }while(0)
 43#define XOR32BY(d,s1,s2) do{ long long int *pd=(long long int *)(d), *ps1=(long long int *)(s1), *ps2=(long long int *)(s2); \
 44                             *pd = *ps1  ^ *ps2; \
 45                             *(pd+1) = *(ps1+1)  ^ *(ps2+1); \
 46                             *(pd+2) = *(ps1+2)  ^ *(ps2+2); \
 47                             *(pd+3) = *(ps1+3)  ^ *(ps2+3); }while(0)
 48#define XOR32BV(d,s1,s2) do{ int *const pd=(int *const)(d), *ps1=(const int *const)(s1), *ps2=(const int *const)(s2); \
 49                             int z; \
 50			     for(z=0;z<8;z++){ \
 51                               pd[z]=ps1[z]^ps2[z]; \
 52			     } \
 53                           }while(0)
 54#define XOREQ4BY(d,s)    do{ int *pd=(int *)(d), *ps=(int *)(s); \
 55                             *pd ^= *ps; }while(0)
 56#define XOREQ8BY(d,s)    do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 57                             *pd ^= *ps; }while(0)
 58#define XOREQ16BY(d,s)   do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 59                             *pd ^= *ps; \
 60			     *(pd+1) ^=*(ps+1); }while(0)
 61#define XOREQ32BY(d,s)   do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 62                             *pd ^= *ps; \
 63			     *(pd+1) ^=*(ps+1); \
 64			     *(pd+2) ^=*(ps+2); \
 65			     *(pd+3) ^=*(ps+3); }while(0)
 66#define XOREQ32BY4(d,s)  do{ int *pd=(int *)(d), *ps=(int *)(s); \
 67                             *pd ^= *ps; \
 68			     *(pd+1) ^=*(ps+1); \
 69			     *(pd+2) ^=*(ps+2); \
 70			     *(pd+3) ^=*(ps+3); \
 71			     *(pd+4) ^=*(ps+4); \
 72			     *(pd+5) ^=*(ps+5); \
 73			     *(pd+6) ^=*(ps+6); \
 74			     *(pd+7) ^=*(ps+7); }while(0)
 75#define XOREQ32BV(d,s)   do{ unsigned char *pd=(unsigned char *)(d), *ps=(unsigned char *)(s); \
 76                             int z; \
 77			     for(z=0;z<32;z++){ \
 78                               pd[z]^=ps[z]; \
 79			     } \
 80                           }while(0)
 81
 82#else
 83#define XOR_4_BY(d,s1,s2)    do{ int *pd=(int *)(d), *ps1=(int *)(s1), *ps2=(int *)(s2); \
 84                               *pd = *ps1  ^ *ps2; }while(0)
 85#define XOR_8_BY(d,s1,s2)    do{ long long int *pd=(long long int *)(d), *ps1=(long long int *)(s1), *ps2=(long long int *)(s2); \
 86                               *pd = *ps1  ^ *ps2; }while(0)
 87#define XOREQ_4_BY(d,s)      do{ int *pd=(int *)(d), *ps=(int *)(s); \
 88                               *pd ^= *ps; }while(0)
 89#define XOREQ_8_BY(d,s)      do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 90                               *pd ^= *ps; }while(0)
 91#define COPY_4_BY(d,s)       do{ int *pd=(int *)(d), *ps=(int *)(s); \
 92                               *pd = *ps; }while(0)
 93#define COPY_8_BY(d,s)       do{ long long int *pd=(long long int *)(d), *ps=(long long int *)(s); \
 94                               *pd = *ps; }while(0)
 95
 96#define BEST_SPAN            8
 97#define XOR_BEST_BY(d,s1,s2) do{ XOR_8_BY(d,s1,s2); }while(0);
 98#define XOREQ_BEST_BY(d,s)   do{ XOREQ_8_BY(d,s); }while(0);
 99#define COPY_BEST_BY(d,s)    do{ COPY_8_BY(d,s); }while(0);
100
101#define END_MM             do{ }while(0);
102#endif