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í
×

včera 23:44 | Komunita

Několik posledních verzí GNOME Shellu obsahuje chybu způsobující memory leak (únik paměti). Viz například videozáznamy verzí 3.26 nebo 3.28. Nalezení chyby #64 a její opravě se věnuje Georges Basile Stavracas Neto v příspěvku na svém blogu [reddit].

Ladislav Hagara | Komentářů: 0
včera 10:33 | Komunita

V pondělí měl na YouTube online premiéru otevřený krátký 2D film Hero vytvořený v 3D softwaru Blender. Cílem stejnojmenného projektu Hero je vylepšit nástroj Grease Pencil (tužka) v Blenderu 2.8.

Ladislav Hagara | Komentářů: 3
20.4. 23:22 | Nová verze

Byla vydána verze 4.0 kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Přehled novinek v Changelogu (GitHub).

Ladislav Hagara | Komentářů: 0
20.4. 17:22 | Komunita

Včera vydanou hru Rise of the Tomb Raider pro Linux lze do pondělí 23. dubna koupit na Steamu s 67% slevou. Místo 49,99 € za 16,49 €.

Ladislav Hagara | Komentářů: 0
20.4. 16:11 | Komunita

Na Humble Bundle lze získat počítačovou hru Satellite Reign (Wikipedie, YouTube) běžící také v Linuxu zdarma. Speciální akce končí v sobotu v 19:00.

Ladislav Hagara | Komentářů: 5
20.4. 15:44 | Zajímavý software

Společnost Apple koupila před třemi lety společnost FoundationDB vyvíjející stejnojmenný NoSQL databázový systém FoundationDB (Wikipedie). Včera byl tento systém uvolněn jako open source pod licencí Apache 2.0. Zdrojové kódy jsou k dispozici na GitHubu.

Ladislav Hagara | Komentářů: 0
20.4. 15:00 | Nová verze

Po dva a půl roce od vydání verze 5.7 oznámila společnost Oracle vydání nové major verze 8.0 (8.0.11) databázového systému MySQL (Wikipedie). Přehled novinek v poznámkách k vydání. Zdrojové kódy komunitní verze MySQL jsou k dispozici na GitHubu.

Ladislav Hagara | Komentářů: 2
19.4. 14:44 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 151. brněnský sraz, který proběhne v pátek 20. 4. od 18:00 hodin v restauraci Benjamin na Drobného 46.

Ladislav Hagara | Komentářů: 0
19.4. 13:33 | Nová verze

Byla vydána verze 18.04.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi.

Ladislav Hagara | Komentářů: 0
19.4. 13:11 | Nová verze

Bylo oznámeno vydání nové stabilní verze 1.26 a beta verze 1.27 open source textového editoru Atom (Wikipedie). Přehled novinek i s náhledy v příspěvku na blogu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
Používáte na serverech port knocking?
 (3%)
 (7%)
 (46%)
 (27%)
 (17%)
Celkem 342 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    Rozcestník

    Oprava Yakumo QuickStick DVB-T pod linuxem

    26.9.2010 14:26 | Přečteno: 1262× | 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: 35 | 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: 74 | blog: Výlevníček | 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?
    Cestovat na exkurzi z Ochrany ovzduší se bude autem, na naftovném se domluvíme s vrchním dovozcem.
    Petr Tomášek avatar 26.9.2010 15:39 Petr Tomášek | skóre: 37 | 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)
    26.9.2010 15:30 pc2005 | skóre: 35 | 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: 37 | 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...
    Grunt avatar 26.9.2010 18:58 Grunt | skóre: 22 | 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.