0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034 #include <string.h>
0035 #include <stdio.h>
0036 #include <stdint.h>
0037 #include <stdlib.h>
0038 #include <memory.h>
0039 #include <errno.h>
0040 #include <dlfcn.h>
0041
0042 #include <atmi.h>
0043 #include <atmi_tls.h>
0044 #include <ndrstandard.h>
0045 #include <ndebug.h>
0046 #include <ndrxdcmn.h>
0047 #include <userlog.h>
0048 #include <xa_cmn.h>
0049
0050
0051
0052
0053
0054
0055
0056
0057
0058
0059
0060 expublic char * ONstrerror(TPCONTEXT_T *p_ctxt, int err)
0061 {
0062 int did_set = EXFALSE;
0063 char * ret = NULL;
0064
0065
0066 #ifdef NDRX_OAPI_DEBUG
0067 NDRX_LOG(log_debug, "ENTRY: Nstrerror() enter, context: %p, current: %p", *p_ctxt, G_atmi_tls);
0068 NDRX_LOG(log_debug, "ENTRY: is_associated_with_thread = %d",
0069 ((atmi_tls_t *)*p_ctxt)->is_associated_with_thread);
0070
0071 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_NSTD = %d",
0072 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_NSTD );
0073
0074 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_UBF = %d",
0075 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_UBF );
0076
0077 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_ATMI = %d",
0078 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_ATMI );
0079
0080 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_TRAN = %d",
0081 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_TRAN );
0082
0083 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_NOCHK = %d",
0084 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_NOCHK );
0085
0086 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_IGN = %d",
0087 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_IGN );
0088 #endif
0089
0090
0091
0092 if (!((atmi_tls_t *)*p_ctxt)->is_associated_with_thread)
0093 {
0094
0095 if (EXSUCCEED!=ndrx_tpsetctxt(*p_ctxt, 0,
0096 CTXT_PRIV_NSTD | CTXT_PRIV_IGN))
0097 {
0098 userlog("ERROR! Nstrerror() failed to set context");
0099 ret = NULL;
0100 goto out;
0101 }
0102 did_set = EXTRUE;
0103 }
0104 else if ((atmi_tls_t *)*p_ctxt != G_atmi_tls)
0105 {
0106 userlog("WARNING! Nstrerror() context %p thinks that it is assocated "
0107 "with current thread, but thread is associated with %p context!",
0108 p_ctxt, G_atmi_tls);
0109 }
0110
0111 ret = Nstrerror(err);
0112
0113 if (did_set)
0114 {
0115 if (TPMULTICONTEXTS!=ndrx_tpgetctxt(p_ctxt, 0,
0116 CTXT_PRIV_NSTD | CTXT_PRIV_IGN))
0117 {
0118 userlog("ERROR! Nstrerror() failed to get context");
0119 ret = NULL;
0120 goto out;
0121 }
0122 }
0123 out:
0124
0125 #ifdef NDRX_OAPI_DEBUG
0126 NDRX_LOG(log_debug, "RETURN: Nstrerror() returns, context: %p, current: %p",
0127 *p_ctxt, G_atmi_tls);
0128 #endif
0129
0130
0131 return ret;
0132 }
0133
0134
0135
0136
0137
0138 expublic int * O_Nget_Nerror_addr(TPCONTEXT_T *p_ctxt)
0139 {
0140 int did_set = EXFALSE;
0141 int * ret = NULL;
0142
0143
0144 #ifdef NDRX_OAPI_DEBUG
0145 NDRX_LOG(log_debug, "ENTRY: _Nget_Nerror_addr() enter, context: %p, current: %p", *p_ctxt, G_atmi_tls);
0146 NDRX_LOG(log_debug, "ENTRY: is_associated_with_thread = %d",
0147 ((atmi_tls_t *)*p_ctxt)->is_associated_with_thread);
0148
0149 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_NSTD = %d",
0150 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_NSTD );
0151
0152 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_UBF = %d",
0153 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_UBF );
0154
0155 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_ATMI = %d",
0156 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_ATMI );
0157
0158 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_TRAN = %d",
0159 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_TRAN );
0160
0161 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_NOCHK = %d",
0162 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_NOCHK );
0163
0164 NDRX_LOG(log_debug, "ENTRY: CTXT_PRIV_IGN = %d",
0165 (CTXT_PRIV_NSTD | CTXT_PRIV_IGN) & CTXT_PRIV_IGN );
0166 #endif
0167
0168
0169
0170 if (!((atmi_tls_t *)*p_ctxt)->is_associated_with_thread)
0171 {
0172
0173 if (EXSUCCEED!=ndrx_tpsetctxt(*p_ctxt, 0,
0174 CTXT_PRIV_NSTD | CTXT_PRIV_IGN))
0175 {
0176 userlog("ERROR! _Nget_Nerror_addr() failed to set context");
0177 ret = NULL;
0178 goto out;
0179 }
0180 did_set = EXTRUE;
0181 }
0182 else if ((atmi_tls_t *)*p_ctxt != G_atmi_tls)
0183 {
0184 userlog("WARNING! _Nget_Nerror_addr() context %p thinks that it is assocated "
0185 "with current thread, but thread is associated with %p context!",
0186 p_ctxt, G_atmi_tls);
0187 }
0188
0189 ret = _Nget_Nerror_addr();
0190
0191 if (did_set)
0192 {
0193 if (TPMULTICONTEXTS!=ndrx_tpgetctxt(p_ctxt, 0,
0194 CTXT_PRIV_NSTD | CTXT_PRIV_IGN))
0195 {
0196 userlog("ERROR! _Nget_Nerror_addr() failed to get context");
0197 ret = NULL;
0198 goto out;
0199 }
0200 }
0201 out:
0202
0203 #ifdef NDRX_OAPI_DEBUG
0204 NDRX_LOG(log_debug, "RETURN: _Nget_Nerror_addr() returns, context: %p, current: %p",
0205 *p_ctxt, G_atmi_tls);
0206 #endif
0207
0208
0209 return ret;
0210 }
0211
0212