public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result
@ 2008-04-20 10:51 fxcoudert at gcc dot gnu dot org
2008-04-20 11:41 ` [Bug fortran/35983] " burnus at gcc dot gnu dot org
` (5 more replies)
0 siblings, 6 replies; 7+ messages in thread
From: fxcoudert at gcc dot gnu dot org @ 2008-04-20 10:51 UTC (permalink / raw)
To: gcc-bugs
$ cat a.f90
program main
use ISO_C_BINDING
implicit none
type, bind(C) :: descr
type(C_PTR) :: address
end type descr
type(descr) :: DD
double precision, target :: buf(1)
buf = (/ 0 /)
DD = descr(c_loc(buf))
print *, transfer(DD%address, 0_c_intptr_t), &
transfer(c_loc (buf), 0_c_intptr_t)
end program main
$ gfortran a.f90 && ./a.out
0 -1073744200
--
Summary: C_LOC in derived type constructor gives weird result
Product: gcc
Version: 4.4.0
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: fortran
AssignedTo: unassigned at gcc dot gnu dot org
ReportedBy: fxcoudert at gcc dot gnu dot org
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug fortran/35983] C_LOC in derived type constructor gives weird result
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
@ 2008-04-20 11:41 ` burnus at gcc dot gnu dot org
2008-11-05 11:45 ` mikael dot morin at tele2 dot fr
` (4 subsequent siblings)
5 siblings, 0 replies; 7+ messages in thread
From: burnus at gcc dot gnu dot org @ 2008-04-20 11:41 UTC (permalink / raw)
To: gcc-bugs
------- Comment #1 from burnus at gcc dot gnu dot org 2008-04-20 11:40 -------
Confirm. While for
type(c_ptr) :: cptr
cptr = c_loc(buf)
the dump is:
void * D.910;
D.910 = (void *) &buf;
dd.address = D.910;
Your structure constructor, DD = descr(c_loc(buf)), gives:
struct descr descr.2;
descr.2.address = 0B;
--
burnus at gcc dot gnu dot org changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|UNCONFIRMED |NEW
Ever Confirmed|0 |1
Keywords| |wrong-code
Last reconfirmed|0000-00-00 00:00:00 |2008-04-20 11:40:52
date| |
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug fortran/35983] C_LOC in derived type constructor gives weird result
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
2008-04-20 11:41 ` [Bug fortran/35983] " burnus at gcc dot gnu dot org
@ 2008-11-05 11:45 ` mikael dot morin at tele2 dot fr
2008-12-09 19:15 ` mikael at gcc dot gnu dot org
` (3 subsequent siblings)
5 siblings, 0 replies; 7+ messages in thread
From: mikael dot morin at tele2 dot fr @ 2008-11-05 11:45 UTC (permalink / raw)
To: gcc-bugs
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1: Type: text/plain, Size: 2042 bytes --]
------- Comment #2 from mikael dot morin at tele2 dot fr 2008-11-05 11:43 -------
There is a reset of the expression to NULL_EXPR in case we encounter c_null_ptr
or c_null_funptr.
However, the if conditions for this relies on the is_iso_c attribute, which is
the case of c_loc.
This patch changes this behavior by relying on the symtree names instead.
Index: trans-expr.c
===================================================================
--- trans-expr.c (révision 141583)
+++ trans-expr.c (copie de travail)
@@ -3689,15 +3682,16 @@ gfc_trans_structure_assign (tree dest, gfc_expr *
{
/* Skip absent members in default initializers. */
if (!c->expr)
- continue;
+ continue;
/* Update the type/kind of the expression if it represents either
C_NULL_PTR or C_NULL_FUNPTR. This is done here because this may
be the first place reached for initializing output variables that
have components of type C_PTR/C_FUNPTR that are initialized. */
- if (c->expr->ts.type == BT_DERIVED && c->expr->ts.derived
- && c->expr->ts.derived->attr.is_iso_c)
- {
+ if (c->expr->symtree && c->expr->symtree->name
+ && (!strcmp ("c_null_ptr", c->expr->symtree->name)
+ || !strcmp ("c_null_funptr", c->expr->symtree->name)))
+ {
c->expr->expr_type = EXPR_NULL;
c->expr->ts.type = c->expr->ts.derived->ts.type;
c->expr->ts.f90_type = c->expr->ts.derived->ts.f90_type;
With this patch alone, I still get wrong-code though (pointer uninitialized
instead of nullified).
I've had to revert this patch
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35150#c7
to have it working.
There is only one regression, c_loc_tests_12.f03.
That one is expected, and we are back at PR35150.
I looked at that one too, but I must admit I'm at least as confused as FX when
he fixed it.
If some middle-end gurus could take a look/give some tips there...
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug fortran/35983] C_LOC in derived type constructor gives weird result
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
2008-04-20 11:41 ` [Bug fortran/35983] " burnus at gcc dot gnu dot org
2008-11-05 11:45 ` mikael dot morin at tele2 dot fr
@ 2008-12-09 19:15 ` mikael at gcc dot gnu dot org
2008-12-09 19:44 ` mikael at gcc dot gnu dot org
` (2 subsequent siblings)
5 siblings, 0 replies; 7+ messages in thread
From: mikael at gcc dot gnu dot org @ 2008-12-09 19:15 UTC (permalink / raw)
To: gcc-bugs
------- Comment #3 from mikael at gcc dot gnu dot org 2008-12-09 19:13 -------
Subject: Bug 35983
Author: mikael
Date: Tue Dec 9 19:12:27 2008
New Revision: 142605
URL: http://gcc.gnu.org/viewcvs?root=gcc&view=rev&rev=142605
Log:
2008-12-09 Mikael Morin <mikael.morin@tele2.fr>
PR fortran/35983
* trans-expr.c (gfc_trans_subcomponent_assign):
Add se's pre and post blocks to current block.
(gfc_trans_structure_assign): Remove specific handling
of C_NULL_PTR and C_NULL_FUNPTR.
2008-12-09 Mikael Morin <mikael.morin@tele2.fr>
PR fortran/35983
* gfortran.dg/pr35983.f90: New test.
Added:
trunk/gcc/testsuite/gfortran.dg/pr35983.f90
Modified:
trunk/gcc/fortran/ChangeLog
trunk/gcc/fortran/trans-expr.c
trunk/gcc/testsuite/ChangeLog
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug fortran/35983] C_LOC in derived type constructor gives weird result
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
` (2 preceding siblings ...)
2008-12-09 19:15 ` mikael at gcc dot gnu dot org
@ 2008-12-09 19:44 ` mikael at gcc dot gnu dot org
2008-12-21 15:08 ` mikael at gcc dot gnu dot org
2008-12-21 15:12 ` mikael at gcc dot gnu dot org
5 siblings, 0 replies; 7+ messages in thread
From: mikael at gcc dot gnu dot org @ 2008-12-09 19:44 UTC (permalink / raw)
To: gcc-bugs
--
mikael at gcc dot gnu dot org changed:
What |Removed |Added
----------------------------------------------------------------------------
AssignedTo|unassigned at gcc dot gnu |mikael at gcc dot gnu dot
|dot org |org
Status|NEW |ASSIGNED
Last reconfirmed|2008-04-20 11:40:52 |2008-12-09 19:32:41
date| |
Target Milestone|--- |4.4.0
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug fortran/35983] C_LOC in derived type constructor gives weird result
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
` (3 preceding siblings ...)
2008-12-09 19:44 ` mikael at gcc dot gnu dot org
@ 2008-12-21 15:08 ` mikael at gcc dot gnu dot org
2008-12-21 15:12 ` mikael at gcc dot gnu dot org
5 siblings, 0 replies; 7+ messages in thread
From: mikael at gcc dot gnu dot org @ 2008-12-21 15:08 UTC (permalink / raw)
To: gcc-bugs
------- Comment #4 from mikael at gcc dot gnu dot org 2008-12-21 15:07 -------
Subject: Bug 35983
Author: mikael
Date: Sun Dec 21 15:06:15 2008
New Revision: 142860
URL: http://gcc.gnu.org/viewcvs?root=gcc&view=rev&rev=142860
Log:
2008-12-21 Mikael Morin <mikael.morin@tele2.fr>
PR fortran/35983
* trans-expr.c (gfc_trans_subcomponent_assign):
Add se's pre and post blocks to current block.
(gfc_trans_structure_assign): Remove specific handling
of C_NULL_PTR and C_NULL_FUNPTR.
2008-12-21 Mikael Morin <mikael.morin@tele2.fr>
PR fortran/35983
* gfortran.dg/pr35983.f90: New test.
Added:
branches/gcc-4_3-branch/gcc/testsuite/gfortran.dg/pr35983.f90
Modified:
branches/gcc-4_3-branch/gcc/fortran/ChangeLog
branches/gcc-4_3-branch/gcc/fortran/trans-expr.c
branches/gcc-4_3-branch/gcc/testsuite/ChangeLog
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
* [Bug fortran/35983] C_LOC in derived type constructor gives weird result
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
` (4 preceding siblings ...)
2008-12-21 15:08 ` mikael at gcc dot gnu dot org
@ 2008-12-21 15:12 ` mikael at gcc dot gnu dot org
5 siblings, 0 replies; 7+ messages in thread
From: mikael at gcc dot gnu dot org @ 2008-12-21 15:12 UTC (permalink / raw)
To: gcc-bugs
------- Comment #5 from mikael at gcc dot gnu dot org 2008-12-21 15:10 -------
Fixed on trunk(4.4) and 4.3.
Thanks for the report.
--
mikael at gcc dot gnu dot org changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|ASSIGNED |RESOLVED
Resolution| |FIXED
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=35983
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2008-12-21 15:12 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-04-20 10:51 [Bug fortran/35983] New: C_LOC in derived type constructor gives weird result fxcoudert at gcc dot gnu dot org
2008-04-20 11:41 ` [Bug fortran/35983] " burnus at gcc dot gnu dot org
2008-11-05 11:45 ` mikael dot morin at tele2 dot fr
2008-12-09 19:15 ` mikael at gcc dot gnu dot org
2008-12-09 19:44 ` mikael at gcc dot gnu dot org
2008-12-21 15:08 ` mikael at gcc dot gnu dot org
2008-12-21 15:12 ` mikael at gcc dot gnu dot org
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).