Tag Archives: SOFT

Blogas GCC arba x86 bėdos

Papuolė į rankas tokia maža ISA PCB su keliais čipais. Su magišku užrašu “Y2000”. Ir iškarto trenkė nostalgija, apie tai, kaip visi panikavo, kad kompiuteriai 2000-taisiais metais išprotės, nes metai tik dviženklis skaičius. Aišku buvo bėdų su tais metais, bet daugelis panikuotojų nepagalvojo, kad technologija smarkiai tobulėja ir kompai pradėjo labai greitai morališkai senti.

O tiems, kurie strigo su sena technika, atsirado visokie BIOS pataisymai. O jei nėra BIOS pataisymo, va jums papildoma plokštė su ROM. (Kitos mikroschemos tik supaprastina ROM pajungimą prie ISA linijų)

Nutariau pažiūrėti, kas tos mikroschemos viduje. Viduje labai mažai kodo, tai buvo kaip tik, kad pasimokinti Hidros (GHIDRA) programos vartojimo.

ISA PCB yra 8 bitų. Vadinasi suderinama su pačiais primityviausiais x86 procesoriais. Vadinasi kiek rimtesni procesoriai turi veikti “REAL MODE” režime. x86 procesoriaus kodas vos vos panašus į Z80 ir tikrai panašus į 8086. Hidra išardė kodą. O internetai padėjo atpažinti- pirmi trys baitai tai 55 AA 10. “55AA” tai signatūra, o 10 tai programos ROM dydis (kart 512 baitų, h100). O nuo 4 baito prasideda pati programa.

Konkreti Y2K PCB darė šitą: išvalo ekraną (rodos), parašo užrašą, nuskaito dalį RAM ir kažką paskaičiuoją ir jei nepavyko, sako error ir išeina, nuskaito RTC per BIOS, nuskaito RTC tiesiogai, palygina, ir jei kažkas gaunasi arba rašo, kad kompas suderinamas su Y2K arba bando (?) pačinti BIOSą. Čia jau spėlioju, nes mano žinio gana trumpos čia.

Kilo mintis padaryti va taip:

Copy-paste kažkiek asemblerio mnemonikų… ir kaip sukompiliuoti? Internetai sako, kad standartinis GCC, su raktažodžiais tipo “-m16 -nostdlib -ffreestanding” turi gaminti x86, 16bitų, REAL kodą. Ir tikrai, kopijuotas kodas iš Hidros susikompiliavo. Toliau teko kankintis su LD.exe ir visokiais loaderiais, kad gautųsi ROM image, o ne exe failas. Tai irgi buvo pilnas nuotykių žaidimas kuris nepavyko iki galo.

Tačiau kodas neveikė realiuose kompiuteriuose.

Ir pasirodo, kad JOKS GCC nesugeba generuoti teisingą 16 bitų, REAL MODE kodą. Iš principo. Binarinių failų palyginimas parodė, kad CALL, RETF ir gal kitokios instrukcijos generuojamas 32 bitų. Tas 32 bitų kodas “kaip ir suderinamas”, bet kai paleidi iš BIOSo, tai tikrai nesuderinamas. Ir nesvarbu koks procesorius- 486DX irgi nesuprato.

Rašyti softą be CALL kaip ir sunkoka. Gerai, kad čia tik kelios eilutės- išvalyti ekraną, per BIOSą (TTY režime) išspjauti tekstą ir nuskaityti ANYKEY iš klaviatūros. Teko viską perrašyti tiesiogiai. Ir rankutėmis įkelti “RETF” teisingą kodą programos gale. Kodu nesidalinu, nes jis baisus, nesuprantamas ir ten per daug POP/PUSH (kopijavau iš tikrų paprogramių, kur išsaugoja registrus). Svarbu veikia.

ROMas turi primityviausią kontrolinę, 8 bitų, sumą. Todėl reikią paskutinį baitą ROMe kaitalioti tol, kol suma nepasidaro 00.

O dar radau keistą PCI plokštę iš Izraelio- kažkoks tipo “security”. Pati PCB tai kastruota tinklo plokštė su BOOT ROM. Jei bus azarto, bus galima pasinagrinėti šitą kodą.

Taigi, be normalaus asemblerio, koduoti ROMą labai sunku. O tiek turėjau planų- panaudoti C kalbą ROMe ir PC kompiuterį panaudoti kaip mikrokontrolerį. Kam? Ogi smalsu. Nebent PCI kompiuteriai jau tikrai valgo 32 bitus ROMe.

