diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2011-04-09 14:06:12 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2011-04-09 14:06:12 +0000 |
commit | 5731ff636b87abf648ceea51c404d6ae6b27f65f (patch) | |
tree | 68dffc3f27a0927f234456b196b9aea57e878acf | |
parent | c18214a6e0a22ffa6886c70dbd6176ac9e91c847 (diff) | |
download | external_llvm-5731ff636b87abf648ceea51c404d6ae6b27f65f.zip external_llvm-5731ff636b87abf648ceea51c404d6ae6b27f65f.tar.gz external_llvm-5731ff636b87abf648ceea51c404d6ae6b27f65f.tar.bz2 |
Fix potential buffer overflow on win32.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129214 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/MC/MCDisassembler/Disassembler.cpp | 21 |
1 files changed, 9 insertions, 12 deletions
diff --git a/lib/MC/MCDisassembler/Disassembler.cpp b/lib/MC/MCDisassembler/Disassembler.cpp index 4707198..6ccade9 100644 --- a/lib/MC/MCDisassembler/Disassembler.cpp +++ b/lib/MC/MCDisassembler/Disassembler.cpp @@ -128,9 +128,9 @@ public: } // namespace // -// LLVMDisasmInstruction() disassmbles a single instruction using the +// LLVMDisasmInstruction() disassembles a single instruction using the // disassembler context specified in the parameter DC. The bytes of the -// instuction are specified in the parameter Bytes, and contains at least +// instruction are specified in the parameter Bytes, and contains at least // BytesSize number of bytes. The instruction is at the address specified by // the PC parameter. If a valid instruction can be disassembled its string is // returned indirectly in OutString which whos size is specified in the @@ -155,16 +155,13 @@ size_t LLVMDisasmInstruction(LLVMDisasmContextRef DCR, uint8_t *Bytes, std::string InsnStr; raw_string_ostream OS(InsnStr); - raw_ostream &Out = OS; - IP->printInst(&Inst, Out); - - std::string p; - p = OS.str(); -#ifdef LLVM_ON_WIN32 - sprintf(OutString, "%s", p.c_str()); -#else - snprintf(OutString, OutStringSize, "%s", p.c_str()); -#endif + IP->printInst(&Inst, OS); + OS.flush(); + + size_t OutputSize = std::min(OutStringSize-1, InsnStr.size()); + std::memcpy(OutString, InsnStr.data(), OutputSize); + OutString[OutputSize] = '\0'; // Terminate string. + return Size; } |