Grafický správce balíčků Myrlyn pro SUSE a openSUSE, původně YQPkg, dospěl do stabilní verze 1.0.0. Postaven je nad libzypp a Qt 6. Projekt začal na SUSE Hack Weeku 24.
Vývojáři se podařilo vytvořit patch pro Wine, díky kterému je možné na linuxovém stroji nainstalovat a spustit Adobe Photoshop (testováno s verzemi Photoshopu PS2021 a PS2025). Dalším patchem se podařilo umožnit dokonce instalaci téměř celého Adobe Creative Cloud Collection 2023, vyjma aplikací Adobe XD a Adobe Fresco. Patch řeší kompatibilitu s windowsovými subsystémy MSHTML - jádrem prohlížeče Internet exporer, a MSXML3 - parserem
… více »Hackeři zaútočili na portál veřejných zakázek a vyřadili ho z provozu. Systém, ve kterém musí být ze zákona sdíleny informace o veřejných zakázkách, se ministerstvo pro místní rozvoj (MMR) nyní pokouší co nejdříve zprovoznit. Úřad o tom informoval na svém webu a na sociálních sítích. Portál slouží pro sdílení informací mezi zadavateli a dodavateli veřejných zakázek.
Javascriptová knihovna jQuery (Wikipedie) oslavila 20. narozeniny, John Resig ji představil v lednu 2006 na newyorském BarCampu. Při této příležitosti byla vydána nová major verze 4.0.0.
Singularity je rootkit ve formě jaderného modulu (Linux Kernel Module), s otevřeným zdrojovým kódem dostupným pod licencí MIT. Tento rootkit je určený pro moderní linuxová jádra 6.x a poskytuje své 'komplexní skryté funkce' prostřednictvím hookingu systémových volání pomocí ftrace. Pro nadšence je k dispozici podrobnější popis rootkitu na blogu autora, případně v článku na LWN.net. Projekt je zamýšlen jako pomůcka pro bezpečnostní experty a výzkumníky, takže instalujte pouze na vlastní nebezpečí a raději pouze do vlastních strojů 😉.
Iconify je seznam a galerie kolekcí vektorových open-source ikon, ke stažení je přes 275000 ikon z více jak dvou set sad. Tento rovněž open-source projekt dává vývojářům k dispozici i API pro snadnou integraci svobodných ikon do jejich projektů.
Dle plánu certifikační autorita Let's Encrypt nově vydává také certifikáty s šestidenní platností (160 hodin) s možností vystavit je na IP adresu.
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 14.0 (Mastodon). Forgejo je fork Gitei.
Just the Browser je projekt, 'který vám pomůže v internetovém prohlížeči deaktivovat funkce umělé inteligence, telemetrii, sponzorovaný obsah, integraci produktů a další nepříjemnosti' (repozitář na GitHubu). Využívá k tomu skrytá nastavení ve webových prohlížečích, určená původně pro firmy a organizace ('enterprise policies'). Pod linuxem je skriptem pro automatickou úpravu nastavení prozatím podporován pouze prohlížeč Firefox.
Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <usb.h>
void usage() {
fprintf(stderr, "Usage: yakumo-repair <old_vid:old_pid> <new_vid:new_pid>\n");
fprintf(stderr, "You have to download Vend_ax.hex (using e.g. cycfx2prog) first!\n");
exit (-1);
}
unsigned int vid_o, pid_o, vid_n, pid_n;
void repair (struct usb_device *dev, usb_dev_handle *h) {
unsigned char buffer[256], b2[256];
int i,n,ok;
n=usb_control_msg(h, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_ENDPOINT_IN,
0xa2, 0, 0, (char *)buffer, sizeof(buffer), 5000);
printf ("EEPROM READ: [%d]\t", n);
if (n) for (i=0; i<n; i++)
{
printf(" %02x", buffer[i]);
}
printf ("\n");
if (n!=256)
{
fprintf (stderr, "Error reading EEPROM!\n");
return;
}
if (
(buffer[1]==(vid_o%0x100)) &&
(buffer[2]==(vid_o/0x100)) &&
(buffer[3]==(pid_o%0x100)) &&
(buffer[4]==(pid_o/0x100))
)
{
printf ("... old VID/PID OK! Trying to overwrite VID/PID in EEPROM...\n");
// set new VID/PID into the buffer!
buffer[0]=0xc0;
buffer[1]=(vid_n%0x100);
buffer[2]=(vid_n/0x100);
buffer[3]=(pid_n%0x100);
buffer[4]=(pid_n/0x100);
n=usb_control_msg(h, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_ENDPOINT_OUT,
0xa2, 0, 0, (char *)buffer, 5, 5000);
printf ("... written %d bytes...\n", n);
printf ("Verifying...\n");
n=usb_control_msg(h, USB_TYPE_VENDOR | USB_RECIP_DEVICE | USB_ENDPOINT_IN,
0xa2, 0, 0, (char *)b2, sizeof(b2), 5000);
if (n!=256)
{
fprintf (stderr, "Error reading EEPROM!\n");
return;
}
ok=1;
for (i=0; i<n; i++)
if (buffer[i]!=b2[i]) ok=0;
printf (ok?"Verified, OK!\n":"Error occured!\n");
}
else
fprintf (stderr, "VID/PID in EEPROM don't match! Skipping...");
}
int main (int argc, char **argv) {
struct usb_bus *bus;
struct usb_device *dev;
usb_dev_handle *handle = NULL;
if (argc!=3) usage();
sscanf(argv[1], "%x:%x", &vid_o, &pid_o);
sscanf(argv[2], "%x:%x", &vid_n, &pid_n);
if ((vid_o>0xffff) || (pid_o>0xffff) || (vid_n>0xffff) || (pid_n>0xffff)) usage();
printf ("\nRepairing: [%04x:%04x] => [%04x:%04x]\n\n", vid_o, pid_o, vid_n, pid_n);
usb_init();
usb_find_busses();
usb_find_devices();
for (bus=usb_get_busses(); bus; bus=bus->next)
{
for (dev=bus->devices; dev; dev=dev->next)
{
if ((dev->descriptor.idVendor==vid_o) && (dev->descriptor.idProduct==pid_o))
{
handle=usb_open(dev);
if (!handle)
printf("Error opening [%04x:%04x]!\n", vid_o, pid_o);
else
{
printf("Found [%04x:%04x]: trying to repair ----------------\n", vid_o, pid_o);
repair(dev, handle);
}
}
}
}
return 0;
}
V adresáři rovněž vytvoříme soubor Makefile a do něj dáme:
BIN=/usr/bin USBFLAGS = `libusb-config --cflags` USBLIBS = `libusb-config --libs` CC = gcc CFLAGS = $(USBFLAGS) -O3 -Wall LIBS = $(USBLIBS) PROGRAM=yakumo-repair all: $(PROGRAM) .c.o: $(CC) $(CFLAGS) -c $< $(PROGRAM): $(PROGRAM).o $(CC) -o $(PROGRAM) $(PROGRAM).o $(LIBS) strip: $(PROGRAM) strip $(PROGRAM) install: strip cp -f $(PROGRAM) $(BIN) clean: rm -f *.o $(PROGRAM)Program zkompilujeme pomocí 'make'.
./cycfx2prog -id=14ee:0225 prg:Vend_ax.hex runProgram vypíše něco jako:
Using ID 14ee:0226 on 001.014. Putting 8051 into reset. Programming 8051 using "Vend_ax.hex". Putting 8051 out of reset.Poté spustíme náš program se dvěma parametry: prvním je současný (nekorektní) pár VID/PID, druhým je opravený VID/PID:
./yakumo-repair 14ee:0225 14aa:0225Program vypíše:
Repairing: [14ee:0225] => [14aa:0225] Found [14ee:0225]: trying to repair ---------------- EEPROM READ: [256] c0 ee 14 25 02 00 00 08 ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ... old VID/PID OK! Trying to overwrite VID/PID in EEPROM... ... written 5 bytes... Verifying... Verified, OK!Což znamená, že v tomto okamžiku by mělo být vše v pořádku, stačí adaptér odpojit a znovu zapojit a měl by znovu fungovat.
Tiskni
Sdílej:
.
.
odcihleníRDAA-81 pomocí JTAGu po těch peripetiích i napíšu, ale jak se dívám tak jsem pořád slabé máslo a ještě budu muset počkat na corovější zážitky.