Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.
Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.
Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.
Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.
Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.
Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.
Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.
Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.
n procesov a aby kazdy potomok vypisal cislo od 0 po 4. Preco to ale nebezi naraz(paralelne?)
pid_t pid[n+1];
for(p = 0; p < n; p++)
{
pid[p] = fork();
switch(pid[p])
{
case -1:
/* fork error */
PANIC("fork");
break;
case 0:
child = true;
for(int i = 0; i < 5; i++) { printf("%d\n", i); fflush(stdout); }
break;
default:
waitpid(pid[p], NULL, 0);
child = false;
break;
}
if(child) break;
}
printf("--- (%d) => (%d)\n", getppid(), getpid());
Toto je vystup:
0
1
2
3
4
--- (12622) => (12623)
0
1
2
3
4
--- (12622) => (12624)
0
1
2
3
4
--- (12622) => (12625)
0
1
2
3
4
--- (12622) => (12626)
0
1
2
3
4
--- (12622) => (12627)
--- (3683) => (12622)
3683 je bash.
Dakujem za radu
Řešení dotazu:
default:
waitpid(pid[p], NULL, 0);
Ak tomu dobre rozumiem, tak sa hlavny proces najprv zdvoji (fork),
a pocka waitpid kym synovsky proces skonci.
A az potom pokracuje vo vykonavani cyklu
n vlakien:
for(p = 0; p < n; p++)
{
pid[p] = fork();
switch(pid[p])
{
case -1:
/* fork error */
PANIC("fork");
break;
case 0:
child = true;
break;
default:
child = false;
break;
}
if(child) break;
}
if(child)
{
sleep(5);
//do_child_job(p);
}
if(parent)
{
for(p = 0; p < n; p++)
{
printf("parent\n");
waitpid(pid[p], NULL, 0);
}
Problem je vsak, ze ked napriklad 1. child proces nieco robi dlhsie, tak waitpid zablokuje hlavny proces cakanim na skoncenie a az potom sa zavola waitpid na dalsie procesy. Comu ale uz vobec nerozumiem, preco sa tento kod sprava tak, ze da takyto vystup:
parent // tu caka tych 5 sekund
parent // dalsie 4 riadky uz vypise okamzite
parent
parent
parent
Slo by asi pouzit WNOHANG vo waitpid namiesto 0, ale potom hlavny proces skonci a nepocka na skoncenie deti.
Ako teda zabezpecit, ze hlavny proces nebude blokovany child procesmy, ale zaroven pocka, kym vsetky skoncia?
static void sigchld_hdl(int sig)
{
running_children--;
printf("sigchld_hdl\n"); fflush(stdout);
/* Wait for all dead processes.
* We use a non-blocking call to be sure this signal handler will not
* block if a child was cleaned up in another part of the program. */
while (waitpid(-1, NULL, WNOHANG) > 0)
{
}
if(running_children == 0) // toto je vlastne na upratanie po detoch, ked uz vsetky su skoncene
{
printf("--QUITING\n"); fflush(stdout);
fclose(fp);
if (msgctl(msqid, IPC_RMID, NULL) == -1)
PANIC("msgctl");
exit(EXIT_SUCCESS);
}
}
potom v main()
struct sigaction act;
memset (&act, 0, sizeof(act));
act.sa_handler = sigchld_hdl;
if (sigaction(SIGCHLD, &act, 0)) {
perror ("sigaction");
return 1;
}
for(p = 0; p < n; p++)
{
pid[p] = fork();
switch(pid[p])
{
case -1:
/* fork error */
PANIC("fork");
break;
case 0:
child = true;
break;
default:
child = false;
running_children++;
printf("adding child: %ld\n", running_children); fflush(stdout);
break;
}
if(child) break;
}
if(child)
{
printf("(%d) cakam...\n", getpid()); fflush(stdout);
msg_rcv(READY_TO_START);
printf("(%d) child\n", getpid()); fflush(stdout);
exit(EXIT_SUCCESS);
// sleep(1);
}
if(parent)
{
for(p = 0; p < n; p++)
{
printf("parent\n"); fflush(stdout);
waitpid(pid[p], NULL, WNOHANG);//WNOHANG
msg_snd(READY_TO_START, READY_TO_START_TRUE);
}
while (running_children>0) {
sleep(1);
printf("sleeping, running children: %ld\n", running_children); fflush(stdout);
}
}
Toto teda vacsinou funguje, avsak niekedy sa to zasekne na tom poslednom while(running_children>0) a vystup je takyto:
$ ./philosophers 5
(26467) >> sending message(1): 1
(26467) >> sending message(2): 0
adding child: 1
(26468) cakam...
adding child: 2
(26469) cakam...
adding child: 3
(26470) cakam...
adding child: 4
(26471) cakam...
adding child: 5
parent
(26467) >> sending message(3): 0
parent
(26468) >> receiving message(3): 0
(26468) child
(26469) >> receiving message(3): 0
(26469) child
sigchld_hdl
(26467) >> sending message(3): 0
parent
(26467) >> sending message(3): 0
parent
(26470) >> receiving message(3): 0
(26470) child
(26471) >> receiving message(3): 0
(26471) child
(26472) cakam...
sigchld_hdl
(26467) >> sending message(3): 0
parent
(26467) >> sending message(3): 0
(26472) >> receiving message(3): 0
(26472) child
sigchld_hdl
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
sleeping, running children: 2
^C
Chape to niekto?
Dakujem
Problém už byl vyřešen, ale neodpustím si terminologickou poznámku:
Nasledujuci kod spusti pekne n vlakien:
Syscall fork() nevytváří vlákna ale procesy. Vlákna by se vytvářela pomocí pthread_create().
Tiskni
Sdílej: