public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
* [PATCH 0/4] Restartable Sequences support for glibc 2.30
@ 2019-02-12 19:43 Mathieu Desnoyers
  2019-02-12 19:43 ` [PATCH 3/4] support record failure: allow use from constructor Mathieu Desnoyers
                   ` (5 more replies)
  0 siblings, 6 replies; 52+ messages in thread
From: Mathieu Desnoyers @ 2019-02-12 19:43 UTC (permalink / raw)
  To: Carlos O'Donell
  Cc: Florian Weimer, Joseph Myers, Szabolcs Nagy, libc-alpha,
	Mathieu Desnoyers

Hi,

This patchset implements basic support for the "rseq" Linux system call
in glibc by registering the rseq TLS abi.

One patch in this series modifies sched_getcpu() to speed up reading the
current CPU number by reading __rseq_abi.cpu_id when rseq is available.

The only point that still appears to not reach concensus is whether it's
acceptable to define the RSEQ_SIG code signature for each architecture.
If I missed other points that failed to reach concensus, please let me
know!

Please consider for inclusion into glibc,

Thanks,

Mathieu


Mathieu Desnoyers (4):
  glibc: Perform rseq(2) registration at C startup and thread creation
    (v7)
  glibc: sched_getcpu(): use rseq cpu_id TLS on Linux
  support record failure: allow use from constructor
  rseq registration tests (v2)

 NEWS                                          |  11 +
 csu/libc-start.c                              |  12 +-
 misc/Makefile                                 |   3 +-
 misc/rseq-internal.h                          |  34 ++
 nptl/pthread_create.c                         |   9 +
 support/check.h                               |   4 +
 support/support_record_failure.c              |  18 +-
 sysdeps/unix/sysv/linux/Makefile              |   8 +-
 sysdeps/unix/sysv/linux/Versions              |   4 +
 sysdeps/unix/sysv/linux/aarch64/bits/rseq.h   |  24 ++
 sysdeps/unix/sysv/linux/aarch64/libc.abilist  |   2 +
 sysdeps/unix/sysv/linux/alpha/libc.abilist    |   2 +
 sysdeps/unix/sysv/linux/arm/bits/rseq.h       |  24 ++
 sysdeps/unix/sysv/linux/arm/libc.abilist      |   2 +
 sysdeps/unix/sysv/linux/bits/rseq.h           |  24 ++
 sysdeps/unix/sysv/linux/hppa/libc.abilist     |   2 +
 sysdeps/unix/sysv/linux/i386/libc.abilist     |   2 +
 sysdeps/unix/sysv/linux/ia64/libc.abilist     |   2 +
 .../sysv/linux/m68k/coldfire/libc.abilist     |   2 +
 .../unix/sysv/linux/m68k/m680x0/libc.abilist  |   2 +
 .../unix/sysv/linux/microblaze/libc.abilist   |   2 +
 sysdeps/unix/sysv/linux/mips/bits/rseq.h      |  24 ++
 .../sysv/linux/mips/mips32/fpu/libc.abilist   |   2 +
 .../sysv/linux/mips/mips32/nofpu/libc.abilist |   2 +
 .../sysv/linux/mips/mips64/n32/libc.abilist   |   2 +
 .../sysv/linux/mips/mips64/n64/libc.abilist   |   2 +
 sysdeps/unix/sysv/linux/nios2/libc.abilist    |   2 +
 sysdeps/unix/sysv/linux/powerpc/bits/rseq.h   |  24 ++
 .../linux/powerpc/powerpc32/fpu/libc.abilist  |   2 +
 .../powerpc/powerpc32/nofpu/libc.abilist      |   2 +
 .../linux/powerpc/powerpc64/be/libc.abilist   |   2 +
 .../linux/powerpc/powerpc64/le/libc.abilist   |   2 +
 .../unix/sysv/linux/riscv/rv64/libc.abilist   |   2 +
 sysdeps/unix/sysv/linux/rseq-internal.h       |  91 +++++
 sysdeps/unix/sysv/linux/rseq-sym.c            |  54 +++
 sysdeps/unix/sysv/linux/s390/bits/rseq.h      |  24 ++
 .../unix/sysv/linux/s390/s390-32/libc.abilist |   2 +
 .../unix/sysv/linux/s390/s390-64/libc.abilist |   2 +
 sysdeps/unix/sysv/linux/sched_getcpu.c        |  25 +-
 sysdeps/unix/sysv/linux/sh/libc.abilist       |   2 +
 .../sysv/linux/sparc/sparc32/libc.abilist     |   2 +
 .../sysv/linux/sparc/sparc64/libc.abilist     |   2 +
 sysdeps/unix/sysv/linux/sys/rseq.h            |  65 +++
 sysdeps/unix/sysv/linux/tst-rseq-nptl.c       | 381 ++++++++++++++++++
 sysdeps/unix/sysv/linux/tst-rseq.c            | 110 +++++
 sysdeps/unix/sysv/linux/x86/bits/rseq.h       |  24 ++
 .../unix/sysv/linux/x86_64/64/libc.abilist    |   2 +
 .../unix/sysv/linux/x86_64/x32/libc.abilist   |   2 +
 48 files changed, 1034 insertions(+), 15 deletions(-)
 create mode 100644 misc/rseq-internal.h
 create mode 100644 sysdeps/unix/sysv/linux/aarch64/bits/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/arm/bits/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/bits/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/mips/bits/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/powerpc/bits/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/rseq-internal.h
 create mode 100644 sysdeps/unix/sysv/linux/rseq-sym.c
 create mode 100644 sysdeps/unix/sysv/linux/s390/bits/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/sys/rseq.h
 create mode 100644 sysdeps/unix/sysv/linux/tst-rseq-nptl.c
 create mode 100644 sysdeps/unix/sysv/linux/tst-rseq.c
 create mode 100644 sysdeps/unix/sysv/linux/x86/bits/rseq.h

