Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.
Linuxová distribuce Frugalware (Wikipedie) ke konci roku 2025 oficiálně končí.
Byla vydána nová verze 3.0.6 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP bude brzy k dispozici také na Flathubu.
Americký výrobce čipů AMD uzavřel s americkou společností OpenAI smlouvu na několikaleté dodávky vyspělých mikročipů pro umělou inteligenci (AI). Součástí dohody je i předkupní právo OpenAI na přibližně desetiprocentní podíl v AMD.
Byla vydána nová verze 10.1 sady aplikací pro SSH komunikaci OpenSSH. Uživatel je nově varován, když se nepoužívá postkvantovou výměnu klíčů.
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: