BPatch functions that block are now locked (on a finer grain than the rest of the...
[dyninst.git] / dyninstAPI_RT / src / RTosf.c
1 /*
2  * Copyright (c) 1996-2004 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * This license is for research uses.  For such uses, there is no
12  * charge. We define "research use" to mean you may freely use it
13  * inside your organization for whatever purposes you see fit. But you
14  * may not re-distribute Paradyn or parts of Paradyn, in any form
15  * source or binary (including derivatives), electronic or otherwise,
16  * to any other organization or entity without our permission.
17  * 
18  * (for other uses, please contact us at paradyn@cs.wisc.edu)
19  * 
20  * All warranties, including without limitation, any warranty of
21  * merchantability or fitness for a particular purpose, are hereby
22  * excluded.
23  * 
24  * By your use of Paradyn, you understand and agree that we (or any
25  * other person or entity with proprietary rights in Paradyn) are
26  * under no obligation to provide either maintenance services,
27  * update services, notices of latent defects, or correction of
28  * defects for Paradyn.
29  * 
30  * Even if advised of the possibility of such damages, under no
31  * circumstances shall we (or any other person or entity with
32  * proprietary rights in the software licensed hereunder) be liable
33  * to you or any third party for direct, indirect, or consequential
34  * damages of any character regardless of type of action, including,
35  * without limitation, loss of profits, loss of use, loss of good
36  * will, or computer failure or malfunction.  You agree to indemnify
37  * us (and any other person or entity with proprietary rights in the
38  * software licensed hereunder) for any and all liability it may
39  * incur to third parties resulting from your use of Paradyn.
40  */
41
42 /************************************************************************
43  * RTosf.c: mutatee-side library function specific to OSF
44 ************************************************************************/
45 #include "dyninstAPI_RT/h/dyninstAPI_RT.h"
46 #if !defined (EXPORT_SPINLOCKS_AS_HEADER)
47 /* everything should be under this flag except for the assembly code
48    that handles the runtime spinlocks  -- this is imported into the
49    test suite for direct testing */
50
51 #include <stdio.h>
52 #include <errno.h>
53 #include <stdlib.h>
54 #include <string.h>
55 #include <sys/types.h>
56 #include <dlfcn.h>                    /* dlopen() */
57
58 /* The alpha does not have a divide instruction */
59 /* Division is emulated in software */
60 int divide(int a,int b)
61 {
62   return (a/b);
63 }
64
65 char gLoadLibraryErrorString[ERROR_STRING_LENGTH];
66 int DYNINSTloadLibrary(char *libname)
67 {
68   void *res;
69   char *err_str;
70   gLoadLibraryErrorString[0]='\0';
71   
72   if (NULL == (res = dlopen(libname, RTLD_NOW | RTLD_GLOBAL))) {
73     // An error has occurred
74     perror( "DYNINSTloadLibrary -- dlopen" );
75     
76     if (NULL != (err_str = dlerror()))
77       strncpy(gLoadLibraryErrorString, err_str, ERROR_STRING_LENGTH);
78     else 
79       sprintf(gLoadLibraryErrorString,"unknown error with dlopen");
80     
81     //fprintf(stderr, "%s[%d]: %s\n",__FILE__,__LINE__,gLoadLibraryErrorString);
82     return 0;  
83   } else
84     return 1;
85 }
86
87 void DYNINSTos_init(int calledByFork, int calledByAttach)
88 {
89 }
90 #endif /* EXPORT SPINLOCKS */
91 void DYNINSTlock_spinlock(dyninst_spinlock *mut)
92 {
93
94  asm (
95          "  ldq         $3, 16($15)  # R3 <- mut\n"
96
97          "  1:                       # Loop 1: try to get and store lock\n"
98          "  ldl_l       $4, 0($3)    # R4 <- mut->lock, (locked operation)\n"
99          "  blbs        $4, 2f       # if lock bit set, spin in loop 2\n"
100          "  bne         $4, 1b       # R4 != 0, someone else has lock, spin.\n"
101          "  addl        $4, 1, $4    # R4 == 0, add 1 ( 1 = mutex locked)\n"
102          "  stl_c       $4, 0($3)    # R4 -> mut->lock\n"
103          "  beq         $4, 2f       # if R4 == 0, store failed, lock contention, spin\n"
104          "                           # in Loop2 until lock is released\n"
105          "  br          3f           # have lock, jump to end. \n"
106
107          "  2:                       # Loop 2: spin until lock bit unset\n"
108          "  ldl         $4, 0($3)    # R4 <- mut->lock\n"
109          "  blbs        $4, 2b       # if lock bit set, spin in loop 2\n"
110          "  br          1b           # if lock bit unset, start over in Loop\n"
111
112          "  3:          mb           # memory barrier, and we're done\n"
113      );
114
115
116
117 }