+2017-12-02 Jerry DeLisle <jvdelisle@gcc.gnu.org>
+
+ PR libgfortran/83225
+ * io/io.h (is_internal_unit): Use the unit_is_internal bit.
+ * io/transfer.c (data_transfer_init): Set the bit to true for
+ internal umits. Use that bit for checks for internal unit
+ initializations.
+ * io/unit.c (insert_unit): As a precaution, set the
+ internal_unit_kind to zero when a unit structure is first created.
+
2017-11-28 Janne Blomqvist <jb@gcc.gnu.org>
PR fortran/53796
#define is_array_io(dtp) ((dtp)->internal_unit_desc)
-#define is_internal_unit(dtp) ((dtp)->u.p.current_unit->internal_unit_kind)
+#define is_internal_unit(dtp) ((dtp)->u.p.unit_is_internal)
#define is_stream_io(dtp) ((dtp)->u.p.current_unit->flags.access == ACCESS_STREAM)
else
dtp->u.p.current_unit->has_size = false;
}
+ else if (dtp->u.p.current_unit->internal_unit_kind > 0)
+ dtp->u.p.unit_is_internal = 1;
/* Check the action. */
if (dtp->u.p.current_unit != NULL
&& dtp->u.p.current_unit->child_dtio == 0)
{
- if (is_internal_unit (dtp))
+ if (dtp->u.p.unit_is_internal)
{
if ((dtp->common.flags & IOPARM_DT_HAS_UDTIO) == 0)
{
}
newunit_free (dtp->common.unit);
}
- if (is_internal_unit (dtp) || dtp->u.p.format_not_saved)
+ if (dtp->u.p.unit_is_internal || dtp->u.p.format_not_saved)
{
free_format_data (dtp->u.p.fmt);
free_format (dtp);
/* If this is a parent WRITE statement we do not need to retain the
internal unit structure for child use. */
- if (is_internal_unit (dtp))
+ if (dtp->u.p.unit_is_internal)
{
if ((dtp->common.flags & IOPARM_DT_HAS_UDTIO) == 0)
{
}
newunit_free (dtp->common.unit);
}
- if (is_internal_unit (dtp) || dtp->u.p.format_not_saved)
+ if (dtp->u.p.unit_is_internal || dtp->u.p.format_not_saved)
{
free_format_data (dtp->u.p.fmt);
free_format (dtp);
{
gfc_unit *u = xcalloc (1, sizeof (gfc_unit));
u->unit_number = n;
+ u->internal_unit_kind = 0;
#ifdef __GTHREAD_MUTEX_INIT
{
__gthread_mutex_t tmp = __GTHREAD_MUTEX_INIT;