ALT Linux Community general discussions
 help / color / mirror / Atom feed
* [Comm] Как работает fork()?
@ 2004-08-25  9:11 AD
  2004-08-25 10:20 ` Макс
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: AD @ 2004-08-25  9:11 UTC (permalink / raw)
  To: Community

Привет!

Поясните как работает fork().

Если не ошибаюсь, в результате вызова, дублируются, в частности, файловые
дескрипторы.
Что будет если:

1. Файл открыт для эксклюзивного доступа. Вторая копия сможет работать с
файлом?

2. Где-то в расшареной памяти есть мьютекс - используется несколькими
процессами. Процесс захватил мьютекс и вызвал fork. Каково будет состояние
мьютекса во второй копии.

3. В процессе 2 потока. Один поток ожидает получения данных: int
result=read(h, .. , .. ); Данные не готовы и драйвер устройства усыпляет
поток:
static DECLARE_WAIT_QUEUE_HEAD(wq);
...
  interruptible_sleep_on(&wq);
В это время второй поток делает вызов fork. Что будет содержать result во
второй копии?

-- 
AD



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

* RE: [Comm] Как работает fork()?
  2004-08-25  9:11 [Comm] Как работает fork()? AD
@ 2004-08-25 10:20 ` Макс
  2004-08-26  8:17 ` php-coder
  2004-08-27  7:57 ` Anton V. Boyarshinov
  2 siblings, 0 replies; 5+ messages in thread
From: Макс @ 2004-08-25 10:20 UTC (permalink / raw)
  To: community

>> Привет!
>> Поясните как работает fork().
>> Если не ошибаюсь, в результате вызова, дублируются, в частности, файловые
>> дескрипторы.
>> Что будет если:
>> 1. Файл открыт для эксклюзивного доступа. Вторая копия сможет работать с
>> файлом?

>> 2. Где-то в расшареной памяти есть мьютекс - используется несколькими
>> процессами. Процесс захватил мьютекс и вызвал fork. Каково будет
>>состояние мьютекса во второй копии.

>> 3. В процессе 2 потока. Один поток ожидает получения данных: int
>> result=read(h, .. , .. ); Данные не готовы и драйвер устройства усыпляет
>> поток:
>> static DECLARE_WAIT_QUEUE_HEAD(wq);
>>...
>>   interruptible_sleep_on(&wq);
>> В это время второй поток делает вызов fork. Что будет содержать result во
>> второй копии?

Мне кажется, что:
1. да
2. Идентичное
3. Ничего, т.к. вторая копия будет тоже ждать данных из read();

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

* Re: [Comm] Как работает fork()?
  2004-08-25  9:11 [Comm] Как работает fork()? AD
  2004-08-25 10:20 ` Макс
@ 2004-08-26  8:17 ` php-coder
  2004-08-26  9:48   ` Re[2]: " AD
  2004-08-27  7:57 ` Anton V. Boyarshinov
  2 siblings, 1 reply; 5+ messages in thread
From: php-coder @ 2004-08-26  8:17 UTC (permalink / raw)
  To: AD

0000100101011110100100101::25.08.2004::0110001001001000100111100100010

    Здравствуйте, AD!
    Отвечаю на Ваше письмо:
  
A> Поясните как работает fork().

    Надеюсь, что следующая статья поможет вам разобраться как работает
    fork(): http://www.linuxfocus.org/Russian/November2002/article272.shtml
    
-- 
  С уважением, php-coder (mailto:php-coder[at]ngs[dot]ru)
  Registered Linux User #327594
  ALT Linux Master 2.2 (kernel 2.4.27)

010010010010010001010101100::Linux RuleZz!::100010010001000100010001110



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

* Re[2]: [Comm] Как работает fork()?
  2004-08-26  8:17 ` php-coder
@ 2004-08-26  9:48   ` AD
  0 siblings, 0 replies; 5+ messages in thread
From: AD @ 2004-08-26  9:48 UTC (permalink / raw)
  To: community

Здравствуйте!
  
> A> Поясните как работает fork().
> 
>     Надеюсь, что следующая статья поможет вам разобраться как работает
>     fork(): http://www.linuxfocus.org/Russian/November2002/article272.shtml
>     

Спасибо за ссылку, но меня интересуют нюансы связанные с разделением ресурсов.
Есть какой-то ресурс (захваченный мьютекс, файл открытый для эксклюзивного использования и т.п.) который может принадлежать одному и только одному процессу или, в отдельных случаях, потоку. Что происходит с этим ресурсом при клонировании (в общем случае) процесса? (Я имею ввиду именно вызов fork, а не clone).
Есть общая политика в *nix системах? Или все зависит от особенностей реализации fork в различных ядрах?


-- 
AD



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

* Re: [Comm] Как работает fork()?
  2004-08-25  9:11 [Comm] Как работает fork()? AD
  2004-08-25 10:20 ` Макс
  2004-08-26  8:17 ` php-coder
@ 2004-08-27  7:57 ` Anton V. Boyarshinov
  2 siblings, 0 replies; 5+ messages in thread
From: Anton V. Boyarshinov @ 2004-08-27  7:57 UTC (permalink / raw)
  To: community

On Wed, 25 Aug 2004 13:11:24 +0400 AD
 wrote:

> 1. Файл открыт для эксклюзивного доступа. Вторая копия сможет
> работать с файлом?

А что вы под этим понимаете (под экслюзивным доступом)? Пока (кто
угодно) второй раз на файл flock не позовёт -- может рабоать с
ним сколько ему угодно.

Антон
-- 
mailto:boyarsh@mail.ru
mailto:boyarsh@ru.echo.fr
 11:56:00  up 27 days, 10:32, 10 users,  load average: 0.00,
0.04, 0.03


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

end of thread, other threads:[~2004-08-27  7:57 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2004-08-25  9:11 [Comm] Как работает fork()? AD
2004-08-25 10:20 ` Макс
2004-08-26  8:17 ` php-coder
2004-08-26  9:48   ` Re[2]: " AD
2004-08-27  7:57 ` Anton V. Boyarshinov

ALT Linux Community general discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/community/0 community/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 community community/ http://lore.altlinux.org/community \
		mandrake-russian@linuxteam.iplabs.ru community@lists.altlinux.org community@lists.altlinux.ru community@lists.altlinux.com
	public-inbox-index community

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.community


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git