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 01:33 | Pozvánky
Konference Prague PostgreSQL Developers Day 2015 se uskuteční ve dnech 11. a 12. 2. 2015 v Praze (místo bude upřesněno). Letošní konferenci plánujeme jako dvojdenní - první den (středa 11.2.) se budou konat školení, druhý den (12.2.) bude mít podobu "tradiční" konference. … více »
TomasVondra | Komentářů: 0
včera 22:39 | Pozvánky
Už tuto sobotu se na půdě FIT ČVUT v pražských Dejvicích uskuteční další konference Internet a Technologie (IT 14.2). Pro ty, kteří se akce nemohou zúčastnit, připravili organizátoři na internetové adrese www.nic.cz/it14.2 živý přenos. … více »
Vilem Sladek | Komentářů: 0
včera 14:10 | Nová verze
Laboratoře CZ.NIC vydaly další testovací verzi (0.2.0) desktopové aplikace Datovka, která plně nahrazuje starší Datovku napsanou v jazyce Python. Verze 0.2.0 přináší plnou podporu ověřování podpisů zpráv a časových značek. Dále umožňuje stahování zpráv a příloh na pozadí aplikace, přičemž v seznamu zpráv je ikonou zobrazováno, zda již byly přílohy staženy či nikoliv. Uživatel také může k jednotlivým zprávám přiřazovat stav jejich … více »
Vilem Sladek | Komentářů: 17
včera 09:48 | Pozvánky
Z cyklu prednášok Confused Coder nám Tomáš Kulich 2.decembra v SPOTe v Bratislave o 19:00 porozpráva nasledovné: … více »
Vacuumlabs | Komentářů: 2
26.11. 23:38 | Bezpečnostní upozornění
Společnost Adobe vydala záplatu APSB14-26 pro kritickou zranitelnost (CVE-2014-8439) nalezenou v Adobe Flash Playeru. Zranitelnost postihuje všechny verze Flash Playeru a Adobe AIR na Windows, Macu a Linuxu. Zranitelnost už prý také byla použita "in the wild". [CSIRT.CZ]
Ladislav Hagara | Komentářů: 4
26.11. 22:58 | Bezpečnostní upozornění
V některých linuxových distribucích může být problém s implementací příkazu less, který volá přes skripty další utility, které nebyly nikdy zamýšleny k prohlížení nedůvěryhodných souborů z internetu. [CSIRT.CZ]
Ladislav Hagara | Komentářů: 8
25.11. 08:54 | Humor
Neil McGovern, aktivní vývojář Debianu, zveřejnil na svém blogu příběh Barbie, vývojářky Debianu začínající: Jednou se Barbie, vývojářka Debianu, rozhodla, že do Debianu přidá nový init nazvaný systemd, myslela si, že to všichni ocení. Jedná se o modifikaci doprovodné knihy vydané k panence Barbie, můžu být počítačovou inženýrkou (Wikipedia). V knize se píše například, že Barbie počítačovou hru jenom navrhla, naprogramovat ji už … více »
Ladislav Hagara | Komentářů: 46
24.11. 22:51 | Komunita
Na konferenci Meet BSD California 2014 přednesl Jordan Hubbard, spoluzakladatel FreeBSD, svůj pohled na budoucí vývoj FreeBSD (video, prezentace). Přál by si otevřenost novým přístupům a ochotu k přebírání fungujících věcí odjinud. Vyjádřil i potřebu systému správy služeb po vzoru launchd nebo systemd.
michich | Komentářů: 37
22.11. 22:30 | Zajímavý projekt
Steve Chamberlin představil (YouTube) svůj malý počítač s Linuxem, jenž pojmenoval 68 Katy. Jádrem počítače postaveného na nepájivém poli (breadboard) je procesor Motorola 68008. [Slashdot]
Ladislav Hagara | Komentářů: 32
21.11. 08:57 | Zajímavý článek
Na titulnej stránke slashdotu dnes nájdete aj správičku o Vojtěchovi Pavlíkovi. Patrí mu uznanie za vedúcu rolu v SUSE Labs a projekty, ako sú kGraft (patchovanie jadra za behu) a bootovanie počítačov zamknutých pomocou secure boot. Pôvodný článok o Vojtěchovi Pavlíkovi nájdete na IT Wire. Gratulujeme.
rastos | Komentářů: 21
Disketu jsem naposledy použil během
 (47%)
 (3%)
 (11%)
 (37%)
 (2%)
Celkem 1215 hlasů
 Komentářů: 42, poslední včera 11:17
Rozcestník
Reklama
Autoškola testy online Levný benzín

Oprava Yakumo QuickStick DVB-T pod linuxem

26.9.2010 14:26 | Přečteno: 1155× | 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: 29 | 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.
帮帮我,我被锁在中国房 | Opensource 32bit osmijádro
Jendа avatar 26.9.2010 15:18 Jendа | skóre: 68 | 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?
Petr Tomášek avatar 26.9.2010 15:39 Petr Tomášek | skóre: 33 | 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: 29 | 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.
帮帮我,我被锁在中国房 | Opensource 32bit osmijádro
Petr Tomášek avatar 26.9.2010 16:50 Petr Tomášek | skóre: 33 | 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: 19 | 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   Powered by Hosting 90 Server hosting
© 1999-2013 Argonit s. r. o. Všechna práva vyhrazena.