191 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			191 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
| /*********************************************************************/
 | |
| /* Copyright 2009, 2010 The University of Texas at Austin.           */
 | |
| /* All rights reserved.                                              */
 | |
| /*                                                                   */
 | |
| /* Redistribution and use in source and binary forms, with or        */
 | |
| /* without modification, are permitted provided that the following   */
 | |
| /* conditions are met:                                               */
 | |
| /*                                                                   */
 | |
| /*   1. Redistributions of source code must retain the above         */
 | |
| /*      copyright notice, this list of conditions and the following  */
 | |
| /*      disclaimer.                                                  */
 | |
| /*                                                                   */
 | |
| /*   2. Redistributions in binary form must reproduce the above      */
 | |
| /*      copyright notice, this list of conditions and the following  */
 | |
| /*      disclaimer in the documentation and/or other materials       */
 | |
| /*      provided with the distribution.                              */
 | |
| /*                                                                   */
 | |
| /*    THIS  SOFTWARE IS PROVIDED  BY THE  UNIVERSITY OF  TEXAS AT    */
 | |
| /*    AUSTIN  ``AS IS''  AND ANY  EXPRESS OR  IMPLIED WARRANTIES,    */
 | |
| /*    INCLUDING, BUT  NOT LIMITED  TO, THE IMPLIED  WARRANTIES OF    */
 | |
| /*    MERCHANTABILITY  AND FITNESS FOR  A PARTICULAR  PURPOSE ARE    */
 | |
| /*    DISCLAIMED.  IN  NO EVENT SHALL THE UNIVERSITY  OF TEXAS AT    */
 | |
| /*    AUSTIN OR CONTRIBUTORS BE  LIABLE FOR ANY DIRECT, INDIRECT,    */
 | |
| /*    INCIDENTAL,  SPECIAL, EXEMPLARY,  OR  CONSEQUENTIAL DAMAGES    */
 | |
| /*    (INCLUDING, BUT  NOT LIMITED TO,  PROCUREMENT OF SUBSTITUTE    */
 | |
| /*    GOODS  OR  SERVICES; LOSS  OF  USE,  DATA,  OR PROFITS;  OR    */
 | |
| /*    BUSINESS INTERRUPTION) HOWEVER CAUSED  AND ON ANY THEORY OF    */
 | |
| /*    LIABILITY, WHETHER  IN CONTRACT, STRICT  LIABILITY, OR TORT    */
 | |
| /*    (INCLUDING NEGLIGENCE OR OTHERWISE)  ARISING IN ANY WAY OUT    */
 | |
| /*    OF  THE  USE OF  THIS  SOFTWARE,  EVEN  IF ADVISED  OF  THE    */
 | |
| /*    POSSIBILITY OF SUCH DAMAGE.                                    */
 | |
| /*                                                                   */
 | |
| /* The views and conclusions contained in the software and           */
 | |
| /* documentation are those of the authors and should not be          */
 | |
| /* interpreted as representing official policies, either expressed   */
 | |
| /* or implied, of The University of Texas at Austin.                 */
 | |
| /*********************************************************************/
 | |
| 
 | |
| #ifndef COMMON_ALPHA
 | |
| #define COMMON_ALPHA
 | |
| 
 | |
| #ifndef ASSEMBLER
 | |
| 
 | |
| #define MB  asm("mb")
 | |
| #define WMB asm("wmb")
 | |
| #define RMB asm("mb")
 | |
| 
 | |
| static __inline void blas_lock(unsigned long *address){
 | |
| #ifndef __DECC
 | |
|   unsigned long tmp1, tmp2;
 | |
|   asm volatile(
 | |
|     "1: ldq	%1,  %0\n"
 | |
|     "	bne	%1,  2f\n"
 | |
|     "	ldq_l	%1,  %0\n"
 | |
|     "	bne	%1,  2f\n"
 | |
|     "	or	%1,  1, %2\n"
 | |
|     "	stq_c	%2,  %0\n"
 | |
|     "	beq	%2,  2f\n"
 | |
|     "	mb\n              "
 | |
|     "	br      $31, 3f\n"
 | |
|     "2: br      $31, 1b\n"
 | |
|     "3:\n" : "=m"(*address), "=&r"(tmp1), "=&r"(tmp2) : :  "memory");
 | |
| #else
 | |
|   asm (
 | |
|     "10:"
 | |
|     "   ldq	%t0,  0(%a0); "
 | |
|     "	bne	%t0, 20f;     "
 | |
|     "	ldq_l	%t0,  0(%a0); "
 | |
|     "	bne	%t0, 20f;     "
 | |
|     "	or	%t0, 1, %t1;"
 | |
|     "	stq_c	%t1,  0(%a0); "
 | |
|     "	beq	%t1, 20f;     "
 | |
|     "	mb;                   "
 | |
|     "	br      %r31,30f;     "
 | |
|     "20:                      "
 | |
|     "	br      %r31,10b;     "
 | |
|     "30:", address);
 | |
| #endif
 | |
| }
 | |