O grynai asembleris tai NASM. Jam puikiausiai kompiliuojasi. Tikriausiai komentaruose bus pilnas komplektas NASM kompiliatoriui.

P.S. Originalus Y2000 ROMas.

Senobinis Cisco

Elektroninėse atliekose buvo atvežta gal paletė NOS1, nenaudotų, originaliose dėžutėse Cisco Access Pointų. Kelis paėmiau pabandyti ir mano nelaimei, pagal geras Cisco tradicijas, firmwarė viduje buvo “valdoma iš serverio”. T.y. tokia firmwarė, kuri skirta didelėm įmonėm, kur visokie prietaisai patogiai valdomi ir specialaus “kontrolerio” (serverio). Ir įjungimo metu, likusi firmwarė ir konfiguracija užsikrauna ir nieko nereikia individualiai konfiguruoti.

Pats AP gana elegantiškas, palaiko 2 ir 5G dažnius, POE ir panašiai. Patingėjau tada aš ieškoti kaip juos paleisti ir keliasdešimt jų išardė. Keli liko, ir iš neturėjimo ką veikti (ir su slaptais kėslais) aš nutariau perrašyti jų programinę įrangą į “user friendly” ir “Self containing”. Tam reikalui reikia Cisco serial kabelio (realiai kogero TTL lygio COM kabelis, netikras RS232). Netikėtai aš tokį kabelį turiu.

Nustatom kompiuterio IP adresą: 10.0.0.1 (255.255.255.0). Bet nežinau, ką padariau, kad mano laidinis ryšis turi du adresus:

Ethernet adapter Ethernet:
Connection-specific DNS Suffix . :
IPv4 Address. . . . . . . . . . . : 10.0.0.1
Subnet Mask . . . . . . . . . . . : 255.255.255.0
IPv4 Address. . . . . . . . . . . : 10.0.0.254
Subnet Mask . . . . . . . . . . . : 255.255.255.0
Default Gateway . . . . . . . . . : 10.0.0.2

Terminalas 9600.8.n.1, ir konsolėje matome informaciją, kaip kuriasi AP savo keistam režime.

Pasileidžiam, tftpd64. Pasididinam “timeout” iki kokių 30 sekundžių. DHCP nustatymuose parašom, kad duotų IP adresus tame pat potinklyje. Ir log langelyje matome, kad AP pasiėmė adresą. Nenustebkite, kad adresas kaitaliosis, čia greičiausiai Tftpd bėdos. Base aplankas nurodo į ten, kur yra firmware failai.

Terminale kartais reikia paspausti ENTER, kad atsirastu command promptas “>“.
Pirma komanda: enable
slaptažodis: Cisco
Jei AP jau turi kokią nors konfiguraciją, reikia nuspausti “mode” mygtuką, išjungti prietaisą ir vėl įjungti laikant mygtuką. Ir tik po kokių 20s, LEDas pasidarys raudonas, o terminale parašys, kad mygtukas nuspaustas, tada jį atleisti. Tada AP persikraus į avarinį “image” ir gal slaptažodis nusimuš.

Suveikus slaptažodžiui, AP command promptas pasidaro su “#“. Vadinasi dirbame “root” teisėmis.

sh ip int brief ← pasitikrinti ip. Šį komanda parodo, ar AP pasigavo adresą iš DHCP. Teoriškai galima rankomis nustatyti tą adresą terminale. Bet ten daug komandų. Paprasčiau vieną kartą susikonfiguruoti tftpd/dhcp ir viskas veikia.

Dabar kogero reikia parašyti šią komandą (arba sekančią), kad veiktu komanda “archive”. Kokią komandą? Priklauso nuo originalios firmwarės versijos.
debug lwapp console cli arba debug capwap console cli (c l i , i trumpoji)

Ir pats firmware įkrovimas. Pačios firmwarės jau nėra seniems prietaisams pas Cisco. Jie dėjo skersą ant savo senų produktų. Gal kokia webarchive gal rastumėt… Man padėjo guglės paieška ir kažkoks geras žmogus, kuris į githubą padėjo “testavimui” tuos image. Pasiguglinam apie firmwarės versijas ir kaip failai vadinasi. Mums reikia pilnaverčio, “standalone”, “self managable” failo. Nusikrautą imagę reikia pervadinti į defaultinį pavadinimą jei darome avarinį užkrovimą. Tačiau darant “mano” metodu, tereikia parašyti failo pavadinimą į komandinę eilutę:

