mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2025-02-20 17:52:46 +00:00
Clean up a bunch of valgrind errors, nix a potentially unsafe op in Buffer assignment operator.
This commit is contained in:
parent
93a7eef2a5
commit
f5d77a1bc2
@ -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
|
||||
*/
|
||||
|
10
selftest.cpp
10
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();
|
||||
|
Loading…
x
Reference in New Issue
Block a user