| #define BLAS_LOCK_DEFINED
 | |
| 
 | |
| static __inline unsigned int rpcc(void){
 | |
| 
 | |
|   unsigned int r0;
 | |
| 
 | |
| #ifndef __DECC
 | |
|   asm __volatile__("rpcc %0" : "=r"(r0)  : : "memory");
 | |
| #else
 | |
|   r0 = asm("rpcc %v0");
 | |
| #endif
 | |
| 
 | |
|   return r0;
 | |
| }
 | |
| #define RPCC_DEFINED
 | |
| 
 | |
| 
 | |
| #define HALT 	ldq	$0, 0($0)
 | |
| 
 | |
| #ifndef __DECC
 | |
| #define GET_IMAGE(res)  asm __volatile__("fmov $f1, %0" : "=f"(res)  : : "memory")
 | |
| #else
 | |
| #define GET_IMAGE(res) res = dasm("fmov $f1, %f0")
 | |
| #endif
 | |
| 
 | |
| #ifdef SMP
 | |
| #ifdef USE64BITINT
 | |
| static __inline long blas_quickdivide(long x, long y){
 | |
|   return x/y;
 | |
| }
 | |
| #else
 | |
| extern unsigned int blas_quick_divide_table[];
 | |
| 
 | |
| static __inline int blas_quickdivide(unsigned int x, unsigned int y){
 | |
|   if (y <= 1) return x;
 | |
|   return (int)((x * (unsigned long)blas_quick_divide_table[y]) >> 32);
 | |
| }
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| #define BASE_ADDRESS ((0x1b0UL << 33) | (0x1c0UL << 23) | (0x000UL << 13))
 | |
| 
 | |
| #ifndef PAGESIZE
 | |
| #define PAGESIZE	( 8UL << 10)
 | |
| #define HUGE_PAGESIZE	( 4 << 20)
 | |
| #endif
 | |
| #define BUFFER_SIZE	(32UL << 20)
 | |
| 
 | |
| #else
 | |
| 
 | |
| #ifndef F_INTERFACE
 | |
| #define REALNAME ASMNAME
 | |
| #else
 | |
| #define REALNAME ASMFNAME
 | |
| #endif
 | |
| 
 | |
| #define PROLOGUE \
 | |
| 	.arch ev6; \
 | |
| 	.set noat; \
 | |
| 	.set noreorder; \
 | |
| .text; \
 | |
| 	.align 5; \
 | |
| 	.globl REALNAME; \
 | |
| 	.ent REALNAME; \
 | |
| REALNAME:
 | |
| 
 | |
| #ifdef PROFILE
 | |
| #define PROFCODE \
 | |
| 	ldgp	$gp, 0($27); \
 | |
| 	lda	$28, _mcount; \
 | |
| 	jsr	$28, ($28), _mcount; \
 | |
| 	.prologue 1
 | |
| #else
 | |
| #define PROFCODE .prologue 0
 | |
| #endif
 | |
| 
 | |
| #if defined(__linux__) && defined(__ELF__)
 | |
| #define GNUSTACK .section .note.GNU-stack,"",@progbits
 | |
| #else
 | |
| #define GNUSTACK
 | |
| #endif
 | |
| 
 | |
| #define EPILOGUE \
 | |
| 	.end REALNAME; \
 | |
| 	.ident VERSION; \
 | |
| 	GNUSTACK
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #ifdef DOUBLE
 | |
| #define SXADDQ	s8addq
 | |
| #define SXSUBL	s8subl
 | |
| #define LD	ldt
 | |
| #define ST	stt
 | |
| #define STQ	stq
 | |
| #define ADD	addt/su
 | |
| #define SUB	subt/su
 | |
| #define MUL	mult/su
 | |
| #define DIV	divt/su
 | |
| #else
 | |
| #define SXADDQ  s4addq
 | |
| #define SXSUBL	s4subl
 | |
| #define LD      lds
 | |
| #define ST	sts
 | |
| #define STQ	stl
 | |
| #define ADD	adds/su
 | |
| #define SUB	subs/su
 | |
| #define MUL	muls/su
 | |
| #define DIV	divs/su
 | |
| #endif
 | |
| #endif
 |