archive download-sw /force-reload /overwrite tftp://10.0.0.1/c1130-k9w7-tar.tar

Poto bus siaubingai daug teksto terminale, ir tikrai palaukite iki galo. Pilnas softo perrašymas užtrunka kelias minutes. Palyginimui, palieku putty log failą. Ir aišku palieku tftpd log failą (ten pasimato, kokius failus AP bando nusikrauti). Ten matosi normalios AP užklausos viso proceso metu ir per pirmą normalų užsikrovimą.

Toliau užtenka eiti į naršyklę, suvesti DHCP priskirtą IP adresą ir konfiguruoti AP. Pirmo prisijungimo vartotojo vardas: Cisco, slaptažodis: Cisco

Sukonfiguruoti AP per WWW yra dar vienas tikras questas, nes Cisco pasistengė viską padaryti kaip galima sudėtingiau. Gal yra tokiems AP koks user friendly firmware?

  1. NOS, angl. New Old Stock. Nenaudoti, seni daiktai. ↩︎

Veikiantis CF kortelių pavertimas diskais

Kas nors kiek užsiima retro kompiuteriais, žino, kad seni mechaniniai diskai gali bet kuriuo momentų subyrėti. Arba jie labai cypia, ir kai kuriems žmonėms jau nebelaiko nervai.

Yra visiems žinomas būdas, kaip pereiti prie SSD sistemos. Seniems kompiuteriams su IDE lizdu tai ypač lengva, nes dar plačiai paplitusios CF kortelės turi būtent IDE interfeisą ir kompui jos atrodo kaip IDE diskas. Ypač geros “industrinės” CF kortelės, nes jos stipriai nebijo perrašymų. Ir aišku kažkaip jau taip atsitiko, kad vienu metu prisirinkau gal šimtą tokių kortelių. Kai kurios CF kortelės, ypač iš kokio CISCO įrenginio, kartais būna su “write protect”, bet dažniausiai jos pilnai ištrinamos.

Kaip naudotis? Pirmiausia reikia dviejų “hardwarių”- bet kokio USB-CF skaitytuvo ir CF-IDE adapterio.

Retro kompiuteris ir net du CF-IDE adapteriai (plačia jungtimi)

Toliau atrodo, kad viskas paprasta? Diskelis į kompą, fdisk, format /s ir t.t. Ogi ne. Kartai veikia, o kartais neveikia ir retro kompiuteris pakimba kraudamasis arba sako “missing operating system”. Nors BIOSas ir pamatė diską, ir net užkurus ir disketės kaip ir viskas gerai. Kankinausi kelias dienas, kol išmąsčiau kodėl neveikia (gal būt) ir kaip padaryti, kad veiktu.

Manau bėda tame, kad visokie MSDOS ir senieji DOS pagrindo windows ir kitokios operacinės sistemos labai jautrios ir kultūringos. Jos neištrina disko taip kaip reikia. Dažnai lieka keisti boot įrašai (nors fdisk /mbr) turėtu padėti. O dar lieka visokios nesąmonės pačiam diske. Ar net “FF” informacija. Ji kažkaip “klaidina” microsofto operacines sistemas.

Teoriškai turėtu padėti visokie “Rufus”, “rmprep” ar net “HP USB disk storage tools”… nieko jie nepadeda. Aš kalbu apie Windows 10 host kompiuterius.

Reikia daryti taip ir veiks (išbandyta su 1G ir 2G kortelėm). Pirmiausia reikia ištrinti esamas particijas (gal nereikia, bet geriau, nes kai diske nėra nieko- tada windows nesikiša su savo trigrašiu).

Pašalinam. Čia buvo “rufus” sukurta neveikianti particija (skirsnis). Toliau reikia su senu geru Win32 Disk Imager nuskaityti visą CF kortelę? Kam? Ogi 2GB kortelė viduje bus biški ne 2GB, o kažkiek kitaip. Nuskaitant pasidarom tikrą “fizinio disko” kopiją.

Nuskaitytą failą kietam diske galima iš karto pažymėti kaip kompresuojamą, tada disko failas bus mažytis.

