f873b20530
2010-04-22 Laurynas Biveinis <laurynas.biveinis@gmail.com> * tree-parloops.c (loop_parallel_p): New argument parloop_obstack. Pass it down. (parallelize_loops): New variable parloop_obstack. Initialize it, pass it down, free it. * tree-loop-linear.c (linear_transform_loops): Pass down lambda_obstack. * tree-data-ref.h (lambda_compute_access_matrices): New argument of type struct obstack *. * tree-data-ref.c (analyze_subscript_affine_affine): New variable scratch_obstack. Initialize it, pass down, free it. * lambda.h (lambda_loop_new): Remove. (lambda_matrix_new, lambda_matrix_inverse) (lambda_trans_matrix_new, lambda_trans_matrix_inverse): New argument of type struct obstack *. * lambda-trans.c (lambda_trans_matrix_new): New argument lambda_obstack. Pass it down, use obstack allocation for ret. (lambda_trans_matrix_inverse): New argument lambda_obstack. Pass it down. * lambda-mat.c (lambda_matrix_get_column) (lambda_matrix_project_to_null): Remove. (lambda_matrix_new): New argument lambda_obstack. Use obstack allocation for mat. (lambda_matrix_inverse_hard, lambda_matrix_inverse): New argument lambda_obstack. * lambda-code.c (lambda_loop_new): New function. (lambda_lattice_new, compute_nest_using_fourier_motzkin) (lambda_compute_auxillary_space, lambda_compute_target_space) (lambda_loopnest_transform, gcc_loop_to_lambda_loop) (lambda_loopnest_to_gcc_loopnest): Pass down lambda_obstack. (build_access_matrix): New argument lambda_obstack. Use obstack allocation for am. (lambda_compute_step_signs, lambda_compute_access_matrices): New argument lambda_obstack. Pass it down. From-SVN: r158644
85 lines
2.4 KiB
C
85 lines
2.4 KiB
C
/* Lambda matrix transformations.
|
|
Copyright (C) 2003, 2004, 2007, 2008 Free Software Foundation, Inc.
|
|
Contributed by Daniel Berlin <dberlin@dberlin.org>.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC 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; either version 3, or (at your option) any later
|
|
version.
|
|
|
|
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GCC; see the file COPYING3. If not see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#include "config.h"
|
|
#include "system.h"
|
|
#include "coretypes.h"
|
|
#include "tm.h"
|
|
#include "ggc.h"
|
|
#include "tree.h"
|
|
#include "target.h"
|
|
#include "tree-flow.h"
|
|
#include "lambda.h"
|
|
|
|
/* Allocate a new transformation matrix. */
|
|
|
|
lambda_trans_matrix
|
|
lambda_trans_matrix_new (int colsize, int rowsize,
|
|
struct obstack * lambda_obstack)
|
|
{
|
|
lambda_trans_matrix ret;
|
|
|
|
ret = (lambda_trans_matrix)
|
|
obstack_alloc (lambda_obstack, sizeof (struct lambda_trans_matrix_s));
|
|
LTM_MATRIX (ret) = lambda_matrix_new (rowsize, colsize, lambda_obstack);
|
|
LTM_ROWSIZE (ret) = rowsize;
|
|
LTM_COLSIZE (ret) = colsize;
|
|
LTM_DENOMINATOR (ret) = 1;
|
|
return ret;
|
|
}
|
|
|
|
/* Return true if MAT is an identity matrix. */
|
|
|
|
bool
|
|
lambda_trans_matrix_id_p (lambda_trans_matrix mat)
|
|
{
|
|
if (LTM_ROWSIZE (mat) != LTM_COLSIZE (mat))
|
|
return false;
|
|
return lambda_matrix_id_p (LTM_MATRIX (mat), LTM_ROWSIZE (mat));
|
|
}
|
|
|
|
|
|
/* Compute the inverse of the transformation matrix MAT. */
|
|
|
|
lambda_trans_matrix
|
|
lambda_trans_matrix_inverse (lambda_trans_matrix mat,
|
|
struct obstack * lambda_obstack)
|
|
{
|
|
lambda_trans_matrix inverse;
|
|
int determinant;
|
|
|
|
inverse = lambda_trans_matrix_new (LTM_ROWSIZE (mat), LTM_COLSIZE (mat),
|
|
lambda_obstack);
|
|
determinant = lambda_matrix_inverse (LTM_MATRIX (mat), LTM_MATRIX (inverse),
|
|
LTM_ROWSIZE (mat), lambda_obstack);
|
|
LTM_DENOMINATOR (inverse) = determinant;
|
|
return inverse;
|
|
}
|
|
|
|
|
|
/* Print out a transformation matrix. */
|
|
|
|
void
|
|
print_lambda_trans_matrix (FILE *outfile, lambda_trans_matrix mat)
|
|
{
|
|
print_lambda_matrix (outfile, LTM_MATRIX (mat), LTM_ROWSIZE (mat),
|
|
LTM_COLSIZE (mat));
|
|
}
|