Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).
V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.
Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.
O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).
Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.
Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.
Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Zdravím, chci alokovat paměť zarovnanou na cache line size, používám k tomu posix_memalign. Někdy však dojde k tomu, že přístup k části paměti, která alokovaná je, selže. Ukazuje to následující program (povinný argv[1] je kolikrát spustit alokaci):
#include<stdlib.h>
#include<stdio.h>
int main(int argc, char** argv){
int n=atoi(argv[1]), i, value;
for(i=0; i<n; i++){
int* addr;
int succ=posix_memalign((void**)&(addr),64,64);
if(succ!=0) { fprintf(stderr,"Allocation error."); return 1; }
value=*(int*)(addr+(64-sizeof(int)));
// fprintf(stderr,"%p:%d\n",addr,value);
}
}
Jestli tomu správně rozumím, tak posix_memalign by mělo alokovat 64b paměti zarovnaných na 64b. Pokusím se potom přistoupit ke konci alokovaného kusu přes *(int*)(addr+64-sizeof(int)), což by mělo vzít konec alokovaného úseku jako int.
Bohužel když program pustím, tak při větším poštu cyklů (argv[1]) se vyseká se segmentation fault. Vyzkoušel jsem, že pomůže alokovat větší množství pamětí (např. 96, třetí argument posix_memalign), ale nerozumím proč to tak je.
Poradí mi někdo v čem je problém?
Díky moc. Venca
Řešení dotazu:
addr+1 dá adresu (void*)addr+1*sizeof(int).
Tiskni
Sdílej: