Bylo vydáno Ubuntu 24.04.4 LTS, tj. čtvrté opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.
V pátek 20. února 2025 se v pražské kanceláři SUSE v Karlíně uskuteční 6. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj a uživatelský prostor. Akce proběhne od 10:00 do večera. Hackday je určen všem, kteří si chtějí prakticky vyzkoušet práci s linuxovým jádrem i uživatelským prostorem, od posílání patchů například pomocí nástroje b4, přes balíčkování a Flatpak až po drobné úpravy
… více »Evropská rada vydavatelů (EPC) předložila Evropské komisi stížnost na americkou internetovou společnost Google kvůli její službě AI Overviews (AI souhrny), která při vyhledávání na internetu zobrazuje shrnutí informací ze zpravodajských serverů vytvořená pomocí umělé inteligence (AI). Evropská komise již v prosinci oznámila, že v souvislosti s touto službou začala firmu Google vyšetřovat. Google obvinění ze strany vydavatelů
… více »Ubuntu 26.04 (Resolute Raccoon) už nebude v desktopové instalaci obsahovat GUI nástroj 'Software & Updates'. Důvodem jsou obavy z jeho složitosti pro běžné uživatele a z toho plynoucích bezpečnostních rizik. Nástroj lze doinstalovat ručně (sudo apt install software-properties-gtk).
Thomas Dohmke, bývalý CEO GitHubu, představil startup Entire - platformu pro spolupráci vývojářů a agentů umělé inteligence. Entire získalo rekordních 60 milionů dolarů na vývoj databáze a nástrojů, které mají zefektivnit spolupráci mezi lidmi a agenty umělé inteligence. Dohmke zdůrazňuje potřebu přepracovat tradiční vývojové postupy tak, aby odpovídaly realitě, kdy většinu kódu produkuje umělá inteligence.
Toyota Connected North America oznámila vývoj open-source herního enginu Fluorite, postaveného na frameworku Flutter. Pro renderování grafiky využívá 3D engine Filament od společnosti Google a dle svého tvrzení cílí na konzolovou kvalitu her. Fluorite je zřejmě navržen tak, aby fungoval i na méně výkonném hardware, což naznačuje možnost použití přímo v ICE systémech vozidel. Zdrojový kód zatím zveřejněný není.
Byl vytvořen nástroj a postup pro překonání věkového ověření platforem Discord, Kick, Twitch, Snapchat (a možná dalších), kód je open-source a dostupný na GitHubu. Všechny tyto sítě používají stejnou službu k-ID, která určuje věk uživatele scanem obličeje a na původní server posílá pouze šifrovaná metadata, ty ale sociální síť už nedokáže sama nijak validovat, 'útok' spočívá ve vygenerování a podstrčení legitimně vypadajících ověřovacích metadat.
Jihokorejská kryptoměnová burza Bithumb přiznala vážné selhání interních systémů, které ji vystavilo riziku sabotáže a nezabránilo chybné transakci v hodnotě přes 40 miliard dolarů (814 miliard Kč). Druhá největší kryptoměnová burza v Koreji minulý týden při propagační akci omylem rozeslala zákazníkům zhruba 620 000 bitcoinů místo 620 000 wonů (8700 Kč). Incident vyvolal pokles ceny bitcoinu o 17 procent. Většinu
… více »Google Chrome 145 byl prohlášen za stabilní. Nejnovější stabilní verze 145.0.7632.45 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Zpátky je podpora grafického formátu JPEG XL, viz Platform Status. Odstraněna byla před třemi lety. Nový dekodér JPEG XL jxl-rs je napsán v Rustu. Zobrazování JPEG XL lze vyzkoušet na testovací stránce. Povolit lze v nastavení chrome://flags (Enable JXL image format).
Byla vydána nová verze 1.26 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.
void EventPumpX11::waitForWork()
{
UISystemX11* uiSystem = UI_SYSTEM();
int fd = uiSystem->_fd;
int fdSize = fd + 1;
fd_set fdSet;
struct timeval tval;
FD_ZERO(&fdSet);
FD_SET(fd, &fdSet);
TimeDelta delay = _delayedWorkTime - Time::now();
if (delay > TimeDelta())
{
// Go to sleep. X11 will wake us to process X events. We also set interval
// to wake up if there are planned tasks to specific time (Timers).
int64_t udelay = delay.inMicroseconds();
tval.tv_sec = (int)(udelay / 1000000);
tval.tv_usec = (int)(udelay % 1000000);
if (tval.tv_usec <= 100) tval.tv_usec = 100;
int ret = ::select(fdSize, &fdSet, NULL, NULL, &tval);
// TODO: Check for select result
}
else
{
// It looks like delayedWorkTime indicates a time in the past, so we
// need to call doDelayedWork now.
_delayedWorkTime = Time();
}
}
kde fd je deskriptor, který jsem obdržel pomocí ConnectionNumber(Display*) (Xlib). O co mi jde, potřeboval bych probudit event loop, když chci z jiného vlákna poslat událost do toho hlavního, které čeká buď na událost z X11 nebo na vypršení časového limitu potřebného pro jiné úkoly (delay).
Myslím, že správná cesta bude vytvořit vlastní file descriptor, na který pošlu 1 byte v případě, že budu chtít probudit event loop, ale nějak nevím jak přesně na to (toto jsem ještě nikdy nedělal). Použít fd_set a do masky dát vlastní fd?
Stačí mi nakopnutí správným směrem ;)
void EventPumpX11::waitForWork()
{
UISystemX11* uiSystem = UI_SYSTEM();
int fd = uiSystem->_fd;
int fdSize = fog_max(fd, uiSystem->_wakeUpPipe[0]) + 1;
fd_set fdSet;
struct timeval tval;
struct timeval* ptval = NULL;
FD_ZERO(&fdSet);
FD_SET(fd, &fdSet);
FD_SET(uiSystem->_wakeUpPipe[0], &fdSet);
if (_delayedWorkTime.isNull())
{
// There are no scheduled tasks, so ptval is NULL and this tells to select()
// that it should wait infitine time.
}
else
{
TimeDelta delay = _delayedWorkTime - Time::now();
if (delay > TimeDelta())
{
// Go to sleep. X11 will wake us to process X events and we also set
// interval to wake up to run planned tasks (usually Timers).
int64_t udelay = delay.inMicroseconds();
tval.tv_sec = (int)(udelay / 1000000);
tval.tv_usec = (int)(udelay % 1000000);
if (tval.tv_usec <= 100) tval.tv_usec = 100;
ptval = &tval;
}
else
{
// It looks like delayedWorkTime indicates a time in the past, so we
// need to call doDelayedWork now.
_delayedWorkTime = Time();
return;
}
}
int ret = ::select(fdSize, &fdSet, NULL, NULL, ptval);
if (ret < 0)
{
fog_debug("Fog::EventPumpX11::waitForWork() - select() failed (errno=%d).", errno);
}
if (ret > 0)
{
if (FD_ISSET(uiSystem->_wakeUpPipe[0], &fdSet))
{
// Dummy c, the actual value is out of our interest.
uint8_t c;
read(uiSystem->_wakeUpPipe[0], &c, 1);
_wakeUpSent.cmpXchg(1, 0);
}
}
}
a Kód pro probuzen9 z jiiného vlákna vypadá takto:
void EventPumpX11::sendWakeUp()
{
if (_wakeUpSent.cmpXchg(0, 1))
{
UISystemX11* uiSystem = UI_SYSTEM();
uint8_t c = 'W';
write(uiSystem->_wakeUpPipe[1], &c, 1);
}
}
požil jsem atomické operace k tomu, abych do pipe neposílal příliš moc, teď tam je normálně jen ten 1 BYTE, který probudí select. Funguje to, ale samořejmě to může obsahovat chyby (zase tak moc jsem to neotestoval)...
Ke kompletnosti ještě vytvoření pipe:
// Create wakeup pipe.
if (pipe(_wakeUpPipe) < 0)
{
fog_debug("Fog::UISystemX11::Can't create wakeup pipe");
goto fail;
}
K zápisu používám _wakeUpPipe[1] a ke čtení _wakeUpPipe[0], doufám, že jsem to pochopil správně...:)
Tiskni
Sdílej: