Req to commit: Changes for hs16 build

Edward Nevill ed at camswl.com
Thu Oct 29 10:30:27 PDT 2009


Hi folks,

The following changes make ARM build with hs16 and fix the broken build for Shark on ARM.

The changes are as follows

- Move mkbc.c from toplevel to ports/hotspot/tools
- Remove rules to generate 'mkbc' and 'bytecodes_arm.s' from toplevel Makefile.am
- Add rules to generate 'mkbc' and 'bytecodes_arm.s' to zero.make
- Add -DDISABLE_NOTICE_SAFEPOINTS to cppInterpreter_arm.s and bytecodes_arm.def for SHARK

Ok to commit?

Regards,
Ed.

----------------------------------------------------------------------------------------------
diff -ruNE old/icedtea6/Makefile.am new/icedtea6/Makefile.am
--- old/icedtea6/Makefile.am	2009-10-28 15:02:32.000000000 +0000
+++ new/icedtea6/Makefile.am	2009-10-29 13:33:37.000000000 +0000
@@ -489,36 +489,10 @@
 	rm -f $(NETBEANS_PROFILER_SRC_ZIP)
 endif
 
-# Build asm interpreter bytecodes
-ZERO_ASM_BC_DEF = $(abs_top_srcdir)/ports/hotspot/src/cpu/zero/vm/bytecodes_$(ZERO_LIBARCH).def
-ZERO_ASM_BC_ASM = $(abs_top_srcdir)/ports/hotspot/src/cpu/zero/vm/bytecodes_$(ZERO_LIBARCH).s
-ZERO_ASM_BC_ASM_COND = $(shell test -f ${ZERO_ASM_BC_DEF} && echo ${ZERO_ASM_BC_ASM})
-
-$(abs_top_srcdir)/mkbc: $(abs_top_srcdir)/mkbc.c
-	$(CC) $< -o $@
-
-# ECN: The following rule has been changed to allow preprocessing of the bytecode definition
-# file prior to running 'mkbc'. This allows you to use -DXXX on the gcc command. There are two
-# options currently recognized.
-#
-# -DDISABLE_NOTICE_SAFEPONTS	- Always run in 'safe' mode.
-# -DDISABLE_FAST_BYTECODES	- Disable fast bytecode replacement and bytecode sequences
-#
-# These options are provided mainly to assist debugging by returning the bytecode interpreter
-# to a 'vanilla' interpreter.
-#
-if SHARK_BUILD
-${ZERO_ASM_BC_ASM}: ${ZERO_ASM_BC_DEF} $(abs_top_srcdir)/mkbc
-	gcc -E -DDISABLE_NOTICE_SAFEPOINTS - < $< | $(abs_top_srcdir)/mkbc - $@
-else
-${ZERO_ASM_BC_ASM}: ${ZERO_ASM_BC_DEF} $(abs_top_srcdir)/mkbc
-	gcc -E - < $< | $(abs_top_srcdir)/mkbc - $@
-endif
-
-
 # Copy ports sources into tree
 stamps/ports.stamp: stamps/replace-hotspot.stamp
 	for target in $(abs_top_srcdir)/ports/hotspot/build/*/makefiles/* \
+		      $(abs_top_srcdir)/ports/hotspot/tools \
 		      $(abs_top_srcdir)/ports/hotspot/src/*cpu/* \
 		      $(abs_top_srcdir)/ports/hotspot/src/share/vm/*; do \
 	  link=$$(dirname $$target | sed 's/^.*ports/openjdk/'|sed "s#hotspot/build#hotspot/$(HOTSPOT_MAKE_DIR)#"); \
@@ -1104,7 +1078,7 @@
 	stamps/ports.stamp stamps/patch.stamp stamps/overlay.stamp \
 	$(ICEDTEAPLUGIN_TARGET) $(ICEDTEANPPLUGIN_TARGET) \
 	extra-lib/about.jar stamps/cacao.stamp stamps/visualvm.stamp \
-	stamps/pulse-java.stamp $(ZERO_ASM_BC_ASM_COND)
+	stamps/pulse-java.stamp
 	$(ARCH_PREFIX) $(MAKE) \
 	  $(ICEDTEA_ENV) \
 	  -C openjdk \
@@ -1201,7 +1175,7 @@
 	stamps/ports.stamp stamps/patch.stamp stamps/overlay.stamp \
 	$(ICEDTEAPLUGIN_TARGET) $(ICEDTEANPPLUGIN_TARGET) \
 	extra-lib/about.jar stamps/cacao.stamp stamps/visualvm.stamp \
-	stamps/pulse-java.stamp $(ZERO_ASM_BC_ASM_COND)
+	stamps/pulse-java.stamp
 	$(ARCH_PREFIX) $(MAKE) \
 	  $(ICEDTEA_ENV) \
 	  -C openjdk \
@@ -1325,8 +1299,7 @@
 
 stamps/icedtea-ecj.stamp: stamps/bootstrap-directory-symlink-ecj.stamp \
 	stamps/hotspot-tools.stamp stamps/plugs.stamp \
-	stamps/patch-ecj.stamp stamps/cacao.stamp \
-	$(ZERO_ASM_BC_ASM_COND)
+	stamps/patch-ecj.stamp stamps/cacao.stamp
 	$(ARCH_PREFIX) $(MAKE) \
 	  $(ICEDTEA_ENV_ECJ) \
 	  -C openjdk-ecj/ \
diff -ruNE old/icedtea6/mkbc.c new/icedtea6/mkbc.c
--- old/icedtea6/mkbc.c	2009-10-28 15:02:33.000000000 +0000
+++ new/icedtea6/mkbc.c	1970-01-01 01:00:00.000000000 +0100
@@ -1,605 +0,0 @@
-/*
- * Copyright 2009 Edward Nevill
- *
- * This code is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License version 2 only, as
- * published by the Free Software Foundation.
- *
- * This code 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
- * version 2 for more details (a copy is included in the LICENSE file that
- * accompanied this code).
- */
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <ctype.h>
-
-#define DEFAULT_PREFIX	"do_"
-
-static char *prefix = DEFAULT_PREFIX;
-
-#define ISALPHA(c) (isalpha(c) || (c) == '_')
-#define ISALNUM(c) (isalnum(c) || (c) == '_')
-
-FILE *source_f, *bci_f;
-
-typedef struct Bytecode {
-	char	*name;
-	int	len;
-} Bytecode;
-
-typedef struct StringList {
-	struct StringList *next;
-	char 		*line;
-} StringList;
-
-typedef struct OpcodeList {
-	struct OpcodeList *next;
-	long	 	opcode;
-} OpcodeList;
-
-typedef struct OpcodeSequence {
-	struct OpcodeSequence *next;
-	OpcodeList	*opcode_list;
-} OpcodeSequence;
-
-typedef struct BytecodeImpl {
-	struct BytecodeImpl *next;
-	OpcodeSequence	*opcode_seq;
-	StringList	*macro_impl;
-	StringList	*direct_impl;
-	int		len;
-	char		*name;
-	char		*do_name;
-} BytecodeImpl;
-
-Bytecode bytecodes[256];
-
-BytecodeImpl *the_impl = 0;
-BytecodeImpl **the_impl_ptr = &the_impl;
-
-#define BUFLEN 1024
-
-static int lineno = 1;
-
-void fatal(const char *s)
-{
-	fputs(s, stderr);
-	fputc('\n', stderr);
-	exit(1);
-}
-
-void outmem(void)
-{
-	fprintf(stderr, "Out of memory\n");
-	exit(1);
-}
-
-void synerr(void)
-{
-	fprintf(stderr, "Syntax error at line %d\n", lineno);
-	exit(1);
-}
-
-int readchar()
-{
-	int c;
-
-	c = getc(source_f);
-	if (c == '\n') lineno++;
-	return c;
-}
-
-int readwhitespace(int c, char *buf, int len)
-{
-	int i = 0;
-
-	while ((isspace)(c)) {
-		if (buf && i < len-1) buf[i++] = c;
-		c = (readchar)();
-	}
-	if (buf && i < len) buf[i] = 0;
-	return c;
-}
-
-int skipwhitespace(int c)
-{
-	while ((isspace)(c)) {
-		c = (readchar)();
-	}
-	return c;
-}
-
-int readeol(int c, char *buf, int len)
-{
-	int i = 0;
-
-	while (c != '\n' && c != EOF) {
-		if (buf && i < len-1) buf[i++] = c;
-		c = (readchar)();
-	}
-	if (buf && i < len) buf[i] = 0;
-	if (c == '\n') c = (readchar)();
-	return c;
-}
-
-int skipeol(int c)
-{
-	while (c != '\n' && c != EOF) c = (readchar)();
-	if (c == '\n') c = (readchar)();
-	return c;
-}
-
-int readsymbol(int c, char *buf, int len)
-{
-	int i = 0;
-
-	while (ISALNUM(c)) {
-		if (buf && i < len-1) buf[i++] = c;
-		c = (readchar)();
-	}
-	if (buf && i < len) buf[i] = 0;
-	return c;
-}
-
-int bcdef(int c, char *buf, int len)
-{
-	BytecodeImpl *def;
-	OpcodeSequence *seq;
-	OpcodeSequence **seqp;
-	OpcodeList *opc;
-	OpcodeList **opcp;
-	StringList *macro, **macrop;
-	StringList *direct, **directp;
-	char *name;
-	char *line;
-	int i;
-	int length, overall_len;
-
-	def = malloc(sizeof(BytecodeImpl));
-	if (!def) outmem();
-	def->next = 0;
-	def->opcode_seq = 0;
-	def->macro_impl = 0;
-	def->direct_impl = 0;
-	def->len = -1;
-	*the_impl_ptr = def;
-	the_impl_ptr = &(def->next);
-	seqp = &(def->opcode_seq);
-	overall_len = 0;
-	do {
-		seq = malloc(sizeof(OpcodeSequence));
-		if (!seq) outmem();
-		seq->next = 0;
-		seq->opcode_list = 0;
-		*seqp = seq;
-		seqp = &(seq->next);
-		opcp = &(seq->opcode_list);
-		length = -2;
-		do {
-			c = (readchar)();
-			c = skipwhitespace(c);
-			if (!ISALPHA(c)) synerr();
-			c = readsymbol(c, buf, len);
-			c = skipwhitespace(c);
-			opc = malloc(sizeof(OpcodeList));
-			if (!opc) outmem();
-			opc->next = 0;
-			opc->opcode = -1;
-			*opcp = opc;
-			opcp = &(opc->next);
-			name = strdup(buf);
-			if (!name) outmem();
-			for (i = 0; i < 256; i++) {
-				if (strcmp(name, bytecodes[i].name) == 0) {
-					opc->opcode = i;
-					break;
-				}
-			}
-			if (i == 256) {
-				fprintf(stderr, "No such opcode '%s'\n", name);
-				exit(1);
-			}
-			if (length == -2) length = bytecodes[i].len;
-		} while (c == ',');
-		overall_len += length;
-		if (c != ')') synerr();
-		c = (readchar)();
-		c = skipwhitespace(c);
-	} while (c == '(');
-//	strcpy(buf, "do_");
-	*buf = 0;
-	if (ISALPHA(c)) {
-		c = readsymbol(c, buf, len);
-		c = skipwhitespace(c);
-	} else {
-		seq = def->opcode_seq;
-//		strcat(buf, "bytecode");
-		while (seq) {
-			opc = seq->opcode_list;
-			if (*buf) strcat(buf, "_");
-			strcat(buf, bytecodes[opc->opcode].name);
-//			sprintf(buf+strlen(buf), "_%ld", opc->opcode);
-			seq = seq->next;
-		}
-	}
-	name = strdup(buf);
-	if (!name) outmem();
-	def->name = name;
-	def->do_name = name;
-	def->len = overall_len;
-	if (c != '{') synerr();
-	c = (readchar)();
-	while (c != '\n' && isspace(c)) c = (readchar)();
-	if (c != '\n') synerr();
-	c = (readchar)();
-	c = readwhitespace(c, buf, len);
-	macrop = &(def->macro_impl);
-	while (c != '}' && c != EOF) {
-		c = readeol(c, buf + strlen(buf), len - strlen(buf));
-		line = strdup(buf);
-		if (!line) outmem();
-		macro = malloc(sizeof(StringList));
-		if (!macro) outmem();
-		*macrop = macro;
-		macrop = &(macro->next);
-		macro->next = 0;
-		macro->line = line;
-		c = readwhitespace(c, buf, len);
-	}
-	if (c != '}') synerr();
-	c = (readchar)();
-	c = skipwhitespace(c);
-	if (ISALPHA(c)) {
-		c = readsymbol(c, buf, len);
-		c = skipwhitespace(c);
-		name = strdup(buf);
-		if (!name) outmem();
-		def->do_name = name;
-	}
-	if (c == '[') {
-		c = (readchar)();
-		while (c != '\n' && isspace(c)) c = (readchar)();
-		if (c != '\n') synerr();
-		c = (readchar)();
-		c = readwhitespace(c, buf, len);
-		directp = &(def->direct_impl);
-		while (c != ']' && c != EOF) {
-			c = readeol(c, buf + strlen(buf), len - strlen(buf));
-			line = strdup(buf);
-			if (!line) outmem();
-			direct = malloc(sizeof(StringList));
-			if (!direct) outmem();
-			*directp = direct;
-			directp = &(direct->next);
-			direct->next = 0;
-			direct->line = line;
-			c = readwhitespace(c, buf, len);
-		}
-		if (c != ']') synerr();
-		c = (readchar)();
-	}
-	return c;
-}
-
-void mkbc(void)
-{
-	char buf[BUFLEN];
-	char *endptr;
-	int c;
-	char *name;
-	long opcode, len;
-
-	c = (readchar)();
-	c = skipwhitespace(c);
-	while (c != EOF) {
-		if (c == '@' || c == '#') {
-			c = skipeol(c);
-		} else if (ISALPHA(c)) {
-			c = readsymbol(c, buf, BUFLEN);
-			c = skipwhitespace(c);
-			if (c == '=') {
-				name = strdup(buf);
-				if (!name) outmem();
-				c = (readchar)();
-				c = skipwhitespace(c);
-				if (!(isdigit)(c)) synerr();
-				c = readsymbol(c, buf, BUFLEN);
-				opcode = strtol(buf, &endptr, 0);
-				if (*endptr != 0) synerr();
-				c = skipwhitespace(c);
-				if (c != ',') synerr();
-				c = (readchar)();
-				c = skipwhitespace(c);
-				if (!(isdigit)(c)) synerr();
-				c = readsymbol(c, buf, BUFLEN);
-				len = strtol(buf, &endptr, 0);
-				if (*endptr != 0) synerr();
-				bytecodes[opcode].name = name;
-				bytecodes[opcode].len = len;
-			}
-		} else if (c == '(') {
-			c = bcdef(c, buf, BUFLEN);
-		} else synerr();
-		c = skipwhitespace(c);
-	}
-}
-
-typedef struct TableEntry {
-	BytecodeImpl *impl;
-	char *impl_name;
-	char *def_name;
-	struct TableEntry *subtable;
-} TableEntry;
-
-TableEntry *the_table;
-
-int is_duplicate(TableEntry *a, TableEntry *b)
-{
-	int i;
-	char buf[256];
-
-	for (i = 0; i < 256; i++) {
-		if (a[i].subtable || b[i].subtable) {
-			if (!(a[i].subtable) || !(b[i].subtable)) return 0;
-			if (!is_duplicate(a[i].subtable, b[i].subtable)) return 0;
-		} else if (a[i].impl_name && b[i].impl_name) {
-			if (strcmp(a[i].impl_name, b[i].impl_name) != 0)
-				return 0;
-		} else if (a[i].def_name && b[i].def_name) {
-			if (strcmp(a[i].def_name, b[i].def_name) != 0)
-				return 0;
-		} else return 0;
-	}
-	return 1;
-}
-
-void remove_duplicates(TableEntry *table, int start, int *table_indices, int depth)
-{
-	TableEntry *start_entry = table[start].subtable;
-	int i, j;
-
-	if (!start_entry) fatal("Subtable is NULL in remove_duplicates!!!");
-	for (i = start+1; i < 256; i++) {
-		if (table[i].subtable) {
-			if (is_duplicate(start_entry, table[i].subtable)) {
-				fputs("dispatch", bci_f);
-				for (j = 0; j < depth; j++) {
-					fputc('_', bci_f);
-					fputs(bytecodes[table_indices[j]].name, bci_f);
-				}
-				fputc('_', bci_f);
-				fputs(bytecodes[i].name, bci_f);
-				fputs(":\n", bci_f);
-				free(table[i].subtable);
-				table[i].subtable = 0;
-			}
-		}
-	}
-}
-
-void writeouttable(TableEntry *table, int *table_indices, int depth)
-{
-	int i, j;
-	int len;
-
-	for (i = 0; i < 256; i++) {
-		if (table[i].subtable) {
-			len = 0;
-			fputs("\t.word\tdispatch", bci_f);
-			table_indices[depth] = i;
-			for (j = 0; j <= depth; j++) {
-				fputc('_', bci_f);
-				fputs(bytecodes[table_indices[j]].name, bci_f);
-				len += bytecodes[table_indices[j]].len;
-			}
-			fprintf(bci_f, "+%d\n", len);
-		} else {
-			if (table[i].impl_name)
-				fprintf(bci_f, "\t.word\t%s%s\n", prefix, table[i].impl_name);
-			else
-				fprintf(bci_f, "\t.word\t%s%s\n", prefix, table[i].def_name);
-		}
-	}
-	if (depth == 0) {
-		fputs("\t.endm\n", bci_f);
-		fputs("\t.macro\tSUB_DISPATCH_TABLES\n", bci_f);
-	}
-	for (i = 0; i < 256; i++) {
-		if (table[i].subtable) {
-			fputs("dispatch", bci_f);
-			table_indices[depth] = i;
-			for (j = 0; j <= depth; j++) {
-				fputc('_', bci_f);
-				fputs(bytecodes[table_indices[j]].name, bci_f);
-			}
-			fputs(":\n", bci_f);
-			remove_duplicates(table, i, table_indices, depth);
-			writeouttable(table[i].subtable, table_indices, depth+1);
-		}
-	}
-}
-
-void do_tableentry(BytecodeImpl *impl, TableEntry **tablep, int *table_indices, int depth)
-{
-	TableEntry *table;
-	char *def = "undefined";
-	int i,j;
-
-	if (depth == 0) fatal("Depth = 0 for tableentry\n");
-	for (i = 0; i < depth; i++) {
-		table = *tablep;
-		if (!table) {
-			table = malloc(sizeof(TableEntry) * 256);
-			if (!table) outmem();
-			*tablep = table;
-			def = strdup(def);
-			if (!def) outmem();
-			for (j = 0; j < 256; j++) {
-				table[j].impl_name = 0;
-				table[j].def_name = def;
-				table[j].subtable = 0;
-			}
-		}
-		table = &table[table_indices[i]];
-		tablep = &(table->subtable);
-		if (table->impl_name) def = table->def_name;
-	}
-	if (!table->impl_name)
-		table->impl_name = impl->do_name;
-	table->def_name = impl->do_name;
-}
-
-void dumpseq(BytecodeImpl *impl, OpcodeSequence *seq, int *table_indices, int depth)
-{
-	OpcodeList *opc;
-
-	opc = seq->opcode_list;
-	while (opc) {
-		table_indices[depth++] = opc->opcode;
-		if (seq->next != NULL) {
-			dumpseq(impl, seq->next, table_indices, depth);
-		} else {
-			do_tableentry(impl, &the_table, table_indices, depth);
-		}
-		depth--;
-		opc = opc->next;
-	}
-}
-
-void dumptable(void)
-{
-	BytecodeImpl *impl = the_impl;
-	int table_indices[256];
-	int j;
-	char	buf[256];
-	char *def;
-
-	the_table = malloc(sizeof(TableEntry) * 256);
-	if (!the_table) outmem();
-	for (j = 0; j < 256; j++) {
-		sprintf(buf, "%s", bytecodes[j].name);
-		def = strdup(buf);
-		if (!def) outmem();
-		the_table[j].impl_name = 0;
-		the_table[j].def_name = def;
-		the_table[j].subtable = 0;
-	}
-	while (impl) {
-		dumpseq(impl, impl->opcode_seq, table_indices, 0);
-		impl = impl->next;
-	}
-	fputs("\t.macro\tMAIN_DISPATCH_TABLE\n", bci_f);
-	writeouttable(the_table, table_indices, 0);
-	fputs("\t.endm\n", bci_f);
-}
-
-void dumpimpl(void)
-{
-	BytecodeImpl *impl = the_impl;
-	OpcodeList *opc;
-	StringList *code;
-	StringList *sl;
-	char buf[BUFLEN];
-	char macro[BUFLEN];
-
-	while (impl) {
-		buf[0] = 0;
-		fprintf(bci_f, "@-----------------------------------------------------------------------------\n");
-		fprintf(bci_f, "\t.macro\t%s\tjpc_off=0, seq_len=%d\n", impl->name, impl->len);
-		sl = impl->macro_impl;
-		while (sl) {
-			fputs(sl->line, bci_f);
-			fputc('\n', bci_f);
-			sl = sl->next;
-		}
-		fprintf(bci_f, "\t.endm\n\n");
-		sl = impl->direct_impl;
-		if (sl) {
-			do {
-				fputs(sl->line, bci_f);
-				fputc('\n', bci_f);
-				sl = sl->next;
-			} while (sl);
-		} else {
-			fprintf(bci_f, "\tOpcode\t%s\n", impl->do_name);
-//			fprintf(bci_f, "%s:\n", impl->do_name);
-			fprintf(bci_f, "\t%s\n", impl->name);
-//			fprintf(bci_f, "\tDISPATCH\t%d\n", impl->len);
-		}
-		impl = impl->next;
-	}
-}
-
-void dumpbc()
-{
-	int i;
-
-	for (i = 0; i < 256; i++) {
-		if (strcmp(bytecodes[i].name, "undefined") != 0)
-			fprintf(bci_f, "#define opc_%s\t\t0x%02x\n", bytecodes[i].name, i);
-	}
-	fputc('\n', bci_f);
-	dumpimpl();
-	dumptable();
-}
-
-void usage(void)
-{
-	fatal("Usage: mkbc <bytecode definition file> <asm output file>");
-}
-
-int main(int argc, char **argv)
-{
-	int i;
-	char *source, *bci;
-	char *s;
-
-	source = bci = 0;
-	while (s = *++argv) {
-		if (s[0] == '-' && s[1] != 0) {
-			if (s[1] == 'P') {
-				prefix = s+2;
-			} else {
-				fprintf(stderr, "Unrecognized option %s\n", s);
-				usage();
-			}
-		} else {
-			if (!source) source = s;
-			else if (!bci) bci = s;
-			else {
-				fprintf(stderr, "Too many arguments\n");
-				usage();
-			}
-		}
-	}
-	if (!bci) {
-		fprintf(stderr, "Too few arguments\n");
-		usage();
-	}
-	if (strcmp(source, "-") == 0) {
-		source_f = stdin;
-	} else {
-		source_f = fopen(source, "r");
-		if (!source_f) fatal("Error opening source file");
-	}
-	if (strcmp(bci, "-") == 0) {
-		bci_f = stdout;
-	} else {
-		bci_f = fopen(bci, "w");
-		if (!bci_f) fatal("Error opening bci file for write");
-	}
-	for (i = 0; i < 256; i++) {
-		bytecodes[i].name = "undefined";
-		bytecodes[i].len = -1;
-	}
-	mkbc();
-	dumpbc();
-	if (ferror(source_f)) fatal("Error reading source");
-	if (ferror(bci_f)) fatal("Error writing bci");
-	if (source_f != stdin) fclose(source_f);
-	if (bci_f != stdout) fclose(bci_f);
-}
diff -ruNE old/icedtea6/ports/hotspot/build/linux/makefiles/zero.make new/icedtea6/ports/hotspot/build/linux/makefiles/zero.make
--- old/icedtea6/ports/hotspot/build/linux/makefiles/zero.make	2009-10-28 15:02:34.000000000 +0000
+++ new/icedtea6/ports/hotspot/build/linux/makefiles/zero.make	2009-10-29 14:03:19.000000000 +0000
@@ -35,12 +35,20 @@
 	$(QUIETLY) $(REMOVE_TARGET)
 	$(COMPILE.CC) -o $@ $< $(COMPILE_DONE)
 
