Máirín Duffy a Brian Smith v článku pro Fedora Magazine ukazují použití LLM pro diagnostiku systému (Fedora Linuxu) přes Model Context Protocol od firmy Anthropic. I ukázkové výstupy v samotném článku obsahují AI vygenerované nesmysly, např. doporučení přeinstalovat balíček pomocí správce balíčků APT z Debianu místo DNF nativního na Fedoře.
Projekt D7VK dospěl do verze 1.0. Jedná se o fork DXVK implementující překlad volání Direct3D 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.
Byla vydána nová verze 2025.4 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) zveřejnil Národní politiku koordinovaného zveřejňování zranitelností (pdf), jejímž cílem je nejen zvyšování bezpečnosti produktů informačních a komunikačních technologií (ICT), ale také ochrana objevitelů zranitelností před negativními právními dopady. Součástí je rovněž vytvoření „koordinátora pro účely CVD“, jímž je podle nového zákona o kybernetické … více »
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.12. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Společnost System76 vydala Pop!_OS 24.04 LTS s desktopovým prostředím COSMIC. Videoukázky na YouTube.
Byla vydána verze 1.92.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2024. Oceněni byli Andy Wingo, jeden ze správců GNU Guile, Alx Sa za příspěvky do Gimpu a Govdirectory jako společensky prospěšný projekt.
Bylo vydáno Eclipse IDE 2025-12 aneb Eclipse 4.38. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
U příležitosti oslav osmi let prací na debianím balíčku vyšlo GPXSee 15.6. Nová verze přináší především podporu pro geotagované MP4 soubory, včetně GoPro videí. Kdo nechce čekat, až nová verze dorazí do jeho distribuce, nalezne zdrojové kódy na GitHubu.
Zdravim mohl byste mi nekdo poradit jak se da resit programek v cecku abych si pri spusteni navolil v prikazove radce jaky pseudo terminal se bude pouzivat ( ptsX ). Program se pak propoji na dalsi pseudo terminal a navzajem si posilaji data.
Presne zadani zde:
........................................Napište program, teletype. Tento program otevře sériový port a vyšle na něj každý z klávesnice zapsaný znak a vypíše každý jednotlivý znak ze sériové linky přijatý. Pomocí sériového kabelu propojte COM1 a COM2 a spusťte 2 instance programu teletype. Který COM se bude používat specifikujte z příkazové řádky při spouštění programu.
________________Vim jak udelat abych se propojil na terminal a cetl z nej znaky ale nevim jak udelat aby jsme mohl navzajem mezi terminali prijimat i odesilat. Snad pomoci fce select? Prosim poradte, ( nechci to naprogramovat, jen nakopnout), zatim je to pro me spanelska vesnice. Dekuji
EXAMPLE
#include <stdio.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>
int
main(void) {
fd_set rfds;
struct timeval tv;
int retval;
/* Watch stdin (fd 0) to see when it has input. */
FD_ZERO(&rfds);
FD_SET(0, &rfds);
/* Wait up to five seconds. */
tv.tv_sec = 5;
tv.tv_usec = 0;
retval = select(1, &rfds, NULL, NULL, &tv);
/* Don't rely on the value of tv now! */
if (retval == -1)
perror("select()");
else
if (retval)
printf("Data is available now.\n");
/* FD_ISSET(0, &rfds) will be true. */
else
printf("No data within five seconds.\n");
return 0;
}
#define BUF_LEN 200
struct termios set_attributes;
int main(int argc, char *argv[]) {
char *ttyID;
char buffer[BUF_LEN];
int result;
fd_set terminal, klavesnice;
struct timeval timeout; /* Struktura s časovým limitem */
size_t len;
ttyID = argv[1]; /* Nacteme ttyID pseudo terminalu */
int tty = open(ttyID, O_RDWR);
// nastav nove parametry terminalu
tcgetattr(tty, &set_attributes);
set_attributes.c_lflag &= ~ICANON; // necekej na cely radek (noncanonical)
//set_attributes.c_lflag &= ~ECHO; // nezobrazuj ctene znaky
set_attributes.c_cc[VMIN] = 1;
set_attributes.c_cc[VTIME] = 0;
tcsetattr(tty, TCSAFLUSH, &set_attributes);
while(1){
FD_ZERO(&terminal); /* Odstranime nahodna data z mnoziny */
FD_ZERO(&klavesnice); /* Odstranime nahodna data z mnoziny */
FD_SET(fileno(stdin), &klavesnice); /* Naplnime mnozinu stdin */
FD_SET(tty, &terminal); /* Naplnime mnozinu ttyckem */
// Nadefinovany casovy interval 4 sekundy a 5 milis..
timeout.tv_sec = 4;
timeout.tv_usec = 50000;
// Zavolám select (V Linuxu musím mít nastavenou proměnnou FD_SETSIZE) --- tezko rict co je na tom pravdy
result = select(FD_SETSIZE, &klavesnice, &terminal, NULL, &timeout);
switch(result){
case -1:
perror("select"); /* Nastala chyba */
exit(1);
case 0:
printf("timeout \n"); /* Vypršel časový limit */
break;
default:
/* Obsluha soketu. Zde je možné vytvořit nové vlákno nebo proces,
který obslouží událost na soketu. Server pak je vícevláknový.
*/
if (FD_ISSET(fileno(stdin), &klavesnice)) {
/* Data available on stdin */
char a;
read(fileno(stdin), &a, sizeof(a));
write(tty, &a, sizeof(a));
}
if (FD_ISSET(tty, &terminal)) {
char c;
read(tty, &c, sizeof(c));/*:!*/
if(c == '\004') { // `C-d'
// program skonci az prijme Ctrl-D
break;
}
else {
putchar(c);
// vyprazdni vystupni buffer
// a zpusob tak zobrazeni znaku
// i v nekanonickem modu terminalu
fflush(stdout);
}
}
break;
}
}
}
.
.
.
switch(select(1, &rfds, NULL, NULL, &tv))
{
case -1:
perror("select()");
return -1;
/* no break */
case 0:
printf("No data in 5 sec.\n");
break;
default:
printf("DAATAAA!!!.\n");
/* FD_ISSET(0, &rfds) will be true. */
break;
}
return 0;
.
.
.
hlavicky
void *readFromTERMINAL( void *ptr )
{
char *terminal;
terminal = (char *) ptr;
int tty = open(terminal, O_RDONLY);/*:!*/
if(tty < 0) {
perror("ERROR open device /dev/ttyS1");
exit(EXIT_FAILURE);
}
while(1) {
char c;
read(tty, &c, sizeof(c));
if(c == '\004') { // `C-d'
// program skonci az prijme Ctrl-D
close(tty);
break;
}
else {
putchar(c);
// vyprazdni vystupni buffer
// a zpusob tak zobrazeni znaku
// i v nekanonickem modu terminalu
fflush(stdout);
}
}
close(tty);
}
int main(int argc, char *argv[])
{
pthread_t thread1, thread2;
char *parametr;
parametr = argv[1];
// vlakno cte z daneho portu a vypisuje na terminal
pthread_create( &thread1, NULL, readFromTERMINAL, parametr);
pthread_join(thread1, NULL);
printf("\nKonec\n");
return EXIT_SUCCESS;
}
moje_skvela_utilita </dev/bagr/jahoda/konzole >/dev/bagr/jahoda/konzole
Tiskni
Sdílej: