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 05:11 | Nová verze

    OCCT3D (Open CASCADE Technology) Open Source 8.0 bylo vydáno. OCCT3D (Wikipedie, GitHub) je objektově orientovaná knihovna pro 3D CAD, CAM nebo CAE. Používá se například v softwarech FreeCAD a KiCad.

    Ladislav Hagara | Komentářů: 2
    včera 02:22 | Bezpečnostní upozornění

    Ve FreeBSD byla nalezena a již opravena 21letá zranitelnost CVE-2026-42511 v dhclient. Jedná se o vzdálené spuštění kódu (RCE). Útočník mající pod správou DHCP server může získat plnou kontrolu nad systémem FreeBSD pouze jeho připojením k místní síti.

    Ladislav Hagara | Komentářů: 0
    9.5. 17:22 | 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.

    Ladislav Hagara | Komentářů: 0
    9.5. 00:11 | Nová verze

    UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.

    Ladislav Hagara | Komentářů: 0
    8.5. 17:11 | Zajímavý projekt

    Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).

    |🇵🇸 | Komentářů: 0
    8.5. 03:33 | Zajímavý článek

    Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    7.5. 22:55 | Bezpečnostní upozornění

    Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].

    Ladislav Hagara | Komentářů: 9
    7.5. 14:00 | Humor

    Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.

    Ladislav Hagara | Komentářů: 11
    7.5. 05:11 | Nová verze

    Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.

    Ladislav Hagara | Komentářů: 0
    7.5. 05:00 | Nová verze

    Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (25%)
    Celkem 1570 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: 1561× | 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.