public inbox for newlib@sourceware.org
 help / color / mirror / Atom feed
From: Sebastian Huber <sebastian.huber@embedded-brains.de>
To: newlib@sourceware.org
Subject: [PATCH 00/14] Add --enable-newlib-reent-thread-local option
Date: Tue, 21 Jun 2022 14:49:17 +0200	[thread overview]
Message-ID: <20220621124931.36450-1-sebastian.huber@embedded-brains.de> (raw)

By default, Newlib uses a huge object of type struct _reent to store
thread-specific data.  This object is returned by __getreent() if the
__DYNAMIC_REENT__ Newlib configuration option is defined.

The reentrancy structure contains for example errno and the standard input,
output, and error file streams.  This means that if an application only uses
errno it has a dependency on the file stream support even if it does not use
it.  This is an issue for lower end targets and applications which need to
qualify the software according to safety standards (for example ECSS-E-ST-40C,
ECSS-Q-ST-80C, IEC 61508, ISO 26262, DO-178, DO-330, DO-333).

If the new _REENT_THREAD_LOCAL configuration option is enabled, then struct
_reent is replaced by dedicated thread-local objects for each struct _reent
member.  The thread-local objects are defined in translation units which use
the corresponding object.

Patches 1 to 13 contain no functional changes (hopefully).  They just introduce
macros to be able to use struct _reent members or thread-local objects
depending on the new _REENT_THREAD_LOCAL option.  Patch 14 adds the new
configuration option.

Matt Joyce (13):
  Define _REENT_EMERGENCY(ptr) only once
  Add _REENT_ERRNO(ptr)
  Add _REENT_STDIN(ptr)
  Add _REENT_STDOUT(ptr)
  Add _REENT_STDERR(ptr)
  Add _REENT_INC(ptr)
  Add _REENT_LOCALE(ptr)
  Add _REENT_CLEANUP(ptr)
  Add _REENT_CVTLEN(ptr)
  Add _REENT_CVTBUF(ptr)
  Add _REENT_SIG_FUNC(ptr)
  Add _REENT_IS_NULL()
  Add --enable-newlib-reent-thread-local option

