From: Florian Weimer <fweimer@redhat.com>
To: Adhemerval Zanella <adhemerval.zanella@linaro.org>
Cc: Adhemerval Zanella via Libc-alpha <libc-alpha@sourceware.org>
Subject: Re: [PATCH v2 2/4] Consolidate stdio-lock.h
Date: Wed, 27 Apr 2022 20:00:30 +0200 [thread overview]
Message-ID: <874k2ee79d.fsf@oldenburg.str.redhat.com> (raw)
In-Reply-To: <c01b81f8-caca-c9ee-591b-0efe5d0c1b01@linaro.org> (Adhemerval Zanella's message of "Wed, 27 Apr 2022 13:15:18 -0300")
* Adhemerval Zanella:
> On 27/04/2022 10:25, Florian Weimer wrote:
>> * Adhemerval Zanella via Libc-alpha:
>>
>>> diff --git a/sysdeps/generic/stdio-lock.h b/sysdeps/generic/stdio-lock.h
>>> index 14cf458bdd..fd61f0b5b7 100644
>>> --- a/sysdeps/generic/stdio-lock.h
>>> +++ b/sysdeps/generic/stdio-lock.h
>>> @@ -45,20 +45,13 @@ __libc_lock_define_recursive (typedef, _IO_lock_t)
>>> #define _IO_cleanup_region_end(_doit) \
>>> __libc_cleanup_region_end (_doit)
>>>
>>> -#if defined _LIBC && IS_IN (libc)
>>> -
>>> -# ifdef __EXCEPTIONS
>>> -# define _IO_acquire_lock(_fp) \
>>> +#define _IO_acquire_lock(_fp) \
>>> do { \
>>> - FILE *_IO_acquire_lock_file \
>>> - __attribute__((cleanup (_IO_acquire_lock_fct))) \
>>> - = (_fp); \
>>> - _IO_flockfile (_IO_acquire_lock_file);
>>> -# else
>>> -# define _IO_acquire_lock(_fp) _IO_acquire_lock_needs_exceptions_enabled
>>> -# endif
>>> -# define _IO_release_lock(_fp) ; } while (0)
>>> -
>>> -#endif
>>> + _IO_cleanup_region_start((void (*) (void *)) &_IO_funlockfile, _fp); \
>>> + _IO_flockfile (_fp);
>>> +#define _IO_release_lock(_fp) \
>>> + _IO_funlockfile (_fp); \
>>> + _IO_cleanup_region_end (0); \
>>> + } while (0)
>>>
>>> #endif /* stdio-lock.h */
>>
>> I think this change replaces unwind tables for -fexceptions builds. If
>> GCC can't turn the indirect call to the unlock function into a direct
>> call, this will result in a loss of hardening due to the additional
>> indirect function call.
>>
>> This change may also lose C++ unwinding compatibility for some
>> fopencookie use cases, I think.
>
> This is an internal header where if __EXCEPTIONS is not defined we will
> get a compiler error because of an undefined symbol
> (_IO_acquire_lock_needs_exceptions_enabled). So internally all
> _IO_acquire_lock usage already requires __EXCEPTIONS, so the fallback
> is just unused definitions.
I see this code generation change in libio/fputc.os. The new code uses
an on-stack pointer saved at the start of the cleanup region:
+ 90: 48 8b 05 00 00 00 00 mov 0x0(%rip),%rax # 97 <fputc+0x97>
+ 93: R_X86_64_REX_GOTPCRELX _IO_funlockfile-0x4
+ 97: 48 89 e7 mov %rsp,%rdi
+ 9a: 48 89 04 24 mov %rax,(%rsp)
+ 9e: e8 00 00 00 00 call a3 <fputc+0xa3>
+ 9f: R_X86_64_PLT32 __GI___libc_cleanup_push_defer-0x4
+ a3: 8b 45 00 mov 0x0(%rbp),%eax
+ a6: 25 00 80 00 00 and $0x8000,%eax
+ ab: 0f 85 d1 00 00 00 jne 182 <fputc+0x182>
+ b1: 64 4c 8b 2c 25 10 00 mov %fs:0x10,%r13
+ b8: 00 00
+ ba: 48 8b bd 88 00 00 00 mov 0x88(%rbp),%rdi
+ c1: 4c 39 6f 08 cmp %r13,0x8(%rdi)
+ c5: 74 1a je e1 <fputc+0xe1>
+ c7: ba 01 00 00 00 mov $0x1,%edx
+ cc: f0 0f b1 17 lock cmpxchg %edx,(%rdi)
+ d0: 0f 85 a2 00 00 00 jne 178 <fputc+0x178>
+ d6: 48 8b bd 88 00 00 00 mov 0x88(%rbp),%rdi
+ dd: 4c 89 6f 08 mov %r13,0x8(%rdi)
+ e1: 83 47 04 01 addl $0x1,0x4(%rdi)
+ e5: 41 bd 01 00 00 00 mov $0x1,%r13d
+ eb: e9 3d ff ff ff jmp 2d <fputc+0x2d>
+ f0: 48 89 e7 mov %rsp,%rdi
+ f3: e8 00 00 00 00 call f8 <fputc+0xf8>
+ f4: R_X86_64_PLT32 __GI___libc_cleanup_pop_restore-0x4
This is a from a build with CFLAGS="-O2 -fexceptions -s -DNDEBUG"
(for comparison purposes).
The old code just inlined the _IO_funlockfile fast path.
(We seem to lack libc_hidden_proto/libc_hidden_def for _IO_funlockfile.)
Thanks,
Florian
next prev parent reply other threads:[~2022-04-27 18:00 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-04-26 19:15 [PATCH v2 0/4] Move libio lock single-thread optimization to generic libc-lock Adhemerval Zanella
2022-04-26 19:15 ` [PATCH v2 1/4] libio: Assume _IO_MTSAFE_IO Adhemerval Zanella
2022-04-27 12:34 ` Florian Weimer
2022-04-27 18:40 ` Adhemerval Zanella
2022-04-27 19:35 ` Adhemerval Zanella
2022-04-26 19:15 ` [PATCH v2 2/4] Consolidate stdio-lock.h Adhemerval Zanella
2022-04-27 13:25 ` Florian Weimer
2022-04-27 16:15 ` Adhemerval Zanella
2022-04-27 18:00 ` Florian Weimer [this message]
2022-04-27 18:35 ` Adhemerval Zanella
2022-04-27 18:44 ` Florian Weimer
2022-04-27 18:49 ` Adhemerval Zanella
2022-04-26 19:15 ` [PATCH v2 3/4] Move libio lock single-thread optimization to generic libc-lock (BZ #27842) Adhemerval Zanella
2022-04-27 13:30 ` Florian Weimer
2022-04-27 16:32 ` Adhemerval Zanella
2022-04-28 16:39 ` Adhemerval Zanella
2022-04-28 16:56 ` Florian Weimer
2022-04-28 17:14 ` Adhemerval Zanella
2022-04-26 19:15 ` [PATCH v2 4/4] Assume _LIBC and libc module for libc-lock.h Adhemerval Zanella
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=874k2ee79d.fsf@oldenburg.str.redhat.com \
--to=fweimer@redhat.com \
--cc=adhemerval.zanella@linaro.org \
--cc=libc-alpha@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).