public inbox for fortran@gcc.gnu.org
 help / color / mirror / Atom feed
  • * nvptx, libgcc: Stub unwinding implementation
           [not found] <ae825c453f484ffd99c9be34af726089@mentor.com>
           [not found] ` <87mtaigz3l.fsf@dem-tschwing-1.ger.mentorg.com>
    @ 2023-01-20 21:04 ` Thomas Schwinge
      2023-01-20 21:16   ` nvptx, libgfortran: Switch out of "minimal" mode Thomas Schwinge
      1 sibling, 1 reply; 11+ messages in thread
    From: Thomas Schwinge @ 2023-01-20 21:04 UTC (permalink / raw)
      To: gcc-patches; +Cc: fortran, Tom de Vries, Andrew Stubbs
    
    [-- Attachment #1: Type: text/plain, Size: 796 bytes --]
    
    Hi!
    
    We've been (t)asked to enable (portions of) GCC/Fortran I/O for nvptx
    offloading, which means building a normal (non-'LIBGFOR_MINIMAL')
    configuration of libgfortran.  One prerequisite patch, based on WIP work
    by Andrew Stubbs, is: "nvptx, libgcc: Stub unwinding implementation", see
    attached.  This I've just pushed to devel/omp/gcc-12 branch in
    commit 26d3146736218ccaaaafdaba4da1edf969bc190d, and would like to push
    to master branch once other pending GCC patches have been accepted.
    
    
    Grüße
     Thomas
    
    
    -----------------
    Siemens Electronic Design Automation GmbH; Anschrift: Arnulfstraße 201, 80634 München; Gesellschaft mit beschränkter Haftung; Geschäftsführer: Thomas Heurung, Frank Thürauf; Sitz der Gesellschaft: München; Registergericht München, HRB 106955
    
    [-- Warning: decoded text below may be mangled, UTF-8 assumed --]
    [-- Attachment #2: 0001-nvptx-libgcc-Stub-unwinding-implementation.patch --]
    [-- Type: text/x-diff, Size: 3312 bytes --]
    
    From 26d3146736218ccaaaafdaba4da1edf969bc190d Mon Sep 17 00:00:00 2001
    From: Thomas Schwinge <thomas@codesourcery.com>
    Date: Wed, 21 Sep 2022 18:58:34 +0200
    Subject: [PATCH] nvptx, libgcc: Stub unwinding implementation
    
    Adding stub '_Unwind_Backtrace', '_Unwind_GetIPInfo' functions is necessary
    for linking libbacktrace, as a normal (non-'LIBGFOR_MINIMAL') configuration
    of libgfortran wants to do, for example.
    
    The file 'libgcc/config/nvptx/unwind-nvptx.c' is copied from
    'libgcc/config/gcn/unwind-gcn.c'.
    
    libgcc/ChangeLog:
    
    	* config/nvptx/t-nvptx: Add unwind-nvptx.c.
    	* config/nvptx/unwind-nvptx.c: New file.
    
    Co-authored-by: Andrew Stubbs <ams@codesourcery.com>
    ---
     libgcc/ChangeLog.omp               |  6 +++++
     libgcc/config/nvptx/t-nvptx        |  3 ++-
     libgcc/config/nvptx/unwind-nvptx.c | 36 ++++++++++++++++++++++++++++++
     3 files changed, 44 insertions(+), 1 deletion(-)
     create mode 100644 libgcc/config/nvptx/unwind-nvptx.c
    
    diff --git a/libgcc/ChangeLog.omp b/libgcc/ChangeLog.omp
    index 2e7bf5cc029..c46f49bf5b7 100644
    --- a/libgcc/ChangeLog.omp
    +++ b/libgcc/ChangeLog.omp
    @@ -1,3 +1,9 @@
    +2023-01-20  Thomas Schwinge  <thomas@codesourcery.com>
    +	    Andrew Stubbs  <ams@codesourcery.com>
    +
    +	* config/nvptx/t-nvptx: Add unwind-nvptx.c.
    +	* config/nvptx/unwind-nvptx.c: New file.
    +
     2023-01-20  Thomas Schwinge  <thomas@codesourcery.com>
     
     	* config/nvptx/crtstuff.c ["mgomp"]
    diff --git a/libgcc/config/nvptx/t-nvptx b/libgcc/config/nvptx/t-nvptx
    index 9a0454c3a4d..1845a38a35e 100644
    --- a/libgcc/config/nvptx/t-nvptx
    +++ b/libgcc/config/nvptx/t-nvptx
    @@ -1,6 +1,7 @@
     LIB2ADD=$(srcdir)/config/nvptx/reduction.c \
     	$(srcdir)/config/nvptx/mgomp.c \
    -	$(srcdir)/config/nvptx/atomic.c
    +	$(srcdir)/config/nvptx/atomic.c \
    +	$(srcdir)/config/nvptx/unwind-nvptx.c
     
     LIB2ADDEH=
     LIB2FUNCS_EXCLUDE=
    diff --git a/libgcc/config/nvptx/unwind-nvptx.c b/libgcc/config/nvptx/unwind-nvptx.c
    new file mode 100644
    index 00000000000..c657b2af6f3
    --- /dev/null
    +++ b/libgcc/config/nvptx/unwind-nvptx.c
    @@ -0,0 +1,36 @@
    +/* Stub unwinding implementation.
    +
    +   Copyright (C) 2019-2023 Free Software Foundation, Inc.
    +
    +   This file is free software; you can redistribute it and/or modify it
    +   under the terms of the GNU General Public License as published by the
    +   Free Software Foundation; either version 3, or (at your option) any
    +   later version.
    +
    +   This file is distributed in the hope that it will be useful, but
    +   WITHOUT ANY WARRANTY; without even the implied warranty of
    +   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    +   General Public License for more details.
    +
    +   Under Section 7 of GPL version 3, you are granted additional
    +   permissions described in the GCC Runtime Library Exception, version
    +   3.1, as published by the Free Software Foundation.
    +
    +   You should have received a copy of the GNU General Public License and
    +   a copy of the GCC Runtime Library Exception along with this program;
    +   see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
    +   <http://www.gnu.org/licenses/>.  */
    +
    +#include "unwind.h"
    +
    +_Unwind_Reason_Code
    +_Unwind_Backtrace(_Unwind_Trace_Fn trace, void * trace_argument)
    +{
    +  return 0;
    +}
    +
    +_Unwind_Ptr
    +_Unwind_GetIPInfo (struct _Unwind_Context *c, int *ip_before_insn)
    +{
    +  return 0;
    +}
    -- 
    2.25.1
    
    
    ^ permalink raw reply	[flat|nested] 11+ messages in thread

  • end of thread, other threads:[~2023-01-24  9:37 UTC | newest]
    
    Thread overview: 11+ messages (download: mbox.gz / follow: Atom feed)
    -- links below jump to the message on this page --
         [not found] <ae825c453f484ffd99c9be34af726089@mentor.com>
         [not found] ` <87mtaigz3l.fsf@dem-tschwing-1.ger.mentorg.com>
    2022-11-11 14:12   ` Handling of large stack objects in GPU code generation -- maybe transform into heap allocation? Thomas Schwinge
    2022-11-11 14:35     ` Richard Biener
    2022-12-23 14:08       ` nvptx: '-mframe-malloc-threshold', '-Wframe-malloc-threshold' (was: Handling of large stack objects in GPU code generation -- maybe transform into heap allocation?) Thomas Schwinge
    2022-12-23 21:23         ` Jerry D
    2023-01-11 12:06         ` [PING] " Thomas Schwinge
    2023-01-12  2:46           ` Jerry D
    2022-11-11 14:38     ` Handling of large stack objects in GPU code generation -- maybe transform into heap allocation? Janne Blomqvist
    2023-01-20 21:04 ` nvptx, libgcc: Stub unwinding implementation Thomas Schwinge
    2023-01-20 21:16   ` nvptx, libgfortran: Switch out of "minimal" mode Thomas Schwinge
    2023-01-20 22:10     ` Thomas Koenig
    2023-01-24  9:37     ` Update 'libgomp/libgomp.texi' for 'nvptx, libgfortran: Switch out of "minimal" mode' (was: nvptx, libgfortran: Switch out of "minimal" mode) Thomas Schwinge
    

    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).