Chris Down v obsáhlém článku „vyvrací mýty o zswap a zram“, vysvětluje, co vlastně dělají a jaké jsou mezi nimi rozdíly. Doporučuje vyhýbat se zram na serveru a bez OOM.
Porota v Los Angeles shledala firmy Google a Meta odpovědnými v přelomovém soudním sporu, který se týká závislosti na sociálních sítích; firmy musí zaplatit odškodné tři miliony dolarů (63,4 milionu Kč). Společnosti, které s verdiktem nesouhlasí, čelily obvinění, že své sociální sítě a platformy záměrně navrhly tak, aby si na nich děti vypěstovaly závislost. Porota došla k závěru, že technologické společnosti při navrhování a
… více »Jelikož vývojáři editorů Vim a Neovim začali při vývoji využívat LLM, Drew DeVault se rozhodl forknout Vim a vytvořil projekt Vim Classic. Vychází z Vimu 8.2.0148, tj. těsně před zavedením Vim9 skriptování.
Byla vydána nová verze 0.56 open source počítačové hry Unvanquished (Wikipedie), forku počítačové hry Tremulous. Instalovat ji lze také z Flathubu.
FreeCAD (Wikipedie), tj. svobodný multiplatformní parametrický 3D CAD, byl vydán ve verzi 1.1 (YouTube). Po roce a čtyřech měsících od předchozí verze 1.0. Přehled novinek i s náhledy v poznámkách k vydání.
Společnost OpenAI oznámila [𝕏], že ukončí aplikaci Sora pro generování krátkých videí pomocí umělé inteligence. Podrobné informace a harmonogram pro aplikaci a API budou brzy zveřejněny.
Evropská směrnice NIS2 přináší nové požadavky v oblasti kybernetické bezpečnosti, které se promítají také do správy doménových jmen. Do českého právního řádu je směrnice implementována prostřednictvím nového zákona o kybernetické bezpečnosti. Jedním z praktických důsledků této legislativní změny je posílení požadavků na dostupnost a správnost kontaktních údajů držitelů domén. Správce registru domény .cz, sdružení CZ.NIC, je v
… více »Jonathan Thomas oznámil vydání nové verze 3.5.0 video editoru OpenShot (Wikipedie). Zdrojové kódy OpenShotu jsou k dispozici na GitHubu. Ke stažení je i balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit.
Byla vydána (𝕏, Bluesky) nová verze 2026.1 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem 8 nových nástrojů v oficiálním oznámení na blogu.
Vláda jmenovala novým zmocněncem pro digitalizaci a strategickou bezpečnost prvního náměstka ministra vnitra Lukáše Klučku. Ten ve funkci nahradil poslance Roberta Králíčka poté, co Králíček na tento post vládního zmocněnce rezignoval. Klučka chce do roka digitalizovat všechny státní služby tak, aby vyhověly zákonu o právu na digitální služby, přičemž dosavadní plán Fialovy vlády počítal s dokončením digitalizace až někdy v roce
… více »epoll_wait vyplní poskytnuté pole epoll_eventů událostmi na registrovaných deskriptorech. Pokud přes epoll_ctl odeberete nějaký deskriptor, nebude epoll_wait události k tomu deskriptoru vracet, takže ve vráceném poli epoll_data_t asociovaný s tím deskriptorem nebude.
man epoll:
If you use an event cache or store all the file descriptors returned from epoll_wait(2), then make sure to provide a way to mark its closure dynamically (i.e., caused by a previous event's processing). Suppose you receive 100 events from epoll_wait(2), and in event #47 a condition causes event #13 to be closed. If you remove the structure and close(2) the file descriptor for event #13, then your event cache might still say there are events waiting for that file descriptor causing confusion. One solution for this is to call, during the processing of event 47, epoll_ctl(EPOLL_CTL_DEL) to delete file descriptor 13 and close(2), then mark its associated data structure as removed and link it to a cleanup list. If you find another event for file descriptor 13 in your batch processing, you will discover the file descriptor had been previously removed and there will be no confusion.
#include <errno.h>
#include <inttypes.h>
#include <stdlib.h>
#include <sys/epoll.h>
#include <unistd.h>
typedef struct JRPollable JRPollable;
typedef void (*JRPollableReady)(JRPollable*, uint32_t);
typedef struct JREpoll JREpoll;
struct JRPollable
{
JRPollableReady jrCallback;
int jrFD;
uint32_t jrEvents;
};
struct JREpoll
{
int jrEpollFD;
int jrEventsAvail;
struct epoll_event jrEvents[100];
};
int JREpoll_init(JREpoll *jrEpoll)
{
jrEpoll->jrEpollFD = epoll_create1(EPOLL_CLOEXEC);
if (jrEpoll->jrEpollFD == -1)
return errno;
jrEpoll->jrEventsAvail = 0;
return 0;
}
int JREpoll_add(JREpoll *jrEpoll, JRPollable *jrPollable)
{
struct epoll_event ee = { .events = jrPollable->jrEvents,
.data = { .ptr = jrPollable } };
if (epoll_ctl(jrEpoll->jrEpollFD, EPOLL_CTL_ADD, jrPollable->jrFD, &ee) != 0)
return errno;
return 0;
}
int JREpoll_remove(JREpoll *jrEpoll, JRPollable *jrPollable)
{
struct epoll_event kernelBugDummyEv_lt2_6_9;
if (epoll_ctl(jrEpoll->jrEpollFD, EPOLL_CTL_DEL, jrPollable->jrFD,
&kernelBugDummyEv_lt2_6_9) != 0)
return errno;
int avail = jrEpoll->jrEventsAvail;
struct epoll_event *events = jrEpoll->jrEvents;
for (int i = 0; i < avail; ++i)
{
if (events[i].data.ptr == jrPollable) {
events[i] = events[avail-1];
--jrEpoll->jrEventsAvail;
break;
}
}
return 0;
}
int JREpoll_destroy(JREpoll *jrEpoll)
{
if (close(jrEpoll->jrEpollFD) != 0)
return errno;
return 0;
}
int JREpoll_wait(JREpoll *jrEpoll)
{
int ret = epoll_wait(jrEpoll->jrEpollFD, jrEpoll->jrEvents,
sizeof(jrEpoll->jrEvents) / sizeof(struct epoll_event),
-1);
if (ret < 0) {
int errnoSave = errno;
if (errnoSave != EINTR)
return errnoSave;
ret = 0;
}
jrEpoll->jrEventsAvail = ret;
return 0;
}
void JREpoll_dispatch(JREpoll *jrEpoll)
{
struct epoll_event *events = jrEpoll->jrEvents;
for (int avail = jrEpoll->jrEventsAvail;
avail > 0;
avail = jrEpoll->jrEventsAvail)
{
jrEpoll->jrEventsAvail = --avail;
struct epoll_event ev = events[avail];
JRPollable *pollable = ev.data.ptr;
pollable->jrCallback(pollable, ev.events);
}
}
Ta struktura JRPollable může být pak součástí většího objektu, který v příslušném callbacku dostanu po "hrátkách" s offsetof(), nebo přetypováním, pokud je struktura jako první prvek. Schválně jsem to navrhl tímto stylem, abych se vyhnul extra alokacím. Strukturu JRPollable tedy vlastní samotný objekt, nikoliv ten epoll wrapper. Abych dosáhl tedy rychlejšího remove, tak se zdá, že se extra alokacím wrapperům nevyhnu, budu muset udržovat list odebraných položek a ty uvolňovat na konci cyklu, až projdu všechny položky.
Tiskni
Sdílej: