https://gcc.gnu.org/bugzilla/show_bug.cgi?id=68746

--- Comment #12 from dave.anglin at bell dot net ---
On 2018-01-31 3:17 AM, tkoenig at gcc dot gnu.org wrote:
> Is there anything than can be done to debug this?
> What happens if you compile the test with -g and
> run it under a debgger?
It's not easy.  It turns out the "system" call causes gdb to crash. 
Working around that,
we have at the end of data_transfer_init:

Breakpoint 34, data_transfer_init (dtp=0x800003fffdff0ad0,
     read_flag=<optimized out>) at 
../../../gcc/libgfortran/io/transfer.c:3201
3201          if ((cf & (IOPARM_DT_LIST_FORMAT | 
IOPARM_DT_HAS_NAMELIST_NAME)) == 0
(gdb) p cf
$7 = 128
(gdb) p *dtp
$8 = {common = {flags = 128, unit = 6,
     filename = 0x4000000000001860 "read_dir.f90", line = 10,
     iomsg_len = 9223376434867631712, iomsg = 0x800003fffdfedbf8 "\200",
     iostat = 0x800003fffdff0acc}, rec = 0, size = 0x9,
   iolength = 0x4000000000001870, internal_unit_desc = 0x0,
   format = 0x40000000000018a0 <options.4> "", format_len = 6,
   advance_len = 4611686018427394176,
   advance = 0x1 <error: Cannot access memory at address 0x1>,
   internal_unit = 0x0, internal_unit_len = 9223376434866410515,
   namelist_name_len = 9223376434866047520,
   namelist_name = 0x4 <error: Cannot access memory at address 0x4>, id 
= 0x0,
   pos = 4, asynchronous = 0x4000000000001888 "read", asynchronous_len = 0,
   blank_len = 0, blank = 0x800003fffdff07b0 "\200",
   decimal = 0x800003fffde64a20 "\200", decimal_len = 3,
   delim_len = 9223376434866032944, delim = 0x800003fffdff0b10 "@",
   pad = 0x318 <error: Cannot access memory at address 0x318>, pad_len = 1,
   round_len = 0, round = 0x0,
   sign = 0x800003fffdda4293 <signal+136> "\301\210\034 
\030S\302>\241S\334?\001\350@\320", sign_len = 281479271677959, u = {p = {
       transfer = 0x800003fffde62260, current_unit = 0x800000010000a518,
       item_count = 0, mode = WRITING, blank_status = BLANK_NULL,
       sign_status = SIGN_UNSPECIFIED, scale_factor = 0, max_pos = 0,
       skips = 0, pending_spaces = 0, sf_seen_eor = 0,
---Type <return> to continue, or q <return> to quit---
       advance_status = ADVANCE_YES, reversion_flag = 0, first_item = 1,
       seen_dollar = 0, eor_condition = 0, no_leading_blank = 0, 
char_flag = 0,
       input_complete = 0, at_eol = 0, comma_flag = 0, namelist_mode = 0,
       nml_read_error = 0, sf_read_comma = 0, line_buffer_enabled = 0,
       unit_is_internal = 0, at_eof = 0, g0_no_blanks = 0,
       format_not_saved = 0, expanded_read = 0, child_saved_iostat = 0,
       nml_delim = 0, repeat_count = 0, saved_length = 0, saved_used = 0,
       saved_type = BT_UNKNOWN, saved_string = 0x0, scratch = 0x0,
       line_buffer = 0x0, fmt = 0x0, ionml = 0x0, line_buffer_pos = 0,
       value = '\000' <repeats 31 times>, not_used = 0, fdtio_ptr = 0x0,
       ufdtio_ptr = 0x0, cc = {type = 0, len = 0, u = {start = 0 '\000',
           end = 0 '\000'}}},
     pad = 
"\200\000\003\377\375\346\"`\200\000\000\001\000\000\245\030\000\000\000\000\000\000\000\001\000\000\000\000\000\000\000\003",
 
'\000' <repeats 24 times>, "@", '\000' <repeats 151 times>...}}

Reply via email to