I have another file (card.raw) that I have to check for deleted images. I read a buffer into memory then check if it is the start of an image and if it is I write the first buffer, if it is not the start of a new image it keeps on writing till the next image starts. The images are back to back in the card.raw file. I have placed a few printf functions in the code and I have isolated the segfault to the last fwrite function but I have no idea what is causing it. I have tried Valgrind but I am not sure what the output means or how to fix it.
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
int main(int argc, char *argv[])
{
FILE *raw = fopen(argv[1], "r");
int SIZE = sizeof(raw);
int buffer[512];
int JPEG_num = 0;
FILE *img[50];
char filename[4];
for(int j = 0; j < SIZE; j++)
{
for(int i = 0; i < 512; i++)
{
fread(&buffer[i], 1, 1, raw);
}
if(buffer[0] == 0xff)
{
if(buffer[1] == 0xd8)
{
if(buffer[2] == 0xff)
{
if(buffer[3] >= 0xe0 && buffer[3] <= 0xef)
{
if(JPEG_num == 0)
{
sprintf(filename, "%03i.jpg", 0);
img[0] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[0]);
JPEG_num++;
}
else
{
fclose(img[0]);
sprintf(filename, "%03i.jpg", JPEG_num);
img[JPEG_num] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[JPEG_num]);
JPEG_num++;
}
}
}
}
}
else
{
if(JPEG_num != 0)
{
fwrite(&buffer, 1, 512, img[JPEG_num]);
JPEG_num++;
}
}
}
fclose(img[JPEG_num]);
}
EDIT
I changed the filename size and the if conditions and the SIZE integer to the size of a pointer(I'm not sure if I did this correctly like suggested)
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
int main(int argc, char *argv[])
{
FILE *raw = fopen(argv[1], "r");
int SIZE = sizeof(*raw);
int buffer[512];
int JPEG_num = 0;
FILE *img[50];
char filename[9];
for(int j = 0; j < SIZE; j++)
{
for(int i = 0; i < 512; i++)
{
fread(&buffer[i], 1, 1, raw);
}
if(buffer[0] == 0xff && buffer[1] == 0xd8 && (buffer[3] >= 0xe0 && buffer[3] <= 0xef))
{
if(JPEG_num == 0)
{
sprintf(filename, "%03i.jpg", 0);
img[0] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[0]);
JPEG_num++;
}
else
{
fclose(img[0]);
sprintf(filename, "%03i.jpg", JPEG_num);
img[JPEG_num] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[JPEG_num]);
JPEG_num++;
}
}
else
{
if(JPEG_num != 0)
{
fwrite(&buffer, 1, 512, img[JPEG_num]);
JPEG_num++;
}
}
}
fclose(img[JPEG_num]);
}
EDIT
I removed the int SIZE = sizeof(*raw);
and just changed the for(int j = 0; j < SIZE; j++)
loop to a while (fread(buffer, 1, 512, raw) == 512)
loop
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
int main(int argc, char *argv[])
{
FILE *raw = fopen(argv[1], "r");
int buffer[512];
int JPEG_num = 0;
FILE *img[50];
char filename[260];
while( fread(buffer, 1, 512, raw) == 512 )
{
for(int i = 0; i < 512; i++)
{
fread(&buffer[i], 1, 1, raw);
}
if(buffer[0] == 0xff && buffer[1] == 0xd8 && buffer[2] == 0xff && (buffer[3] >= 0xe0 && buffer[3] <= 0xef))
{
printf("A\n");
if(JPEG_num == 0)
{
sprintf(filename, "%03i.jpg", 0);
img[0] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[0]);
}
else
{
fclose(img[JPEG_num - 1]);
sprintf(filename, "%03i.jpg", JPEG_num);
img[JPEG_num] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[JPEG_num]);
JPEG_num++;
}
}
else
{
if(JPEG_num != 0)
{
fwrite(&buffer, 1, 512, img[JPEG_num]);
}
}
}
fclose(img[JPEG_num]);
}
EDIT
I placed a few printf
functions to see where the problem lies. It just prints out 1 and 2. It never enters the if condition.
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
int main(int argc, char *argv[])
{
FILE *raw = fopen(argv[1], "r");
int buffer[512];
int JPEG_num = 0;
FILE *img[50];
char filename[260];
while( fread(buffer, 1, 512, raw) == 512 )
{
printf("1\n");
for(int i = 0; i < 512; i++)
{
fread(&buffer[i], 1, 1, raw);
}
printf("2\n");
if(buffer[0] == 0xff && buffer[1] == 0xd8 && buffer[2] == 0xff && (buffer[3] >= 0xe0 && buffer[3] <= 0xef))
{
printf("A\n");
if(JPEG_num == 0)
{
printf("B\n");
sprintf(filename, "%03i.jpg", 0);
printf("C\n");
img[0] = fopen(filename, "w");
printf("D\n");
fwrite(&buffer, 1, 512, img[0]);
printf("E\n");
}
else
{
printf("!\n");
fclose(img[JPEG_num - 1]);
printf("@\n");
sprintf(filename, "%03i.jpg", JPEG_num);
printf("#\n");
img[JPEG_num] = fopen(filename, "w");
printf("^\n");
fwrite(&buffer, 1, 512, img[JPEG_num]);
printf("&\n");
JPEG_num++;
}
}
else
{
if(JPEG_num != 0)
{
printf("3\n");
fwrite(&buffer, 1, 512, img[JPEG_num]);
printf("4\n");
}
}
}
fclose(img[JPEG_num]);
}
EDIT
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
int main(int argc, char *argv[])
{
FILE *raw = fopen(argv[1], "r");
int buffer[512];
int JPEG_num = 0;
FILE *img[50];
char filename[260];
while (fread(buffer, 1, 512, raw) == 512)
{
if(buffer[0] == 0xff && buffer[1] == 0xd8 && buffer[2] == 0xff && (buffer[3] >= 0xe0 && buffer[3] <= 0xef))
{
if(JPEG_num == 0)
{
sprintf(filename, "%03i.jpg", 0);
img[0] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[0]);
}
else
{
fclose(img[JPEG_num - 1]);
sprintf(filename, "%03i.jpg", JPEG_num);
img[JPEG_num] = fopen(filename, "w");
fwrite(&buffer, 1, 512, img[JPEG_num]);
JPEG_num++;
}
}
else
{
if(JPEG_num != 0)
{
fwrite(&buffer, 1, 512, img[JPEG_num]);
}
}
}
fclose(img[JPEG_num]);
}