[ctrtool] Fixed issue #7

This commit is contained in:
jakcron
2015-11-20 03:13:31 +08:00
parent 7e04a8249e
commit 127d1161e5
29 changed files with 241 additions and 253 deletions
+23 -10
View File
@@ -1,13 +1,13 @@
#include <stdio.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
#include "utils.h"
#ifdef _WIN32
#include <direct.h>
#else
#include <sys/stat.h>
#include <sys/types.h>
#include <wchar.h>
#endif
@@ -20,7 +20,7 @@ u32 align(u32 offset, u32 alignment)
u64 align64(u64 offset, u32 alignment)
{
u64 mask = ~(alignment-1);
u64 mask = ~(u64)(alignment-1);
return (offset + (alignment-1)) & mask;
}
@@ -91,19 +91,15 @@ void putle32(u8* p, u32 n)
void readkeyfile(u8* key, const char* keyfname)
{
u32 keysize = _fsize(keyfname);
FILE* f = fopen(keyfname, "rb");
u32 keysize = 0;
if (0 == f)
{
fprintf(stdout, "Error opening key file\n");
goto clean;
}
fseek(f, 0, SEEK_END);
keysize = ftell(f);
fseek(f, 0, SEEK_SET);
if (keysize != 16)
{
fprintf(stdout, "Error key size mismatch, got %d, expected %d\n", keysize, 16);
@@ -190,3 +186,20 @@ int makedir(const char* dir)
return mkdir(dir, 0777);
#endif
}
u64 _fsize(const char *filename)
{
#ifdef _WIN32
struct _stat64 st;
if (_stat64(filename, &st) != 0)
return 0;
else
return st.st_size;
#else
struct stat st;
if (stat(filename, &st) != 0)
return 0;
else
return st.st_size;
#endif
}