-- 
2.17.1

^ permalink raw reply	[flat|nested] 52+ messages in thread

end of thread, other threads:[~2019-04-25  0:41 UTC | newest]

Thread overview: 52+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-02-12 19:43 [PATCH 0/4] Restartable Sequences support for glibc 2.30 Mathieu Desnoyers
2019-02-12 19:43 ` [PATCH 3/4] support record failure: allow use from constructor Mathieu Desnoyers
2019-03-22 20:30   ` Carlos O'Donell
2019-02-12 19:43 ` [PATCH 2/4] glibc: sched_getcpu(): use rseq cpu_id TLS on Linux Mathieu Desnoyers
2019-03-22 20:14   ` Carlos O'Donell
2019-02-12 19:43 ` [PATCH 1/4] glibc: Perform rseq(2) registration at C startup and thread creation (v7) Mathieu Desnoyers
2019-03-22 20:09   ` Carlos O'Donell
2019-03-25 15:54     ` Mathieu Desnoyers
2019-03-27  9:16       ` Martin Schwidefsky
2019-03-27 20:01         ` Mathieu Desnoyers
2019-03-27 20:38         ` Carlos O'Donell
2019-03-28  7:50           ` Martin Schwidefsky
2019-03-28 15:43             ` Mathieu Desnoyers
2019-04-02  6:02       ` Michael Ellerman
2019-04-02  7:08         ` Florian Weimer
2019-04-04 20:33           ` Carlos O'Donell
2019-04-05  9:16             ` Florian Weimer
2019-04-05 15:40               ` Carlos O'Donell
2019-04-08 21:45                 ` Tulio Magno Quites Machado Filho
2019-04-08 22:06                   ` Carlos O'Donell
2019-04-09  4:28                     ` Michael Ellerman
2019-04-09  9:52                       ` Alan Modra
2019-04-09 14:13                         ` Tulio Magno Quites Machado Filho
2019-04-09 14:58                           ` Carlos O'Donell
2019-04-09 15:58                             ` Mathieu Desnoyers
2019-04-18 15:33                         ` Mathieu Desnoyers
2019-04-09 16:34                     ` Mathieu Desnoyers
2019-04-04 20:16         ` Carlos O'Donell
2019-04-04 20:50       ` Carlos O'Donell
     [not found]         ` <20190404214151.6ogrm34dok52az4h@pburton-laptop>
2019-04-09 17:24           ` Mathieu Desnoyers
2019-04-18 22:42           ` Mathieu Desnoyers
2019-04-24 15:28             ` Mathieu Desnoyers
     [not found]               ` <20190424231303.zu2irxd5g3v7yqey@pburton-laptop>
2019-04-25  1:57                 ` Maciej W. Rozycki
2019-02-12 19:51 ` [PATCH 4/4] rseq registration tests (v2) Mathieu Desnoyers
2019-03-27 21:21   ` Carlos O'Donell
2019-04-04 20:04     ` Mathieu Desnoyers
2019-04-04 20:11       ` Carlos O'Donell
2019-04-04 20:23         ` Mathieu Desnoyers
2019-04-05 10:01         ` Florian Weimer
2019-04-05 13:50           ` Carlos O'Donell
2019-04-05 15:27             ` Florian Weimer
2019-04-05 17:38               ` Carlos O'Donell
2019-04-05 19:43                 ` Florian Weimer
2019-04-08 22:07                   ` Carlos O'Donell
2019-03-22 17:34 ` [PATCH 0/4] Restartable Sequences support for glibc 2.30 Carlos O'Donell
2019-03-22 17:55   ` Mathieu Desnoyers
2019-03-22 18:04     ` Carlos O'Donell
2019-03-22 17:39 ` Florian Weimer
2019-03-22 17:47   ` Carlos O'Donell
2019-03-22 17:51     ` Florian Weimer
2019-03-22 19:46       ` Carlos O'Donell
2019-03-22 20:14         ` Mathieu Desnoyers

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