Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách
… více »David Malcolm se na blogu vývojářů Red Hatu rozepsal o vybraných novinkách v GCC 16, jež by mělo vyjít v nejbližších dnech. Vypíchnuta jsou vylepšení čitelnosti chybových zpráv v C++, aktualizovaný SARIF (Static Analysis Results Interchange Format) výstup a nová volba experimental-html v HTML výstupu.
Byla vydána verze R14.1.6 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.
Jon Seager z Canonicalu včera na Ubuntu Community Hubu popsal budoucnost AI v Ubuntu. Dnes upřesnil: AI nástroje budou k dispozici jako Snap balíčky, vždy je může uživatel odinstalovat. Ve výchozím nastavení budou všechny AI nástroje používat lokální AI modely.
Nový ovladač Steam Controller jde do prodeje 4. května. Cena je 99 eur.
Greg Kroah-Hartman začal používat AI asistenta pojmenovaného gkh_clanker_t1000. V commitech se objevuje "Assisted-by: gkh_clanker_t1000". Na social.kernel.org publikoval jeho fotografii. Jedná se o Framework Desktop s AMD Ryzen AI Max a lokální LLM.
Ubuntu 26.10 bude Stonking Stingray (úžasný rejnok).
Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.3.0. S experimentální podporou FLTK 1.4. S příkazem dilloc pro ovládání prohlížeče z příkazové řádky. Vývoj prohlížeče se přesunul z GitHubu na vlastní doménu dillo-browser.org (Git).
#!/usr/bin/env python
import sys, os, threading, tty, fcntl, struct, time
class CD_thread(threading.Thread):
def __init__(self):
threading.Thread.__init__(self)
self.fd = fd
def run(self):
while True:
fcntl.ioctl(fd, tty.TIOCMIWAIT, tty.TIOCM_CD)
lock.acquire()
print "DCD changed"
lock.release()
fd = os.open('/dev/ttyS0', os.O_RDWR | os.O_SYNC)
lock = threading.Lock()
cd_thread = CD_thread()
cd_thread.start()
try:
while True:
lock.acquire()
print "heartbeat"
os.write(fd, "\xff"*100)
lock.release()
time.sleep(3)
except:
cd_thread._Thread__stop()
Hlavní vlákno každé tři sekundy něco pošle na sériový port, přičemž jiné vlákno hlídá změnu stavové linky DCD. Zámek hlídá, aby si vlákna moc nelezla do zelí (ale to se stejně trochu děje). Zdá se, že to funguje, ze sériového portu skutečně něco leze a na DCD to reaguje, ale fakt nevím, jestli nemůže nastat nějaká problémová situace.
man 2 signal man 2 alarmJe to jednoduché a mělo by to fungovat bez problémů. Spočívá to v tom, že si nastavíš, za jak dlouho ti má jádro poslat signál SIGALRM. A jakýkoliv příchozí signál by měl přerušit ten syscall, který se během něho prováděl. Takže do obsluhy signálu bych dal jen nastavení nějakého flagu a pořešil to v hlavní smyčce (nebudeš mít problémy se synchronizací).
void sig_alrm(int signo)
{
printf ("posilam heartbeat\n") ;
alarm(3); //znovu za 3 sec
}
int main()
{
int fd,er, rts = TIOCM_RTS, dtr = TIOCM_DTR, talk;
if ((fd=open("/dev/ttyS0", O_RDWR | O_NOCTTY | O_NONBLOCK)) < 0)
{
perror("open_port: Unable to open /dev/ttyS0 - ");
return 1;
}
//nastav bity potrebuju volty na diodu
ioctl(fd, TIOCMBIS, &rts);
ioctl(fd, TIOCMBIC, &dtr);
if (signal(SIGALRM, sig_alrm) == SIG_ERR)
perror("signal(SIGALRM) error");
while(1){
alarm(3);
er = ioctl(fd, TIOCMIWAIT, TIOCM_CAR);
if (er < 0)
{
if (er != EINTR /*ERESTARTSYS*/)
perror("wait_DCD");
}
else {
alarm(0);
if (ioctl(fd, TIOCMGET, &talk) < 0)
perror("get_DCD");
if (talk & TIOCM_CAR)
printf ("1\n");
else
printf ("0\n");
}
}
close (fd);
}
static int s, alarm_flag = 0 ;
static struct sockaddr_in server_address;
void send_data (int data)
{
if (sendto(s, &data, 1, 0, (struct sockaddr*)&server_address, sizeof(server_address))==-1)
{perror("Error sending datagram: "); close(s); exit(-1); }
}
void sig_alrm(int signo)
{
alarm_flag++;
}
int main()
{
int fd, rts = TIOCM_RTS, dtr = TIOCM_DTR, talk, mask = TIOCM_CAR, result, DCD,er;
s = socket(PF_INET, SOCK_DGRAM, 0);
if (s == -1) {
perror("Server: Error Opening socket \n");
exit (-1);
}
// pripravime adresu serveru
server_address.sin_family=AF_INET;
server_address.sin_port=htons(32000);
server_address.sin_addr.s_addr=inet_addr("127.0.0.1");
printf("Sending datagram to server\n");
// posleme datagram na pripravenou adresu serveru
//open the device
if ((fd=open("/dev/ttyS0", O_RDWR | O_NOCTTY | O_NONBLOCK)) < 0)
{
perror("open_port: Unable to open /dev/ttyS0 - ");
return 1;
}
//nastav bity potrebuju volty na diodu
ioctl(fd, TIOCMBIS, &rts);
ioctl(fd, TIOCMBIC, &dtr);
siginterrupt (SIGALRM,1);
if (signal(SIGALRM, sig_alrm) == SIG_ERR)
perror("signal(SIGALRM) error");
while(1){
alarm(3);
if ( ioctl(fd, TIOCMIWAIT, TIOCM_CAR)< 0) if (errno != EINTR /*ERESTARTSYS*/) perror("wait_DCD");
if (alarm_flag) {
printf ("posilam heartbeat\n") ;
send_data (1);
alarm_flag = 0;
}
else {
alarm(0);
if (ioctl(fd, TIOCMGET, &talk) < 0)
perror("get_DCD");
if (talk & TIOCM_CAR)
{printf ("1\n");send_data (10);}
else
{printf ("0\n");send_data (0);}
}
}
close(fd);
close(s);
}
SA_RESTART, viz sigaction(2).
Tiskni
Sdílej: