Commit b6121641 by Thomas Fitzsimmons Committed by Thomas Fitzsimmons

re PR libgcj/20090 (gij should be implemented in Java)

2005-04-01  Thomas Fitzsimmons  <fitzsim@redhat.com>

	* gcj.texi (Invoking gij): Add descriptions of new -X options.
	Mention recognized-and-ignored compatibility options.
	(Memory allocation): Add descriptions of JvMalloc, JvRealloc and
	JvFree.
	(About CNI): Add Memory allocation section.

2005-04-01  Thomas Fitzsimmons  <fitzsim@redhat.com>

	PR libgcj/20090, PR libgcj/20526
	* gij.cc (nonstandard_opts_help): New function.
	(add_option): New function.
	(main): Support java options.  Set java.class.path.  Don't set
	_Jv_Jar_Class_Path.
	* prims.cc (parse_x_arg): New function.
	(parse_init_args): Call parse_x_arg for -X and _ options, when
	ignoreUnrecognized is true.
	(new _Jv_RunMain): New vm_args variant.
	(old _Jv_RunMain): Call new vm_args _Jv_RunMain.
	(_Jv_Jar_Class_Path): Remove variable.
	* include/java-props.h: Likewise.
	* include/cni.h (JvRealloc): New function.
	* include/jvm.h (_Jv_RunMain): Declare vm_args variant.
	* java/lang/natRuntime.cc (insertSystemProperties): Remove
	_Jv_Jar_Class_Path logic.  Use JV_VERSION and JV_API_VERSION
	macros.
	* configure.ac (JV_VERSION): Define.
	(JV_API_VERSION): Likewise.
	* configure: Regenerate.
	* include/config.h.in: Regenerate.