Pasileidžiam programą HexEdit ir viską užnulinam. Tuos visus FF, jei kortelė nauja, ir visokias nesąmones, jei kortelė naudota. Tai svarbu dėl dviejų dalykų- MS DOS nehaliucionuos ir kartu disko image failas host kompiuteryje užims tik megabaitą.

Dabar reikia pasileisti nemokamą retro kompiuterių emuliatorių “PCem“:

Sukonfiguruojam panašios kartos kompiuterį į tą, kuriam ruošiam diską. Pasirenkam naujai pagamintą failą- visi CHS settingai nusistato automatiškai (galima užsirašyti, jei kompas ypač senas). Ir užsikuriam emuliatorių iš MSDOS 6.22 disketės.

Ir atliekam standartinius veiksmus:

  • fdisk /mbr -gal ir nereikia, jei diską užnulinį. Bet atsarga čia gėdos nedaro.
  • fdisk -grynai ir padalinam ar imam visą diską DOSui. RTFM.
  • perkraunam virtualų kompiuterį.
  • format c: /S -formatuojam C diską ir perrašom MSDOS paleidimą.
  • Jei reikia, perkopijuojam DOS disketės turinį: mkdir C:\DOS ir copy *.* C:\DOS
  • Galima pasibandyti kaip veikia kompiuteris iš disko image.

Perkopijuojam atgal disko image į CF kortelę. Paleidžiam retro kompiuterį:

Kas smagiausia, CF kortelė puikiausiai matosi ir šiuolaikiniam kompiuteryje- nėra bėdų su failų apsikeitimu (yra niuansu su ilgais failų vardais, bet čia jau kita tema).

ARM47 ir PID dalis #4

O dabar pašnekėsim apie STM32F4 serijos variantą ir source code. Pirmiausia- kodėl 4 serija? Todėl, kad tokia PCB pasitaikė po ranka. Ir tikrai ne dėl kažkokio mistinio FPU ar net DSP. Ir dar neaišku, ar mano turimas MCU yra originalas, o ne koks nors permarkiruotas šlamštas. Šaltinis solidus, bet kodėl jie juos išmetė? Reikia surasti kur nors panaudotą procesorių ir palyginti.

Source code yra sugeneruotas su CubeMX programa, kompiliuota su gcc. Ryšiai su kubiko paprogramėm tik per callback. Ir tai tik naudojam USB biblioteką (virtualus COM portas) ir taimerių pertraukimus. ADC skaitom blokavimo režime.

Pats PID skaičiavimas, float variantas visiškai toks pats kaip ir teoriniam variante:

float pid_generic(float measured, float setpoint, float amplif)
{
float output;
float deritative;
float error;
float proportional;
 
error = (setpoint - measured)/10;
proportional = error;
 
integral=integral + error * pid_dt;
deritative = (error - old_error) / pid_dt;
old_error = error;
 
output = (PID_KP * proportional + PID_KI * integral + PID_KD * deritative) * amplif;
 
return output;
}

Atsirado papildomas parametras “amplif” – tai bendro rezultato daugiklis, kaip ir sustiprinimas (ar susilpninimas). Teoriškai tą patį galima atlikti su pagrindiniais parametrais (P, I, D), bet taip lengviau priderinti prie “krosnelės” galingumo: kaitinimas dirba su integer skaičiais, ir PID rezultatas apsiapvalina. Taip prarandam “jautrumą”. Ir dar temperatūros parodymus pasmulkinam- tik dėl koeficientų.

uint32_t CalcTemp(void)
{
uint32_t a;
a=median_filter(adc_read_blocking(ADC_CHANNEL_4));
a=median_filter(adc_read_blocking(ADC_CHANNEL_4));
//a=median_filter(adc_read_blocking(ADC_CHANNEL_4));
// 786 - max t, 0.62V ->1655
// 3529 - kambario t, 2.83V -> 283
return (4096-a)/2; //12 bitų max apverčiam ir pašalinam LSB.
}
 

Dėl ADC blogumo, matuojam kelis kartus, invertuojam (dėl schemotechnikos išėjimas mažėja didėjant temperatūrai) ir pašalinam mažiausią bitą, nes jis rodo kvailystes. Funkcija “median filter” vogta iš interneto. Tai funkcija, kuri teoriškai turi išfiltruoti sporadiškus nukrypimus: jei eina 5, 6, 4, 3, 100 – tai tas šimtas kaip ir ne į temą. Kiek veikia per daug netikrinau. Manau, reikia dar padidinti buferį.

  1. readtemp=CalcTemp();
  2. pwm=PID(readtemp, SETTEMP);
  3. SetPWM(pwm);

