aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2009-03-30 16:38:08 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2009-03-30 16:38:08 +0200
commit665733c1215086f71896682d631dd03aec7710d2 (patch)
tree80388c8b8c4e0b0796529810d742e6b4760a67fb /gcc
parentb3f27c1577aba48ad3dc74ebb59587f23506e726 (diff)
downloadgcc-665733c1215086f71896682d631dd03aec7710d2.zip
gcc-665733c1215086f71896682d631dd03aec7710d2.tar.gz
gcc-665733c1215086f71896682d631dd03aec7710d2.tar.bz2
trans-types.c (gfc_sym_type, [...]): For sym->attr.result check sym->ns->proc_name->attr.is_bind_c.
* trans-types.c (gfc_sym_type, gfc_return_by_reference): For sym->attr.result check sym->ns->proc_name->attr.is_bind_c. * gfortran.dg/bind_c_usage_19.f90: New test. From-SVN: r145294
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog5
-rw-r--r--gcc/fortran/trans-types.c13
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gfortran.dg/bind_c_usage_19.f9031
4 files changed, 50 insertions, 3 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index d4a24ddc..bcb3a60 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,8 @@
+2009-03-30 Jakub Jelinek <jakub@redhat.com>
+
+ * trans-types.c (gfc_sym_type, gfc_return_by_reference): For
+ sym->attr.result check sym->ns->proc_name->attr.is_bind_c.
+
2009-03-30 Joseph Myers <joseph@codesourcery.com>
PR rtl-optimization/323
diff --git a/gcc/fortran/trans-types.c b/gcc/fortran/trans-types.c
index de76486..717859c 100644
--- a/gcc/fortran/trans-types.c
+++ b/gcc/fortran/trans-types.c
@@ -1632,8 +1632,11 @@ gfc_sym_type (gfc_symbol * sym)
if (sym->backend_decl && !sym->attr.function)
return TREE_TYPE (sym->backend_decl);
- if (sym->ts.type == BT_CHARACTER && sym->attr.is_bind_c
- && (sym->attr.function || sym->attr.result))
+ if (sym->ts.type == BT_CHARACTER
+ && ((sym->attr.function && sym->attr.is_bind_c)
+ || (sym->attr.result
+ && sym->ns->proc_name
+ && sym->ns->proc_name->attr.is_bind_c)))
type = gfc_character1_type_node;
else
type = gfc_typenode_for_spec (&sym->ts);
@@ -1962,7 +1965,11 @@ gfc_return_by_reference (gfc_symbol * sym)
if (sym->attr.dimension)
return 1;
- if (sym->ts.type == BT_CHARACTER && !sym->attr.is_bind_c)
+ if (sym->ts.type == BT_CHARACTER
+ && !sym->attr.is_bind_c
+ && (!sym->attr.result
+ || !sym->ns->proc_name
+ || !sym->ns->proc_name->attr.is_bind_c))
return 1;
/* Possibly return complex numbers by reference for g77 compatibility.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 37dcc21..d672724 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2009-03-30 Jakub Jelinek <jakub@redhat.com>
+
+ * gfortran.dg/bind_c_usage_19.f90: New test.
+
2009-03-30 Joseph Myers <joseph@codesourcery.com>
PR rtl-optimization/323
diff --git a/gcc/testsuite/gfortran.dg/bind_c_usage_19.f90 b/gcc/testsuite/gfortran.dg/bind_c_usage_19.f90
new file mode 100644
index 0000000..30f9f5e
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/bind_c_usage_19.f90
@@ -0,0 +1,31 @@
+! { dg-do compile }
+function return_char1(i) bind(c,name='return_char1')
+ use iso_c_binding
+ implicit none
+ integer(c_int) :: i
+ character(c_char) :: j
+ character(c_char) :: return_char1
+
+ j = achar(i)
+ return_char1 = j
+end function return_char1
+function return_char2(i) result(output) bind(c,name='return_char2')
+ use iso_c_binding
+ implicit none
+ integer(c_int) :: i
+ character(c_char) :: j
+ character(c_char) :: output
+
+ j = achar(i)
+ output = j
+end function return_char2
+function return_char3(i) bind(c,name='return_char3') result(output)
+ use iso_c_binding
+ implicit none
+ integer(c_int) :: i
+ character(c_char) :: j
+ character(c_char) :: output
+
+ j = achar(i)
+ output = j
+end function return_char3