Vítejte na Elektro Bastlírn?
Nuke - Elektro Bastlirna
  Vytvořit účet
Hlavní · Fórum · DDump · Profil · Zprávy · Hledat na fóru


Nuke - Elektro Bastlirna: Diskuzní fórum

 FAQFAQ   HledatHledat   Uživatelské skupinyUživatelské skupiny   ProfilProfil   Soukromé zprávySoukromé zprávy   PřihlášeníPřihlášení 

Synchronizácia kódovania MFM

 
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů
Zobrazit předchozí téma :: Zobrazit následující téma  
Autor Zpráva
rampage



Založen: Jan 12, 2025
Příspěvky: 242

PříspěvekZaslal: st únor 04 2026, 16:28    Předmět: Synchronizácia kódovania MFM Citovat

Touto témou tu asi rúbem hodne vysoko, každopádne... napadlo mi že sa opýtam človečiny, pretože už ma nebaví čítať fabulácie umelej idiocie Very Happy No a problém bude určite riešiteľný elektronicky.

Mám bastl s Arduinom, ktorý na jednom plošáku obsahuje pokusne rozbehaný radič harddiskov. Prehistorických, MFM. Sú tam dva hlavné čipy; jeden je sekvencer (nepodstatný) a ten druhý synchronizátor dát. Obidva vytiahnuté zo starej ISA karty. Prezrel som im datasheety, zistil, že sa dajú "programovať", tak reku vyskúšam ich. Fungujú. Som schopný pracovať s dinosaurami ktoré boli sformátované na radičoch Westen Digital, OMTI a podobne. /Je mi jasné, že univerzálnejší radič/emulátor už niekto vyvinul predo mnou - beriem to ako výzvu zo "šuflíkových" súčiastok./

A teraz kameň úrazu, kde to nefunguje, a kde by som to chcel vyriešiť.
Použitý dekodér/synchronizátor MFM dát je Silicon Systems 32D534.
Ako i iné radiče, pred tým než môže začať čítať, sa musí na dáta z disku správne zasynchronizovať fázový záves (PLL). A to na hranici bajtu, aby neboli jednotlivé bity poposúvané, alebo povypadávané.
To sa u týchto diskov riešilo tzv. adresnou značkou - zápisom A1, teda postupnosťou 10100001 s jedným MFM clock bitom vynechaným. Tesne pred touto postupnosťou sa nachádza súvislý rad nulových bitov, ktoré slúžia ako indikátor "zachvíľu začnú data". Tento rad sa nazýva "preambula" a býva obvykle 10-13 bajtov dlhý (80-100 nulových bitov).

No - a tento huncút správne funguje iba s takými formátmi, kde sa do tzv. tolerančných medzier disku (umelo vytvorených, aby sa vykompenzovalo kolísanie otáčok), pri formátovaní zapisovali nenulové hodnoty. Akékoľvek, len hlavne nenulové. Pretože po nich nasledujú už záhlavia sektorov.
Ak sú to nuly, tak ten MFM deserializér to začne považovať ako preambulu - istý čas, než to vzdá, vyresetuje sa a začne odznova. A zrovna vtedy preletí A1čku - sekvencer nedostane signál a sektor som nenašiel.
A just som musel taký formát objaviť, SMEP - made in Czechoslovakia. Asi nemali nemali valuty na západný radič, takže to činilo jeden kompletný, škaredý, hradlový orloj, ktorý im dovolil takéto zhovadilosti. Okrem toho dali tú preambulu dlhú (až 16 bajtov).

Tým, že fázový záves po správnom zasynchronizovaní iné formáty číta dobre (PC), si hovorím že jedine ako toto by možno šlo elektricky doladiť, je upraviť časovanie preambule - dať snáď volajaký viacotáčkový trimer do 1FS? Prípadne ešte pre IREF, len s tým to rozhasím asi úplne... Rýchlosť dát je 5Mbps.


Ešte som skúšal takú z núdze cnosť a to vypnúť vyhladávanie preambule/adresnej značky a proste zasynchronizovať hneď po hradlovaní READ GATE; v tom datasheete sa to volá Direct Sync Mode.
Následne zaserializovať bajty do binárnej podoby (do textového reťazca jedničiek a núl) a tam hladať správnu bitovú postupnosť - následne ju textovo "urezať" tam kde to začína. Takto "opravenú" potom deserializovať spátky na bajty.
A ak nesedí CRC, proste repete. Pretože sa to väčšinou striafa do A1čiek v datach, a nie v záhlaví, za preambulou.
No... lenže okrem toho že je takáto zhovadilosť na Arduine pomalá jak pi​ča, beztak toto neprečíta kompletnú stopu. Iba nejakých 10-12 sektorov zo 17tich, pretože to neni iba bitový posun - zlým zasynchronizovaním bity vedia vypadnúť - úplne. Potom nenájde postupnosť bitov, a som nahratý. A to tam mám asi 50 pokusov pred tým, než prehlásim že ten sektor na disku neni Very Happy

To je zase špalek. Napadá niekoho niečo? Vysr​ať sa na to úplne?
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
ondraN



Založen: Aug 16, 2022
Příspěvky: 880
Bydliště: Roztoky

PříspěvekZaslal: st únor 04 2026, 18:51    Předmět: Citovat

Pokud si to dobře pamatuji, tak se na čtení a zapisování dat používalo RLL kódování, takže tam nemohl být větší nulový blok, než je definováno v typu kódu.
https://en.wikipedia.org/wiki/Run-length_limited
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Odeslat e-mail
Zobrazit příspěvky z předchozích:   
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů Časy uváděny v GMT + 1 hodina
Strana 1 z 1

 
Přejdi na:  
Nemůžete odesílat nové téma do tohoto fóra.
Nemůžete odpovídat na témata v tomto fóru.
Nemůžete upravovat své příspěvky v tomto fóru.
Nemůžete mazat své příspěvky v tomto fóru.
Nemůžete hlasovat v tomto fóru.
Nemůžete připojovat soubory k příspěvkům
Můžete stahovat a prohlížet přiložené soubory

Powered by phpBB © 2001, 2005 phpBB Group
Forums ©
Nuke - Elektro Bastlirna

Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.


PHP-Nuke Copyright © 2005 by Francisco Burzi. This is free software, and you may redistribute it under the GPL. PHP-Nuke comes with absolutely no warranty, for details, see the license.
Čas potřebný ke zpracování stránky 0.14 sekund