O čia pats pagrindinis ciklas, kuris kartojamas sistemingai: 1 – nuskaitom, 2 – paskaičiuojam. 3 – valdom kaitinimą.

Visas likęs source kodas aptarnauja kontrolerio valdymą per terminalą (galima keisti parametrus) ir duomenų išmetimą analizei. Tai tik eksperimentinis variantas- darbiniam trūksta dar visokių apsaugų, normalaus valdymo ir indikacijos. Ir aišku, išėjimas čia PWM, kad tinkama mažam rezistoriui, bet ne tikram šildytuvui. Dar nesugalvojau, kaip padaryti korektiškai proporcinį valdymą realiai rėlei ar 50Hz simistoriniam reguliatoriui. Jei užteks kantrybės, tema bus vystoma.

Pats pilnas STM32F446 PID controller source code skirtas gcc ir kartu CubeMX projekto failas (versija užrakinta posto datai, galimi patobulinimai). Prie papildų- median filter, ftoa ir usb paprogramės. Visa mano kūryba “USER” aplanke.

PID, dalis #1

Teorija aišku. Kaip ir visi “interneto puslapiai” turiu įdėti šią formulę vogta iš vikipedijos…

PID

Tačiau tai paprasti puslapiai- mano “brain dump” t.y. čia bus neteisingas paaiškinimas kaip aš supratau.

Formulę susideda iš trijų dalių: prie Kp, Ki ir Kd.

Kp, tai proporcingas skaičius nuo klaidos. Išmatuojam sakysim temperatūrą, palyginam su reikiama, gaunam skirtumą ir jį naudojam rezultatui. Pats koeficientas Kp tai tik ant kiek jautriai reaguojam. Gaunasi- per šaltas, dar padidinam liepsną po puodu. Kuo skirtumas (klaida) mažesnė, tuo mažiau įtakoja. Gaunasi matematinis paradoksas, kad niekada nesigaus tiksli temperatūra. Aišku realiam pasaulyje dėl apvalinimo ir matavimo tikslumo, rezultatas pasiekiamas. Tačiau galimas didelis overšotas (per didelė temperatūra) arba labai lėtai pasiekiamas reikiamas rezultatas.

Ki, tai integralinė dalis. Čia kaupiasi klaida. Klaida turi ženklą (per karštá, per šaltá), o kai viskas gerai, tai klaida turi nusinulinti. Jei dėl kažkokių nors priežasčių tai nepavyksta, tai “likutinė” susikaupusi klaida priveda rezultatą prie teisybės. Įtariu, kad šita dalis “amortizuoja” reakciją.
Mano matematiniam modelyje, kai sistema stabilizuojasi, “integralo” reikšmė rodo mano teorinio šildytuvo išskirta energiją: (0.98 naudingumas, o integralas – 102. Čia 10.2W išskiriama energija, o 10W atšalimas). Čia kaip ir sistemos nuostoliai. Tuo tarpu Kp dalis jau nulinė, nes nebėra temperatūros skirtumo.

Kd, pati mistiškiausia, išvestinė dalis. Paprastai šnekant, tai kokiu greičiu kažkas keičiasi ir pagal tai bandom spėti kas bus ateityje. Kadangi formulė paprasta, tai spėjimas gali ir nepataikyti.

Visų šių parametrų suma ir yra reguliuojamas poveikis. Tačiau čia prasideda tiuninimas su koeficientais: Kp, Ki ir Kd. Visiškai nėra jokių universalių skaičių, kiekviena sistema turi savo skaičius. Žodis sistema reiškia ne tik matematinę formulę, bet ir visus fizinius parametrus ir bėdas: matavimo tikslumus, sistemos inerciją (tiek šildymo, tiek matavimo, tiek šildomo objekto). Yra net keli metodai, kaip koeficientus paskaičiuoti, bet geriausiai stebėti situaciją ir koeficientus pasitiuninti rankiniu metodu. Panaudojus neteisingus (dažniausiai per didelius) koeficientus, sistema gali “siubuoti” t.y. suptis kaip kokios supynės ir niekada nesusistabilizuotis. O per maži skaičiai labai pailgina sistemos reakcijos laiką. (nulinės reikšmės išjungia atitinkamas formulės dalis: taip gaunasi PI ir P kontroleriai.)

