summaryrefslogtreecommitdiffstats
path: root/tools/cpu/nios2/linkcmds.c
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2011-05-17 20:39:40 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2011-05-17 20:39:40 +0000
commitd751cecbb1ca1b7ac0a7bc8492e0e61e6c5fc0c7 (patch)
tree84a74c59b9f7f096e0fae3dd351e5274bf836bb5 /tools/cpu/nios2/linkcmds.c
parent2011-05-17 Joel Sherrill <joel.sherrill@oarcorp.com> (diff)
downloadrtems-d751cecbb1ca1b7ac0a7bc8492e0e61e6c5fc0c7.tar.bz2
* tools/build/.cvsignore, tools/build/ChangeLog,
tools/build/Makefile.am, tools/build/README, tools/build/binpatch.c, tools/build/cklength.c, tools/build/config.h.in, tools/build/configure.ac, tools/build/cvsignore-add.sh, tools/build/doxy-filter, tools/build/eolstrip.c, tools/build/install-if-change.in, tools/build/multigen, tools/build/packhex.c, tools/build/rtems-bin2c.c, tools/build/search-id.sh, tools/build/unhex.c, tools/cpu/.cvsignore, tools/cpu/ChangeLog, tools/cpu/Makefile.am, tools/cpu/configure.ac, tools/cpu/generic/.cvsignore, tools/cpu/generic/ChangeLog, tools/cpu/generic/Makefile.am, tools/cpu/generic/configure.ac, tools/cpu/generic/size_rtems.in, tools/cpu/nios2/.cvsignore, tools/cpu/nios2/ChangeLog, tools/cpu/nios2/Makefile.am, tools/cpu/nios2/README, tools/cpu/nios2/bridges.c, tools/cpu/nios2/bridges.h, tools/cpu/nios2/clocks.c, tools/cpu/nios2/clocks.h, tools/cpu/nios2/configure.ac, tools/cpu/nios2/devices.c, tools/cpu/nios2/devices.h, tools/cpu/nios2/linkcmds.c, tools/cpu/nios2/linkcmds.h, tools/cpu/nios2/memory.c, tools/cpu/nios2/memory.h, tools/cpu/nios2/nios2gen.c, tools/cpu/nios2/output.c, tools/cpu/nios2/output.h, tools/cpu/nios2/ptf.c, tools/cpu/nios2/ptf.h, tools/cpu/nios2/sample.ptf, tools/cpu/sh/.cvsignore, tools/cpu/sh/AUTHORS, tools/cpu/sh/COPYING, tools/cpu/sh/ChangeLog, tools/cpu/sh/Makefile.am, tools/cpu/sh/TODO, tools/cpu/sh/configure.ac, tools/cpu/sh/sci.c, tools/cpu/sh/sci.h, tools/cpu/sh/shgen.c: New files.
Diffstat (limited to '')
-rw-r--r--tools/cpu/nios2/linkcmds.c122
1 files changed, 122 insertions, 0 deletions
diff --git a/tools/cpu/nios2/linkcmds.c b/tools/cpu/nios2/linkcmds.c
new file mode 100644
index 0000000000..28a71cbbc0
--- /dev/null
+++ b/tools/cpu/nios2/linkcmds.c
@@ -0,0 +1,122 @@
+/*
+ * Copyright (c) 2006 Kolja Waschk rtemsdev/ixo.de
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.com/license/LICENSE.
+ *
+ * $Id$
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "ptf.h"
+#include "devices.h"
+#include "output.h" /* is_not_connected, fwrite_value, etc */
+#include "memory.h"
+#include "linkcmds.h"
+
+typedef struct
+{
+ FILE *file;
+ struct ptf *cfg, *cpu;
+ device_desc *devices;
+ memory_desc *memory;
+}
+lcmd_desc;
+
+void fwrite_lcmds_section(struct ptf_item *pi, void *arg)
+{
+ lcmd_desc *li = (lcmd_desc *)arg;
+ struct ptf *p;
+ struct ptf_item lpi;
+ char *location = NULL;
+ char *section_name = pi->item[1]->value;
+
+ if(section_name == 0)
+ {
+ fprintf(stderr, "Found a LINKER/SECTION without name, ignoring it.\n");
+ return;
+ };
+
+ p = ptf_find(pi->item[1]->sub, &lpi, item, "LOCATION", 0);
+ if(p)
+ {
+ location = p->value;
+ }
+ else
+ {
+ if(strcmp(section_name, "entry") == 0)
+ {
+ p = ptf_find(li->cpu, &lpi, item, "reset_slave", 0);
+ }
+ else if(strcmp(section_name, "exceptions") == 0)
+ {
+ p = ptf_find(li->cpu, &lpi, item, "exc_slave", 0);
+ };
+ if(p) location = p->value;
+ /* TODO: This doesn't work yet, parse full slave address, translate into our naming */
+ }
+
+ if(location == 0)
+ {
+ fprintf(stderr, "No LOCATION configured for section '%s'!\n", pi->item[1]->value);
+ return;
+ };
+
+ fprintf(li->file, " .%s :\n {\n", pi->item[1]->value);
+ fprintf(li->file, pi->item[2]->value);
+ fprintf(li->file, " } > %s\n\n", location);
+}
+
+void fwrite_linkcmds_file(FILE *file, struct ptf *cfg, struct ptf *cpu, device_desc *devices, memory_desc *memory)
+{
+ struct ptf *p;
+ struct ptf_item pi;
+ memory_desc *tmd;
+ lcmd_desc linfo;
+
+ struct ptf ptlink = { section, "LINKCMDS", 0, 0, 0 };
+ struct ptf ptleadtext = { item, "LEADTEXT", 0, 0, 0 };
+ struct ptf ptepilog = { item, "EPILOG", 0, 0, 0 };
+ struct ptf_item malihead = { 2, &ptlink, &ptleadtext };
+ struct ptf_item maliepil = { 2, &ptlink, &ptepilog };
+
+ struct ptf ptsect = { section, "SECTION", 0, 0, 0 };
+ struct ptf ptcmds = { item, "COMMANDS", 0, 0, 0 };
+ struct ptf ptstabs = { item, "STABS", 0, 0, 0 };
+ struct ptf_item malisect = { 3, &ptlink, &ptsect, &ptcmds };
+ struct ptf_item malistabs = { 2, &ptlink, &ptstabs };
+
+ linfo.cfg = cfg;
+ linfo.cpu = cpu;
+ linfo.file = file;
+ linfo.devices = devices;
+ linfo.memory = memory;
+
+ ptf_match(cfg, &malihead, fwrite_value, file);
+
+ fprintf(file, "MEMORY\n{\n");
+ for(tmd = linfo.memory; tmd; tmd = tmd->next)
+ {
+ fprintf(file, " %s : ORIGIN = 0x%08X, LENGTH = 0x%08X\n", tmd->dev->cfgname, tmd->base, tmd->size);
+ }
+ fprintf(file, "}\n\nSECTIONS\n{\n");
+
+ ptf_match(cfg, &malisect, fwrite_lcmds_section, &linfo);
+ ptf_match(cfg, &malistabs, fwrite_value, file);
+
+ for(tmd = linfo.memory; tmd; tmd = tmd->next)
+ {
+ fprintf(file, " %s : ORIGIN = 0x%08X, LENGTH = 0x%08X\n", tmd->dev->cfgname, tmd->base, tmd->size);
+ }
+
+
+ fprintf(file, "}\n\n");
+
+ ptf_match(cfg, &maliepil, fwrite_value, file);
+}
+
+