summaryrefslogtreecommitdiff
path: root/node
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2014-10-02 09:08:31 -0700
committerAdam Ierymenko <adam.ierymenko@gmail.com>2014-10-02 09:08:31 -0700
commite8c5495b61ebde115ee133e8c85933191bd0cd61 (patch)
treee8f80f74b77bb1dc83b0fd5fd0d86ebc72c9cd86 /node
parent28646eee0a81a5555fbfa504b66a5b11be4f3fb7 (diff)
downloadinfinitytier-e8c5495b61ebde115ee133e8c85933191bd0cd61.tar.gz
infinitytier-e8c5495b61ebde115ee133e8c85933191bd0cd61.zip
Yes, zero my secret key data. Yes I really, really mean it.
Diffstat (limited to 'node')
-rw-r--r--node/Utils.cpp16
-rw-r--r--node/Utils.hpp14
2 files changed, 19 insertions, 11 deletions
diff --git a/node/Utils.cpp b/node/Utils.cpp
index 80406c3f..f0a03f2c 100644
--- a/node/Utils.cpp
+++ b/node/Utils.cpp
@@ -78,6 +78,22 @@ bool Utils::redirectUnixOutputs(const char *stdoutPath,const char *stderrPath)
}
#endif // __UNIX_LIKE__
+static void _Utils_doBurn(char *ptr,unsigned int len)
+{
+ for(unsigned int i=0;i<len;++i)
+ ptr[i] = (char)0;
+}
+void (*volatile _Utils_doBurn_ptr)(char *,unsigned int) = _Utils_doBurn;
+void Utils::burn(void *ptr,unsigned int len)
+ throw()
+{
+ // Ridiculous hack: call _doBurn() via a volatile function pointer to
+ // hold down compiler optimizers and beat them mercilessly until they
+ // cry and mumble something about never eliding secure memory zeroing
+ // again.
+ (_Utils_doBurn_ptr)((char *)ptr,len);
+}
+
std::map<std::string,bool> Utils::listDirectory(const char *path)
{
std::map<std::string,bool> r;
diff --git a/node/Utils.hpp b/node/Utils.hpp
index affae9a8..defb52a9 100644
--- a/node/Utils.hpp
+++ b/node/Utils.hpp
@@ -101,18 +101,10 @@ public:
}
/**
- * Securely zero memory
- *
- * This just uses volatile to ensure that it's never optimized out.
+ * Securely zero memory, avoiding compiler optimizations and such
*/
- static inline void burn(void *ptr,unsigned int len)
- throw()
- {
- volatile unsigned char *p = (unsigned char *)ptr;
- volatile unsigned char *e = p + len;
- while (p != e)
- *(p++) = (unsigned char)0;
- }
+ static void burn(void *ptr,unsigned int len)
+ throw();
/**
* Delete a file