Sebastian Huber (1):
  Move content in <sys/reent.h>

 newlib/README                             |   8 ++
 newlib/configure                          |  21 ++++
 newlib/configure.ac                       |  15 +++
 newlib/libc/ctype/wctrans.c               |   2 +-
 newlib/libc/ctype/wctype.c                |   2 +-
 newlib/libc/errno/errno.c                 |   8 +-
 newlib/libc/include/stdio.h               |  12 +-
 newlib/libc/include/sys/config.h          |   6 +
 newlib/libc/include/sys/errno.h           |   8 +-
 newlib/libc/include/sys/reent.h           | 132 +++++++++++++++++++---
 newlib/libc/include/wchar.h               |   8 +-
 newlib/libc/locale/locale.c               |   4 +
 newlib/libc/locale/setlocale.h            |   4 +-
 newlib/libc/locale/uselocale.c            |   4 +-
 newlib/libc/machine/cris/sys/errno.h      |   2 +-
 newlib/libc/machine/powerpc/strtosfix16.c |  10 +-
 newlib/libc/machine/powerpc/strtosfix32.c |  10 +-
 newlib/libc/machine/powerpc/strtosfix64.c |  10 +-
 newlib/libc/machine/powerpc/strtoufix16.c |  10 +-
 newlib/libc/machine/powerpc/strtoufix32.c |  10 +-
 newlib/libc/machine/powerpc/strtoufix64.c |  10 +-
 newlib/libc/machine/spu/c99ppe.h          |   8 +-
 newlib/libc/machine/spu/stdio.c           |  16 +--
 newlib/libc/machine/spu/sys/errno.h       |   2 +-
 newlib/libc/reent/closer.c                |   2 +-
 newlib/libc/reent/execr.c                 |   6 +-
 newlib/libc/reent/fcntlr.c                |   2 +-
 newlib/libc/reent/fstat64r.c              |   2 +-
 newlib/libc/reent/fstatr.c                |   2 +-
 newlib/libc/reent/gettimeofdayr.c         |   2 +-
 newlib/libc/reent/impure.c                |   4 +
 newlib/libc/reent/isattyr.c               |   2 +-
 newlib/libc/reent/linkr.c                 |   2 +-
 newlib/libc/reent/lseek64r.c              |   2 +-
 newlib/libc/reent/lseekr.c                |   2 +-
 newlib/libc/reent/mkdirr.c                |   2 +-
 newlib/libc/reent/open64r.c               |   2 +-
 newlib/libc/reent/openr.c                 |   2 +-
 newlib/libc/reent/readr.c                 |   2 +-
 newlib/libc/reent/reent.c                 |  18 +--
 newlib/libc/reent/renamer.c               |   2 +-
 newlib/libc/reent/sbrkr.c                 |   2 +-
 newlib/libc/reent/signalr.c               |   2 +-
 newlib/libc/reent/stat64r.c               |   2 +-
 newlib/libc/reent/statr.c                 |   2 +-
 newlib/libc/reent/unlinkr.c               |   2 +-
 newlib/libc/reent/writer.c                |   2 +-
 newlib/libc/signal/signal.c               |  36 +++---
 newlib/libc/stdio/asniprintf.c            |   4 +-
 newlib/libc/stdio/asnprintf.c             |   4 +-
 newlib/libc/stdio/fdopen.c                |   2 +-
 newlib/libc/stdio/fflush.c                |  18 +--
 newlib/libc/stdio/fileno.c                |   2 +-
 newlib/libc/stdio/fileno_u.c              |   2 +-
 newlib/libc/stdio/findfp.c                |  25 ++--
 newlib/libc/stdio/flags.c                 |   2 +-
 newlib/libc/stdio/fmemopen.c              |  14 +--
 newlib/libc/stdio/fopencookie.c           |  14 +--
 newlib/libc/stdio/fpurge.c                |   2 +-
 newlib/libc/stdio/freopen.c               |   4 +-
 newlib/libc/stdio/fseeko.c                |   4 +-
 newlib/libc/stdio/ftell.c                 |   2 +-
 newlib/libc/stdio/ftello.c                |   2 +-
 newlib/libc/stdio/funopen.c               |  16 +--
 newlib/libc/stdio/fvwrite.c               |   4 +-
 newlib/libc/stdio/local.h                 |   3 +-
 newlib/libc/stdio/mktemp.c                |  14 +--
 newlib/libc/stdio/nano-vfprintf.c         |  10 +-
 newlib/libc/stdio/open_memstream.c        |  14 +--
 newlib/libc/stdio/perror.c                |   2 +-
 newlib/libc/stdio/refill.c                |   2 +-
 newlib/libc/stdio/setvbuf.c               |   2 +-
 newlib/libc/stdio/sniprintf.c             |   8 +-
 newlib/libc/stdio/snprintf.c              |   8 +-
 newlib/libc/stdio/swprintf.c              |   8 +-
 newlib/libc/stdio/tmpfile.c               |   6 +-
 newlib/libc/stdio/tmpnam.c                |  13 ++-
 newlib/libc/stdio/vasniprintf.c           |   2 +-
 newlib/libc/stdio/vasnprintf.c            |   2 +-
 newlib/libc/stdio/vfprintf.c              |  12 +-
 newlib/libc/stdio/vfscanf.c               |   2 +-
 newlib/libc/stdio/vfwprintf.c             |   4 +-
 newlib/libc/stdio/vfwscanf.c              |   2 +-
 newlib/libc/stdio/vsniprintf.c            |   4 +-
 newlib/libc/stdio/vsnprintf.c             |   4 +-
 newlib/libc/stdio/vswprintf.c             |   4 +-
 newlib/libc/stdio/wsetup.c                |   2 +-
 newlib/libc/stdio64/fdopen64.c            |   2 +-
 newlib/libc/stdio64/freopen64.c           |   4 +-
 newlib/libc/stdio64/fseeko64.c            |   6 +-
 newlib/libc/stdio64/ftello64.c            |   2 +-
 newlib/libc/stdio64/tmpfile64.c           |   6 +-
 newlib/libc/stdlib/__adjust.c             |   4 +-
 newlib/libc/stdlib/dtoa.c                 |   5 +
 newlib/libc/stdlib/ecvtbuf.c              |  25 ++--
 newlib/libc/stdlib/l64a.c                 |   4 +
 newlib/libc/stdlib/lcong48.c              |   8 ++
 newlib/libc/stdlib/mblen.c                |   4 +
 newlib/libc/stdlib/mbrlen.c               |   4 +
 newlib/libc/stdlib/mbrtowc.c              |   8 +-
 newlib/libc/stdlib/mbsnrtowcs.c           |   6 +-
 newlib/libc/stdlib/mbtowc.c               |   4 +
 newlib/libc/stdlib/mbtowc_r.c             |  34 +++---
 newlib/libc/stdlib/mprec.c                |   5 +
 newlib/libc/stdlib/rand.c                 |   4 +
 newlib/libc/stdlib/strtod.c               |  10 +-
 newlib/libc/stdlib/strtoimax.c            |   4 +-
 newlib/libc/stdlib/strtol.c               |   2 +-
 newlib/libc/stdlib/strtoll.c              |   2 +-
 newlib/libc/stdlib/strtoul.c              |   2 +-
 newlib/libc/stdlib/strtoull.c             |   2 +-
 newlib/libc/stdlib/strtoumax.c            |   4 +-
 newlib/libc/stdlib/wcrtomb.c              |   8 +-
 newlib/libc/stdlib/wcsnrtombs.c           |   6 +-
 newlib/libc/stdlib/wcstod.c               |   4 +-
 newlib/libc/stdlib/wcstoimax.c            |   4 +-
 newlib/libc/stdlib/wcstol.c               |   2 +-
 newlib/libc/stdlib/wcstoll.c              |   2 +-
 newlib/libc/stdlib/wcstoul.c              |   2 +-
 newlib/libc/stdlib/wcstoull.c             |   4 +-
 newlib/libc/stdlib/wcstoumax.c            |   4 +-
 newlib/libc/stdlib/wctomb.c               |   4 +
 newlib/libc/stdlib/wctomb_r.c             |  18 +--
 newlib/libc/string/strerror.c             |   2 +-
 newlib/libc/string/strsignal.c            |   4 +
 newlib/libc/string/strtok.c               |   4 +
 newlib/libc/sys/arm/syscalls.c            |   3 +-
 newlib/libc/time/asctime.c                |   4 +
 newlib/libc/time/gmtime.c                 |   4 +
 newlib/libm/math/w_lgamma.c               |   4 +
 newlib/newlib.hin                         |   4 +
 winsup/cygwin/cygerrno.h                  |   4 +-
 winsup/cygwin/cygtls.cc                   |   2 +-
 winsup/cygwin/dcrt0.cc                    |   2 +-
 winsup/cygwin/errno.cc                    |   4 +-
 winsup/cygwin/strfuncs.cc                 |  12 +-
 winsup/cygwin/syscalls.cc                 |   4 +-
 137 files changed, 619 insertions(+), 332 deletions(-)

