From: Sergey Vlasov <vsu@altlinux.ru>
To: ALT Linux Sisyphus <sisyphus@altlinux.ru>
Subject: Re: [sisyphus] perl SysV IPC vs Owl
Date: Thu, 21 Jul 2005 19:43:08 +0400
Message-ID: <20050721154308.GG3480@master.mivlgu.local> (raw)
In-Reply-To: <20050721150151.GL24898@solemn.turbinal.org>
[-- Attachment #1: Type: text/plain, Size: 1773 bytes --]
On Thu, Jul 21, 2005 at 07:01:51PM +0400, Alexey Tourbin wrote:
> On Thu, Jul 21, 2005 at 06:08:57PM +0400, Alexey I. Froloff wrote:
> > * Alexey Tourbin <at@> [050721 17:40]:
> > > #7390 perl-base blocker
> > > SysV shared memory support is unfunctional with CONFIG_HARDEN_SHM (Openwall patch)
> > С этой багой надо идти в апстрим... Это проблема дизайна
> > shmread/shmwrite...
>
> В чей апастрим? В чём суть проблемы? Подробнее, пожалуйста...
В патче Openwall для ядер 2.4.x добавляется возможность автоматического
уничтожения неиспользуемых сегментов SysV shared memory (сегмент считается
неиспользуемым, если он не отображается в адресное пространство хотя бы
одного процесса). В ядрах std-* эта опция конфигурации патча Openwall
(CONFIG_HARDEN_SHM) включена.
Функции shmread и shmwrite в Perl при каждом вызове выполняют shmat(),
осуществляют доступ к данным в разделяемой памяти, после чего выполняют
shmdt(). В результате выполнения этих действий, если отсутствуют другие
процессы, использующие этот сегмент, и при этом в ядре включена опция
CONFIG_HARDEN_SHM, при выполнении shmdt() сегмент уничтожается.
Настоящая проблема здесь даже не в Perl, а в самом SysV shared memory API,
допускающем существование областей разделяемой памяти при отсутствии
ответственных за них процессов. В большинстве случаев использования SysV
shm это свойство вызывает только проблемы (в частности, необходимость
ручного удаления сегментов после аварийного завершения использовавших их
процессов).
В случае, если автоматическое удаление сегментов разделяемой памяти
всё-таки нужно выключить, это можно сделать командой
echo 0 >/proc/sys/kernel/shm_destroy_unused
(соответствующий патч есть в ядрах начиная с 2.4.25-std-*-alt3).
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
next prev parent reply other threads:[~2005-07-21 15:43 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-07-21 12:45 [sisyphus] Q: автобаги ? Anton Farygin
2005-07-21 12:56 ` [sisyphus] " Anton Farygin
2005-07-21 13:32 ` Denis Ovsienko
2005-07-21 13:24 ` [sisyphus] " Anton Farygin
2005-07-21 13:29 ` Michael Isachenkov
2005-07-21 13:30 ` [sisyphus] " Anton Farygin
2005-07-21 13:38 ` Alexey Rusakov
2005-07-21 13:38 ` [sisyphus] " Nick S. Grechukh
2005-07-21 13:42 ` [sisyphus] " Anton Farygin
2005-07-21 13:59 ` Nick S. Grechukh
2005-07-21 13:30 ` [sisyphus] " Anton Farygin
2005-07-21 20:28 ` [sisyphus] Нашли источник всех багов Vitaly Lipatov
2005-07-22 7:23 ` Epiphanov Sergei
2005-07-22 7:29 ` Alexey Rusakov
2005-07-22 9:48 ` Epiphanov Sergei
2005-07-22 12:50 ` [sisyphus] " Anton Farygin
2005-07-22 13:06 ` Michael Shigorin
2005-07-22 13:29 ` Epiphanov Sergei
2005-07-22 14:04 ` [sisyphus] " Anton Farygin
2005-07-22 16:00 ` [sisyphus] Re: Нашли родину кракозябров Michael Shigorin
2005-07-22 16:04 ` Nick S. Grechukh
2005-07-22 16:05 ` Michael Isachenkov
2005-07-22 16:09 ` Nick S. Grechukh
2005-07-22 10:07 ` [sisyphus] [JT] Нашли корень зла Epiphanov Sergei
2005-07-22 10:06 ` Michael Isachenkov
2005-07-22 12:47 ` [sisyphus] " Anton Farygin
2005-07-21 14:33 ` [sisyphus] разруха в голове Michael Shigorin
2005-07-21 13:38 ` [sisyphus] Re: Q: автобаги ? Alexey Tourbin
2005-07-21 13:41 ` Anton Farygin
2005-07-21 14:08 ` Alexey I. Froloff
2005-07-21 15:01 ` [sisyphus] perl SysV IPC vs Owl Alexey Tourbin
2005-07-21 15:43 ` Sergey Vlasov [this message]
2005-07-21 12:57 ` [sisyphus] Q: автобаги ? Michael Isachenkov
2005-07-21 14:31 ` [sisyphus] разруха в голове Michael Shigorin
2005-07-21 16:01 ` [sisyphus] " Sergey V Turchin
2005-07-21 20:13 ` Vitaly Lipatov
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=20050721154308.GG3480@master.mivlgu.local \
--to=vsu@altlinux.ru \
--cc=sisyphus@altlinux.ru \
/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
ALT Linux Sisyphus discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/sisyphus/0 sisyphus/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 sisyphus sisyphus/ http://lore.altlinux.org/sisyphus \
sisyphus@altlinux.ru sisyphus@altlinux.org sisyphus@lists.altlinux.org sisyphus@lists.altlinux.ru sisyphus@lists.altlinux.com sisyphus@linuxteam.iplabs.ru sisyphus@list.linux-os.ru
public-inbox-index sisyphus
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.sisyphus
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git