diff options
-rw-r--r-- | crypto-search.cpp | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/crypto-search.cpp b/crypto-search.cpp new file mode 100644 index 0000000..8775095 --- /dev/null +++ b/crypto-search.cpp @@ -0,0 +1,91 @@ +/* + * PSX-Tools Bundle Pack + * Copyright (C) 2002 Nicolas "Pixel" Noble + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +#include <stdio.h> +#include <stdlib.h> +#include <values.h> +#include <string.h> +#include <unistd.h> +#include "generic.h" +#include "fileutils.h" + +int main(int argc, char ** argv) { + int h, size, mind, maxd, delta, len, i, j; + char * buffer, * str; + + if (argc != 3) { + printm(M_BARE, "Usage: %s <inputfile> <needle>\n", argv[0]); + exit(-1); + } + + verbosity = M_INFO; + + if ((h = open(argv[1], O_RDONLY)) < 0) { + printm(M_ERROR, "Unable to open file %s\n", argv[1]); + exit(-1); + } + + str = argv[2]; + size = filesize(h); + + printm(M_STATUS, "Requesting memory (%i bytes)\n", size); + + if (!(buffer = (char *) malloc(size))) { + printm(M_ERROR, "Not enough memory.\n"); + exit(-1); + } + + printm(M_STATUS, "Loading file...\n"); + read(h, buffer, size); + + printm(M_STATUS, "Done, initialising the search.\n"); + len = strlen(argv[2]); + + mind = MININT; + maxd = MAXINT; + + for (i = 0; i < len; i++) { + mind = (mind < (-str[i])) ? -str[i] : mind; + maxd = (maxd > (255 - str[i])) ? 255 - str[i] : maxd; + } + + printm(M_STATUS, "Min Delta = %i, Max Delta = %i\n", mind, maxd); + + printm(M_STATUS, "Beginning searching...\n"); + + for (i = 0; i < (size - len); i++) { + delta = buffer[i] - str[0]; + if ((delta >= mind) && (delta <= maxd)) { + int good = 1; + for (j = 1; j < len; j++) { + if (((delta + str[j]) != buffer[i + j]) && (str[j] != '.')) { + good = 0; + break; + } + } + if (good) { + printm(M_STATUS, "Found a needle at %i = 0x%08x with delta %i:", i, i, delta); + for (j = 0; j < len; j++) { + printm(M_BARE, "%c", buffer[j + i]); + } + printm(M_BARE, "\n"); + } + } + } +} |