FreeCalypso > hg > freecalypso-reveng
view dspanal/char2coff.c @ 350:b2bf3088b660
fluid-mnf/devices.txt: original version from TI's FLUID package
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 13 Mar 2020 06:57:50 +0000 |
parents | f8344bc4fd61 |
children |
line wrap: on
line source
/* * This program will convert C char array files into COFF * for disassembly analysis. */ #include <sys/types.h> #include <stdio.h> #include <stdint.h> #include <stdlib.h> #include "coffout.h" extern unsigned read_char_file(); static u_char binbuffer[300000]; static unsigned array_size; static u_char *array_ptr, *array_end; #define MAX_SECTIONS 256 static struct coff_section sections[MAX_SECTIONS]; static unsigned nsections; static void add_section(addr, size, data) uint32_t addr, size; u_char *data; { struct coff_section *sec; if (nsections >= MAX_SECTIONS) { fprintf(stderr, "error: too many sections\n"); exit(1); } sec = sections + nsections; sec->addr = addr; sec->size = size; sec->data = data; sec->flags = 0x0020; sec->mempage = 0x00; nsections++; } static uint32_t get_longword() { uint32_t datum; if (array_ptr + 4 > array_end) { fprintf(stderr, "error: parse spills past end of array\n"); exit(1); } datum = (array_ptr[3] << 24) | (array_ptr[2] << 16) | (array_ptr[1] << 8) | array_ptr[0]; array_ptr += 4; return datum; } main(argc, argv) char **argv; { uint32_t addr, size; if (argc != 3) { fprintf(stderr, "usage: %s char-array-file coff-output-file\n", argv[0]); exit(1); } array_size = read_char_file(argv[1], binbuffer, sizeof binbuffer); array_ptr = binbuffer; array_end = array_ptr + array_size; if (get_longword() != 0) { fprintf(stderr, "error: initial tag 0 is missing\n"); exit(1); } if (get_longword() != 3) { fprintf(stderr, "error: initial vers 3 is missing\n"); exit(1); } for (;;) { size = get_longword(); if (size > 0x10000) { fprintf(stderr, "error: section size unreasonable\n"); exit(1); } addr = get_longword(); if (!size) break; add_section(addr, size, array_ptr); array_ptr += size << 1; } emit_coff_output(argv[2], sections, nsections); exit(0); }