abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 13:33 | Komunita

    Software Freedom Conservancy v novém dokumentu shrnuje doporučení, jak přistupovat ke generativní AI založené na LLM při přispívání do svobodného a open-source softwaru. Mimo jiné vyzývá k obezřetnosti, transparentnosti a revizi generovaného kódu člověkem.

    |🇵🇸 | Komentářů: 0
    dnes 13:22 | Nová verze

    Byla vydána nová verze 5.6.0 programu na úpravu digitálních fotografií darktable (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    včera 20:11 | Komunita

    Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma. V Týdnu v GNOME je zmíněn flatpak balíček pro GIMP 0.54.1 z roku 1996. Jedná se o poslední verzi GIMPu postavenou nad toolkitem Motif.

    Ladislav Hagara | Komentářů: 0
    včera 19:11 | Nová verze

    Home Assistant Operating System, tj. linuxová distribuce optimalizována pro hostování Home Assistanta a jeho aplikací, byl vydán v nové major verzi 18.0.

    Ladislav Hagara | Komentářů: 0
    včera 18:11 | Komunita

    Po šestiletém úsilí byla z jádra Linux odstraněna funkce strncpy(). Všechna předchozí volání této funkce byla převedena na bezpečnější alternativy.

    Ladislav Hagara | Komentářů: 1
    včera 17:22 | Nová verze

    Byla vydána nová verze 261 správce systému a služeb systemd (Wikipedie, GitHub). Z novinek lze vypíchnout nový subsystém IMDS (Cloud "Instance Metadata Service"), nový příkaz storagectl nebo novou komponentu systemd-sysinstall.

    Ladislav Hagara | Komentářů: 3
    včera 12:00 | Nová verze

    Vývojové prostředí Qt Creator bylo vydáno ve verzi 20 (seznam změn). Novinky zahrnují hlavně rozšíření pro integraci LLM agentů nebo minimalistický editační režim uživatelského rozhraní („zen mode“).

    |🇵🇸 | Komentářů: 0
    19.6. 10:22 | Humor

    Už jste se prolétli na webu Google Earth? Přibyl tam Simulátor letu (Nástroje / Simulátor letu). Funguje i bez účtu Google [𝕏].

    Ladislav Hagara | Komentářů: 0
    19.6. 09:55 | Nová verze

    Byla vydána nová verze 4.7 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 3
    18.6. 13:33 | Nová verze

    Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.6. Přehled novinek s náhledy v oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1953 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Oprava Yakumo QuickStick DVB-T pod linuxem

    26.9.2010 14:26 | Přečteno: 1582× | Hardware | poslední úprava: 26.9.2010 18:16

    Jak jste si možná někteří všimli, hledal jsem tu před pár dny pomoc ohledně svého chcíplého USB televizního adaptéru „Yakumo QuickStick DVB-T“. Na základě odpovědí v poradně, trochy googlování a kapky programování se mi podařilo zmíněný adaptér nakonec úspěšně přívést znovu k životu a to sice bez použití Windows. Zde je návod, co s tím.

    Problém

    Začněme s krátkým popisem toho, co se vlastně adaptéru stalo. Zřejmě při jeho vytahováni z USB portu došlo k poškození dat na EEPROM. Těmito daty přitom jsou VID/PID (Vendor ID/Product ID) pod kterými se USB stick hlásí počítači. Konkrétně mně se VID/PID změnilo z 14aa:0225 ⇒ 14ee:0225 (čili se nastavili - což se de fakto rovná u EEPROM vynulování - dva bity jednoho bajtu). Důsledek: OS nenašel k adaptéru správný ovladač a nic se tedy nedělo.

    Řešení

    Na řešení mě navedli diskutující v poradně, kteří mě odkázali na tento blog. Řešení spočívalo v tom, využít pod Windows speciální vývojové prostředí pro platformu, na které je USB stick založen, pomocí ní do něj nahrát speciální firmware, které umožňuje manipulaci s EEPROM a potom přes toto vývojové prostředí ručně poslat příslušné USB příkazy.

    Jelikož Windows momentálně nemám po ruce, rozhodl jsem se, že se pokusím o stejnou věc, ale čistěji a pod linuxem.

    Co budeme potřebovat

    K „odcihlení“ adaptéru budeme potřebovat a) onen speciální FW pro komunikaci s EEPROM, b) linuxový program, který jej do adaptéru nahraje, c) (náš) linuxový program, který bude s tímto FW komunikovat a pomocí něj korektně nastaví VID/PID v EEPROM adaptéru.

    Ad a): Firmware se jmenuje Vend_Ax.hex a stáhneme jej například odtud.

    Ad b): utilitka pro nahrání firmware se jmenuje cycfx2prog a najdeme ji této stránce. (Klasicky rozbalíme a skompilujeme pomocí 'make').

    Ad c): Vytvoříme adresář a v něm vytvoříme soubor yakumo-repair.c s následujícím obsahem:
    
    #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'.

    Jak na to?

    Nejprve nahrajeme do adaptéru firmware pro práci s EEPROM (nyní spouštíme vše pod rootem!):
    ./cycfx2prog -id=14ee:0225 prg:Vend_ax.hex run
    
    Program 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:0225
    
    Program 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.        

    Hodnocení: 89 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    26.9.2010 14:31 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Oprava Yakumo QuickStick DVB-T pod linuxem
    Wow tomu říkám podpora hardwaru, vývojové prostředí :-O. U některých hw by šlo tak maximálně změnit USB ID ve zdrojáku kernelu :-D.
    Jendа avatar 26.9.2010 15:18 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Oprava Yakumo QuickStick DVB-T pod linuxem
    Nebylo by jednodušší říct ovladači, aby používal i zařízení s tím rozhozeným ID?
    Petr Tomášek avatar 26.9.2010 15:39 Petr Tomášek | skóre: 39 | blog: Vejšplechty
    Rozbalit Rozbalit vše Re: Oprava Yakumo QuickStick DVB-T pod linuxem
    Jo a při dalším upgrade systému to budu muset dělat znova, že? (Navíc chci, aby mi stick fungoval na vícero počítačích)
    multicult.fm | monokultura je zlo | welcome refugees!
    26.9.2010 15:30 pc2005 | skóre: 38 | blog: GardenOfEdenConfiguration | liberec
    Rozbalit Rozbalit vše Re: Oprava Yakumo QuickStick DVB-T pod linuxem
    Rofl on mě přišel i mail z konference LinuxTV :-D.
    Petr Tomášek avatar 26.9.2010 16:50 Petr Tomášek | skóre: 39 | blog: Vejšplechty
    Rozbalit Rozbalit vše Re: Oprava Yakumo QuickStick DVB-T pod linuxem
    Předtím jsem se tam (byť bezúspěšně) ptal, tak mi přišlo slušné dát zprávu o tom, že jak jsem problém vyřešil...
    multicult.fm | monokultura je zlo | welcome refugees!
    Grunt avatar 26.9.2010 18:58 Grunt | skóre: 23 | blog: Expresivní zabručení | Lanžhot
    Rozbalit Rozbalit vše Re: Oprava Yakumo QuickStick DVB-T pod linuxem
    No LOL teda. A to já si myslel, že snad i něco málo o 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.
    Na co 64-bitů když to jde i s jedním? | 80.78.148.5 | Hack (for) free or Die Hard!

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.