From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 15934 invoked by alias); 1 Mar 2007 19:16:13 -0000 Received: (qmail 15810 invoked by uid 48); 1 Mar 2007 19:15:35 -0000 Date: Thu, 01 Mar 2007 19:16:00 -0000 Message-ID: <20070301191535.15809.qmail@sourceware.org> X-Bugzilla-Reason: CC References: Subject: [Bug fortran/31016] Use __buildin_memcpy and __memcpy for array assignment In-Reply-To: Reply-To: gcc-bugzilla@gcc.gnu.org To: gcc-bugs@gcc.gnu.org From: "burnus at gcc dot gnu dot org" Mailing-List: contact gcc-bugs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-bugs-owner@gcc.gnu.org X-SW-Source: 2007-03/txt/msg00052.txt.bz2 ------- Comment #1 from burnus at gcc dot gnu dot org 2007-03-01 19:15 ------- subroutine bar(a,b,n) implicit none integer :: n real :: a(n,n), b(n,n) a = b end subroutine For that example example, the overhead is even more obvious. One needs to run only: for (int i = 0; i < n*n; i++) a[i] = b[i] However, gfortran generates two loops and a whole stack of temporary variables. Analogously for subroutine bar(a,n) implicit none integer :: n real :: a(n,n) a = 12 end subroutine -- http://gcc.gnu.org/bugzilla/show_bug.cgi?id=31016