From b7b74f2328a11ba5abb230b8747ee73f2a235105 Mon Sep 17 00:00:00 2001 From: minggo Date: Fri, 3 Jun 2016 11:39:01 +0800 Subject: [PATCH] avoid to access invalid memory when received data length is the same as buffer size --- .../js-bindings/manual/ScriptingCore.cpp | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/cocos/scripting/js-bindings/manual/ScriptingCore.cpp b/cocos/scripting/js-bindings/manual/ScriptingCore.cpp index ee82390a2c..88088ac20c 100644 --- a/cocos/scripting/js-bindings/manual/ScriptingCore.cpp +++ b/cocos/scripting/js-bindings/manual/ScriptingCore.cpp @@ -1946,6 +1946,12 @@ static void serverEntryPoint(unsigned int port) listen(s, 1); + +#define MAX_RECEIVED_SIZE 1024 +#define BUF_SIZE MAX_RECEIVED_SIZE + 1 + + char buf[BUF_SIZE] = {0}; + int readBytes = 0; while (true) { clientSocket = accept(s, NULL, NULL); @@ -1962,10 +1968,8 @@ static void serverEntryPoint(unsigned int port) inData = "connected"; // process any input, send any output clearBuffers(); - - char buf[1024] = {0}; - int readBytes = 0; - while ((readBytes = (int)::recv(clientSocket, buf, sizeof(buf), 0)) > 0) + + while ((readBytes = (int)::recv(clientSocket, buf, MAX_RECEIVED_SIZE, 0)) > 0) { buf[readBytes] = '\0'; // TRACE_DEBUGGER_SERVER("debug server : received command >%s", buf); @@ -1979,6 +1983,9 @@ static void serverEntryPoint(unsigned int port) cc_closesocket(clientSocket); } } // while(true) + +#undef BUF_SIZE +#undef MAX_RECEIVED_SIZE } bool JSBDebug_BufferWrite(JSContext* cx, unsigned argc, jsval* vp)