From f5d77a1bc21a61c12adb8b1254951a12b26db9e0 Mon Sep 17 00:00:00 2001 From: Adam Ierymenko Date: Mon, 12 Aug 2013 13:17:03 -0400 Subject: [PATCH] Clean up a bunch of valgrind errors, nix a potentially unsafe op in Buffer assignment operator. --- node/Buffer.hpp | 11 ++++++++++- selftest.cpp | 10 ++++++++-- 2 files changed, 18 insertions(+), 3 deletions(-) diff --git a/node/Buffer.hpp b/node/Buffer.hpp index ed463bf63..14dd05c3f 100644 --- a/node/Buffer.hpp +++ b/node/Buffer.hpp @@ -124,7 +124,7 @@ public: { if (b._l > C) throw std::out_of_range("Buffer: assignment from buffer larger than capacity"); - memcpy(this,&b,sizeof(_l) + b._l); // one memcpy for all fields + memcpy(_b,b._b,_l = b._l); return *this; } @@ -357,6 +357,15 @@ public: memset(_b + _l,0,C - _l); } + /** + * Unconditionally zero buffer's underlying memory + */ + inline void zeroAll() + throw() + { + memset(_b,0,sizeof(_b)); + } + /** * @return Size of data in buffer */ diff --git a/selftest.cpp b/selftest.cpp index 5a5288be3..cf4635b75 100644 --- a/selftest.cpp +++ b/selftest.cpp @@ -229,6 +229,9 @@ static int testPacket() unsigned char salsaKey[32],hmacKey[32]; Packet a,b; + a.zeroAll(); + b.zeroAll(); + for(unsigned int i=0;i<32;++i) { salsaKey[i] = (unsigned char)rand(); hmacKey[i] = (unsigned char)rand(); @@ -236,12 +239,15 @@ static int testPacket() std::cout << "[packet] Testing Packet encoder/decoder... "; - a = Packet(); - a.setVerb(Packet::VERB_HELLO); + a.reset(Address(),Address(),Packet::VERB_HELLO); for(int i=0;i<32;++i) a.append("supercalifragilisticexpealidocious",strlen("supercalifragilisticexpealidocious")); b = a; + if (a != b) { + std::cout << "FAIL (assign)" << std::endl; + return -1; + } a.compress(); unsigned int complen = a.size();