mirror of
https://github.com/corda/corda.git
synced 2025-01-16 01:40:17 +00:00
Squashed commit of the following: (#50)
commit 9d8046e310efe860bb9d81e977a323f3905665c1 Author: Haitao Huang <4699115+haitaohuang@users.noreply.github.com> Date: Sat Sep 16 11:26:45 2017 -0500 Check and handle signal interrupts in sockets Signed-off-by: Haitao Huang <4699115+haitaohuang@users.noreply.github.com> commit 960ad91a4a8ec06020273a175471def37870fda6 Author: Haitao Huang <4699115+haitaohuang@users.noreply.github.com> Date: Sat Sep 16 11:27:35 2017 -0500 Add error code in oal for invalid inputs Signed-off-by: Haitao Huang <4699115+haitaohuang@users.noreply.github.com> commit e22c569335c1ec8d18f7df8105a68e9b9a82e691 Author: Li, Xun <xun.li@intel.com> Date: Wed Sep 20 10:51:18 2017 +0800 Update libunwind for glibc 2.26 compatibility libunwind should include <signal.h> explicitly. glibc change sys/ucontext.h as a bug fix(https://sourceware.org/git/?p=glibc.git;a=commit;h=cfed8ece799b6e6540193a14b41d9de52dc3b08f) Signed-off-by: Li, Xun <xun.li@intel.com> commit 9cda5c4774b2f4fc02fd031f98057cd88d14f2e0 Merge: 94c162c98 36918f071 Author: lzha101 <lili.z.zhang@intel.com> Date: Wed Sep 20 09:58:29 2017 +0800 Merge pull request #165 from corda/chrisr3-stack-protector-fix Ensure trts_nsp.cpp is compiled without stack protection. Signed-off-by: Zhang Lili lili.z.zhang@intel.com commit 36918f071fd29c86335b0cea0e072c3f08a51eae Author: Chris Rankin <chris.rankin@r3.com> Date: Tue Sep 19 07:31:57 2017 +0000 Ensure trts_nsp.cpp is compiled without stack protection. Signed-off-by: Chris Rankin <chris.rankin@r3.com> commit 94c162c98bf95a034eadb41bfa6e6a35f410a0c8 Author: Kai Mast <kaimast@cs.cornell.edu> Date: Mon Sep 18 04:07:19 2017 -0400 g++7 fixes (#148) Signed-off-by: Li, Xun<xun.li@intel.com> commit 8a72fed8737dc8e331889e6530925fc5a0be2ea0 Merge: 2133df2d4 635e3a370 Author: Li Xun <xun.li@intel.com> Date: Mon Sep 18 15:58:10 2017 +0800 Merge pull request #159 from corda/chrisr3-gcc7-fix Resolve GCC 7.1 warnings about deprecated throw(std::bad_alloc) in C++11. Signed-off-by: Li, Xun <xun.li@intel.com> commit 635e3a37081ad3f773a0ff24c89f1e6094034d28 Author: Chris Rankin <chris.rankin@r3.com> Date: Wed Sep 13 10:31:11 2017 +0100 Resolve warnings about deprecated throw(std::bad_alloc) in C++11.
This commit is contained in:
parent
4afe8c2a97
commit
04a801e0cd
@ -42,6 +42,7 @@ typedef enum{
|
|||||||
UAE_OAL_ERROR_UNEXPECTED ,
|
UAE_OAL_ERROR_UNEXPECTED ,
|
||||||
UAE_OAL_ERROR_AESM_UNAVAILABLE ,
|
UAE_OAL_ERROR_AESM_UNAVAILABLE ,
|
||||||
UAE_OAL_ERROR_TIMEOUT ,
|
UAE_OAL_ERROR_TIMEOUT ,
|
||||||
|
UAE_OAL_ERROR_INVALID ,
|
||||||
} uae_oal_status_t;
|
} uae_oal_status_t;
|
||||||
|
|
||||||
/*OAL methods from here forward */
|
/*OAL methods from here forward */
|
||||||
|
@ -48,22 +48,22 @@ namespace std
|
|||||||
* The function to call when allocation fails. By default, there is no
|
* The function to call when allocation fails. By default, there is no
|
||||||
* handler and a bad allocation exception is thrown if an allocation fails.
|
* handler and a bad allocation exception is thrown if an allocation fails.
|
||||||
*/
|
*/
|
||||||
new_handler set_new_handler(new_handler handler) throw();
|
new_handler set_new_handler(new_handler handler);
|
||||||
};
|
};
|
||||||
|
|
||||||
void* SGXAPI operator new (size_t) throw (std::bad_alloc);
|
void* SGXAPI operator new (size_t);
|
||||||
void* SGXAPI operator new[] (size_t) throw (std::bad_alloc);
|
void* SGXAPI operator new[] (size_t);
|
||||||
|
|
||||||
void* SGXAPI operator new (size_t, const std::nothrow_t&) throw();
|
void* SGXAPI operator new (size_t, const std::nothrow_t&);
|
||||||
void* SGXAPI operator new (size_t, void*) throw();
|
void* SGXAPI operator new (size_t, void*);
|
||||||
void* SGXAPI operator new[] (size_t, const std::nothrow_t&) throw();
|
void* SGXAPI operator new[] (size_t, const std::nothrow_t&);
|
||||||
void* SGXAPI operator new[] (size_t, void*) throw();
|
void* SGXAPI operator new[] (size_t, void*);
|
||||||
|
|
||||||
void SGXAPI operator delete (void*) throw ();
|
void SGXAPI operator delete (void*) throw ();
|
||||||
void SGXAPI operator delete (void*, const std::nothrow_t&) throw();
|
void SGXAPI operator delete (void*, const std::nothrow_t&);
|
||||||
void SGXAPI operator delete (void*, void*) throw();
|
void SGXAPI operator delete (void*, void*);
|
||||||
void SGXAPI operator delete[] (void*) throw ();
|
void SGXAPI operator delete[] (void*);
|
||||||
void SGXAPI operator delete[] (void*, const std::nothrow_t&) throw();
|
void SGXAPI operator delete[] (void*, const std::nothrow_t&);
|
||||||
void SGXAPI operator delete[] (void*, void*) throw();
|
void SGXAPI operator delete[] (void*, void*);
|
||||||
|
|
||||||
#endif /* _NEW_ */
|
#endif /* _NEW_ */
|
||||||
|
@ -43,7 +43,7 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/epoll.h>
|
#include <sys/epoll.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <se_trace.h>
|
||||||
NonBlockingUnixCommunicationSocket::~NonBlockingUnixCommunicationSocket()
|
NonBlockingUnixCommunicationSocket::~NonBlockingUnixCommunicationSocket()
|
||||||
{
|
{
|
||||||
if (mEvents != NULL)
|
if (mEvents != NULL)
|
||||||
@ -136,6 +136,10 @@ char* NonBlockingUnixCommunicationSocket::readRaw(ssize_t length)
|
|||||||
do{
|
do{
|
||||||
//try a direct read (maybe all data is available already)
|
//try a direct read (maybe all data is available already)
|
||||||
step = read(mSocket, recBuf, length);
|
step = read(mSocket, recBuf, length);
|
||||||
|
if(step == -1 && errno == EINTR && CheckForTimeout() == false){
|
||||||
|
SE_TRACE_WARNING("read is interrupted by signal\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (step == -1 && errno != EAGAIN)
|
if (step == -1 && errno != EAGAIN)
|
||||||
{
|
{
|
||||||
errorDetected = true;
|
errorDetected = true;
|
||||||
@ -154,7 +158,10 @@ char* NonBlockingUnixCommunicationSocket::readRaw(ssize_t length)
|
|||||||
}
|
}
|
||||||
|
|
||||||
//wait for events
|
//wait for events
|
||||||
|
do {
|
||||||
eventNum = epoll_wait(mEpoll, mEvents, MAX_EVENTS, epollTimeout);
|
eventNum = epoll_wait(mEpoll, mEvents, MAX_EVENTS, epollTimeout);
|
||||||
|
} while (eventNum == -1 && errno == EINTR && CheckForTimeout() == false);
|
||||||
|
|
||||||
if (eventNum == -1)
|
if (eventNum == -1)
|
||||||
{
|
{
|
||||||
errorDetected = true;
|
errorDetected = true;
|
||||||
@ -253,6 +260,12 @@ ssize_t NonBlockingUnixCommunicationSocket::partialRead(char* buffer, ssize_t ma
|
|||||||
remaining = maxLength - totalRead;
|
remaining = maxLength - totalRead;
|
||||||
|
|
||||||
step = read(mSocket, buffer + totalRead, (remaining > chunkSize ? chunkSize : remaining));
|
step = read(mSocket, buffer + totalRead, (remaining > chunkSize ? chunkSize : remaining));
|
||||||
|
|
||||||
|
if(step == -1 && errno == EINTR && CheckForTimeout() == false){
|
||||||
|
SE_TRACE_WARNING("read was interrupted by signal\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (step == -1)
|
if (step == -1)
|
||||||
{
|
{
|
||||||
if (errno != EAGAIN)
|
if (errno != EAGAIN)
|
||||||
@ -291,6 +304,10 @@ ssize_t NonBlockingUnixCommunicationSocket::writeRaw(const char* data, ssize_t
|
|||||||
do
|
do
|
||||||
{
|
{
|
||||||
step = write(mSocket, data + total_write, length - total_write);
|
step = write(mSocket, data + total_write, length - total_write);
|
||||||
|
if(step == -1 && errno == EINTR && CheckForTimeout() == false){
|
||||||
|
SE_TRACE_WARNING("write was interrupted by signal\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (step == -1 && errno != EAGAIN)
|
if (step == -1 && errno != EAGAIN)
|
||||||
{
|
{
|
||||||
@ -343,8 +360,9 @@ ssize_t NonBlockingUnixCommunicationSocket::writeRaw(const char* data, ssize_t
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
do {
|
||||||
eventNum = epoll_wait(mEpoll, mEvents, MAX_EVENTS, epollTimeout);
|
eventNum = epoll_wait(mEpoll, mEvents, MAX_EVENTS, epollTimeout);
|
||||||
|
} while (eventNum == -1 && errno == EINTR && CheckForTimeout() == false);
|
||||||
if (eventNum == -1)
|
if (eventNum == -1)
|
||||||
{
|
{
|
||||||
errorDetected = true;
|
errorDetected = true;
|
||||||
|
@ -82,7 +82,7 @@ uae_oal_status_t SocketTransporter::sendMessage(AEMessage *message, ICommunicati
|
|||||||
uae_oal_status_t SocketTransporter::transact(IAERequest* request, IAEResponse* response, uint32_t timeout)
|
uae_oal_status_t SocketTransporter::transact(IAERequest* request, IAEResponse* response, uint32_t timeout)
|
||||||
{
|
{
|
||||||
if (request == NULL || response == NULL)
|
if (request == NULL || response == NULL)
|
||||||
return UAE_OAL_ERROR_UNEXPECTED;
|
return UAE_OAL_ERROR_INVALID;
|
||||||
|
|
||||||
|
|
||||||
ICommunicationSocket* communicationSocket = mSocketFactory->NewCommunicationSocket();
|
ICommunicationSocket* communicationSocket = mSocketFactory->NewCommunicationSocket();
|
||||||
|
@ -34,10 +34,10 @@
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/un.h>
|
#include <sys/un.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <errno.h>
|
||||||
#include <IAERequest.h>
|
#include <IAERequest.h>
|
||||||
#include <IAEResponse.h>
|
#include <IAEResponse.h>
|
||||||
|
#include <se_trace.h>
|
||||||
#include <UnixCommunicationSocket.h>
|
#include <UnixCommunicationSocket.h>
|
||||||
|
|
||||||
|
|
||||||
@ -147,6 +147,10 @@ ssize_t UnixCommunicationSocket::writeRaw(const char* data, ssize_t length)
|
|||||||
do {
|
do {
|
||||||
ssize_t step = write(mSocket, data+written, length-written);
|
ssize_t step = write(mSocket, data+written, length-written);
|
||||||
|
|
||||||
|
if(step == -1 && errno == EINTR && CheckForTimeout() == false){
|
||||||
|
SE_TRACE_WARNING("write was interrupted by signal\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (step < 0 || CheckForTimeout())
|
if (step < 0 || CheckForTimeout())
|
||||||
{
|
{
|
||||||
//this connection is probably closed
|
//this connection is probably closed
|
||||||
@ -174,7 +178,10 @@ char* UnixCommunicationSocket::readRaw(ssize_t length)
|
|||||||
|
|
||||||
do {
|
do {
|
||||||
ssize_t step = read(mSocket, recBuf + total_read, length - total_read);
|
ssize_t step = read(mSocket, recBuf + total_read, length - total_read);
|
||||||
|
if(step == -1 && errno == EINTR && CheckForTimeout() == false){
|
||||||
|
SE_TRACE_WARNING("read was interrupted by signal\n");
|
||||||
|
continue;
|
||||||
|
}
|
||||||
//check connection closed by peer
|
//check connection closed by peer
|
||||||
if (step <= 0 || CheckForTimeout())
|
if (step <= 0 || CheckForTimeout())
|
||||||
{
|
{
|
||||||
|
@ -74,8 +74,9 @@ PROTPBUF_CXXFLAGS += -D_GLIBCXX_USE_CXX11_ABI=0
|
|||||||
EXTERNAL_LIB += -lprotobuf
|
EXTERNAL_LIB += -lprotobuf
|
||||||
|
|
||||||
vpath %.cpp .. $(COMMON_DIR)/src $(IPC_COMMON_SRC_DIR) $(IPC_COMMON_PROTO_DIR) $(UAE_SRC_DIR) $(AE_COMMON_DIR)
|
vpath %.cpp .. $(COMMON_DIR)/src $(IPC_COMMON_SRC_DIR) $(IPC_COMMON_PROTO_DIR) $(UAE_SRC_DIR) $(AE_COMMON_DIR)
|
||||||
|
vpath %.c $(COMMON_DIR)/src
|
||||||
|
|
||||||
|
C_SRC := se_trace.c
|
||||||
|
|
||||||
IPC_SRC := AECloseSessionRequest.cpp \
|
IPC_SRC := AECloseSessionRequest.cpp \
|
||||||
AEGetQuoteResponse.cpp \
|
AEGetQuoteResponse.cpp \
|
||||||
@ -122,7 +123,7 @@ SRC := AEServicesImpl.cpp \
|
|||||||
uae_service_version.cpp \
|
uae_service_version.cpp \
|
||||||
uae_service_assert.cpp
|
uae_service_assert.cpp
|
||||||
|
|
||||||
OBJ := $(SRC:.cpp=.o) $(IPC_SRC:.cpp=.o) $(PROTOBUF_SRC:.cc=.o)
|
OBJ := $(C_SRC:.c=.o) $(SRC:.cpp=.o) $(IPC_SRC:.cpp=.o) $(PROTOBUF_SRC:.cc=.o)
|
||||||
|
|
||||||
LDUFLAGS:= -pthread -L$(BUILD_DIR)
|
LDUFLAGS:= -pthread -L$(BUILD_DIR)
|
||||||
LDUFLAGS += -Wl,--version-script=uae_service.lds -Wl,--gc-sections
|
LDUFLAGS += -Wl,--version-script=uae_service.lds -Wl,--gc-sections
|
||||||
@ -163,6 +164,9 @@ messages.pb.o : $(IPC_COMMON_PROTO_DIR)/messages.pb.cc
|
|||||||
$(CXX) $(filter-out -Wshadow, $(CXXFLAGS)) -c $< -o $@
|
$(CXX) $(filter-out -Wshadow, $(CXXFLAGS)) -c $< -o $@
|
||||||
%.o :%.cpp
|
%.o :%.cpp
|
||||||
$(CXX) $(CXXFLAGS) $(INCLUDE) -c $< -o $@
|
$(CXX) $(CXXFLAGS) $(INCLUDE) -c $< -o $@
|
||||||
|
%.o: %.c
|
||||||
|
$(CC) $(CFLAGS) $(INCLUDE) -Werror -fPIC -c $< -o $@
|
||||||
|
|
||||||
|
|
||||||
$(BUILD_DIR):
|
$(BUILD_DIR):
|
||||||
@$(MKDIR) $@
|
@$(MKDIR) $@
|
||||||
|
@ -623,6 +623,9 @@ sgx_status_t oal_map_status(uae_oal_status_t status)
|
|||||||
case UAE_OAL_ERROR_TIMEOUT:
|
case UAE_OAL_ERROR_TIMEOUT:
|
||||||
retVal = SGX_ERROR_SERVICE_TIMEOUT;
|
retVal = SGX_ERROR_SERVICE_TIMEOUT;
|
||||||
break;
|
break;
|
||||||
|
case UAE_OAL_ERROR_INVALID:
|
||||||
|
retVal = SGX_ERROR_INVALID_PARAMETER;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
retVal = SGX_ERROR_UNEXPECTED;
|
retVal = SGX_ERROR_UNEXPECTED;
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,7 @@ uae_oal_status_t AEServicesImpl::InternalInterface(IAERequest* request, IAERespo
|
|||||||
{
|
{
|
||||||
if(request->check() == false)
|
if(request->check() == false)
|
||||||
{
|
{
|
||||||
return UAE_OAL_ERROR_UNEXPECTED;
|
return UAE_OAL_ERROR_INVALID;
|
||||||
}
|
}
|
||||||
uae_oal_status_t ipc_status = mTransporter->transact(request, response, timeout_msec);
|
uae_oal_status_t ipc_status = mTransporter->transact(request, response, timeout_msec);
|
||||||
|
|
||||||
|
@ -26,6 +26,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|||||||
#define UNW_LOCAL_ONLY
|
#define UNW_LOCAL_ONLY
|
||||||
|
|
||||||
#include <setjmp.h>
|
#include <setjmp.h>
|
||||||
|
#include <signal.h>
|
||||||
|
|
||||||
#include "libunwind_i.h"
|
#include "libunwind_i.h"
|
||||||
#include "jmpbuf.h"
|
#include "jmpbuf.h"
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
#include "sgx_trts.h"
|
#include "sgx_trts.h"
|
||||||
#include "internal/util.h"
|
#include "internal/util.h"
|
||||||
|
|
||||||
SGX_WEAK void SGXAPI operator delete (void* ptr, const std::nothrow_t& nothrow_constant) throw()
|
SGX_WEAK void SGXAPI operator delete (void* ptr, const std::nothrow_t& nothrow_constant)
|
||||||
{
|
{
|
||||||
UNUSED(nothrow_constant);
|
UNUSED(nothrow_constant);
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
#include "sgx_trts.h"
|
#include "sgx_trts.h"
|
||||||
#include "internal/util.h"
|
#include "internal/util.h"
|
||||||
|
|
||||||
SGX_WEAK void SGXAPI operator delete (void* ptr, void* voidptr2) throw()
|
SGX_WEAK void SGXAPI operator delete (void* ptr, void* voidptr2)
|
||||||
{
|
{
|
||||||
UNUSED(ptr);
|
UNUSED(ptr);
|
||||||
UNUSED(voidptr2);
|
UNUSED(voidptr2);
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
#include "internal/se_cdefs.h"
|
#include "internal/se_cdefs.h"
|
||||||
|
|
||||||
//Deallocate storage space of array
|
//Deallocate storage space of array
|
||||||
SGX_WEAK void SGXAPI operator delete[] (void* ptr) throw ()
|
SGX_WEAK void SGXAPI operator delete[] (void* ptr)
|
||||||
{
|
{
|
||||||
operator delete(ptr);
|
operator delete(ptr);
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
#include "sgx_trts.h"
|
#include "sgx_trts.h"
|
||||||
#include "internal/se_cdefs.h"
|
#include "internal/se_cdefs.h"
|
||||||
|
|
||||||
SGX_WEAK void SGXAPI operator delete[] (void* ptr, const std::nothrow_t& nothrow_constant) throw()
|
SGX_WEAK void SGXAPI operator delete[] (void* ptr, const std::nothrow_t& nothrow_constant)
|
||||||
{
|
{
|
||||||
operator delete(ptr, nothrow_constant);
|
operator delete(ptr, nothrow_constant);
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
#include "sgx_trts.h"
|
#include "sgx_trts.h"
|
||||||
#include "internal/util.h"
|
#include "internal/util.h"
|
||||||
|
|
||||||
SGX_WEAK void SGXAPI operator delete[] (void* ptr, void* voidptr2) throw()
|
SGX_WEAK void SGXAPI operator delete[] (void* ptr, void* voidptr2)
|
||||||
{
|
{
|
||||||
UNUSED(ptr);
|
UNUSED(ptr);
|
||||||
UNUSED(voidptr2);
|
UNUSED(voidptr2);
|
||||||
|
@ -39,7 +39,7 @@
|
|||||||
//aligned to represent an object of that size
|
//aligned to represent an object of that size
|
||||||
//and returns a non-null pointer to the first byte of this block.
|
//and returns a non-null pointer to the first byte of this block.
|
||||||
//On failure, it throws a bad_alloc exception.
|
//On failure, it throws a bad_alloc exception.
|
||||||
SGX_WEAK void* SGXAPI operator new(size_t dwBytes) throw(std::bad_alloc)
|
SGX_WEAK void* SGXAPI operator new(size_t dwBytes)
|
||||||
{
|
{
|
||||||
void* address = malloc(dwBytes);
|
void* address = malloc(dwBytes);
|
||||||
while ( address == NULL ){
|
while ( address == NULL ){
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
//nothrow version.
|
//nothrow version.
|
||||||
//on failure it returns a null pointer instead of throwing an exception.
|
//on failure it returns a null pointer instead of throwing an exception.
|
||||||
SGX_WEAK void* SGXAPI operator new (size_t dwBytes, const std::nothrow_t& nothrow_constant) throw()
|
SGX_WEAK void* SGXAPI operator new (size_t dwBytes, const std::nothrow_t& nothrow_constant)
|
||||||
{
|
{
|
||||||
UNUSED(nothrow_constant);
|
UNUSED(nothrow_constant);
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
//placement version
|
//placement version
|
||||||
//that does not allocate memory - it simply returns ptr.
|
//that does not allocate memory - it simply returns ptr.
|
||||||
//Notice though that the constructor for the object (if any) will still be called by the operator expression.
|
//Notice though that the constructor for the object (if any) will still be called by the operator expression.
|
||||||
SGX_WEAK void* SGXAPI operator new (size_t dwBytes, void* ptr) throw()
|
SGX_WEAK void* SGXAPI operator new (size_t dwBytes, void* ptr)
|
||||||
{
|
{
|
||||||
if( !sgx_is_within_enclave(ptr, dwBytes) ){
|
if( !sgx_is_within_enclave(ptr, dwBytes) ){
|
||||||
//compiler will check the pointer before call object construct, so it is OK to return NULL here
|
//compiler will check the pointer before call object construct, so it is OK to return NULL here
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
#include "internal/se_cdefs.h"
|
#include "internal/se_cdefs.h"
|
||||||
|
|
||||||
//Allocate storage space for array
|
//Allocate storage space for array
|
||||||
SGX_WEAK void* SGXAPI operator new[](size_t dwBytes) throw(std::bad_alloc)
|
SGX_WEAK void* SGXAPI operator new[](size_t dwBytes)
|
||||||
{
|
{
|
||||||
return operator new(dwBytes);
|
return operator new(dwBytes);
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
#include "sgx_trts.h"
|
#include "sgx_trts.h"
|
||||||
#include "internal/se_cdefs.h"
|
#include "internal/se_cdefs.h"
|
||||||
|
|
||||||
SGX_WEAK void* SGXAPI operator new[] (size_t dwBytes, const std::nothrow_t& nothrow_constant) throw()
|
SGX_WEAK void* SGXAPI operator new[] (size_t dwBytes, const std::nothrow_t& nothrow_constant)
|
||||||
{
|
{
|
||||||
return operator new(dwBytes, nothrow_constant);
|
return operator new(dwBytes, nothrow_constant);
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
#include "sgx_trts.h"
|
#include "sgx_trts.h"
|
||||||
#include "internal/util.h"
|
#include "internal/util.h"
|
||||||
|
|
||||||
SGX_WEAK void* SGXAPI operator new[] (size_t dwBytes, void* ptr) throw()
|
SGX_WEAK void* SGXAPI operator new[] (size_t dwBytes, void* ptr)
|
||||||
{
|
{
|
||||||
if( !sgx_is_within_enclave(ptr, dwBytes) ){
|
if( !sgx_is_within_enclave(ptr, dwBytes) ){
|
||||||
//compiler will check the pointer before call object construct, so it is OK to return NULL here
|
//compiler will check the pointer before call object construct, so it is OK to return NULL here
|
||||||
|
@ -53,7 +53,7 @@ namespace std{
|
|||||||
// Return Value
|
// Return Value
|
||||||
// new_handler - The value of the current new_handler function if this has been previously set by this function
|
// new_handler - The value of the current new_handler function if this has been previously set by this function
|
||||||
// NULL -if this is the first call to set_new_handler
|
// NULL -if this is the first call to set_new_handler
|
||||||
new_handler set_new_handler(new_handler handle) throw()
|
new_handler set_new_handler(new_handler handle)
|
||||||
{
|
{
|
||||||
sgx_spin_lock(&handler_lock);
|
sgx_spin_lock(&handler_lock);
|
||||||
new_handler retHandle = new_handl;
|
new_handler retHandle = new_handl;
|
||||||
|
@ -40,7 +40,7 @@ CXXFLAGS += $(ENCLAVE_CXXFLAGS) \
|
|||||||
-fno-exceptions \
|
-fno-exceptions \
|
||||||
-fno-rtti
|
-fno-rtti
|
||||||
|
|
||||||
TCXXFLAGS := $(filter-out -fstack-protector-strong, $(CXXFLAGS))
|
TCXXFLAGS := $(patsubst -fstack-protector%,-fno-stack-protector,$(CXXFLAGS))
|
||||||
|
|
||||||
OBJS1 := init_enclave.o \
|
OBJS1 := init_enclave.o \
|
||||||
trts.o \
|
trts.o \
|
||||||
|
Loading…
Reference in New Issue
Block a user