URL
https://opencores.org/ocsvn/open8_urisc/open8_urisc/trunk
Subversion Repositories open8_urisc
[/] [open8_urisc/] [trunk/] [Open8 Tools/] [open8_src/] [open8_link/] [files.c] - Rev 209
Go to most recent revision | Compare with Previous | Blame | View Log
#include <ctype.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include "defines.h" #include "parse.h" #include "files.h" #include "analyze.h" extern struct object_file *obj_first, *obj_last, *obj_tmp; extern struct label *labels_first, *labels_last; extern unsigned char *file_header, *file_footer; extern int file_header_size, file_footer_size; char file_name_error[] = "???"; int load_files(char *argv[], int argc) { struct label *l; int st = STATE_NONE, i, x, line, bank, slot, base, bank_defined, slot_defined, base_defined, n; char tmp[1024], ou[1024]; FILE *fop; fop = fopen(argv[argc - 2], "rb"); if (fop == NULL) { fprintf(stderr, "LOAD_FILES: Could not open file \"%s\".\n", argv[argc - 2]); return FAILED; } line = 0; while (fgets(tmp, 255, fop) != NULL) { line++; x = 0; if (tmp[0] == ';' || tmp[0] == '*' || tmp[0] == '#' || tmp[0] == 0x0D || tmp[0] == 0x0A) continue; /* remove garbage from the end */ for (i = 0; !(tmp[i] == 0x0D || tmp[i] == 0x0A); i++); tmp[i] = 0; /* empty line check */ if (get_next_token(tmp, ou, &x) == FAILED) continue; /* first checks */ if (ou[0] == '[') { if (strcmp("[objects]", ou) == 0) { st = STATE_OBJECT; continue; } else if (strcmp("[libraries]", ou) == 0) { st = STATE_LIBRARY; continue; } else if (strcmp("[header]", ou) == 0) { st = STATE_HEADER; continue; } else if (strcmp("[footer]", ou) == 0) { st = STATE_FOOTER; continue; } else if (strcmp("[definitions]", ou) == 0) { st = STATE_DEFINITION; continue; } else { fprintf(stderr, "%s:%d LOAD_FILES: Unknown group \"%s\".\n", argv[argc - 2], line, ou); fclose(fop); return FAILED; } } if (st == STATE_NONE) { fprintf(stderr, "%s:%d: LOAD_FILES: Before file \"%s\" can be loaded you must define a group for it.\n", argv[argc - 2], line, ou); fclose(fop); return FAILED; } bank_defined = OFF; slot_defined = OFF; base_defined = OFF; bank = 0; slot = 0; base = 0; /* definition loading? */ if (st == STATE_DEFINITION) { l = malloc(sizeof(struct label)); if (l == NULL) { fprintf(stderr, "LOAD_FILES: Out of memory.\n"); return FAILED; } strcpy(l->name, ou); l->status = LABEL_STATUS_DEFINE; l->bank = 0; l->slot = 0; l->base = 0; if (get_next_number(&tmp[x], &n, &x) == FAILED) { fprintf(stderr, "%s:%d: LOAD_FILES: Error in DEFINITION value.\n", argv[argc - 2], line); fclose(fop); return FAILED; } l->address = n; add_label(l); continue; } /* header loading? */ else if (st == STATE_HEADER) { if (file_header != NULL) { fprintf(stderr, "%s:%d: LOAD_FILES: There can be only one header file.\n", argv[argc - 2], line); fclose(fop); return FAILED; } if (load_file_data(ou, &file_header, &file_header_size) == FAILED) { fclose(fop); return FAILED; } if (get_next_token(&tmp[x], ou, &x) == FAILED) continue; fprintf(stderr, "%s:%d: LOAD_FILES: Syntax error.\n", argv[argc - 2], line); fclose(fop); return FAILED; } /* footer loading? */ else if (st == STATE_FOOTER) { if (file_footer != NULL) { fprintf(stderr, "%s:%d: LOAD_FILES: There can be only one footer file.\n", argv[argc - 2], line); fclose(fop); return FAILED; } if (load_file_data(ou, &file_footer, &file_footer_size) == FAILED) { fclose(fop); return FAILED; } if (get_next_token(&tmp[x], ou, &x) == FAILED) continue; fprintf(stderr, "%s:%d: LOAD_FILES: Syntax error.\n", argv[argc - 2], line); fclose(fop); return FAILED; } /* library loading? */ else if (st == STATE_LIBRARY) { i = SUCCEEDED; while (i == SUCCEEDED) { if (strcmp(ou, "bank") == 0 || strcmp(ou, "BANK") == 0) { if (bank_defined == ON) { fprintf(stderr, "%s:%d: LOAD_FILES: BANK defined for the second time for a library file.\n", argv[argc - 2], line); fclose(fop); return FAILED; } bank_defined = ON; if (get_next_number(&tmp[x], &bank, &x) == FAILED) { fprintf(stderr, "%s:%d: LOAD_FILES: Error in BANK number.\n", argv[argc - 2], line); fclose(fop); return FAILED; } } else if (strcmp(ou, "slot") == 0 || strcmp(ou, "SLOT") == 0) { if (slot_defined == ON) { fprintf(stderr, "%s:%d: LOAD_FILES: SLOT defined for the second time for a library file.\n", argv[argc - 2], line); fclose(fop); return FAILED; } slot_defined = ON; if (get_next_number(&tmp[x], &slot, &x) == FAILED) { fprintf(stderr, "%s:%d: LOAD_FILES: Error in SLOT number.\n", argv[argc - 2], line); fclose(fop); return FAILED; } } else if (strcmp(ou, "base") == 0 || strcmp(ou, "BASE") == 0) { if (base_defined == ON) { fprintf(stderr, "%s:%d: LOAD_FILES: BASE defined for the second time for a library file.\n", argv[argc - 2], line); fclose(fop); return FAILED; } base_defined = ON; if (get_next_number(&tmp[x], &base, &x) == FAILED) { fprintf(stderr, "%s:%d: LOAD_FILES: Error in BASE number.\n", argv[argc - 2], line); fclose(fop); return FAILED; } } else break; i = get_next_token(&tmp[x], ou, &x); } if (i == FAILED) { fprintf(stderr, "%s:%d: LOAD_FILES: No library to load.\n", argv[argc - 2], line); fclose(fop); return FAILED; } if (slot_defined == OFF) { fprintf(stderr, "%s:%d: LOAD_FILES: Library file requires a SLOT.\n", argv[argc - 2], line); fclose(fop); return FAILED; } if (bank_defined == OFF) { fprintf(stderr, "%s:%d: LOAD_FILES: Library file requires a BANK.\n", argv[argc - 2], line); fclose(fop); return FAILED; } if (load_file(ou, STATE_LIBRARY, bank, slot, base, base_defined) == FAILED) { fclose(fop); return FAILED; } if (get_next_token(&tmp[x], ou, &x) == SUCCEEDED) { fprintf(stderr, "%s:%d: LOAD_FILES: Syntax error.\n", argv[argc - 2], line); fclose(fop); return FAILED; } continue; } /* object file loading */ else if (load_file(ou, STATE_OBJECT, 0, 0, 0, OFF) == FAILED) { fclose(fop); return FAILED; } if (get_next_token(&tmp[x], ou, &x) == FAILED) continue; fprintf(stderr, "%s:%d: LOAD_FILES: Syntax error.\n", argv[argc - 2], line); fclose(fop); return FAILED; } fclose(fop); return SUCCEEDED; } int load_file(char *fn, int state, int bank, int slot, int base, int base_defined) { struct object_file *o; unsigned char *data; static int id = 0; char *n; int size; o = malloc(sizeof(struct object_file)); n = malloc(strlen(fn)+1); if (o == NULL || n == NULL) { if (o != NULL) free(o); if (n != NULL) free(n); fprintf(stderr, "LOAD_FILE: Out of memory.\n"); return FAILED; } if (load_file_data(fn, &data, &size) == FAILED) { free(n); free(o); return FAILED; } /* only valid for library files */ o->bank = bank; o->slot = slot; o->base = base; o->base_defined = base_defined; /* init the rest of the variables */ o->source_file_names = NULL; o->memorymap = NULL; o->exported_defines = NULL; o->data_blocks = NULL; o->source_file_names_list = NULL; if (obj_first == NULL) { obj_first = o; obj_last = o; } else { obj_last->next = o; obj_last = o; } o->next = NULL; o->size = size; o->data = data; strcpy(n, fn); o->name = n; o->id = id++; return SUCCEEDED; } int load_file_data(char *fn, unsigned char **da, int *size) { FILE *fop; fop = fopen(fn, "rb"); if (fop == NULL) { fprintf(stderr, "LOAD_FILE_DATA: Could not open file \"%s\".\n", fn); return FAILED; } fseek(fop, 0, SEEK_END); *size = ftell(fop); fseek(fop, 0, SEEK_SET); *da = malloc(*size); if (*da == NULL) return FAILED; fread(*da, 1, *size, fop); fclose(fop); return SUCCEEDED; } char *get_file_name(int id) { static char e[] = "GET_FILE_NAME: Internal data corruption."; struct object_file *o; o = obj_first; while (o != NULL) { if (o->id == id) return o->name; o = o->next; } return e; } char *get_source_file_name(int file_id, int source_id) { struct source_file_name *s; struct object_file *o; o = obj_first; while (o != NULL) { if (o->id == file_id) break; o = o->next; } if (o == NULL) return file_name_error; s = o->source_file_names_list; while (s != NULL) { if (s->id == source_id) break; s = s->next; } if (s == NULL) return file_name_error; return s->name; }
Go to most recent revision | Compare with Previous | Blame | View Log