LINUXSOFT.cz
Nazwa użytkownika: Hasło:     
    CZ UK PL

> Komentarze :: Poradna Jak do rodiče info o výsledku fork() a exec()?

Jak do rodiče info o výsledku fork() a exec()? 14.3.2008 11:14
Jan Němec

Jak rozumně po fork() a v synovi exec() do rodičovského procesu protlačím informaci, zda exec() uspěl? Hlavně v případě, že ten exec() uspěl si nevím rady, jelikož v synovi již běží cizí kód. Pokud exec() neuspěje, tak to nějak přes meziprocesovou komunikaci protlačím. Motivace: dělám si takovou knihovničku (C++, unix a MS windows, http://www.linuxsoft.cz/sw_detail.php?id_item=832) a chci tam napsat funkci na spuštění programu. V MS windows je to jen převolání API funkce CreateProcess. Poradí mi někdo? Dík.

Re: Jak do rodiče info o výsledku fork() a exec()? 14.3.2008 12:57
Aleš Hakl

Tradicne se to resi tak, ze pokud exec(2) neuspeje, vrati se nejaka specialni hodnota pres exit(3), nelze pak poznat, jestli proces skoncil s tou hodnotou proto, ze selhel exec, nebo proto, ze ji vratil ten program (coz je typicky stejne jedno, protoze pokud to nekoho zajima, tak ho zajima, jestli ten proces vratil nulu).

Asi by se to dalo resit pres IPC s tim, ze pokud nic pres IPC neprijde, tak exec(2) probehl uspesne.

A nebylo by lepsi pouzit system(3) ci popen(3)? Neumi to sice uplne vse co CreateProcess, nicmene rekl bych, ze na ty nejcastejsi pripady je to vice nez dostacujici.

Re: Jak do rodiče info o výsledku fork() a exec()? 25.9.2008 23:00
Jan Němec
Díky za rady, ale ani jedno řešení se mi nelíbí.

Tradicne se to resi tak, ze pokud exec(2) neuspeje, vrati se nejaka specialni hodnota pres exit(3), nelze pak poznat, jestli proces skoncil s tou hodnotou proto, ze selhel exec, nebo proto, ze ji vratil ten program (coz je typicky stejne jedno, protoze pokud to nekoho zajima, tak ho zajima, jestli ten proces vratil nulu).

Cekani s timeoutem na exec. (Zdrzovani.) Mozna kolize specialni hodnoty.

Asi by se to dalo resit pres IPC s tim, ze pokud nic pres IPC neprijde, tak exec(2) probehl uspesne.

Cekani s timeoutem na IPC. (Zdrzovani.)

system(3)

Nezadouci cekani na dokonceni prikazu. (Hrozne zdrzovani.)

popen(3)

Vynucené přepípování syna, vynucený shell.

Nakonec jsem to vymyslel. Pomohlo mi zavření pípy při execu. Tohle mi (aspoň na mém počítači) funguje výborně:

#include <unistd.h>
#include <sys/types.h>
#include <stdio.h>
int main(void) { int i; pid_t id; int pp[2];
pipe(pp); id = fork(); if (id) { char c; close(pp[1]); int precteno = read(pp[0], (void *)&c, 1); printf("Predek: exec syna se %spodaril\n", precteno ? "ne": ""); close(pp[0]); } else { close(pp[0]); execlp("ls", "ls", "-l", NULL); write(pp[1], (void *)&i, 1); close(pp[1]); } return 0; }
Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 00:12
Aleš Hakl

Tohle opravdu funguje i bez fcntl(pp[1], FD_SETFD, FD_CLOEXEC) ?

Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 07:05
Jan Němec

Díky za podnětnou otázku. V nějakém návodu, jsem četl, že to FD_CLOEXEC je třeba nastavit, ale u mně (stará Mandriva) to funguje i bez toho. Zřejmě je CLOEXEC (aspoň na mém počítači) u pípy nastaveno defaultně. Každopádně bude lepší to fcntl zavolat, kdo ví, jak by to bez toho fungovalo na jiných systémech.

Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 13:25
Aleš Hakl

No single unix specification rika, ze "The O_NONBLOCK and FD_CLOEXEC flags shall be clear on both file descriptors.". Coz mi prijde vcelku logicke.

Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 13:29
Aleš Hakl

A kdyz jsem to ted vyzkousel, tak jsem prisel na to, ze na mem pocitaci to sice na prvni pohled vypada, jako kdyby to fungovalo i bez CLOEXEC, ale nefunguje. Vypada to jako kdyby to fungovalo proto, ze se ta roura zavre ukoncenim toho procesu, coz v pripade toho ls nastane pomerne brzy.

Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 14:12
Jan Němec

Aha. Tak já si to pak schválně doma (v práci mám bohužel wokna) vyzkouším s něčím delším než ls. Ale každopádně to CLOEXEC ve výsledném kódu nastavím. Díky za rady a průzkum.


KOMENTARZE
Jak do rodiče info o výsledku fork() a exec()? 14.3.2008 11:14 Jan Němec
  L Re: Jak do rodiče info o výsledku fork() a exec()? 14.3.2008 12:57 Aleš Hakl
    L Re: Jak do rodiče info o výsledku fork() a exec()? 25.9.2008 23:00 Jan Němec
      L Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 00:12 Aleš Hakl
        L Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 07:05 Jan Němec
          L Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 13:25 Aleš Hakl
            L Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 13:29 Aleš Hakl
              L Re: Jak do rodiče info o výsledku fork() a exec()? 26.9.2008 14:12 Jan Němec
Tylko zarejestrowani użytkownicy mogą dopisywać komentarze.
> Szukanie oprogramowania
1. Pacman linux
Download: 4878x
2. FreeBSD
Download: 9066x
3. PCLinuxOS-2010
Download: 8564x
4. alcolix
Download: 10947x
5. Onebase Linux
Download: 9661x
6. Novell Linux Desktop
Download: 0x
7. KateOS
Download: 6243x

1. xinetd
Download: 2413x
2. RDGS
Download: 937x
3. spkg
Download: 4760x
4. LinPacker
Download: 9966x
5. VFU File Manager
Download: 3198x
6. LeftHand Mała Księgowość
Download: 7203x
7. MISU pyFotoResize
Download: 2808x
8. Lefthand CRM
Download: 3563x
9. MetadataExtractor
Download: 0x
10. RCP100
Download: 3120x
11. Predaj softveru
Download: 0x
12. MSH Free Autoresponder
Download: 0x
©Pavel Kysilka - 2003-2024 | mailatlinuxsoft.cz | Design: www.megadesign.cz