From-SVN: r97429
parent ca6ca8fa
2005-04-01 Thomas Fitzsimmons <fitzsim@redhat.com>
* gcj.texi (Invoking gij): Add descriptions of new -X options.
Mention recognized-and-ignored compatibility options.
(Memory allocation): Add descriptions of JvMalloc, JvRealloc and
JvFree.
(About CNI): Add Memory allocation section.
2005-04-01 Tom Tromey <tromey@redhat.com>
* decl.c (java_init_decl_processing): Fix types of
......
......@@ -949,16 +949,26 @@ be retrieved at runtime using the @code{java.lang.System.getProperty}
method.
@item -ms=@var{number}
This sets the initial heap size.
Equivalent to @code{-Xms}.
@item -mx=@var{number}
This sets the maximum heap size.
Equivalent to @code{-Xmx}.
@item -X
@itemx -X@var{argument}
Supplying @code{-X} by itself will cause @code{gij} to list all the
supported @code{-X} options. Currently there are none. Unrecognized
@code{-X} options are ignored, for compatibility with other runtimes.
supported @code{-X} options. Currently these options are supported:
@table @gcctabopt
@item -Xms@var{size}
Set the initial heap size.
@item -Xmx@var{size}
Set the maximum heap size.
@end table
Unrecognized @code{-X} options are ignored, for compatibility with
other runtimes.
@item -jar
This indicates that the name passed to @code{gij} should be interpreted
......@@ -971,6 +981,9 @@ Print help, then exit.
@item --showversion
Print version number and continue.
@item --fullversion
Print detailed version information, then exit.
@item --version
Print version number, then exit.
......@@ -979,6 +992,12 @@ Print version number, then exit.
Each time a class is initialized, print a short message on standard error.
@end table
@code{gij} also recognizes and ignores the following options, for
compatibility with existing application launch scripts:
@code{-client}, @code{-server}, @code{-hotspot}, @code{-jrockit},
@code{-agentlib}, @code{-agentpath}, @code{-debug}, @code{-d32},
@code{-d64}, @code{-javaagent} and @code{-noclassgc}.
@c man end
@node Invoking gcj-dbtool
......@@ -1250,6 +1269,7 @@ alternative to the standard JNI (Java Native Interface).
* Objects and Classes:: C++ and Java classes.
* Class Initialization:: How objects are initialized.
* Object allocation:: How to create Java objects in C++.
* Memory allocation:: How to allocate and free memory.
* Arrays:: Dealing with Java arrays in C++.
* Methods:: Java methods in C++.
* Strings:: Information about Java Strings.
......@@ -1630,6 +1650,27 @@ java::util::Hashtable *ht = new java::util::Hashtable(120);
@end example
@node Memory allocation
@section Memory allocation
When allocting memory in @acronym{CNI} methods it is best to handle
out-of-memory conditions by throwing a Java exception. These
functions are provided for that purpose:
@deftypefun void* JvMalloc (jsize @var{size})
Calls malloc. Throws @code{java.lang.OutOfMemoryError} if allocation
fails.
@end deftypefun
@deftypefun void* JvRealloc (void* @var{ptr}, jsize @var{size})
Calls realloc. Throws @code{java.lang.OutOfMemoryError} if
reallocation fails.
@end deftypefun
@deftypefun void JvFree (void* @var{ptr})
Calls free.
@end deftypefun
@node Arrays
@section Arrays
......
2005-04-01 Thomas Fitzsimmons <fitzsim@redhat.com>
PR libgcj/20090, PR libgcj/20526
* gij.cc (nonstandard_opts_help): New function.
(add_option): New function.
(main): Support java options. Set java.class.path. Don't set
_Jv_Jar_Class_Path.
* prims.cc (parse_x_arg): New function.
(parse_init_args): Call parse_x_arg for -X and _ options, when
ignoreUnrecognized is true.
(new _Jv_RunMain): New vm_args variant.
(old _Jv_RunMain): Call new vm_args _Jv_RunMain.
(_Jv_Jar_Class_Path): Remove variable.
* include/java-props.h: Likewise.
* include/cni.h (JvRealloc): New function.
* include/jvm.h (_Jv_RunMain): Declare vm_args variant.
* java/lang/natRuntime.cc (insertSystemProperties): Remove
_Jv_Jar_Class_Path logic. Use JV_VERSION and JV_API_VERSION
macros.
* configure.ac (JV_VERSION): Define.
(JV_API_VERSION): Likewise.
* configure: Regenerate.
* include/config.h.in: Regenerate.
2005-04-01 Mark Anderson <mark@panonet.net>
* java/lang/natDouble.cc (parseDouble): Handle NaN, Infinity and
......
......@@ -13829,6 +13829,17 @@ _ACEOF
cat >>confdefs.h <<\_ACEOF
#define JV_VERSION "1.4.2"
_ACEOF
cat >>confdefs.h <<\_ACEOF
#define JV_API_VERSION "1.4"
_ACEOF
case "${with_gxx_include_dir}" in
yes)
{ { echo "$as_me:$LINENO: error: --with-gxx-include-dir=[dir] requires a directory" >&5
......
......@@ -1196,6 +1196,9 @@ GCJVERSION=$gcjversion
AC_SUBST(GCJVERSION)
AC_DEFINE_UNQUOTED(GCJVERSION, "$GCJVERSION", [Short GCJ version ID])
AC_DEFINE(JV_VERSION, "1.4.2", [Compatibility version string])
AC_DEFINE(JV_API_VERSION, "1.4", [API compatibility version string])
TL_AC_GXX_INCLUDE_DIR
# We check for sys/filio.h because Solaris 2.5 defines FIONREAD there.
......
......@@ -108,6 +108,12 @@ JvMalloc (jsize size)
return _Jv_Malloc (size);
}
extern inline void *
JvRealloc (void *ptr, jsize size)
{
return _Jv_Realloc (ptr, size);
}
extern inline void
JvFree (void *ptr)
{
......
......@@ -364,6 +364,9 @@
/* Define if you want a bytecode interpreter. */
#undef INTERPRETER
/* API compatibility version string */
#undef JV_API_VERSION
/* Define if hash synchronization is in use */
#undef JV_HASH_SYNCHRONIZATION
......@@ -373,6 +376,9 @@
/* Indicate that linker is not able to 8-byte align static data */
#undef JV_LINKER_CANNOT_8BYTE_ALIGN_STATICS
/* Compatibility version string */
#undef JV_VERSION
/* Define if we want to use debug calls into the garbage collector. */
#undef LIBGCJ_GC_DEBUG
......
......@@ -23,9 +23,6 @@ typedef struct
extern const char **_Jv_Compiler_Properties;
extern int _Jv_Properties_Count;
// The JAR file to add to the beginning of java.class.path.
extern const char *_Jv_Jar_Class_Path;
// Properties taken from the user's environment.
extern property_pair *_Jv_Environment_Properties;
......
......@@ -360,6 +360,9 @@ extern "C" void JvRunMain (jclass klass, int argc, const char **argv);
void _Jv_RunMain (jclass klass, const char *name, int argc, const char **argv,
bool is_jar);
void _Jv_RunMain (struct _Jv_VMInitArgs *vm_args, jclass klass,
const char *name, int argc, const char **argv, bool is_jar);
// Delayed until after _Jv_AllocBytes is declared.
//
// Note that we allocate this as unscanned memory -- the vtables
......
......@@ -369,8 +369,8 @@ java::lang::Runtime::insertSystemProperties (java::util::Properties *newprops)
// (introduced in 1.2), and earlier versioning properties. Some
// programs rely on seeing values that they expect, so we claim to
// be a 1.4-ish VM for their sake.
SET ("java.version", "1.4.2");
SET ("java.runtime.version", "1.4.2");
SET ("java.version", JV_VERSION);
SET ("java.runtime.version", JV_VERSION);
SET ("java.vendor", "Free Software Foundation, Inc.");
SET ("java.vendor.url", "http://gcc.gnu.org/java/");
SET ("java.class.version", "46.0");
......@@ -380,7 +380,7 @@ java::lang::Runtime::insertSystemProperties (java::util::Properties *newprops)
SET ("java.vm.version", __VERSION__);
SET ("java.vm.vendor", "Free Software Foundation, Inc.");
SET ("java.vm.name", "GNU libgcj");
SET ("java.specification.version", "1.4");
SET ("java.specification.version", JV_API_VERSION);
SET ("java.specification.name", "Java(tm) Platform API Specification");
SET ("java.specification.vendor", "Sun Microsystems Inc.");
......@@ -569,30 +569,6 @@ java::lang::Runtime::insertSystemProperties (java::util::Properties *newprops)
}
#endif
if (_Jv_Jar_Class_Path)
newprops->put(JvNewStringLatin1 ("java.class.path"),
JvNewStringLatin1 (_Jv_Jar_Class_Path));
else
{
// FIXME: find libgcj.zip and append its path?
char *classpath = ::getenv("CLASSPATH");
jstring cp = newprops->getProperty (JvNewStringLatin1("java.class.path"));
java::lang::StringBuffer *sb = new java::lang::StringBuffer ();
if (classpath)
{
sb->append (JvNewStringLatin1 (classpath));
sb->append (_Jv_platform_path_separator);
}
if (cp != NULL)
sb->append (cp);
else
sb->append ((jchar) '.');
newprops->put(JvNewStringLatin1 ("java.class.path"),
sb->toString ());
}
// The name used to invoke this process (argv[0] in C).
SET ("gnu.gcj.progname", _Jv_GetSafeArg (0));
......
......@@ -85,9 +85,6 @@ static java::lang::OutOfMemoryError *no_memory;
const char **_Jv_Compiler_Properties = NULL;
int _Jv_Properties_Count = 0;
// The JAR file to add to the beginning of java.class.path.
const char *_Jv_Jar_Class_Path;
#ifndef DISABLE_GETENV_PROPERTIES
// Property key/value pairs.
property_pair *_Jv_Environment_Properties;
......@@ -909,9 +906,115 @@ namespace gcj
bool runtimeInitialized = false;
}
// We accept all non-standard options accepted by Sun's java command,
// for compatibility with existing application launch scripts.
static jint
parse_x_arg (char* option_string)
{
if (strlen (option_string) <= 0)
return -1;
if (! strcmp (option_string, "int"))
{
// FIXME: this should cause the vm to never load shared objects
}
else if (! strcmp (option_string, "mixed"))
{
// FIXME: allow interpreted and native code
}
else if (! strcmp (option_string, "batch"))
{
// FIXME: disable background JIT'ing
}
else if (! strcmp (option_string, "debug"))
{
// FIXME: add JDWP/JVMDI support
}
else if (! strncmp (option_string, "bootclasspath:", 14))
{
// FIXME: add a parse_bootclasspath_arg function
}
else if (! strncmp (option_string, "bootclasspath/a:", 16))
{
}
else if (! strncmp (option_string, "bootclasspath/p:", 16))
{
}
else if (! strcmp (option_string, "check:jni"))
{
// FIXME: enable strict JNI checking
}
else if (! strcmp (option_string, "future"))
{
// FIXME: enable strict class file format checks
}
else if (! strcmp (option_string, "noclassgc"))
{
// FIXME: disable garbage collection for classes
}
else if (! strcmp (option_string, "incgc"))
{
// FIXME: incremental garbage collection
}
else if (! strncmp (option_string, "loggc:", 6))
{
if (option_string[6] == '\0')
{
fprintf (stderr,
"libgcj: filename argument expected for loggc option\n");
return -1;
}
// FIXME: set gc logging filename
}
else if (! strncmp (option_string, "ms", 2))
{
// FIXME: ignore this option until PR 20699 is fixed.
// _Jv_SetInitialHeapSize (option_string + 2);
}
else if (! strncmp (option_string, "mx", 2))
_Jv_SetMaximumHeapSize (option_string + 2);
else if (! strcmp (option_string, "prof"))
{
// FIXME: enable profiling of program running in vm
}
else if (! strncmp (option_string, "runhprof:", 9))
{
// FIXME: enable specific type of vm profiling. add a
// parse_runhprof_arg function
}
else if (! strcmp (option_string, "rs"))
{
// FIXME: reduced system signal usage. disable thread dumps,
// only terminate in response to user-initiated calls,
// e.g. System.exit()
}
else if (! strncmp (option_string, "ss", 2))
{
// FIXME: set thread stack size
}
else if (! strcmp (option_string, "X:+UseAltSigs"))
{
// FIXME: use signals other than SIGUSR1 and SIGUSR2
}
else if (! strcmp (option_string, "share:off"))
{
// FIXME: don't share class data
}
else if (! strcmp (option_string, "share:auto"))
{
// FIXME: share class data where possible
}
else if (! strcmp (option_string, "share:on"))
{
// FIXME: fail if impossible to share class data
}
return 0;
}
static jint
parse_verbose_args (char* option_string,
bool ignore_unrecognized)
bool ignore_unrecognized)
{
size_t len = sizeof ("-verbose");
......@@ -1045,7 +1148,7 @@ parse_init_args (JvVMInitArgs* vm_args)
"-verbose", sizeof ("-verbose") - 1))
{
jint result = parse_verbose_args (option_string,
vm_args->ignoreUnrecognized);
vm_args->ignoreUnrecognized);
if (result < 0)
return result;
}
......@@ -1061,11 +1164,20 @@ parse_init_args (JvVMInitArgs* vm_args)
continue;
}
else if (vm_args->ignoreUnrecognized)
{
if (option_string[0] == '_'
|| ! strncmp (option_string, "-X", 2))
continue;
{
if (option_string[0] == '_')
parse_x_arg (option_string + 1);
else if (! strncmp (option_string, "-X", 2))
parse_x_arg (option_string + 2);
else
{
unknown_option:
fprintf (stderr, "libgcj: unknown option: %s\n", option_string);
return -1;
}
}
else
goto unknown_option;
}
return 0;
}
......@@ -1167,8 +1279,8 @@ _Jv_CreateJavaVM (JvVMInitArgs* vm_args)
}
void
_Jv_RunMain (jclass klass, const char *name, int argc, const char **argv,
bool is_jar)
_Jv_RunMain (JvVMInitArgs *vm_args, jclass klass, const char *name, int argc,
const char **argv, bool is_jar)
{
#ifndef DISABLE_MAIN_ARGS
_Jv_SetArgs (argc, argv);
......@@ -1178,12 +1290,7 @@ _Jv_RunMain (jclass klass, const char *name, int argc, const char **argv,
try
{
// Set this very early so that it is seen when java.lang.System
// is initialized.
if (is_jar)
_Jv_Jar_Class_Path = strdup (name);
if (_Jv_CreateJavaVM (NULL) < 0)
if (_Jv_CreateJavaVM (vm_args) < 0)
{
fprintf (stderr, "libgcj: couldn't create virtual machine\n");
exit (1);
......@@ -1226,6 +1333,13 @@ _Jv_RunMain (jclass klass, const char *name, int argc, const char **argv,
}
void
_Jv_RunMain (jclass klass, const char *name, int argc, const char **argv,
bool is_jar)
{
_Jv_RunMain (NULL, klass, name, argc, argv, is_jar);
}
void
JvRunMain (jclass klass, int argc, const char **argv)
{
_Jv_RunMain (klass, NULL, argc, argv, false);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment