2005-08-11 15:50:13 +02:00
|
|
|
/* Handling of compile-time options that influence the library.
|
2010-06-25 21:17:21 +02:00
|
|
|
Copyright (C) 2005, 2007, 2009, 2010 Free Software Foundation, Inc.
|
2005-08-11 15:50:13 +02:00
|
|
|
|
2010-06-25 21:17:21 +02:00
|
|
|
This file is part of the GNU Fortran runtime library (libgfortran).
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
Libgfortran is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
2009-04-09 17:00:19 +02:00
|
|
|
the Free Software Foundation; either version 3, or (at your option)
|
2005-08-11 15:50:13 +02:00
|
|
|
any later version.
|
|
|
|
|
|
|
|
Libgfortran 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 for more details.
|
|
|
|
|
2009-04-09 17:00:19 +02:00
|
|
|
Under Section 7 of GPL version 3, you are granted additional
|
|
|
|
permissions described in the GCC Runtime Library Exception, version
|
|
|
|
3.1, as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License and
|
|
|
|
a copy of the GCC Runtime Library Exception along with this program;
|
|
|
|
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
|
|
<http://www.gnu.org/licenses/>. */
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
#include "libgfortran.h"
|
|
|
|
|
2007-08-11 21:52:22 +00:00
|
|
|
#ifdef HAVE_SIGNAL_H
|
|
|
|
#include <signal.h>
|
|
|
|
#endif
|
|
|
|
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
/* Useful compile-time options will be stored in here. */
|
|
|
|
compile_options_t compile_options;
|
|
|
|
|
2007-08-11 21:52:22 +00:00
|
|
|
|
|
|
|
/* A signal handler to allow us to output a backtrace. */
|
|
|
|
void
|
|
|
|
handler (int signum)
|
|
|
|
{
|
|
|
|
const char * name = NULL, * desc = NULL;
|
|
|
|
|
|
|
|
switch (signum)
|
|
|
|
{
|
|
|
|
#if defined(SIGSEGV)
|
|
|
|
case SIGSEGV:
|
|
|
|
name = "SIGSEGV";
|
|
|
|
desc = "Segmentation fault";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGBUS)
|
|
|
|
case SIGBUS:
|
|
|
|
name = "SIGBUS";
|
|
|
|
desc = "Bus error";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGILL)
|
|
|
|
case SIGILL:
|
|
|
|
name = "SIGILL";
|
|
|
|
desc = "Illegal instruction";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGFPE)
|
|
|
|
case SIGFPE:
|
|
|
|
name = "SIGFPE";
|
|
|
|
desc = "Floating-point exception";
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
if (name)
|
|
|
|
st_printf ("\nProgram received signal %d (%s): %s.\n", signum, name, desc);
|
|
|
|
else
|
|
|
|
st_printf ("\nProgram received signal %d.\n", signum);
|
|
|
|
|
|
|
|
sys_exit (5);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-07-15 16:26:22 +00:00
|
|
|
/* Set the usual compile-time options. */
|
|
|
|
extern void set_options (int , int []);
|
|
|
|
export_proto(set_options);
|
2005-08-11 15:50:13 +02:00
|
|
|
|
|
|
|
void
|
2007-07-15 16:26:22 +00:00
|
|
|
set_options (int num, int options[])
|
2005-08-11 15:50:13 +02:00
|
|
|
{
|
2007-07-15 16:26:22 +00:00
|
|
|
if (num >= 1)
|
|
|
|
compile_options.warn_std = options[0];
|
|
|
|
if (num >= 2)
|
|
|
|
compile_options.allow_std = options[1];
|
|
|
|
if (num >= 3)
|
|
|
|
compile_options.pedantic = options[2];
|
|
|
|
if (num >= 4)
|
|
|
|
compile_options.dump_core = options[3];
|
|
|
|
if (num >= 5)
|
|
|
|
compile_options.backtrace = options[4];
|
|
|
|
if (num >= 6)
|
|
|
|
compile_options.sign_zero = options[5];
|
2007-07-24 05:52:44 +00:00
|
|
|
if (num >= 7)
|
|
|
|
compile_options.bounds_check = options[6];
|
2008-06-15 20:02:58 +00:00
|
|
|
if (num >= 8)
|
|
|
|
compile_options.range_check = options[7];
|
2007-08-11 21:52:22 +00:00
|
|
|
|
|
|
|
/* If backtrace is required, we set signal handlers on most common
|
|
|
|
signals. */
|
2007-09-15 14:52:46 +00:00
|
|
|
#if defined(HAVE_SIGNAL) && (defined(SIGSEGV) || defined(SIGBUS) \
|
|
|
|
|| defined(SIGILL) || defined(SIGFPE))
|
2007-08-11 21:52:22 +00:00
|
|
|
if (compile_options.backtrace)
|
|
|
|
{
|
|
|
|
#if defined(SIGSEGV)
|
|
|
|
signal (SIGSEGV, handler);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGBUS)
|
|
|
|
signal (SIGBUS, handler);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGILL)
|
|
|
|
signal (SIGILL, handler);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(SIGFPE)
|
|
|
|
signal (SIGFPE, handler);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2005-08-11 15:50:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* Default values for the compile-time options. Keep in sync with
|
|
|
|
gcc/fortran/options.c (gfc_init_options). */
|
|
|
|
void
|
|
|
|
init_compile_options (void)
|
|
|
|
{
|
2008-09-24 09:08:22 +02:00
|
|
|
compile_options.warn_std = GFC_STD_F95_DEL | GFC_STD_LEGACY;
|
2005-08-11 15:50:13 +02:00
|
|
|
compile_options.allow_std = GFC_STD_F95_OBS | GFC_STD_F95_DEL
|
2008-09-24 09:08:22 +02:00
|
|
|
| GFC_STD_F2003 | GFC_STD_F2008 | GFC_STD_F95 | GFC_STD_F77
|
2010-06-25 21:17:21 +02:00
|
|
|
| GFC_STD_F2008_OBS | GFC_STD_GNU | GFC_STD_LEGACY;
|
2006-02-08 20:54:14 +00:00
|
|
|
compile_options.pedantic = 0;
|
2007-01-18 13:54:11 +01:00
|
|
|
compile_options.dump_core = 0;
|
gfortran.h (gfc_option_t): Add flag_backtrace field.
* gfortran.h (gfc_option_t): Add flag_backtrace field.
* lang.opt: Add -fbacktrace option.
* invoke.texi: Document the new option.
* trans-decl.c (gfc_build_builtin_function_decls): Add new
option to the call to set_std.
* options.c (gfc_init_options, gfc_handle_option): Handle the
new option.
* runtime/backtrace.c: New file.
* runtime/environ.c (variable_table): New GFORTRAN_ERROR_BACKTRACE
environment variable.
* runtime/compile_options.c (set_std): Add new argument.
* runtime/main.c (store_exe_path, full_exe_path): New functions.
* runtime/error.c (sys_exit): Add call to show_backtrace.
* libgfortran.h (options_t): New backtrace field.
(store_exe_path, full_exe_path, show_backtrace): New prototypes.
* configure.ac: Add checks for execinfo.h, execvp, pipe, dup2,
close, fdopen, strcasestr, getrlimit, backtrace, backtrace_symbols
and getppid.
* Makefile.am: Add runtime/backtrace.c.
* fmain.c (main): Add call to store_exe_path.
* Makefile.in: Renegerate.
* config.h.in: Renegerate.
* configure: Regenerate.
From-SVN: r122954
2007-03-15 13:39:47 +01:00
|
|
|
compile_options.backtrace = 0;
|
2007-07-15 16:26:22 +00:00
|
|
|
compile_options.sign_zero = 1;
|
2008-06-15 20:02:58 +00:00
|
|
|
compile_options.range_check = 1;
|
2005-08-11 15:50:13 +02:00
|
|
|
}
|
2006-02-06 20:12:44 +00:00
|
|
|
|
|
|
|
/* Function called by the front-end to tell us the
|
|
|
|
default for unformatted data conversion. */
|
|
|
|
|
|
|
|
extern void set_convert (int);
|
|
|
|
export_proto (set_convert);
|
|
|
|
|
|
|
|
void
|
|
|
|
set_convert (int conv)
|
|
|
|
{
|
|
|
|
compile_options.convert = conv;
|
|
|
|
}
|
2006-03-22 19:09:11 +00:00
|
|
|
|
|
|
|
extern void set_record_marker (int);
|
|
|
|
export_proto (set_record_marker);
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
set_record_marker (int val)
|
|
|
|
{
|
|
|
|
|
|
|
|
switch(val)
|
|
|
|
{
|
|
|
|
case 4:
|
re PR libfortran/29568 (implement unformatted files with subrecords (Intel style))
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.dg/convert_implied_open.f90: Change to
new default record length.
* gfortran.dg/unf_short_record_1.f90: Adapt to
new error message.
* gfortran.dg/unformatted_subrecords_1.f90: New test.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.h (gfc_option_t): Add max_subrecord_length.
(top level): Define MAX_SUBRECORD_LENGTH.
* lang.opt: Add option -fmax-subrecord-length=.
* trans-decl.c: Add new function set_max_subrecord_length.
(gfc_generate_function_code): If we are within the main
program and max_subrecord_length has been set, call
set_max_subrecord_length.
* options.c (gfc_init_options): Add defaults for
max_subrecord_lenght, convert and record_marker.
(gfc_handle_option): Add handling for
-fmax_subrecord_length.
* invoke.texi: Document the new default for
-frecord-marker=<n>.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* libgfortran/libgfortran.h (compile_options_t): Add
record_marker. (top level): Define GFC_MAX_SUBRECORD_LENGTH.
* runtime/compile_options.c (set_record_marker): Change
default to four-byte record marker.
(set_max_subrecord_length): New function.
* runtime/error.c (translate_error): Change error message
for short record on unformatted read.
* io/io.h (gfc_unit): Add recl_subrecord, bytes_left_subrecord
and continued.
* io/file_pos.c (unformatted_backspace): Change default of record
marker size to four bytes. Loop over subrecords.
* io/open.c: Default recl is max_offset. If
compile_options.max_subrecord_length has been set, set set
u->recl_subrecord to its value, to the maximum value otherwise.
* io/transfer.c (top level): Add prototypes for us_read, us_write,
next_record_r_unf and next_record_w_unf.
(read_block_direct): Separate codepaths for unformatted direct
and unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(write_buf): Separate codepaths for unformatted direct and
unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(us_read): Add parameter continued (to indicate that bytes_left
should not be intialized). Change default of record marker size
to four bytes. Use subrecord. If the subrecord length is smaller than
zero, this indicates a continuation.
(us_write): Add parameter continued (to indicate that the continued
flag should be set). Use subrecord.
(pre_position): Use 0 for continued on us_write and us_read calls.
(skip_record): New function.
(next_record_r_unf): New function.
(next_record_r): Use next_record_r_unf.
(write_us_marker): Default size for record markers is four bytes.
(next_record_w_unf): New function.
(next_record_w): Use next_record_w_unf.
From-SVN: r119412
2006-12-01 21:04:38 +00:00
|
|
|
compile_options.record_marker = sizeof (GFC_INTEGER_4);
|
2006-03-22 19:09:11 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 8:
|
re PR libfortran/29568 (implement unformatted files with subrecords (Intel style))
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.dg/convert_implied_open.f90: Change to
new default record length.
* gfortran.dg/unf_short_record_1.f90: Adapt to
new error message.
* gfortran.dg/unformatted_subrecords_1.f90: New test.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.h (gfc_option_t): Add max_subrecord_length.
(top level): Define MAX_SUBRECORD_LENGTH.
* lang.opt: Add option -fmax-subrecord-length=.
* trans-decl.c: Add new function set_max_subrecord_length.
(gfc_generate_function_code): If we are within the main
program and max_subrecord_length has been set, call
set_max_subrecord_length.
* options.c (gfc_init_options): Add defaults for
max_subrecord_lenght, convert and record_marker.
(gfc_handle_option): Add handling for
-fmax_subrecord_length.
* invoke.texi: Document the new default for
-frecord-marker=<n>.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* libgfortran/libgfortran.h (compile_options_t): Add
record_marker. (top level): Define GFC_MAX_SUBRECORD_LENGTH.
* runtime/compile_options.c (set_record_marker): Change
default to four-byte record marker.
(set_max_subrecord_length): New function.
* runtime/error.c (translate_error): Change error message
for short record on unformatted read.
* io/io.h (gfc_unit): Add recl_subrecord, bytes_left_subrecord
and continued.
* io/file_pos.c (unformatted_backspace): Change default of record
marker size to four bytes. Loop over subrecords.
* io/open.c: Default recl is max_offset. If
compile_options.max_subrecord_length has been set, set set
u->recl_subrecord to its value, to the maximum value otherwise.
* io/transfer.c (top level): Add prototypes for us_read, us_write,
next_record_r_unf and next_record_w_unf.
(read_block_direct): Separate codepaths for unformatted direct
and unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(write_buf): Separate codepaths for unformatted direct and
unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(us_read): Add parameter continued (to indicate that bytes_left
should not be intialized). Change default of record marker size
to four bytes. Use subrecord. If the subrecord length is smaller than
zero, this indicates a continuation.
(us_write): Add parameter continued (to indicate that the continued
flag should be set). Use subrecord.
(pre_position): Use 0 for continued on us_write and us_read calls.
(skip_record): New function.
(next_record_r_unf): New function.
(next_record_r): Use next_record_r_unf.
(write_us_marker): Default size for record markers is four bytes.
(next_record_w_unf): New function.
(next_record_w): Use next_record_w_unf.
From-SVN: r119412
2006-12-01 21:04:38 +00:00
|
|
|
compile_options.record_marker = sizeof (GFC_INTEGER_8);
|
2006-03-22 19:09:11 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
runtime_error ("Invalid value for record marker");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
re PR libfortran/29568 (implement unformatted files with subrecords (Intel style))
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.dg/convert_implied_open.f90: Change to
new default record length.
* gfortran.dg/unf_short_record_1.f90: Adapt to
new error message.
* gfortran.dg/unformatted_subrecords_1.f90: New test.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* gfortran.h (gfc_option_t): Add max_subrecord_length.
(top level): Define MAX_SUBRECORD_LENGTH.
* lang.opt: Add option -fmax-subrecord-length=.
* trans-decl.c: Add new function set_max_subrecord_length.
(gfc_generate_function_code): If we are within the main
program and max_subrecord_length has been set, call
set_max_subrecord_length.
* options.c (gfc_init_options): Add defaults for
max_subrecord_lenght, convert and record_marker.
(gfc_handle_option): Add handling for
-fmax_subrecord_length.
* invoke.texi: Document the new default for
-frecord-marker=<n>.
2006-12-01 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/29568
* libgfortran/libgfortran.h (compile_options_t): Add
record_marker. (top level): Define GFC_MAX_SUBRECORD_LENGTH.
* runtime/compile_options.c (set_record_marker): Change
default to four-byte record marker.
(set_max_subrecord_length): New function.
* runtime/error.c (translate_error): Change error message
for short record on unformatted read.
* io/io.h (gfc_unit): Add recl_subrecord, bytes_left_subrecord
and continued.
* io/file_pos.c (unformatted_backspace): Change default of record
marker size to four bytes. Loop over subrecords.
* io/open.c: Default recl is max_offset. If
compile_options.max_subrecord_length has been set, set set
u->recl_subrecord to its value, to the maximum value otherwise.
* io/transfer.c (top level): Add prototypes for us_read, us_write,
next_record_r_unf and next_record_w_unf.
(read_block_direct): Separate codepaths for unformatted direct
and unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(write_buf): Separate codepaths for unformatted direct and
unformatted sequential. If a recl has been set by the
user, use the number of bytes left for the record if it is smaller
than the read request. Loop over subrecords. Set an error if the
user has set a recl and the read was short.
(us_read): Add parameter continued (to indicate that bytes_left
should not be intialized). Change default of record marker size
to four bytes. Use subrecord. If the subrecord length is smaller than
zero, this indicates a continuation.
(us_write): Add parameter continued (to indicate that the continued
flag should be set). Use subrecord.
(pre_position): Use 0 for continued on us_write and us_read calls.
(skip_record): New function.
(next_record_r_unf): New function.
(next_record_r): Use next_record_r_unf.
(write_us_marker): Default size for record markers is four bytes.
(next_record_w_unf): New function.
(next_record_w): Use next_record_w_unf.
From-SVN: r119412
2006-12-01 21:04:38 +00:00
|
|
|
|
|
|
|
extern void set_max_subrecord_length (int);
|
|
|
|
export_proto (set_max_subrecord_length);
|
|
|
|
|
|
|
|
void set_max_subrecord_length(int val)
|
|
|
|
{
|
|
|
|
if (val > GFC_MAX_SUBRECORD_LENGTH || val < 1)
|
|
|
|
{
|
|
|
|
runtime_error ("Invalid value for maximum subrecord length");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
compile_options.max_subrecord_length = val;
|
|
|
|
}
|