Formulė atrodo sudėtinga, bet čia tik dėl mandro užrašymo. Visual Basic kalboje tai viskas paprasčiau:

    Private Sub DoPID()
        P_error = setpoint - measured
        P_proportional = P_error
        P_integral = P_integral + P_error * pid_dt
        P_deritative = (P_error - P_previous_error) / pid_dt
        output = pid_kp * P_proportional + pid_ki * P_integral + pid_kd * P_deritative
        P_previous_error = P_error
    End Sub

Kaip ir viskas. Šią funkciją (paprogramę) reikia paleidinėti pastoviai, teoriškai kas “pid_dt” laiko tarpą. Tačiau tikslūs skaičiai reikalingi tik tada, kai skaičiuojam tikslius vatus ar džiaulius. Jei skaičiuojam santykiniais papūginiais vienetais, tai net “dt” galima išpaprastinti. Ir reikia išsaugoti dvi reikšmes sekančiam skaičiavimui: “P_previous_error” ir kaupiamąjį integralą “P_integral“.

Šiame matematiniam modelyje “output” gali būti ir neigiamas (čia gautusi kaip šaldymas), tačiau realiam pasaulyje šildymo elementas netik negali šaldyti, bet ir jo galingumas ribotas. Todėl programoje naikinam neigiamus skaičius ir ribojam maksimumą. Šie ribojimai visiškai neįtakoja funkcijos rezultato.

Pratesimas – 2 dalis.

PID, dalis #0

Pasišlykštėjęs kiniškų termokontroleriu nutariau kiek pasidomėti PID kontrolerio teorija. O tam reikėjo pasirašyti šildytuvo modelį (emuliatorių).

PID emuliatorius

Gavosi maždaug toks. Tai 100ml vandens kuris neverda (sferinio arklio vakuume) kaitintuvas su stabiliu aušinimu. Man tikrai patiko, kaip kontroleris reaguoja į netikėta aušinimo pastiprinimą ir kaip jis stabilizuojasi.

Kol kas tik tiek. Taip buvo pirmas vakaras. Pratesimas jau čia.

UPGRADE

Tai UPGRADE versija…[1.5.2 upgrading 2.1, 2.2, 2.2.3 -parėjo kategorijos, parėjo Lietuvių kalba. Error!, 2.3 error – teko perkelinėti per export/import XML. UTF8 upgrade, 2.3.3, 2.5, 2.6.1, 2.6.5, 2.7.1, 2.9.1, 3.0.1, 3.2.1, striginėjo -dingo administravimo puslapiai, 3.4.2, 3.8.1, 3.8.41, 4.0.38, 4.4.31, išsidrąsinau, 4.9.24, 5.0.20, 5.1.17, php versijos keitimas, fizinis serverio keitimas, duombazės eksportas, 6.xx versija. Daugiau nėra]

Dabar reikia surasti kokią nors normalią temą.

Serveriai

Čia senas ir naujas serveris. Technologijos tobulėja.

SHUTDOWNAS!

DĖMĖSIO! KONTROLIUOJAMAS ŠUTDAUNAS.

Kontroliuojamas šutdaunas baigtas. Sunaudotas koks kilometras optinio kabelio (x12 rodos), visos tarppastatinės linijos upgreidintos iki 1Gb/s. Gyvas velnias keitiklių ir biški mąstymo.
Šie puslapiai guli dabar ant žemės laboratorijoje. Kitas panašus daiGtas persikraustė į tikrą serverinę. Dar bus sutrikimų, kai telekomas darys savo “voice”, nes “niekas neparašė paraiškos” ir panašiai.

Šios žiemos planas- pilnas puslapių serverio upgreidas. Tiek geležis, tiek programinė pusė. Bet žiauriai tingiu.

Įdomus momentas- transportavimo metu serveris atliko šuolį laike ir kuri laiką rodė rodos 5 metų senumo informaciją. 🙂

