From 88e6164d35bce0d2d7c0d0691ac6b2780e143117 Mon Sep 17 00:00:00 2001 From: Sebastian Messmer Date: Tue, 9 Feb 2016 12:37:30 +0100 Subject: [PATCH] Improve platform indepdendence of directory blobs --- src/filesystem/fsblobstore/utils/DirEntry.cpp | 68 ++++++++++++------- src/filesystem/fsblobstore/utils/DirEntry.h | 3 + 2 files changed, 45 insertions(+), 26 deletions(-) diff --git a/src/filesystem/fsblobstore/utils/DirEntry.cpp b/src/filesystem/fsblobstore/utils/DirEntry.cpp index 2e53ca50..fe2843e2 100644 --- a/src/filesystem/fsblobstore/utils/DirEntry.cpp +++ b/src/filesystem/fsblobstore/utils/DirEntry.cpp @@ -17,28 +17,47 @@ namespace cryfs { key.ToBinary(dest+offset); offset += key.BINARY_LENGTH; - *reinterpret_cast(dest+offset) = uid; - offset += sizeof(uid_t); + *reinterpret_cast(dest+offset) = uid; + offset += sizeof(uint32_t); - *reinterpret_cast(dest+offset) = gid; - offset += sizeof(gid_t); + *reinterpret_cast(dest+offset) = gid; + offset += sizeof(uint32_t); - *reinterpret_cast(dest+offset) = mode; - offset += sizeof(mode_t); + *reinterpret_cast(dest+offset) = mode; + offset += sizeof(uint32_t); - static_assert(sizeof(timespec) == 16, "Ensure platform independence of the serialization"); - *reinterpret_cast(dest+offset) = lastAccessTime; - offset += sizeof(timespec); - *reinterpret_cast(dest+offset) = lastModificationTime; - offset += sizeof(timespec); - *reinterpret_cast(dest+offset) = lastMetadataChangeTime; - offset += sizeof(timespec); + offset += _serializeTimeValue(dest + offset, lastAccessTime); + offset += _serializeTimeValue(dest + offset, lastModificationTime); + offset += _serializeTimeValue(dest + offset, lastMetadataChangeTime); ASSERT(offset == serializedSize(), "Didn't write correct number of elements"); } + unsigned int DirEntry::_serializeTimeValue(uint8_t *dest, timespec value) { + unsigned int offset = 0; + *reinterpret_cast(dest+offset) = value.tv_sec; + offset += sizeof(uint64_t); + *reinterpret_cast(dest+offset) = value.tv_nsec; + offset += sizeof(uint32_t); + ASSERT(offset == _serializedTimeValueSize(), "serialized to wrong size"); + return offset; + } + + size_t DirEntry::_serializedTimeValueSize() { + return sizeof(uint64_t) + sizeof(uint32_t); + } + + timespec DirEntry::_deserializeTimeValue(const char **pos) { + timespec value; + value.tv_sec = *(uint64_t*)(*pos); + *pos += sizeof(uint64_t); + value.tv_nsec = *(uint32_t*)(*pos); + *pos += sizeof(uint32_t); + return value; + } + size_t DirEntry::serializedSize() const { - return 1 + (name.size() + 1) + key.BINARY_LENGTH + sizeof(uid_t) + sizeof(gid_t) + sizeof(mode_t) + 3*sizeof(timespec); + return 1 + (name.size() + 1) + key.BINARY_LENGTH + sizeof(uint32_t) + sizeof(uint32_t) + sizeof(uint32_t) + 3*_serializedTimeValueSize(); } const char *DirEntry::deserializeAndAddToVector(const char *pos, vector *result) { @@ -54,21 +73,18 @@ namespace cryfs { Key key = Key::FromBinary(pos); pos += Key::BINARY_LENGTH; - uid_t uid = *(uid_t*)pos; - pos += sizeof(uid_t); + uid_t uid = *(uint32_t*)pos; + pos += sizeof(uint32_t); - gid_t gid = *(gid_t*)pos; - pos += sizeof(gid_t); + gid_t gid = *(uint32_t*)pos; + pos += sizeof(uint32_t); - mode_t mode = *(mode_t*)pos; - pos += sizeof(mode_t); + mode_t mode = *(uint32_t*)pos; + pos += sizeof(uint32_t); - timespec lastAccessTime = *(timespec*)pos; - pos += sizeof(timespec); - timespec lastModificationTime = *(timespec*)pos; - pos += sizeof(timespec); - timespec lastMetadataChangeTime = *(timespec*)pos; - pos += sizeof(timespec); + timespec lastAccessTime = _deserializeTimeValue(&pos); + timespec lastModificationTime = _deserializeTimeValue(&pos); + timespec lastMetadataChangeTime = _deserializeTimeValue(&pos); result->emplace_back(type, name, key, mode, uid, gid, lastAccessTime, lastModificationTime, lastMetadataChangeTime); return pos; diff --git a/src/filesystem/fsblobstore/utils/DirEntry.h b/src/filesystem/fsblobstore/utils/DirEntry.h index 3f65541a..363ef175 100644 --- a/src/filesystem/fsblobstore/utils/DirEntry.h +++ b/src/filesystem/fsblobstore/utils/DirEntry.h @@ -34,6 +34,9 @@ namespace cryfs { void serialize(uint8_t* dest) const; size_t serializedSize() const; static const char *deserializeAndAddToVector(const char *pos, std::vector *result); + static size_t _serializedTimeValueSize(); + static unsigned int _serializeTimeValue(uint8_t *dest, timespec value); + static timespec _deserializeTimeValue(const char **pos); fspp::Dir::EntryType type; std::string name;