ALT Linux Sisyphus discussions
 help / color / mirror / Atom feed
From: Ivan Adzhubey <iadzhubey@rics.bwh.harvard.edu>
To: ALT Linux Sisyphus discussion list <sisyphus@altlinux.ru>
Subject: Re: [sisyphus] Shared memory - HELP PLEASE!
Date: Thu, 25 Mar 2004 02:59:41 -0500
Message-ID: <200403250259.41119.iadzhubey@rics.bwh.harvard.edu> (raw)
In-Reply-To: <200403250229.12542.iadzhubey@rics.bwh.harvard.edu>

On Thursday 25 March 2004 02:29 am, Ivan Adzhubey wrote:
> > > > ------ Shared Memory Segments --------
> > > > key        shmid      owner      perms      bytes      nattch
> > > > status 0x00000000 1245187    bga       700        1048576    1
> > >
> > > Спасибо, Григорий!
> > >
> > > К сожалению, там все сложнее. Ваша программа работает, и такие простые
> > > тесты я уже научился сам писать ;). Проблема возникает когда a) есть
> > > минимум два процесса пользующихся этой памятью (хотя бы по очереди,
> > > например форкнутый child и его parent) b) используется блокировка
> > > (lock)
> > >
> > > А хотя нет, погодите! Кажется что-то видно... у вас запрашивается 2K
> > > памяти и выделяется 2K. А у меня вашей программе выделяется в четыре
> > > раза больше:
> > >
> > > ------ Shared Memory Segments --------
> > > key        shmid      owner      perms      bytes      nattch    
> > > status 0x00000000 1736711    ivan      700        4194304    1
> > >
> > > Кажется это все-таки баг. Сейчас проверю под другим ядром...
> >
> > Конечно, 2MB а не 2KB, опечатка.
> >
> > Странно, проверил на кластерном ноде под 2.4.22, там тоже выделяется 4MB.
> > Что-то с выравниванием памяти? Вы каким компилятором собирали? И на какой
> > системе запускали (ядро, libc)? Может это из-за того что я пробовал
> > только на smp ядрах, сейчас буду дальше проверять, где-то в сетке у меня
> > up ядро должно было остаться...
>
> Проверил, на 2.4.25-std-up-alt1 тоже самое - выделяется 4MB вместо 2MB. И
> 8-й тест IPC::ShareLite так же виснет. Похоже это все-таки баг. Только на
> что его вешать? На ядро, glibc, gcc?
>
> Еще раз спасибо за помощь!

Так, слегка запутался:

man shmget:

int shmget(key_t key, int size, int shmflg);

...shmget() returns the identifier of the shared memory segment associated
with the value of the argument key.  A new shared memory segment,  with
size  equal to the value of size rounded up to a multiple of PAGE_SIZE, ...

PAGE_SIZE у нас вроде бы 0x400 == 1024 bytes
shm.h: #define SHMMIN 1    /* min shared seg size (bytes) */
но shmget работает как-то странно:

shmtest.c:
shmid = shmget(IPC_PRIVATE, 1, IPC_CREAT|0700);

ipcs:
------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 1966087    ivan      700        0          1

<size=2...1022> аналогично

shmtest.c:
shmid = shmget(IPC_PRIVATE, 1023, IPC_CREAT|0700);

ipcs:
------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 1966087    ivan      700        0          1

то есть никакой памяти не выделяется, хотя и ошибки тоже не генерируется.

shmtest.c:
shmid = shmget(IPC_PRIVATE, 1024, IPC_CREAT|0700);

ipcs:
------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 1966087    ivan      700        4096          1

Опа, сразу 4 страницы!

shmtest.c:
shmid = shmget(IPC_PRIVATE, 2*1024, IPC_CREAT|0700);

ipcs:
------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00000000 1966087    ivan      700        8192          1

И так далее, в два раза больше чем запрошено.

Грустно, но курение манов совершенно не помогает.

Не перекинет ли кто из подписантов этот тред в devel@? Может гуру курят что-то 
более подходящее к случаю и смогут помочь мне узреть истину?

-- 
Иван



  reply	other threads:[~2004-03-25  7:59 UTC|newest]

Thread overview: 33+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-03-24 22:17   ` Ivan Adzhubey
2004-03-25  4:14     ` Eugene Ostapets
2004-03-25  4:36       ` Ivan Adzhubey
2004-03-25  4:43         ` Denis S. Filimonov
2004-03-25  4:50           ` Ivan Adzhubey
2004-03-25  5:04         ` Eugene Ostapets
2004-03-25  6:53           ` Ivan Adzhubey
2004-03-25  7:44           ` Serj
2004-03-25  8:28             ` Ivan Adzhubey
2004-03-25  5:09         ` Mike Lykov
2004-03-25  5:23           ` Ivan Adzhubey
2004-03-25  5:28             ` Mike Lykov
2004-03-25  5:30               ` Ivan Adzhubey
2004-03-25  6:42         ` Grigory Batalov
2004-03-25  7:05           ` Ivan Adzhubey
2004-03-25  7:17             ` Ivan Adzhubey
2004-03-25  7:29               ` Ivan Adzhubey
2004-03-25  7:59                 ` Ivan Adzhubey [this message]
2004-03-25  7:44               ` Grigory Batalov
2004-03-25  8:09                 ` Ivan Adzhubey
2004-03-25  8:24                 ` Ivan Adzhubey
2004-03-25 11:54                   ` Sergey Vlasov
2004-03-25  4:22     ` Denis S. Filimonov
2004-03-25 12:22     ` Sergey Vlasov
2004-03-25 12:58       ` [JT] снова проблемы от security fixes? (WAS: Re: [sisyphus] Shared memory - HELP PLEASE!) Andrei Bulava
2004-03-25 13:12         ` Sergey Vlasov
2004-04-06  8:57     ` [sisyphus] Shared memory - HELP PLEASE! Sergey Vlasov
2004-04-06  9:08       ` Ivan Adzhubey
2004-04-06  9:24         ` Dmitry V. Levin
2004-04-06  9:50         ` Sergey Vlasov
2004-04-06 21:06           ` Ivan Adzhubey
2004-04-07  6:25             ` Sergey Vlasov
2004-04-07 16:12               ` Ivan Adzhubey

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=200403250259.41119.iadzhubey@rics.bwh.harvard.edu \
    --to=iadzhubey@rics.bwh.harvard.edu \
    --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