2023.11.14:
Pradėjom migruoti į naują softą ir SSL variantą (https://www.vabolis.lt). Galimi puslapių sutrikimai. Per dešimtmečius iš esmės pasikeitė wordpress. Iš paprasto blogų rašymo įrankio konvertavosi į pilną ultra uždizaineriuotą CMS. Baisu.

2023.11.16:
“Specifinis” softas kuris sukosi ant senojo serverio tiesiogiai nesikelia į naują. Dėl PHP versijų kardinalaus pasikeitimo. Kromelis jau veikia abiem variantais http://kromelis.savel.org ir https://kromelis.savel.org

Gali kilti klausimų, kodėl čia taip sunkiai gaunasi. Ogi pabandykit paprastais metodais paleisti 80 ir 443 versijas ant skirtingų fiziškai serverių, kur visas softas skiriasi iš esmės. O visokie LetsEncrypt nori, kad sertifikatai instaliuotusi per 80, o veiktu per 443.

Iš juokingų nuotykių- niekada nepagelbėkite statybininkams. Žmogus atsakingas už video stebėjimo kamerų perkėlimą paėmė ir nukirpo optinį kabelį (gerai, kad seną), bet kartu nusikirpo visas savo kameras ir internetą griauname pastate. Dar rytoj turės viską suvirinti, nors kabelis bus naikinamas po mėnesio. Kodėl nukirpo? Ogi kažkoks statybininkas paprašė… 🙂

Ne emuliatorius!

Čia tikrai ne emuliatorius, o multifunkcinis vienetinis instrumentas….
Kažkada rašiau apie Z80 plokštę ir pramoninį kompiuterį. O dabar neturėjau ką veikti ir ištraukiau seną “toolsą”, kiek ji patobulinau ir pademonstruosiu. Tai tikrai ne ZX spectrum emuliatorius, nors jis tai gali daryti:
multifunkcinis Z80 daiGtas: ZX spectrum mode
Aišku taimingai neteisingi, kokios nors prigulnybės nepadarytos. Bet čia ne ZX emuliatorius, o Z80 debug įrankis. Nuo randomu internete jis skiriasi tuom, kad bet kuriu momentu galima bet ką sugadinti- perrašyti procesoriaus registrus, pakeisti RAM turinį (ar ROM), peršokti iš vieno procesoriaus emuliatoriaus į kitą. Čia iš esmės yra du “procikai”: loginis- kuris gal labiau intelio, Zilog režime jis neparašytas iki galo, nes man to nereikėjo. Ir “C-sharp”, tai procikas kurį radau internete.
Continue reading →

ZX klonų CP/M diskų žiūreklis

Atnešė diskelių kurie buvo rašyti su ZX klonu. Juos nuskaitėm su Greaseweazle, bet joks emuliatorius neleido paleisti CP/M iš disko kopijų. O ir šiaip, labai norėjosi ištraukti failus. Tačiau, nei vienas CP/M diskų analizatorius nematė failų- paprasčiausiai, mūsų “hakeriai” kai konstravo tą kastruotą CP/M kažką kitaip padarė. O “viešos” programos neleido modifikuoti disko sektorių struktūros.

Todėl teko pasirašyti nepilnai veikiančią programą:
CP/M ZX disk image browser
Diskai tai HD (80 takelių)*, 5 sektoriai takelyje (cilindre) ir 1024 baitai sektoriuje. Tačiau CP/M blokas yra 2048 baitų.

Dabartinė programa gali eksportuoti failus, tačiau kol kas nesugalvojau, kaip eksportuoti failus kurie surašyti kaip keli įrašai direktorijoje (failai didesnis nei 8*2048 baitai). Direktorija- 20 ir 21 sektorius.
Rodos pagal CP/M specifikacijas failo dydis aprašomas vienaip, tačiau mūsų “santakistai” kažkaip ignoravo tuos laukelius ir ten visur nuliai (arba aš dar nesupratau kaip). Taip pat kiek neaišku su failo ilgiu- CP/M rašo 128 baitų blokais, tačiau failai ne visada būna kartotini 128 baitams.
Svarbu, kad didžioji dalis unikalių failų išsitraukė.

Tačiau! Kitas žmogus atnešė irgi “santakos diskelių” su CP/M ir jie vėl kitokie! Gal vėliau išgaminsim ir jiems programą ir patobulinsim šią. Tačiau kiek pavargom, gal net keturis vakarus rašėm softą.

Nelabai tikiu, kad kam nors to reikia, bet programą CPMD galima nusikrauti.

*) Rašė kaip HD, bet dėl ubagystės dažnai naudojo DD diskelius. Todėl dabar jie sunkiai nusiskaito.

P.S.
Kai parašiau programą, atsiliepė vienas iš “ten” ir paaiškino kaip sukonfiguruoti jo programą darbui su šiais diskais. Programa vadinasi “Steinblume”.