Příspěvek na blogu Raspberry Pi představuje novou kompletně přepracovanou verzi 2.0 aplikace Raspberry Pi Imager (YouTube) pro stažení, nakonfigurování a zapsání obrazu operačního systému pro Raspberry Pi na SD kartu. Z novinek lze vypíchnout volitelnou konfiguraci Raspberry Pi Connect.
Memtest86+ (Wikipedie), svobodný nástroj pro kontrolu operační paměti, byl vydán ve verzi 8.00. Přináší podporu nejnovějších procesorů Intel a AMD nebo také tmavý režim.
Programovací jazyk Racket (Wikipedie), tj. jazyk z rodiny jazyků Lisp a potomek jazyka Scheme, byl vydán v nové major verzi 9.0. Hlavní novinku jsou paralelní vlákna (Parallel Threads).
Před šesti týdny bylo oznámeno, že Qualcomm kupuje Arduino. Minulý týden byly na stránkách Arduina aktualizovány podmínky používání a zásady ochrany osobních údajů. Objevily se obavy, že by otevřená povaha Arduina mohla být ohrožena. Arduino ubezpečuje, že se nic nemění a například omezení reverzního inženýrství v podmínkách používání se týká pouze SaaS cloudové aplikace.
Knihovna libpng, tj. oficiální referenční knihovna grafického formátu PNG (Portable Network Graphics), byla vydána ve verzi 1.6.51. Opraveny jsou 4 bezpečnostní chyby obsaženy ve verzích 1.6.0 (vydána 14. února 2013) až 1.6.50. Nejvážnější z chyb CVE-2025-65018 může vést ke spuštění libovolného kódu.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 159 (pdf).
Hru Warhammer: Vermintide 2 (ProtonDB) lze na Steamu získat zdarma napořád, když aktivaci provedete do pondělí 24. listopadu.
Virtualizační software Xen (Wikipedie) byl vydán v nové verzi 4.21. Podrobnosti v poznámkách k vydání a přehledu nových vlastností.
Evropská komise schválila český plán na poskytnutí státní pomoci v objemu 450 milionů eur (téměř 11 miliard Kč) na rozšíření výroby amerického producenta polovodičů onsemi v Rožnově pod Radhoštěm. Komise o tom informovala v dnešní tiskové zprávě. Společnost onsemi by podle ní do nového závodu v Rožnově pod Radhoštěm měla investovat 1,64 miliardy eur (téměř 40 miliard Kč).
Microsoft v příspěvku na svém blogu věnovaném open source oznámil, že textové adventury Zork I, Zork II a Zork III (Wikipedie) jsou oficiálně open source pod licencí MIT.
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: