public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug fortran/36842] New: Fortran: Minimize heap allocation of temporary arrays.
@ 2008-07-15 18:15 rajiv dot adhikary at amd dot com
2008-07-23 9:44 ` [Bug fortran/36842] " rguenth at gcc dot gnu dot org
2010-05-10 18:26 ` mikael at gcc dot gnu dot org
0 siblings, 2 replies; 3+ messages in thread
From: rajiv dot adhikary at amd dot com @ 2008-07-15 18:15 UTC (permalink / raw)
To: gcc-bugs
Instead of automatically allocating the temporary array in heap, it would be
wise to perform a few checks to determine a temporary array is actually
required, whether to reserve memory in stack instead etc.
The code produced by GCC for the following subroutine does the following.
i. Start the loop.
ii. Malloc memory required to hold Ry(:,n) * Rx(:)
iii. Perform Ry(:,n)* Rx(:), store result in malloced memory
iv. Copy result from malloced memory to Ry(:,n)
v. Free malloced memory
vi. go to loop start.
This is very inefficient.
subroutine malloc_test(Ry, Rx, ny)
implicit none
integer(kind=kind(1)), intent(in) :: ny
real(kind=kind(1.0d0)), dimension(:,:), pointer :: Ry
real(kind=kind(1.0d0)), dimension(:), pointer :: Rx
integer(kind=kind(1)) :: n
do n = 1,ny
Ry(:,n) = Ry(:,n) * Rx(:)
end do
end subroutine malloc_test
Other relevant information:
1. Compile flags: -O3 -ffast-math -m64 -march=amdfam10
2. gfortran version: gfortran -v
Using built-in specs.
Target: x86_64-unknown-linux-gnu
Configured with: /tmp/src/gcc-4.3.0/configure --prefix=/opt/amd/gcc-4.3.0
--enable-languages=c,c++,fortran --enable-stage1-checking
--with-as=/opt/amd/gcc-4.3.0/bin/as --with-ld=/opt/amd/gcc-4.3.0/bin/ld
--with-mpfr=/tmp/install/mpfr-2.3.0 --with-gmp=/tmp/install/gmp-4.2.2
Thread model: posix
gcc version 4.3.1 20080312 (prerelease) (GCC)
3. model name: AMD Phenom(tm) 8650 Triple-Core Processor
4. flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov
pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt rdtscp lm
3dnowext 3dnow constant_tsc pni cx16 popcnt lahf_lm cmp_legacy svm extapic
cr8_legacy altmovcr8 abm sse4a misalignsse 3dnowprefetch osvw
--
Summary: Fortran: Minimize heap allocation of temporary arrays.
Product: gcc
Version: 4.3.1
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: fortran
AssignedTo: unassigned at gcc dot gnu dot org
ReportedBy: rajiv dot adhikary at amd dot com
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=36842
^ permalink raw reply [flat|nested] 3+ messages in thread
* [Bug fortran/36842] Fortran: Minimize heap allocation of temporary arrays.
2008-07-15 18:15 [Bug fortran/36842] New: Fortran: Minimize heap allocation of temporary arrays rajiv dot adhikary at amd dot com
@ 2008-07-23 9:44 ` rguenth at gcc dot gnu dot org
2010-05-10 18:26 ` mikael at gcc dot gnu dot org
1 sibling, 0 replies; 3+ messages in thread
From: rguenth at gcc dot gnu dot org @ 2008-07-23 9:44 UTC (permalink / raw)
To: gcc-bugs
------- Comment #1 from rguenth at gcc dot gnu dot org 2008-07-23 09:43 -------
Confirmed. Dependency analysis should see that no temporary is required here.
--
rguenth at gcc dot gnu dot org changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|UNCONFIRMED |NEW
Ever Confirmed|0 |1
Last reconfirmed|0000-00-00 00:00:00 |2008-07-23 09:43:44
date| |
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=36842
^ permalink raw reply [flat|nested] 3+ messages in thread
* [Bug fortran/36842] Fortran: Minimize heap allocation of temporary arrays.
2008-07-15 18:15 [Bug fortran/36842] New: Fortran: Minimize heap allocation of temporary arrays rajiv dot adhikary at amd dot com
2008-07-23 9:44 ` [Bug fortran/36842] " rguenth at gcc dot gnu dot org
@ 2010-05-10 18:26 ` mikael at gcc dot gnu dot org
1 sibling, 0 replies; 3+ messages in thread
From: mikael at gcc dot gnu dot org @ 2010-05-10 18:26 UTC (permalink / raw)
To: gcc-bugs
------- Comment #2 from mikael at gcc dot gnu dot org 2010-05-10 18:25 -------
(In reply to comment #1)
> Confirmed. Dependency analysis should see that no temporary is required here.
>
As both Rx and Ry have the pointer attribute, I'm not so sure about it.
Note that if one removes the pointer attribute, there is no temporary any more.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=36842
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2010-05-10 18:26 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-07-15 18:15 [Bug fortran/36842] New: Fortran: Minimize heap allocation of temporary arrays rajiv dot adhikary at amd dot com
2008-07-23 9:44 ` [Bug fortran/36842] " rguenth at gcc dot gnu dot org
2010-05-10 18:26 ` 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).