Use 64-bit off_t when computing digests

This allows 32-bit platforms like Raspberry Pi to upload single-part
objects larger than 2 GB.
This commit is contained in:
Andrew Gaul 2020-09-12 15:00:23 +09:00
parent 0d4e39ad1c
commit ffc33a447f
5 changed files with 36 additions and 36 deletions

View File

@ -54,7 +54,7 @@ string s3fs_get_content_md5(int fd)
return Signature; return Signature;
} }
string s3fs_md5sum(int fd, off_t start, ssize_t size) string s3fs_md5sum(int fd, off_t start, off_t size)
{ {
size_t digestlen = get_md5_digest_length(); size_t digestlen = get_md5_digest_length();
unsigned char* md5hex; unsigned char* md5hex;
@ -69,7 +69,7 @@ string s3fs_md5sum(int fd, off_t start, ssize_t size)
return md5; return md5;
} }
string s3fs_sha256sum(int fd, off_t start, ssize_t size) string s3fs_sha256sum(int fd, off_t start, off_t size)
{ {
size_t digestlen = get_sha256_digest_length(); size_t digestlen = get_sha256_digest_length();
char sha256[2 * digestlen + 1]; char sha256[2 * digestlen + 1];

View File

@ -190,17 +190,17 @@ size_t get_md5_digest_length()
} }
#ifdef USE_GNUTLS_NETTLE #ifdef USE_GNUTLS_NETTLE
unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_md5hexsum(int fd, off_t start, off_t size)
{ {
struct md5_ctx ctx_md5; struct md5_ctx ctx_md5;
unsigned char buf[512]; unsigned char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
memset(buf, 0, 512); memset(buf, 0, 512);
md5_init(&ctx_md5); md5_init(&ctx_md5);
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){
@ -222,12 +222,12 @@ unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size)
#else // USE_GNUTLS_NETTLE #else // USE_GNUTLS_NETTLE
unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_md5hexsum(int fd, off_t start, off_t size)
{ {
gcry_md_hd_t ctx_md5; gcry_md_hd_t ctx_md5;
gcry_error_t err; gcry_error_t err;
char buf[512]; char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
if(-1 == size){ if(-1 == size){
@ -235,7 +235,7 @@ unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size)
if(-1 == fstat(fd, &st)){ if(-1 == fstat(fd, &st)){
return NULL; return NULL;
} }
size = static_cast<ssize_t>(st.st_size); size = st.st_size;
} }
memset(buf, 0, 512); memset(buf, 0, 512);
@ -244,7 +244,7 @@ unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size)
return NULL; return NULL;
} }
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){
@ -290,17 +290,17 @@ bool s3fs_sha256(const unsigned char* data, unsigned int datalen, unsigned char*
return true; return true;
} }
unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_sha256hexsum(int fd, off_t start, off_t size)
{ {
struct sha256_ctx ctx_sha256; struct sha256_ctx ctx_sha256;
unsigned char buf[512]; unsigned char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
memset(buf, 0, 512); memset(buf, 0, 512);
sha256_init(&ctx_sha256); sha256_init(&ctx_sha256);
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){
@ -341,12 +341,12 @@ bool s3fs_sha256(const unsigned char* data, unsigned int datalen, unsigned char*
return true; return true;
} }
unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_sha256hexsum(int fd, off_t start, off_t size)
{ {
gcry_md_hd_t ctx_sha256; gcry_md_hd_t ctx_sha256;
gcry_error_t err; gcry_error_t err;
char buf[512]; char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
if(-1 == size){ if(-1 == size){
@ -354,7 +354,7 @@ unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size)
if(-1 == fstat(fd, &st)){ if(-1 == fstat(fd, &st)){
return NULL; return NULL;
} }
size = static_cast<ssize_t>(st.st_size); size = st.st_size;
} }
memset(buf, 0, 512); memset(buf, 0, 512);
@ -363,7 +363,7 @@ unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size)
return NULL; return NULL;
} }
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){

View File

@ -152,11 +152,11 @@ size_t get_md5_digest_length()
return MD5_LENGTH; return MD5_LENGTH;
} }
unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_md5hexsum(int fd, off_t start, off_t size)
{ {
PK11Context* md5ctx; PK11Context* md5ctx;
unsigned char buf[512]; unsigned char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
unsigned int md5outlen; unsigned int md5outlen;
@ -165,13 +165,13 @@ unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size)
if(-1 == fstat(fd, &st)){ if(-1 == fstat(fd, &st)){
return NULL; return NULL;
} }
size = static_cast<ssize_t>(st.st_size); size = st.st_size;
} }
memset(buf, 0, 512); memset(buf, 0, 512);
md5ctx = PK11_CreateDigestContext(SEC_OID_MD5); md5ctx = PK11_CreateDigestContext(SEC_OID_MD5);
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){
@ -218,11 +218,11 @@ bool s3fs_sha256(const unsigned char* data, unsigned int datalen, unsigned char*
return true; return true;
} }
unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_sha256hexsum(int fd, off_t start, off_t size)
{ {
PK11Context* sha256ctx; PK11Context* sha256ctx;
unsigned char buf[512]; unsigned char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
unsigned int sha256outlen; unsigned int sha256outlen;
@ -231,13 +231,13 @@ unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size)
if(-1 == fstat(fd, &st)){ if(-1 == fstat(fd, &st)){
return NULL; return NULL;
} }
size = static_cast<ssize_t>(st.st_size); size = st.st_size;
} }
memset(buf, 0, 512); memset(buf, 0, 512);
sha256ctx = PK11_CreateDigestContext(SEC_OID_SHA256); sha256ctx = PK11_CreateDigestContext(SEC_OID_SHA256);
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){

View File

@ -255,11 +255,11 @@ size_t get_md5_digest_length()
return MD5_DIGEST_LENGTH; return MD5_DIGEST_LENGTH;
} }
unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_md5hexsum(int fd, off_t start, off_t size)
{ {
MD5_CTX md5ctx; MD5_CTX md5ctx;
char buf[512]; char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
if(-1 == size){ if(-1 == size){
@ -267,13 +267,13 @@ unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size)
if(-1 == fstat(fd, &st)){ if(-1 == fstat(fd, &st)){
return NULL; return NULL;
} }
size = static_cast<ssize_t>(st.st_size); size = st.st_size;
} }
memset(buf, 0, 512); memset(buf, 0, 512);
MD5_Init(&md5ctx); MD5_Init(&md5ctx);
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){
@ -317,12 +317,12 @@ bool s3fs_sha256(const unsigned char* data, unsigned int datalen, unsigned char*
return true; return true;
} }
unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size) unsigned char* s3fs_sha256hexsum(int fd, off_t start, off_t size)
{ {
const EVP_MD* md = EVP_get_digestbyname("sha256"); const EVP_MD* md = EVP_get_digestbyname("sha256");
EVP_MD_CTX* sha256ctx; EVP_MD_CTX* sha256ctx;
char buf[512]; char buf[512];
ssize_t bytes; off_t bytes;
unsigned char* result; unsigned char* result;
if(-1 == size){ if(-1 == size){
@ -330,14 +330,14 @@ unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size)
if(-1 == fstat(fd, &st)){ if(-1 == fstat(fd, &st)){
return NULL; return NULL;
} }
size = static_cast<ssize_t>(st.st_size); size = st.st_size;
} }
sha256ctx = EVP_MD_CTX_create(); sha256ctx = EVP_MD_CTX_create();
EVP_DigestInit_ex(sha256ctx, md, NULL); EVP_DigestInit_ex(sha256ctx, md, NULL);
memset(buf, 0, 512); memset(buf, 0, 512);
for(ssize_t total = 0; total < size; total += bytes){ for(off_t total = 0; total < size; total += bytes){
bytes = 512 < (size - total) ? 512 : (size - total); bytes = 512 < (size - total) ? 512 : (size - total);
bytes = pread(fd, buf, bytes, start + total); bytes = pread(fd, buf, bytes, start + total);
if(0 == bytes){ if(0 == bytes){

View File

@ -31,8 +31,8 @@
// in common_auth.cpp // in common_auth.cpp
// //
std::string s3fs_get_content_md5(int fd); std::string s3fs_get_content_md5(int fd);
std::string s3fs_md5sum(int fd, off_t start, ssize_t size); std::string s3fs_md5sum(int fd, off_t start, off_t size);
std::string s3fs_sha256sum(int fd, off_t start, ssize_t size); std::string s3fs_sha256sum(int fd, off_t start, off_t size);
// //
// in xxxxxx_auth.cpp // in xxxxxx_auth.cpp
@ -45,10 +45,10 @@ bool s3fs_destroy_crypt_mutex(void);
bool s3fs_HMAC(const void* key, size_t keylen, const unsigned char* data, size_t datalen, unsigned char** digest, unsigned int* digestlen); bool s3fs_HMAC(const void* key, size_t keylen, const unsigned char* data, size_t datalen, unsigned char** digest, unsigned int* digestlen);
bool s3fs_HMAC256(const void* key, size_t keylen, const unsigned char* data, size_t datalen, unsigned char** digest, unsigned int* digestlen); bool s3fs_HMAC256(const void* key, size_t keylen, const unsigned char* data, size_t datalen, unsigned char** digest, unsigned int* digestlen);
size_t get_md5_digest_length(void); size_t get_md5_digest_length(void);
unsigned char* s3fs_md5hexsum(int fd, off_t start, ssize_t size); unsigned char* s3fs_md5hexsum(int fd, off_t start, off_t size);
bool s3fs_sha256(const unsigned char* data, unsigned int datalen, unsigned char** digest, unsigned int* digestlen); bool s3fs_sha256(const unsigned char* data, unsigned int datalen, unsigned char** digest, unsigned int* digestlen);
size_t get_sha256_digest_length(void); size_t get_sha256_digest_length(void);
unsigned char* s3fs_sha256hexsum(int fd, off_t start, ssize_t size); unsigned char* s3fs_sha256hexsum(int fd, off_t start, off_t size);
#endif // S3FS_AUTH_H_ #endif // S3FS_AUTH_H_