2
/* ---------------------------------------------------------------------
4
* -- Automatically Tuned Linear Algebra Software (ATLAS)
5
* (C) Copyright 2000 All Rights Reserved
7
* -- ATLAS routine -- Version 3.2 -- December 25, 2000
9
* Author : Antoine P. Petitet
10
* Originally developed at the University of Tennessee,
11
* Innovative Computing Laboratory, Knoxville TN, 37996-1301, USA.
13
* ---------------------------------------------------------------------
15
* -- Copyright notice and Licensing terms:
17
* Redistribution and use in source and binary forms, with or without
18
* modification, are permitted provided that the following conditions
21
* 1. Redistributions of source code must retain the above copyright
22
* notice, this list of conditions and the following disclaimer.
23
* 2. Redistributions in binary form must reproduce the above copyright
24
* notice, this list of conditions, and the following disclaimer in
25
* the documentation and/or other materials provided with the distri-
27
* 3. The name of the University, the ATLAS group, or the names of its
28
* contributors may not be used to endorse or promote products deri-
29
* ved from this software without specific written permission.
33
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
34
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
35
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
36
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY
37
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPE-
38
* CIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
39
* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
40
* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEO-
41
* RY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (IN-
42
* CLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
43
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
45
* ---------------------------------------------------------------------
51
#include "atlas_ptmisc.h"
52
#include "atlas_ptlvl3.h"
53
#include "atlas_ptlevel3.h"
55
void Mjoin( PATL, ptl3settype )
57
PT_LVL3_TYPE_T * PLVL3
61
* .. Local Variables ..
63
static TYPE scalars[6] = { ATL_rnone, ATL_rzero,
65
ATL_rone, ATL_rzero };
67
* .. Executable Statements ..
71
PLVL3->size = sizeof( TYPE );
73
PLVL3->size = sizeof( TYPE[2] );
75
PLVL3->negone = (void *)(&(scalars[0]));
76
PLVL3->zero = (void *)(&(scalars[2]));
77
PLVL3->one = (void *)(&(scalars[4]));
79
PLVL3->geadd0 = Mjoin( PATL, ptgeadd0 );
80
PLVL3->gemm0 = Mjoin( PATL, ptgemm0 );
81
PLVL3->symm0 = Mjoin( PATL, ptsymm0 );
83
PLVL3->hemm0 = Mjoin( PATL, ptsymm0 );
85
PLVL3->hemm0 = Mjoin( PATL, pthemm0 );
87
PLVL3->syrk0 = Mjoin( PATL, ptsyrk0 );
88
PLVL3->syr2k0 = Mjoin( PATL, ptsyr2k0 );
90
PLVL3->herk0 = Mjoin( PATL, ptsyrk0 );
91
PLVL3->her2k0 = Mjoin( PATL, ptsyr2k0 );
93
PLVL3->herk0 = Mjoin( PATL, ptherk0 );
94
PLVL3->her2k0 = Mjoin( PATL, pther2k0 );
96
PLVL3->trmm0 = Mjoin( PATL, pttrmm0 );
97
PLVL3->trsm0 = Mjoin( PATL, pttrsm0 );
99
PLVL3->ptgemm = Mjoin( PATL, ptgemm_nt );
100
PLVL3->pttrmm = Mjoin( PATL, pttrmm_nt );
102
PLVL3->ptsyr2k0 = Mjoin( PATL, ptsyr2k0_nt );
103
PLVL3->pther2k0 = Mjoin( PATL, ptsyr2k0_nt );
105
PLVL3->ptsyr2k0 = Mjoin( PATL, ptsyr2k0_nt );
106
PLVL3->pther2k0 = Mjoin( PATL, pther2k0_nt );
110
* End of Mjoin( PATL, ptl3settype )