/src/fftw3/kernel/solver.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* |
2 | | * Copyright (c) 2003, 2007-14 Matteo Frigo |
3 | | * Copyright (c) 2003, 2007-14 Massachusetts Institute of Technology |
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
18 | | * |
19 | | */ |
20 | | |
21 | | |
22 | | #include "kernel/ifftw.h" |
23 | | |
24 | | solver *X(mksolver)(size_t size, const solver_adt *adt) |
25 | 613 | { |
26 | 613 | solver *s = (solver *)MALLOC(size, SOLVERS); |
27 | | |
28 | 613 | s->adt = adt; |
29 | 613 | s->refcnt = 0; |
30 | 613 | return s; |
31 | 613 | } |
32 | | |
33 | | void X(solver_use)(solver *ego) |
34 | 613 | { |
35 | 613 | ++ego->refcnt; |
36 | 613 | } |
37 | | |
38 | | void X(solver_destroy)(solver *ego) |
39 | 0 | { |
40 | 0 | if ((--ego->refcnt) == 0) { |
41 | 0 | if (ego->adt->destroy) |
42 | 0 | ego->adt->destroy(ego); |
43 | 0 | X(ifree)(ego); |
44 | 0 | } |
45 | 0 | } |
46 | | |
47 | | void X(solver_register)(planner *plnr, solver *s) |
48 | 613 | { |
49 | 613 | plnr->adt->register_solver(plnr, s); |
50 | 613 | } |