scrap-is-not-scrap/sins.cpp

144 lines
3.2 KiB
C++
Raw Normal View History

2016-01-08 19:47:59 +00:00
#include <stdio.h>
#include <stdlib.h>
2016-01-13 01:05:45 +00:00
#include <malloc.h>
#include <time.h>
2016-01-08 19:47:59 +00:00
#include <string.h>
#include <errno.h>
#include <sysexits.h>
2016-01-13 01:05:45 +00:00
#include <sys/mman.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
2016-01-08 19:47:59 +00:00
#include <openssl/sha.h>
2016-01-13 23:32:51 +00:00
#include <signal.h>
2016-01-08 19:47:59 +00:00
2016-01-08 23:31:31 +00:00
#pragma comment(lib, "openssl/sha.lib")
#define SHA_SUM_LENGTH (SHA_DIGEST_LENGTH + SHA_DIGEST_LENGTH + 1)
2016-06-27 23:54:47 +00:00
void picProto(void *picAddr, size_t picSize, void *clonePtr)
{
void (*cloneFunc)(void *, size_t) = clonePtr;
cloneFunc(picAddr, picSize);
return;
2016-01-08 19:47:59 +00:00
}
2016-06-27 23:54:47 +00:00
void clone(void *picAddr, size_t picSize)
{
auto retVal = EX_SOFTWARE;
2016-01-08 19:47:59 +00:00
2016-06-27 23:54:47 +00:00
struct drand48_data drand_data;
srand48_r(time(NULL), &drand_data);
long int randVal;
lrand48_r(&drand_data, &randVal);
2016-01-08 19:47:59 +00:00
2016-06-27 23:54:47 +00:00
unsigned int picOffset = (randVal % (picSize + 1));
unsigned char picFlip = ((char *)picAddr)[picOffset] & (randVal % 2);
2016-06-27 23:54:47 +00:00
printf("%x\t%x\n", picOffset, picFlip);
2016-01-08 19:47:59 +00:00
2016-06-27 23:54:47 +00:00
((char *)picAddr)[picOffset] = picFlip;
2016-01-08 19:47:59 +00:00
2016-06-27 23:54:47 +00:00
unsigned char digest[SHA_DIGEST_LENGTH];
SHA1(picAddr, picSize, digest);
2016-01-08 19:47:59 +00:00
2016-06-27 23:54:47 +00:00
for (int iter = 0; iter < SHA_DIGEST_LENGTH; iter++)
{
sprintf(&checksum[iter * 2], "%02x", digest[iter]);
}
2016-06-27 23:54:47 +00:00
FILE *fileOutHandle = fopen(checksum, "w+");
if (NULL == fileOutHandle)
{
retVal = errno;
goto CLONE_CLEANUP;
}
2016-06-27 23:54:47 +00:00
retVal = fwrite(picAddr, 1, picSize, fileOutHandle);
if (retVal != picSize)
{
retVal = errno;
goto CLONE_CLEANUP;
}
2016-06-27 23:54:47 +00:00
retVal = EX_OK;
CLONE_CLEANUP:
if (fileOutHandle)
{
fclose(fileOutHandle);
}
2016-06-27 23:54:47 +00:00
return;
}
2016-06-27 23:54:47 +00:00
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)
{
fileInHandle = fopen(fileInPath, "rb");
if (NULL == fileInHandle)
{
retVal = errno;
goto MAIN_CLEANUP;
}
retVal = fstat(fileno(fileInHandle), &picStat);
if (-1 == retVal)
{
retVal = errno;
goto MAIN_CLEANUP;
}
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)
{
retVal = errno;
goto MAIN_CLEANUP;
}
if (NULL != fileInHandle)
{
fclose(fileInHandle);
fileInHandle = NULL;
}
memset(checksum, 0, SHA_SUM_LENGTH);
void (*cloneFunc)(void *, size_t) = clone;
void (*picFunc)(void *, size_t, void *) = picBuffer;
picFunc(picBuffer, picStat.st_size, cloneFunc);
strncpy(fileInPath, checksum, SHA_SUM_LENGTH);
}
retVal = EX_OK;
2016-06-27 23:54:47 +00:00
MAIN_CLEANUP:
if (NULL != picBuffer)
{
munmap(picBuffer, picStat.st_size);
}
2016-06-27 23:54:47 +00:00
if (NULL != fileInHandle)
{
fclose(fileInHandle);
fileInHandle = NULL;
}
2016-01-08 19:47:59 +00:00
2016-06-27 23:54:47 +00:00
return retVal;
}