-- 
2.35.3


             reply	other threads:[~2022-06-21 12:49 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-06-21 12:49 Sebastian Huber [this message]
2022-06-21 12:49 ` [PATCH 01/14] Move content in <sys/reent.h> Sebastian Huber
2022-06-21 12:49 ` [PATCH 02/14] Define _REENT_EMERGENCY(ptr) only once Sebastian Huber
2022-06-21 12:49 ` [PATCH 03/14] Add _REENT_ERRNO(ptr) Sebastian Huber
     [not found]   ` <BN2P110MB15447CD8C6DD815779AA7E4C9AB39@BN2P110MB1544.NAMP110.PROD.OUTLOOK.COM>
2022-06-21 14:41     ` Fw: " C Howland
2022-06-23 10:55       ` Sebastian Huber
2022-07-11  7:41         ` Sebastian Huber
2022-07-12 16:11         ` Corinna Vinschen
2022-07-12 16:38           ` Sebastian Huber
2022-07-12 18:25             ` Corinna Vinschen
2022-07-13  7:17               ` Sebastian Huber
2022-07-13  7:50                 ` Corinna Vinschen
2022-07-13  8:19                   ` Sebastian Huber
2022-07-13 11:13                     ` Corinna Vinschen
2022-06-21 12:49 ` [PATCH 04/14] Add _REENT_STDIN(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 05/14] Add _REENT_STDOUT(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 06/14] Add _REENT_STDERR(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 07/14] Add _REENT_INC(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 08/14] Add _REENT_LOCALE(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 09/14] Add _REENT_CLEANUP(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 10/14] Add _REENT_CVTLEN(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 11/14] Add _REENT_CVTBUF(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 12/14] Add _REENT_SIG_FUNC(ptr) Sebastian Huber
2022-06-21 12:49 ` [PATCH 13/14] Add _REENT_IS_NULL() Sebastian Huber
2022-06-21 12:49 ` [PATCH 14/14] Add --enable-newlib-reent-thread-local option Sebastian Huber
2022-06-21 13:59   ` Torbjorn SVENSSON
2022-06-21 15:10     ` Sebastian Huber
2022-07-12 11:18 ` [PATCH 00/14] " Sebastian Huber
2022-07-12 14:45   ` Corinna Vinschen
2022-07-12 15:53     ` Sebastian Huber

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20220621124931.36450-1-sebastian.huber@embedded-brains.de \
    --to=sebastian.huber@embedded-brains.de \
    --cc=newlib@sourceware.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).