Mercurial > hg > sv-dependency-builds
annotate src/fftw-3.3.8/simd-support/taint.c @ 167:bd3cc4d1df30
Add FFTW 3.3.8 source, and a Linux build
author | Chris Cannam <cannam@all-day-breakfast.com> |
---|---|
date | Tue, 19 Nov 2019 14:52:55 +0000 |
parents | |
children |
rev | line source |
---|---|
cannam@167 | 1 /* |
cannam@167 | 2 * Copyright (c) 2003, 2007-14 Matteo Frigo |
cannam@167 | 3 * Copyright (c) 2003, 2007-14 Massachusetts Institute of Technology |
cannam@167 | 4 * |
cannam@167 | 5 * This program is free software; you can redistribute it and/or modify |
cannam@167 | 6 * it under the terms of the GNU General Public License as published by |
cannam@167 | 7 * the Free Software Foundation; either version 2 of the License, or |
cannam@167 | 8 * (at your option) any later version. |
cannam@167 | 9 * |
cannam@167 | 10 * This program is distributed in the hope that it will be useful, |
cannam@167 | 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
cannam@167 | 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
cannam@167 | 13 * GNU General Public License for more details. |
cannam@167 | 14 * |
cannam@167 | 15 * You should have received a copy of the GNU General Public License |
cannam@167 | 16 * along with this program; if not, write to the Free Software |
cannam@167 | 17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
cannam@167 | 18 * |
cannam@167 | 19 */ |
cannam@167 | 20 |
cannam@167 | 21 |
cannam@167 | 22 #include "kernel/ifftw.h" |
cannam@167 | 23 #include "simd-common.h" |
cannam@167 | 24 |
cannam@167 | 25 #if HAVE_SIMD |
cannam@167 | 26 |
cannam@167 | 27 R *X(taint)(R *p, INT s) |
cannam@167 | 28 { |
cannam@167 | 29 if (((unsigned)s * sizeof(R)) % ALIGNMENT) |
cannam@167 | 30 p = (R *) (PTRINT(p) | TAINT_BIT); |
cannam@167 | 31 if (((unsigned)s * sizeof(R)) % ALIGNMENTA) |
cannam@167 | 32 p = (R *) (PTRINT(p) | TAINT_BITA); |
cannam@167 | 33 return p; |
cannam@167 | 34 } |
cannam@167 | 35 |
cannam@167 | 36 /* join the taint of two pointers that are supposed to be |
cannam@167 | 37 the same modulo the taint */ |
cannam@167 | 38 R *X(join_taint)(R *p1, R *p2) |
cannam@167 | 39 { |
cannam@167 | 40 A(UNTAINT(p1) == UNTAINT(p2)); |
cannam@167 | 41 return (R *)(PTRINT(p1) | PTRINT(p2)); |
cannam@167 | 42 } |
cannam@167 | 43 #endif |