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