-cppInterpreter_arm.o:	offsets_arm.s
+cppInterpreter_arm.o:	offsets_arm.s bytecodes_arm.s
 
 offsets_arm.s:	mkoffsets
 	@echo Generating assembler offsets
 	./mkoffsets > $@
 
+bytecodes_arm.s: bytecodes_arm.def mkbc
+	@echo Generatine ARM assembler bytecode sequences
+	$(CC_COMPILE) -E -x c++ - < $< | ./mkbc - $@ $(COMPILE_DONE)
+
+mkbc:	$(GAMMADIR)/tools/mkbc.c
+	@echo Compiling mkbc tool
+	$(CC_COMPILE) -o $@ $< $(COMPILE_DONE)
+
 mkoffsets:	asm_helper.cpp
 	@echo Compiling offset generator
 	$(QUIETLY) $(REMOVE_TARGET)
diff -ruNE old/icedtea6/ports/hotspot/src/cpu/zero/vm/bytecodes_arm.def new/icedtea6/ports/hotspot/src/cpu/zero/vm/bytecodes_arm.def
--- old/icedtea6/ports/hotspot/src/cpu/zero/vm/bytecodes_arm.def	2009-10-28 15:02:34.000000000 +0000
+++ new/icedtea6/ports/hotspot/src/cpu/zero/vm/bytecodes_arm.def	2009-10-29 09:20:01.000000000 +0000
@@ -15,6 +15,10 @@
 @ 2 along with this work; if not, write to the Free Software Foundation,
 @ Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 
