2013-08-07 12:39:56 -04:00
/ * - * - l i n u x - c - * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - *
*
* Copyright 2002 H . Peter Anvin - All Rights Reserved
* Copyright 2012 Tilera Corporation - All Rights Reserved
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , Inc . , 53 Temple Place Ste 330 ,
* Boston MA 02111 - 1307 , USA ; either version 2 of the License , or
* ( at your option ) any later version ; incorporated herein by reference .
*
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - * /
/ *
* tilegx$ # . c
*
* $ # - way unrolled TILE - Gx SIMD for RAID - 6 math .
*
* This file is postprocessed using unroll . awk .
*
* /
# include < linux / raid / pq . h >
/* Create 8 byte copies of constant byte */
# define NBYTES ( x ) ( _ _insn _v1addi ( 0 , x ) )
# define NSIZE 8
/ *
* The SHLBYTE ( ) operation shifts each byte left by 1 , * not *
* rolling over into the next byte
* /
static inline _ _attribute _const _ _ u64 SHLBYTE ( u64 v )
{
/* Vector One Byte Shift Left Immediate. */
return _ _insn _v1shli ( v , 1 ) ;
}
/ *
* The MASK ( ) operation returns 0xFF in any byte for which the high
* bit is 1 , 0x00 for any byte for which the high bit is 0.
* /
static inline _ _attribute _const _ _ u64 MASK ( u64 v )
{
/* Vector One Byte Shift Right Signed Immediate. */
return _ _insn _v1shrsi ( v , 7 ) ;
}
void raid6 _tilegx$ # _gen _syndrome ( int disks , size _t bytes , void * * ptrs )
{
u8 * * dptr = ( u8 * * ) ptrs ;
u64 * p , * q ;
int d , z , z0 ;
u64 wd$$ , wq$$ , wp$$ , w1$$ , w2$$ ;
u64 x1d = NBYTES ( 0x1d ) ;
u64 * z0ptr ;
z0 = disks - 3 ; /* Highest data disk */
p = ( u64 * ) dptr [ z0 + 1 ] ; /* XOR parity */
q = ( u64 * ) dptr [ z0 + 2 ] ; /* RS syndrome */
z0ptr = ( u64 * ) & dptr [ z0 ] [ 0 ] ;
for ( d = 0 ; d < bytes ; d += NSIZE * $ # ) {
wq$$ = wp$$ = * z0ptr ++ ;
for ( z = z0 - 1 ; z >= 0 ; z -- ) {
wd$$ = * ( u64 * ) & dptr [ z ] [ d + $$ * NSIZE ] ;
wp$$ = wp$$ ^ wd$$ ;
w2$$ = MASK ( wq$$ ) ;
w1$$ = SHLBYTE ( wq$$ ) ;
w2$$ = w2$$ & x1d ;
w1$$ = w1$$ ^ w2$$ ;
wq$$ = w1$$ ^ wd$$ ;
}
* p ++ = wp$$ ;
* q ++ = wq$$ ;
}
}
const struct raid6 _calls raid6 _tilegx$ # = {
raid6 _tilegx$ # _gen _syndrome ,
2014-12-15 12:57:04 +11:00
NULL , /* XOR not yet implemented */
2013-08-07 12:39:56 -04:00
NULL ,
"tilegx$#" ,
0
} ;