eh, moving out of cloud9

master
Xyc0 2016-06-27 23:54:47 +00:00
parent 8ccbadf94b
commit 50533d793e
3 changed files with 115 additions and 100 deletions

View File

@ -20,7 +20,7 @@ BreakBeforeTernaryOperators: true
BreakConstructorInitializersBeforeComma: false
BinPackParameters: true
BinPackArguments: true
ColumnLimit: 80
ColumnLimit: 120
ConstructorInitializerAllOnOneLineOrOnePerLine: false
ConstructorInitializerIndentWidth: 4
DerivePointerAlignment: false
@ -31,7 +31,7 @@ IndentFunctionDeclarationAfterType: false
MaxEmptyLinesToKeep: 1
KeepEmptyLinesAtTheStartOfBlocks: true
NamespaceIndentation: None
ObjCBlockIndentWidth: 4
ObjCBlockIndentWidth: 2
ObjCSpaceAfterProperty: false
ObjCSpaceBeforeProtocolList: true
PenaltyBreakBeforeFirstCallParameter: 19
@ -45,7 +45,7 @@ SpacesBeforeTrailingComments: 1
Cpp11BracedListStyle: true
Standard: Cpp11
IndentWidth: 4
TabWidth: 8
TabWidth: 4
UseTab: Never
BreakBeforeBraces: Allman
SpacesInParentheses: false

View File

@ -16,13 +16,15 @@
#define SHA_SUM_LENGTH (SHA_DIGEST_LENGTH + SHA_DIGEST_LENGTH + 1)
void picProto(void *picAddr, size_t picSize, void *clonePtr) {
void (*cloneFunc)(void *, size_t, char *) = clonePtr;
void picProto(void *picAddr, size_t picSize, void *clonePtr)
{
void (*cloneFunc)(void *, size_t) = clonePtr;
cloneFunc(picAddr, picSize);
return;
}
void clone(void *picAddr, size_t picSize, char *checksum) {
void clone(void *picAddr, size_t picSize)
{
auto retVal = EX_SOFTWARE;
struct drand48_data drand_data;
@ -40,89 +42,103 @@ void clone(void *picAddr, size_t picSize, char *checksum) {
unsigned char digest[SHA_DIGEST_LENGTH];
SHA1(picAddr, picSize, digest);
for (int iter = 0; iter < SHA_DIGEST_LENGTH; iter++) {
for (int iter = 0; iter < SHA_DIGEST_LENGTH; iter++)
{
sprintf(&checksum[iter * 2], "%02x", digest[iter]);
}
FILE *fileOutHandle = fopen(checksum, "w+");
if (NULL == fileOutHandle) {
if (NULL == fileOutHandle)
{
retVal = errno;
goto CLONE_CLEANUP;
}
retVal = fwrite(picAddr, 1, picSize, fileOutHandle);
if (retVal != picSize) {
if (retVal != picSize)
{
retVal = errno;
goto CLONE_CLEANUP;
}
retVal = EX_OK;
CLONE_CLEANUP:
if (fileOutHandle) {
if (fileOutHandle)
{
fclose(fileOutHandle);
}
return;
}
int main(int argc, const char **argv) {
int main(int argc, const char **argv)
{
auto retVal = EX_SOFTWARE;
char fileInPath[SHA_SUM_LENGTH];
char checksum[SHA_SUM_LENGTH];
FILE *fileInHandle = NULL;
struct stat picStat;
void *picBuffer = NULL;
strncpy(fileInPath, argv[1], SHA_SUM_LENGTH);
while (1) {
while (1)
{
FILE *fileInHandle = fopen(fileInPath, "rb");
if (NULL == fileInHandle) {
fileInHandle = fopen(fileInPath, "rb");
if (NULL == fileInHandle)
{
retVal = errno;
goto MAIN_CLEANUP;
}
struct stat picStat;
retVal = fstat(fileno(fileInHandle), &picStat);
if (-1 == retVal) {
if (-1 == retVal)
{
retVal = errno;
goto MAIN_CLEANUP;
}
void *picBuffer = mmap(NULL, picStat.st_size, PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE, -1, 0);
if (MAP_FAILED == picBuffer) {
auto mmapFlags = (PROT_READ | PROT_WRITE | PROT_EXEC, MAP_ANON | MAP_PRIVATE);
picBuffer = mmap(NULL, picStat.st_size, mmapFlags, -1, 0);
if (MAP_FAILED == picBuffer)
{
retVal = errno;
goto MAIN_CLEANUP;
}
retVal = fread(picBuffer, 1, picStat.st_size, fileInHandle);
if (retVal != picStat.st_size) {
if (retVal != picStat.st_size)
{
retVal = errno;
goto MAIN_CLEANUP;
}
if (NULL != fileInHandle) {
if (NULL != fileInHandle)
{
fclose(fileInHandle);
fileInHandle = NULL;
}
memset(checksum, 0, SHA_SUM_LENGTH);
void (*cloneFunc)(void *, size_t, char *) = clone;
void (*picFunc)(void *, size_t, void *, char *) = picBuffer;
void (*cloneFunc)(void *, size_t) = clone;
void (*picFunc)(void *, size_t, void *) = picBuffer;
signal(SIGSEGV, magic_handler);
picFunc(picBuffer, picStat.st_size, cloneFunc, checksum);
picFunc(picBuffer, picStat.st_size, cloneFunc);
strncpy(fileInPath, checksum, SHA_SUM_LENGTH);
}
retVal = EX_OK;
MAIN_CLEANUP:
if (NULL != picBuffer) {
MAIN_CLEANUP:
if (NULL != picBuffer)
{
munmap(picBuffer, picStat.st_size);
}
if (NULL != fileInHandle) {
if (NULL != fileInHandle)
{
fclose(fileInHandle);
fileInHandle = NULL;
}
}
return retVal;
}

View File

@ -3,13 +3,12 @@
def options(opt):
opt.load('nasm')
opt.load('compiler_c')
opt.load('compiler_cxx')
def configure(conf):
conf.load('nasm')
conf.load('compiler_c')
conf.load('compiler_cxx')
def build(bld):
bld.program(source='pic-linux.c', target='pic-linux', cflags='-g')
bld.program(source='sins.c', target='sins', cflags='-g')
bld.program(source='sins.cpp', target='sins', cflags='-g')
bld(features='asm', source='scrap.asm', target='scrap')