+#ifdef SHARK
+#define DISABLE_NOTICE_SAFEPOINTS
+#endif
+
 #ifndef DISABLE_HW_FP
 #define HW_FP
 #endif
diff -ruNE old/icedtea6/ports/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S new/icedtea6/ports/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S
--- old/icedtea6/ports/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S	2009-10-28 15:02:34.000000000 +0000
+++ new/icedtea6/ports/hotspot/src/cpu/zero/vm/cppInterpreter_arm.S	2009-10-29 09:19:14.000000000 +0000
@@ -19,6 +19,7 @@
 
 #ifdef SHARK
 #define USE_COMPILER
+#define DISABLE_NOTICE_SAFEPOINTS
 #endif
 
 #define ARMv4
diff -ruNE old/icedtea6/ports/hotspot/tools/mkbc.c new/icedtea6/ports/hotspot/tools/mkbc.c
--- old/icedtea6/ports/hotspot/tools/mkbc.c	1970-01-01 01:00:00.000000000 +0100
+++ new/icedtea6/ports/hotspot/tools/mkbc.c	2009-10-29 13:42:24.000000000 +0000
@@ -0,0 +1,605 @@
+/*
+ * Copyright 2009 Edward Nevill
+ *
+ * This code is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 only, as
+ * published by the Free Software Foundation.
+ *
+ * This code 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
+ * version 2 for more details (a copy is included in the LICENSE file that
+ * accompanied this code).
+ */
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <ctype.h>
+
+#define DEFAULT_PREFIX	"do_"
+
+static char *prefix = (char *)DEFAULT_PREFIX;
+
+#define ISALPHA(c) (isalpha(c) || (c) == '_')
+#define ISALNUM(c) (isalnum(c) || (c) == '_')
+
+FILE *source_f, *bci_f;
+
+typedef struct Bytecode {
+	char	*name;
+	int	len;
+} Bytecode;
+
+typedef struct StringList {
+	struct StringList *next;
+	char 		*line;
+} StringList;
+
+typedef struct OpcodeList {
+	struct OpcodeList *next;
+	long	 	opcode;
+} OpcodeList;
+
+typedef struct OpcodeSequence {
+	struct OpcodeSequence *next;
+	OpcodeList	*opcode_list;
+} OpcodeSequence;
+
+typedef struct BytecodeImpl {
+	struct BytecodeImpl *next;
+	OpcodeSequence	*opcode_seq;
+	StringList	*macro_impl;
+	StringList	*direct_impl;
+	int		len;
+	char		*name;
+	char		*do_name;
+} BytecodeImpl;
+
+Bytecode bytecodes[256];
+
+BytecodeImpl *the_impl = 0;
+BytecodeImpl **the_impl_ptr = &the_impl;
+
+#define BUFLEN 1024
+
+static int lineno = 1;
+
+void fatal(const char *s)
+{
+	fputs(s, stderr);
+	fputc('\n', stderr);
+	exit(1);
+}
+
+void outmem(void)
+{
+	fprintf(stderr, "Out of memory\n");
+	exit(1);
+}
+
+void synerr(void)
+{
+	fprintf(stderr, "Syntax error at line %d\n", lineno);
+	exit(1);
+}
+
+int readchar()
+{
+	int c;
+
+	c = getc(source_f);
+	if (c == '\n') lineno++;
+	return c;
+}
+
+int readwhitespace(int c, char *buf, int len)
+{
+	int i = 0;
+
+	while ((isspace)(c)) {
+		if (buf && i < len-1) buf[i++] = c;
+		c = (readchar)();
+	}
+	if (buf && i < len) buf[i] = 0;
+	return c;
+}
+
+int skipwhitespace(int c)
+{
+	while ((isspace)(c)) {
+		c = (readchar)();
+	}
+	return c;
+}
+
+int readeol(int c, char *buf, int len)
+{
+	int i = 0;
+
+	while (c != '\n' && c != EOF) {
+		if (buf && i < len-1) buf[i++] = c;
+		c = (readchar)();
+	}
+	if (buf && i < len) buf[i] = 0;
+	if (c == '\n') c = (readchar)();
+	return c;
+}
+
+int skipeol(int c)
+{
+	while (c != '\n' && c != EOF) c = (readchar)();
+	if (c == '\n') c = (readchar)();
+	return c;
+}
+
+int readsymbol(int c, char *buf, int len)
+{
+	int i = 0;
+
+	while (ISALNUM(c)) {
+		if (buf && i < len-1) buf[i++] = c;
+		c = (readchar)();
+	}
+	if (buf && i < len) buf[i] = 0;
+	return c;
+}
+
+int bcdef(int c, char *buf, int len)
+{
+	BytecodeImpl *def;
+	OpcodeSequence *seq;
+	OpcodeSequence **seqp;
+	OpcodeList *opc;
+	OpcodeList **opcp;
+	StringList *macro, **macrop;
+	StringList *direct, **directp;
+	char *name;
+	char *line;
+	int i;
+	int length, overall_len;
+
+	def = (BytecodeImpl *)malloc(sizeof(BytecodeImpl));
+	if (!def) outmem();
+	def->next = 0;
+	def->opcode_seq = 0;
+	def->macro_impl = 0;
+	def->direct_impl = 0;
+	def->len = -1;
+	*the_impl_ptr = def;
+	the_impl_ptr = &(def->next);
+	seqp = &(def->opcode_seq);
+	overall_len = 0;
+	do {
+		seq = (OpcodeSequence *)malloc(sizeof(OpcodeSequence));
+		if (!seq) outmem();
+		seq->next = 0;
+		seq->opcode_list = 0;
+		*seqp = seq;
+		seqp = &(seq->next);
+		opcp = &(seq->opcode_list);
+		length = -2;
+		do {
+			c = (readchar)();
+			c = skipwhitespace(c);
+			if (!ISALPHA(c)) synerr();
+			c = readsymbol(c, buf, len);
+			c = skipwhitespace(c);
+			opc = (OpcodeList *)malloc(sizeof(OpcodeList));
+			if (!opc) outmem();
+			opc->next = 0;
+			opc->opcode = -1;
+			*opcp = opc;
+			opcp = &(opc->next);
+			name = strdup(buf);
+			if (!name) outmem();
+			for (i = 0; i < 256; i++) {
+				if (strcmp(name, bytecodes[i].name) == 0) {
+					opc->opcode = i;
+					break;
+				}
+			}
+			if (i == 256) {
+				fprintf(stderr, "No such opcode '%s'\n", name);
+				exit(1);
+			}
+			if (length == -2) length = bytecodes[i].len;
+		} while (c == ',');
+		overall_len += length;
+		if (c != ')') synerr();
+		c = (readchar)();
+		c = skipwhitespace(c);
+	} while (c == '(');
+//	strcpy(buf, "do_");
+	*buf = 0;
+	if (ISALPHA(c)) {
+		c = readsymbol(c, buf, len);
+		c = skipwhitespace(c);
+	} else {
+		seq = def->opcode_seq;
+//		strcat(buf, "bytecode");
+		while (seq) {
+			opc = seq->opcode_list;
+			if (*buf) strcat(buf, "_");
+			strcat(buf, bytecodes[opc->opcode].name);
+//			sprintf(buf+strlen(buf), "_%ld", opc->opcode);
+			seq = seq->next;
+		}
+	}
+	name = strdup(buf);
+	if (!name) outmem();
+	def->name = name;
+	def->do_name = name;
+	def->len = overall_len;
+	if (c != '{') synerr();
+	c = (readchar)();
+	while (c != '\n' && isspace(c)) c = (readchar)();
+	if (c != '\n') synerr();
+	c = (readchar)();
+	c = readwhitespace(c, buf, len);
+	macrop = &(def->macro_impl);
+	while (c != '}' && c != EOF) {
+		c = readeol(c, buf + strlen(buf), len - strlen(buf));
+		line = strdup(buf);
+		if (!line) outmem();
+		macro = (StringList *)malloc(sizeof(StringList));
+		if (!macro) outmem();
+		*macrop = macro;
+		macrop = &(macro->next);
+		macro->next = 0;
+		macro->line = line;
+		c = readwhitespace(c, buf, len);
+	}
+	if (c != '}') synerr();
+	c = (readchar)();
+	c = skipwhitespace(c);
+	if (ISALPHA(c)) {
+		c = readsymbol(c, buf, len);
+		c = skipwhitespace(c);
+		name = strdup(buf);
+		if (!name) outmem();
+		def->do_name = name;
+	}
+	if (c == '[') {
+		c = (readchar)();
+		while (c != '\n' && isspace(c)) c = (readchar)();
+		if (c != '\n') synerr();
+		c = (readchar)();
+		c = readwhitespace(c, buf, len);
+		directp = &(def->direct_impl);
+		while (c != ']' && c != EOF) {
+			c = readeol(c, buf + strlen(buf), len - strlen(buf));
+			line = strdup(buf);
+			if (!line) outmem();
+			direct = (StringList *)malloc(sizeof(StringList));
+			if (!direct) outmem();
+			*directp = direct;
+			directp = &(direct->next);
+			direct->next = 0;
+			direct->line = line;
+			c = readwhitespace(c, buf, len);
+		}
+		if (c != ']') synerr();
+		c = (readchar)();
+	}
+	return c;
+}
+
+void mkbc(void)
+{
+	char buf[BUFLEN];
+	char *endptr;
+	int c;
+	char *name;
+	long opcode, len;
+
+	c = (readchar)();
+	c = skipwhitespace(c);
+	while (c != EOF) {
+		if (c == '@' || c == '#') {
+			c = skipeol(c);
+		} else if (ISALPHA(c)) {
+			c = readsymbol(c, buf, BUFLEN);
+			c = skipwhitespace(c);
+			if (c == '=') {
+				name = strdup(buf);
+				if (!name) outmem();
+				c = (readchar)();
+				c = skipwhitespace(c);
+				if (!(isdigit)(c)) synerr();
+				c = readsymbol(c, buf, BUFLEN);
+				opcode = strtol(buf, &endptr, 0);
+				if (*endptr != 0) synerr();
+				c = skipwhitespace(c);
+				if (c != ',') synerr();
+				c = (readchar)();
+				c = skipwhitespace(c);
+				if (!(isdigit)(c)) synerr();
+				c = readsymbol(c, buf, BUFLEN);
+				len = strtol(buf, &endptr, 0);
+				if (*endptr != 0) synerr();
+				bytecodes[opcode].name = name;
+				bytecodes[opcode].len = len;
+			}
+		} else if (c == '(') {
+			c = bcdef(c, buf, BUFLEN);
+		} else synerr();
+		c = skipwhitespace(c);
+	}
+}
+
+typedef struct TableEntry {
+	BytecodeImpl *impl;
+	char *impl_name;
+	char *def_name;
+	struct TableEntry *subtable;
+} TableEntry;
+
+TableEntry *the_table;
+
+int is_duplicate(TableEntry *a, TableEntry *b)
+{
+	int i;
+	char buf[256];
+
+	for (i = 0; i < 256; i++) {
+		if (a[i].subtable || b[i].subtable) {
+			if (!(a[i].subtable) || !(b[i].subtable)) return 0;
+			if (!is_duplicate(a[i].subtable, b[i].subtable)) return 0;
+		} else if (a[i].impl_name && b[i].impl_name) {
+			if (strcmp(a[i].impl_name, b[i].impl_name) != 0)
+				return 0;
+		} else if (a[i].def_name && b[i].def_name) {
+			if (strcmp(a[i].def_name, b[i].def_name) != 0)
+				return 0;
+		} else return 0;
+	}
+	return 1;
+}
+
+void remove_duplicates(TableEntry *table, int start, int *table_indices, int depth)
+{
+	TableEntry *start_entry = table[start].subtable;
+	int i, j;
+
+	if (!start_entry) fatal("Subtable is NULL in remove_duplicates!!!");
+	for (i = start+1; i < 256; i++) {
+		if (table[i].subtable) {
+			if (is_duplicate(start_entry, table[i].subtable)) {
+				fputs("dispatch", bci_f);
+				for (j = 0; j < depth; j++) {
+					fputc('_', bci_f);
+					fputs(bytecodes[table_indices[j]].name, bci_f);
+				}
+				fputc('_', bci_f);
+				fputs(bytecodes[i].name, bci_f);
+				fputs(":\n", bci_f);
+				free(table[i].subtable);
+				table[i].subtable = 0;
+			}
+		}
+	}
+}
+
+void writeouttable(TableEntry *table, int *table_indices, int depth)
+{
+	int i, j;
+	int len;
+
+	for (i = 0; i < 256; i++) {
+		if (table[i].subtable) {
+			len = 0;
+			fputs("\t.word\tdispatch", bci_f);
+			table_indices[depth] = i;
+			for (j = 0; j <= depth; j++) {
+				fputc('_', bci_f);
+				fputs(bytecodes[table_indices[j]].name, bci_f);
+				len += bytecodes[table_indices[j]].len;
+			}
+			fprintf(bci_f, "+%d\n", len);
+		} else {
+			if (table[i].impl_name)
+				fprintf(bci_f, "\t.word\t%s%s\n", prefix, table[i].impl_name);
+			else
+				fprintf(bci_f, "\t.word\t%s%s\n", prefix, table[i].def_name);
+		}
+	}
+	if (depth == 0) {
+		fputs("\t.endm\n", bci_f);
+		fputs("\t.macro\tSUB_DISPATCH_TABLES\n", bci_f);
+	}
+	for (i = 0; i < 256; i++) {
+		if (table[i].subtable) {
+			fputs("dispatch", bci_f);
+			table_indices[depth] = i;
+			for (j = 0; j <= depth; j++) {
+				fputc('_', bci_f);
+				fputs(bytecodes[table_indices[j]].name, bci_f);
+			}
+			fputs(":\n", bci_f);
+			remove_duplicates(table, i, table_indices, depth);
+			writeouttable(table[i].subtable, table_indices, depth+1);
+		}
+	}
+}
+
+void do_tableentry(BytecodeImpl *impl, TableEntry **tablep, int *table_indices, int depth)
+{
+	TableEntry *table;
+	char *def = (char *)"undefined";
+	int i,j;
+
+	if (depth == 0) fatal("Depth = 0 for tableentry\n");
+	for (i = 0; i < depth; i++) {
+		table = *tablep;
+		if (!table) {
+			table = (TableEntry *)malloc(sizeof(TableEntry) * 256);
+			if (!table) outmem();
+			*tablep = table;
+			def = strdup(def);
+			if (!def) outmem();
+			for (j = 0; j < 256; j++) {
+				table[j].impl_name = 0;
+				table[j].def_name = def;
+				table[j].subtable = 0;
+			}
+		}
+		table = &table[table_indices[i]];
+		tablep = &(table->subtable);
+		if (table->impl_name) def = table->def_name;
+	}
+	if (!table->impl_name)
+		table->impl_name = impl->do_name;
+	table->def_name = impl->do_name;
+}
+
+void dumpseq(BytecodeImpl *impl, OpcodeSequence *seq, int *table_indices, int depth)
+{
+	OpcodeList *opc;
+
+	opc = seq->opcode_list;
+	while (opc) {
+		table_indices[depth++] = opc->opcode;
+		if (seq->next != NULL) {
+			dumpseq(impl, seq->next, table_indices, depth);
+		} else {
+			do_tableentry(impl, &the_table, table_indices, depth);
+		}
+		depth--;
+		opc = opc->next;
+	}
+}
+
+void dumptable(void)
+{
+	BytecodeImpl *impl = the_impl;
+	int table_indices[256];
+	int j;
+	char	buf[256];
+	char *def;
+
+	the_table = (TableEntry *)malloc(sizeof(TableEntry) * 256);
+	if (!the_table) outmem();
+	for (j = 0; j < 256; j++) {
+		sprintf(buf, "%s", bytecodes[j].name);
+		def = strdup(buf);
+		if (!def) outmem();
+		the_table[j].impl_name = 0;
+		the_table[j].def_name = def;
+		the_table[j].subtable = 0;
+	}
+	while (impl) {
+		dumpseq(impl, impl->opcode_seq, table_indices, 0);
+		impl = impl->next;
+	}
+	fputs("\t.macro\tMAIN_DISPATCH_TABLE\n", bci_f);
+	writeouttable(the_table, table_indices, 0);
+	fputs("\t.endm\n", bci_f);
+}
+
+void dumpimpl(void)
+{
+	BytecodeImpl *impl = the_impl;
+	OpcodeList *opc;
+	StringList *code;
+	StringList *sl;
+	char buf[BUFLEN];
+	char macro[BUFLEN];
+
+	while (impl) {
+		buf[0] = 0;
+		fprintf(bci_f, "@-----------------------------------------------------------------------------\n");
+		fprintf(bci_f, "\t.macro\t%s\tjpc_off=0, seq_len=%d\n", impl->name, impl->len);
+		sl = impl->macro_impl;
+		while (sl) {
+			fputs(sl->line, bci_f);
+			fputc('\n', bci_f);
+			sl = sl->next;
+		}
+		fprintf(bci_f, "\t.endm\n\n");
+		sl = impl->direct_impl;
+		if (sl) {
+			do {
+				fputs(sl->line, bci_f);
+				fputc('\n', bci_f);
+				sl = sl->next;
+			} while (sl);
+		} else {
+			fprintf(bci_f, "\tOpcode\t%s\n", impl->do_name);
+//			fprintf(bci_f, "%s:\n", impl->do_name);
+			fprintf(bci_f, "\t%s\n", impl->name);
+//			fprintf(bci_f, "\tDISPATCH\t%d\n", impl->len);
+		}
+		impl = impl->next;
+	}
+}
+
+void dumpbc()
+{
+	int i;
+
+	for (i = 0; i < 256; i++) {
+		if (strcmp(bytecodes[i].name, "undefined") != 0)
+			fprintf(bci_f, "#define opc_%s\t\t0x%02x\n", bytecodes[i].name, i);
+	}
+	fputc('\n', bci_f);
+	dumpimpl();
+	dumptable();
+}
+
+void usage(void)
+{
+	fatal("Usage: mkbc <bytecode definition file> <asm output file>");
+}
+
+int main(int argc, char **argv)
+{
+	int i;
+	char *source, *bci;
+	char *s;
+
+	source = bci = 0;
+	while (s = *++argv) {
+		if (s[0] == '-' && s[1] != 0) {
+			if (s[1] == 'P') {
+				prefix = s+2;
+			} else {
+				fprintf(stderr, "Unrecognized option %s\n", s);
+				usage();
+			}
+		} else {
+			if (!source) source = s;
+			else if (!bci) bci = s;
+			else {
+				fprintf(stderr, "Too many arguments\n");
+				usage();
+			}
+		}
+	}
+	if (!bci) {
+		fprintf(stderr, "Too few arguments\n");
+		usage();
+	}
+	if (strcmp(source, "-") == 0) {
+		source_f = stdin;
+	} else {
+		source_f = fopen(source, "r");
+		if (!source_f) fatal("Error opening source file");
+	}
+	if (strcmp(bci, "-") == 0) {
+		bci_f = stdout;
+	} else {
+		bci_f = fopen(bci, "w");
+		if (!bci_f) fatal("Error opening bci file for write");
+	}
+	for (i = 0; i < 256; i++) {
+		bytecodes[i].name = (char *)"undefined";
+		bytecodes[i].len = -1;
+	}
+	mkbc();
+	dumpbc();
+	if (ferror(source_f)) fatal("Error reading source");
+	if (ferror(bci_f)) fatal("Error writing bci");
+	if (source_f != stdin) fclose(source_f);
+	if (bci_f != stdout) fclose(bci_f);
+}



More information about the distro-pkg-dev mailing list