GNU bug report logs - #77232
[PATCH] Allow also to get attributes of the terminal line

Previous Next

Package: emacs;

Reported by: Werner Fink <werner <at> suse.de>

Date: Mon, 24 Mar 2025 08:54:01 UTC

Severity: normal

Tags: patch

Done: Eli Zaretskii <eliz <at> gnu.org>

Bug is archived. No further changes may be made.

Full log


View this message in rfc822 format

From: Philipp Stephani <p.stephani2 <at> gmail.com>
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: Philipp Stephani <phst <at> google.com>, 77232 <at> debbugs.gnu.org, Werner Fink <werner <at> suse.de>
Subject: bug#77232: [PATCH] Allow also to get attributes of the terminal line
Date: Tue, 25 Mar 2025 16:06:39 +0100

> Am 24.03.2025 um 13:42 schrieb Eli Zaretskii <eliz <at> gnu.org>:
> 
>> Cc: Werner Fink <werner <at> suse.de>
>> From: Werner Fink <werner <at> suse.de>
>> Date: Mon, 24 Mar 2025 09:51:47 +0100
>> 
>> as well as support mmap(2) flag MAP_DROPPABLE to allow
>> zero memory under memory pressure on newer Linux systems.
>> 
>> Otherwise a `make -k check` fails here in our build environment
>> with newer kernels and with /dev/console as physical device.
>> 
>> Signed-off-by: Werner Fink <werner <at> suse.de>
> 
> Thanks.
> 
> Philipp, any comments?
> 
>> ---
>> lib-src/seccomp-filter.c | 19 ++++++++++++++++++-
>> 1 file changed, 18 insertions(+), 1 deletion(-)
>> 
>> diff --git lib-src/seccomp-filter.c lib-src/seccomp-filter.c
>> index d6421f0ebdb..4dda7d8f020 100644
>> --- lib-src/seccomp-filter.c
>> +++ lib-src/seccomp-filter.c
>> @@ -42,6 +42,9 @@ variants of those files that can be used to sandbox Emacs before
>> #include <stdlib.h>
>> #include <stdint.h>
>> #include <stdio.h>
>> +/* glibc uses internal an other TCGETS ioctl for its
>> +   tcgetattr(3) call with its internal struct termios */
>> +#include <asm/termbits.h>
>> #include <time.h>
>> 
>> #include <asm/prctl.h>
>> @@ -64,6 +67,11 @@ variants of those files that can be used to sandbox Emacs before
>> #define ARCH_CET_STATUS 0x3001
>> #endif
>> 
>> +/* https://github.com/torvalds/linux/commit/9651fcedf7b92d3f7f1ab179e8ab55b85ee10fc1 */
>> +#ifndef MAP_DROPPABLE
>> +#define MAP_DROPPABLE 0x0

Shouldn't this be 0x08? At least that's how it's defined in mman.h.

>> +#endif
>> +
>> static ATTRIBUTE_FORMAT_PRINTF (2, 3) _Noreturn void
>> fail (int error, const char *format, ...)
>> {
>> @@ -187,7 +195,7 @@ main (int argc, char **argv)
>>            some versions of the dynamic loader still use it.  Also
>>            allow allocating thread stacks.  */
>>         SCMP_A3_32 (SCMP_CMP_MASKED_EQ,
>> -                    ~(MAP_SHARED | MAP_PRIVATE | MAP_FILE
>> +                    ~(MAP_SHARED | MAP_PRIVATE | MAP_FILE | MAP_DROPPABLE
>>                       | MAP_ANONYMOUS | MAP_FIXED | MAP_DENYWRITE
>>                       | MAP_STACK | MAP_NORESERVE),
>>                     0));
>> @@ -274,6 +282,11 @@ main (int argc, char **argv)
>>         SCMP_A0_32 (SCMP_CMP_EQ, STDIN_FILENO),
>>         SCMP_A1_32 (SCMP_CMP_EQ, TIOCGPGRP));
>> 
>> +  /* Allow `tcgetattr' call of glibc on physical terminal devices. */
>> +  RULE (SCMP_ACT_ALLOW, SCMP_SYS (ioctl),
>> +        SCMP_A0_32 (SCMP_CMP_EQ, STDERR_FILENO),
>> +        SCMP_A1_32 (SCMP_CMP_EQ, TCGETS));
>> +
>>   /* Allow reading (but not setting) file flags.  */
>>   RULE (SCMP_ACT_ALLOW, SCMP_SYS (fcntl),
>>         SCMP_A1_32 (SCMP_CMP_EQ, F_GETFL));
>> -- 
>> 2.35.3
>> 
>> 
>> 
>> 
>> 





This bug report was last modified 29 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.