V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.
Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.
Výroba 8bitových domácích počítačů Commodore 64 byla ukončena v dubnu 1994. Po více než 30 letech byl představen nový oficiální Commodore 64 Ultimate (YouTube). S deskou postavenou na FPGA. Ve 3 edicích v ceně od 299 dolarů a plánovaným dodáním v říjnu a listopadu letošního roku.
Společnost Hugging Face ve spolupráci se společností Pollen Robotics představila open source robota Reachy Mini (YouTube). Předobjednat lze lite verzi za 299 dolarů a wireless verzi s Raspberry Pi 5 za 449 dolarů.
Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.
McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.
Byla vydána (𝕏) červnová aktualizace aneb nová verze 1.102 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.102 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Byla vydána nová verze 2.4.64 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 8 bezpečnostních chyb.
Společnost xAI na síti 𝕏 představila Grok 4, tj. novou verzi svého AI LLM modelu Grok.
Ministerstvo vnitra odhalilo závažný kyberincident v IT systému resortu. Systém, do kterého se dostal útočník bez oprávnění, byl odpojen a nedošlo k odcizení dat [𝕏].
Nezatracoval bych popen()
, myslím, že to také není špatné řešení. Tak proč mu to rovnou nepředáš jako argument, když se jedná jen o pár dat. Kdyžtak víc rozepiš o co konkrétně jde, třeba nás toho pak napadne víc.
I při použití fork()
a zabití rodiče dle mého názoru pokračuje potomek v pohodě, stačí postupovat dle Linux Daemon Writing HOWTO
#include <sys/types.h>
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <errno.h>
#include <unistd.h>
#include <syslog.h>
#include <string.h>
int main(void) {
/* Our process ID and Session ID */
pid_t pid, sid;
/* Fork off the parent process */
pid = fork();
if (pid < 0) {
exit(EXIT_FAILURE);
}
/* If we got a good PID, then
we can exit the parent process. */
if (pid > 0) {
exit(EXIT_SUCCESS);
}
/* Change the file mode mask */
umask(0);
/* Open any logs here */
/* Create a new SID for the child process */
sid = setsid();
if (sid < 0) {
/* Log the failure */
exit(EXIT_FAILURE);
}
/* Change the current working directory */
if ((chdir("/")) < 0) {
/* Log the failure */
exit(EXIT_FAILURE);
}
/* Close out the standard file descriptors */
close(STDIN_FILENO);
close(STDOUT_FILENO);
close(STDERR_FILENO);
/* Daemon-specific initialization goes here */
/* The Big Loop */
while (1) {
/* Do some task here ... */
sleep(30); /* wait 30 seconds */
}
exit(EXIT_SUCCESS);
}
Jinak proč před fork()
nepřipravíš data do paměti, jejich kopie bude dostupná i v potomku, včetně stejné adresy.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#define STRING_MAX 512
int main(int argc, char *argv[])
{
char string[STRING_MAX+1];
pid_t pid;
strcpy(string, "Hello World");
pid = fork();
if (pid < 0) {
exit(EXIT_FAILURE);
}
else if (pid > 0) {
memset(string, 0, STRING_MAX+1);
printf("0x%x parent string = '%s'\n", string, string);
printf("Exit the parent process\n");
exit(EXIT_SUCCESS);
}
sleep(3);
printf("0x%x child string = '%s'\n", string, string);
return 0;
}
$ ./example01
0xbfa67f1f parent string = ''
Exit the parent process
0xbfa67f1f child string = 'Hello World'
Nebo mu to šoupni takhle, když se Ti nechce vytvářet rouru:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[])
{
system("echo 'ABC' |sed 's/ABC/abc/'");
return 0;
}
if (fork() == 0) { char data[25]="Heslo"; fprintf (stdin,"%s",data); exec ('/usr/bin/cat'); }Případně méně šílená varianta:
if (fork() == 0) { char data[25]="Heslo"; FILE *f; f = fmemopen(data, 25, "r"); freopen (f,"r",stdin); exec ('/usr/bin/cat'); }Tady je problém s tím, že freopen() potřebuje cestu k souboru, takže mu nemůžu podstrčit memstream...
pro duplikaci deskriptoru jsou funkce dup/dup2.
dup2(fd, 0); // fd -> 0
exec(...);
Tohle by se Ti mohlo líbit. Stejný příklad je v knížce "Linux začínáme programovat" v kapitole "Vzájemná komunikace mezi procesy: Roury" a části "Roury a funkce dup". Je to tam i pěkně vysvětleno.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
#define STRING_MAX 512
int main(int argc, char *argv[])
{
char string[STRING_MAX+1];
int pipes[2];
pid_t pid;
strcpy(string, "Hello World");
if (pipe(pipes) == 0) {
pid = fork();
if (pid < 0) {
exit(EXIT_FAILURE);
}
else if (pid > 0) {
close(pipes[0]);
write(pipes[1], string, strlen(string));
close(pipes[1]);
}
close(0);
dup(pipes[0]);
close(pipes[0]);
close(pipes[1]);
execlp("cat", "cat");
}
return 0;
}
Zásadní jsou tyto dva řádky:
close(0);
dup(pipes[0]);
Nejprve se zavře stdin a díky tomu pak následně volaná fce vytvoří kopii deskriptoru nastavenou na 0, protože je nový deskriptor vždy nejnižší možné číslo. V případě fce dup2() je nastaven na hodnotu předanou v druhém argumentu nebo nejbližší větší, v případě, že požadovaná hodnota je již využívána.
Díky moc za vyvedení z omylu. Máš pravdu, zmátla mě formulace v knize, jak v originále, tak překladu.
... zatímco v případě funkce dup2 je nový deskriptor shodný nebo první volný, který je větší než parametr newfd ...
... while in the case of dup2 it's the same as, or the first available descriptor greater than, the parameter newfd ...
Takže jim evidentně zmizel kus textu a mělo tam být něco jako:
If newfd is negative or greater than or equal to OPEN_MAX, the dup2() function returns a value of -1 and sets errno to EBADF.
V manuálové stránce to řekli hezky na rovinu:
dup2() makes newfd be the copy of oldfd, closing newfd first if necessary.
The call:
fid = dup2(fildes, fildes2);
is equivalent to:
close(fildes2);
fid = fcntl(fildes, F_DUPFD, fildes2);
with the following exceptions:
If fildes2 is negative or greater than or equal to OPEN_MAX, the dup2() function returns a value of -1 and sets errno to EBADF.
If fildes is a valid file descriptor and is equal to fildes2, the dup2() function returns fildes2 without closing it.
If fildes is not a valid file descriptor, dup2() fails and does not close fildes2.
If successful, dup2() returns a value that is equal to the value of fildes2.
If a failure occurs, it returns a value of -1.
Tiskni
Sdílej: