- retrocomputing 28
- cpm 11
- CP/M 11
- ibm_pc_compat 9
- comp_eng 5
- dos 5
- pok 2
- popular 1
- physics 1
- other 1
- disk images 1
- cpp 1
- os 1
- os2 1
retrocomputing
Материнська плата Juko ST – ще одна XT-машина
Материнська плата XT-класу, Juko ST (SuperTurbo) з’явилася в мене кілька років тому, завдяки віртуальному музею комп’ютерного андеграунду, але якщо сумісні з 8-бітовими ISA VGA картки в мене знайшлися, то працездатні контролери вводу-виводу – не вдавалося добути. Так і стояла вона ‘‘безхозною’’.
В Інтернеті практично тотожні плати трапляються під іменем Unique UX-12. На жаль, я поки не зміг розібратися, чи це клон – і тоді, хто чий клон, чи просто інша назва? Виглядає, що була доволі популярною – в Інеті, зокрема, на Vogons – багато постів про неї (1, 2, 3 – лише як початок).
З появою PicoMEM, зміг трохи з нею побавитися – підкинула пару цікавинок.
Продовження...PicoMEM – крутезна сучасна плата для IBM PC/XT/AT
Нещодавно завелася в мене PicoMEM – крутезна плата оновлення, зовсім недавно створена. Я все ще під враження, то ж запрошую познайомитися і читачів.
Опис
Згадуючи попередній мій огляд плат оновлення, PicoMEM, заміняє більшість з них, при чому – одночасно. Базується на Raspberry Pi Zero, з мікроконтролером RP2040. На момент написання1 вміє наступне:
-
Серпень 2024. Автор називає її “програмно визначена ISA-плата”, з часом функціонал доповнюється або змінюється. ↩
Amstrad PC1640
Попередні машини, про які тут писав1 – пафосні, їх мало хто міг собі дозволити. А зараз хотів би розповісти вам про значно більш скромний комп’ютер – entry level, як його називали в тогочасних оглядах – Amstrad PC16402.
Це перший мій нетривіальний “брендовий” ретрокомп’ютер3 – придбав його на початку 2014, і дуже давно планував про нього написати – але не дуже вмів. Останнім часом вже боюся, що він почне ревнувати – я все про інших пишу, та й зламається.
Фото з інструкції. Зауважте, картинка на екрані – плюс-мінус реалістична, хоч і трішки прикрашена. |
Увага, багато фото, часто – технічно сумнівної якості!
-
Osborne Executive, Tandy 1400LT, Compaq portable III та 386. ↩
-
В США відомий як PC6400. Його попередник, теж доволі відомий – PC1512. ↩
-
До того були ще пара ноутбуків початку 90-х та AST Power Premium 4/25s – машинки симпатичні, але вже помітно більш однорідні, ніж XT-клони середини 80-х. ↩
Огляд книг ‘‘Inside OS/2’’ та ‘‘Advanced Os/2 Programming’’ з кінця 1980-х
Продовжуючи серію ретро-літоглядів, хочу розповісти про дві книги, присвячені OS/21: “Inside OS/2” by Gordon Letwin, 1988 та “Advanced Os/2 Programming” by Ray Duncan, 1989.
Вони зовсім протилежні за призначенням. Друга – глибоко прагматична, а перша – навпаки, більше про ідею і принципи. Іншими словами, вони взаємно доповнюють одна одну.
Предмет книг
Дуже коротко про тему цих книг, OS/2. Це багатозадачна однокористувацька операційна система. Розпочалася як плід дружби IBM та Microsoft, потім розвивалася IBM, але з часом програла іншим ОС загального використання. Існує досі, як спеціалізована, з назвою ArcaOS.
Поміж іншого, була чи не першою масовою ОС з підтримкою потоків – напишу про це окремо.
Розпочинала своє життя як 16-бітова система для 286 – через дивні тогочасні ідеї IBM. Такими залишалися версії 1.xx – 2.xx і наступні вже були 32-бітовими2. Обидві книги стосуються якраз 16-бітових варіантів OS/2 – 32-бітова з’явилася вже в 1991-1992.
- “Inside OS/2” згадує лише версію 1.00 (грудень 1987).
- “Advanced Os/2 Programming” вже знає про 1.10 (листопад 1988, при тому, що книжка містить передмову від грудня 1988) – ту, що з GUI, але говорити про GUI автор уникає.
Переходимо до огляду книг.
-
Ця система один час мала для мене певну містичну привабливість – в юності багато про неї чув, але не бачив, за межами книжки3, прочитаної щоб здати курс “Операційних систем” на екстернаті в “Львівській політехніці”. ↩
-
16-бітовий код залишався, для зворотної сумісності, як і в Windows 9x. ↩
-
Російський переклад (1991-го) “Inside OS/2 : the complete programmer’s reference”, J. Campbell, 1988. ↩
Звідна таблиця версій DOS – work in progress
Поки писав про DOS 4.00, Tandy 1400LT тощо, регулярно мусив уточнювати всілякі подробиці щодо можливостей різних версій DOS. При чому, в різних джерелах є різнобій. То вирішив зібрати все в одному місці і потроху уточнювати.
Продовження...До релізу джерельних текстів DOS 4.0x та матеріалів European DOS 4
Два місяці тому1 Microsoft відкрила (майже) повні джерельні тексти MS DOS 4.00 та частину славнозвісно загадкового Multitasking чи European MS DOS 4.02, приблизно еквівалентну OEM Adaptation Kit (OAK)3. Звичайно, я зразу захотів спробувати скомпілювати та подивитися, що там із SYS.COM. Але, хоча, з підказками спільноти, це вдалося швидко, через звичну безліч справ з студентами і взагалі в УКУ, описати свої знахідки тоді не вдавалося і пишу, вкотре, безнадійно відставши від першовідкривачів.
Отож, експериментуємо.
-
26 квітня 2024 року. ↩
-
Базується на DOS 2.0, працює в реальному режимі, не має відношення до “справжнього” MS DOS 4.0. Див. також Wiki: MS-DOS 4.0 (multitasking) та ‘‘The History of Multitasking MS-DOS’’. ↩
-
Джерельні тексти та об’єктні файли, які Microsoft надавала OEM-виробникам для адаптації під їх комп’ютери. Див, наприклад: Microsoft MS-DOS OEM Adaption Kit 3.x, [MS-DOS 2.0 OEM Adaptation Kit (February 8, 1983)] (https://archive.org/details/msdos-2.0-oak). Зазвичай, IO.SYS, FORMAT.COM чи SYS.COM постачалися як джерельні тексти, а MSDOS.SYS, як умовно-платформонезалежний, постачався як набір об’єктних файлів. ↩
SYS.COM з 86-DOS 1.10
Поки возився з SYS.COM з 86-DOS версій 0.11 та 0.34, випадково дизасемблював цю ж утиліту з 86-DOS 1.10. Тож, вирішив доповнити колекцію статей про неї.
Продовження...SYS.COM з 86-DOS 0.11 та 0.34
Насправді, ця стаття – трішки обман. Все почалося з того, що до 86-DOS я поліз, щоб глянути на їх SYS.COM, який багато раз дизасемблював для різних версій MS/PC-DOS.
Продовження...86-DOS 0.11 та 0.34
Знайдені нові старі версії 86-DOS – 0.11 та 0.34, спричинили цілу хвилю публікацій. Десь на десятку побачених, вирішив і я спробувати їх.
- Емуляція
- Формат диску – FAT12, з 16-байтовими записами каталогу
- Вміст дисків та експерименти
- Посилання
- Виноски
Compaq Portable III (з 286) та Portable 386
Знову ж, завдяки учаснику спільноти ретрокомп’ютерщиків – засновнику Віртуального музею комп’ютерного андеграунду маємо два варіанти Compaq Portable III, з 286 та Compaq Portable 386.
Перший мій, другий – Львівського Музею Комп’ютерних Технологій.
Вони дуже схожі, насправді. Згідно Вікі, компанія поспішала випустити на ринок портативний комп’ютер, а в наявності мала хіба материнські плати 286-го, тому спершу випустила варіант з ними, до готовності новішої плати. Тому, далі в тексті я буду їх розрізняти за типом процесора – 386 чи 286.
Обережно – далі 20 Мб фотографій, більшість з яких, на жаль, неякісні або й жахливі.
- Загальний опис
- Налаштування та продуктивність
- Досвід експлуатації
- Підсумок
- Посилання
- Виноски
Compaq Portable III, 286, фото з журналу “Australian Personal Computer”, Volume 8, Number 6, June 1987. Мій зараз помітно жовтіший. Зверніть увагу на розкладку клавіатури. |
Лептоп Tandy 1400 LT
Завдяки одному учаснику спільноти ретрокомп’ютерщиків у мене з’явився цей ноутбук, а завдяки іншому – він ще й запрацював! Оскільки машинка дуже мила, коротко розкажу про неї та покажу свої експерименти1. Забігаючи наперед, вдалося отримати 630 Кб вільної основної пам’яті – не так погано для системи без XMS чи EMS2, і це з завантаженим DOSKEY та драйвером мишки3.
Tandy 1400 LT, фото з вікі. |
- Апаратне забезпечення
- DOS
- UMB
- Приклади використання програмного забезпечення
- Підсумок
- Посилання
- Виноски
-
На жаль, традиційно, якість фото більш ніж сумнівна, але вибір – або такі, або взагалі ніякі, то я вирішив – хай будуть. ↩
-
Думаю, наступна ітерація буде про 8086 з EMS – видатний ж костиль, а потім – 286 з ним же. ↩
-
Чітерство, зізнаюся, як в рекламі солі без ГМО – якщо є UMB, все що у ній, не займатиме основної пам’яті. ↩
Пошук-1
Моїм першим комп’ютером був “Пошук-1”1. В середині 90-х, навіть у нас, це була глибоко застаріла машина. Тому, про Pentium MMX-200, який з’явився в 1999-му2, часто кажу “мій перший справжній комп’ютер”. Але і з “Пошуком-1” пов’язано багато спогадів – перші спроби бути користувачем, перші спроби програмувати, колупатися в файлових системах, писати віруси тощо.
Написано про цю машину немало: wiki і посилання там, зокрема: “ПК Поиск” та всілякий софт – поки до того навряд чи зможу щось додати, тому пост – більше ностальгічний.
-
Купили в 1994, ввімкнути його вдалося в 1995 і до 1999 він залишався єдиним. ↩
-
Він глючив – за використання відеорежимів за межами стандартних VGA, регулярно в Blue screen вилітав. Тому, коли з’явився потужніший, продав його. Жив тоді у Жидачеві, продав у Львові. Було дуже кумедно, коли, через кілька тижнів, сусідських хлопчина попросив мого брата подивитися до його нового комп’ютера і це виявився щойно проданий мій – на материнській платі був характерний надлам. ↩
Комп’ютерна інженерія
Вітаю у розділі узагальнено кажучи, комп’ютерної інженерії. Створюється, в основному, за матеріалами мого викладання на Факультеті прикладних наук УКУ та роботи із кластером ІФКС.
- C++
- Основи – “Принципи організації комп’ютера”
- Високопродуктивні обчислення та “Архітектура комп’ютерних систем”
- Операційні системи
- Embedded
- Інше
C++
Методичні матеріали
- Книги по C++ – загальні міркування, 2013
- Деякі “загрози” вже потроху відходять в минуле, але текст все ще актуальний.
- Книги по C++ – список літератури, 2018 – найновіший, на цей час, але потребує оновлення. Нижче – стара версія цього списку.
- Онлайн інструменти для С++, 2020
- Навіщо розуміти комп’ютер, якщо сучасні мови та їх бібліотеки такі потужні? – все почалося із максимально збоченого способу перевірити значення біта, яке побачив в коді студентів. Приклад використання онлайн-інструментів С++.
Статті
- C/C++, стандарти, компілятори, оптимізація…, 2013 – дещо наївний текст про те, що знакове переповнення – невизначена поведінка.
- Містить опис різних кодувань від’ємних чисел.
- Мікро-оптимізація, 2015 – есей про оптимізації обчислювальної програми, доволі наївний. Треба буде перевірити, але маю надію, що зараз компілятори краще справляються.
- Чергове збочене використання С++, 2023.
Бібліотеки
Основи – “Принципи організації комп’ютера”
- Література до принципів організації комп’ютера – книги, 2017
- Огляд floating point – комп’ютерних чисел з рухомою крапкою
Високопродуктивні обчислення та “Архітектура комп’ютерних систем”
Методичні матеріали
- Вимірювання часу роботи коду, 2017
- Уроки захищеного режиму x86. Весь цикл разом
- Планую перенести код на git, а текст сюди, додати як 64-бітний захищений режим, так і 16-бітний, можливо – засоби підтримки віртуалізації.
Застарілі тексти
Операційні системи
Файлові системи
Дещо застаріла серія статей про Lustre (2011)
- Огляд Lustre, кластерної файлової системи
- Інсталяція Lustre 2.0
- Іграшкова Lustre
- Перевірка ФС Lustre на цілісність
- Квоти в Lustre
- Зміна NID серверів Lustre
- Не такі часті питання з приводу Lustre
- Міграція OSS в Lustre
Embedded
Методичні матеріали
- GPIO мікроконтролерів STM32F303 з використанням HAL, 2016 – методичні рекомендації до виконання лабораторних.
- Планую переписати на цьому хостингу, модульно – для спрощення використання та оновлення.
- Зовсім просто про semihosting, 2017
- SemiHosting без дебаггера, 2017
- Досьє на плати сімейства STM32 Discovery, 2017
- STM Studio – монітор змінних STM32
- Зовсім просто про Virtual COM Port поверх USB плати STM32F3Discovery – методичні рекомендації до використання USB під час лабораторних.
- Дисплей Nokia 5110 на контролері PCD8544 - огляд – дуже простий дисплей, який використовуємо із студентами.
- Дисплей Nokia 5110 на контролері PCD8544 - бібліотека для STM32 – бібліотека вульгарна та дуже проста, давно планую оновити…
- Гігрометри DHT11 і DHT22
Далекомір HC-SR04
- Далекомір HC-SR04 – зміст
- Далекомір HC-SR04 – огляд.
- Далекомір HC-SR04 – використовуючи GPIO/CMSIS
- Далекомір HC-SR04 – використовуючи GPIO/SPL
- Далекомір HC-SR04 – використовуючи GPIO/CoX
- Далекомір HC-SR04 – використовуючи GPIO/HAL/STM32CubeMX
- Далекомір HC-SR04 – GPIO/C++
- Далекомір HC-SR04 – GPIO/висновки
- Далекомір HC-SR04 – два таймери/CMSIS
- Далекомір HC-SR04 – два таймери/HAL
- Далекомір HC-SR04 – один таймер/CMSIS
- Далекомір HC-SR04 – один таймер/HAL
- Далекомір HC-SR04 – зовнішні переривання EXTI/CMSIS
- Далекомір HC-SR04 – зовнішні переривання EXTI/HAL
- ”Зовсім просто про далекомір HC-SR04 із GPIO/HAL”
Таймери STM32
-2. Відлік часу без таймерів -1. Мікросекундні затримки та відлік мікросекунд для STM32
- Таймер SysTick
- Таймери STM32 – огляд
- Таймери STM32 – відлік часу/CMSIS
- Таймери STM32 – відлік часу/HAL
- Таймери STM32 – ШІМ/CMSIS
Розповідається, що таке ШІМ, і як попросити таймер генерувати його на одному із своїх каналів. Розгляд відбувається на класичному прикладі керування яскравістю світлодіода. - Таймери STM32 – ШІМ/HAL
- Таймери STM32 – зовнішнє тактування/CMSIS
- Таймери STM32 – зовнішнє тактування/HAL
- Таймери STM32 – внутрішні тригери/CMSIS
- Таймери STM32 – внутрішні тригери/HAL
Те ж, засобами HAL. Розглянуто, як HAL керує налаштуванням генерацією TRGO (функція HAL_TIMEx_MasterConfigSynchronization()) та внутрішнім тактуванням (HAL_TIM_SlaveConfigSynchronization()) - Таймери STM32 – автоматична зупинка/CMSIS
- Таймери STM32 – автоматична зупинка/HAL
- Таймери STM32 – захоплення вводу/CMSIS
- Таймери STM32 – захоплення вводу/HAL
- Таймери STM32 – захоплення ШІМ/CMSIS
- Таймери STM32 – захоплення ШІМ/HAL
- Таймери STM32 – одноімпульсний режим/CMSIS
- Таймери STM32 – одноімпульсний режим/HAL
- Таймери STM32 – remapping/CMSIS
- Таймери STM32 – порівняння розмірів коду для CMSIS i HAL
Статті
- Помилка оптимізації GCC-AVR, 29 березня 2013 р.
- Надіюся, зараз такого менше.
- Стандартна бібліотека C та SemiHosting (на прикладі STM32 і CoIDE), 2015,
- C++ із ARM GCC + STM32 (+ CoIDE),2015
- Планую повторити таке дослідження стану справ для сучасних компіляторів та пакетів програм, але в цілому – ситуація із підтримкою С++ якісно покращилася, більшість таких “костилів” більше не потрібні. Однак, стаття може бути корисною, щоб краще зрозуміти затрати на різні засоби С++.
- libcxxrt в ролі libsupc++ – бібліотеки підтримки мовних засобів часу виконання, 2015 – доповнення до попередньої статті, спроба економніше обробляти виключення. Тоді я так і не розібрався, зараз шанси більші, але поки не варту необхідних витрат часу і сил.
- Мікро-реалізація стандартної бібліотеки C++ – uClibc++, 2015 – доволі дискусійна бібліотека, та й суттєво краще з 2015 до 2022 року не стало, а останній комміт – 2020-06-04.
- Огляд STM32 (ARM Cortex-M від STMicroelectronics), 15 жовтня 2012 р. – трохи застарілий і трохи наївний текст.
- Помилка в ARM CMSIS, 6 квітня 2013 р.
I2C EEPROM – 24CXX
Перша моя серія статей про Embedded – виконувалося із дуже обмеженим доступом до обладнання і взагалі без попередніх знань. Можливо, колись оновлю.
- Робота з EEPROM пам’яттю 24CXX – огляд – зокрема, огляд I2C.
- Робота з EEPROM пам’яттю 24CXX – Arduino Wire
- Робота з EEPROM пам’яттю 24CXX – Software, Arduino
- Робота з EEPROM пам’яттю 24CXX – Soft, AVR8
Застарілі тексти
Залишаю їх для колекції та для довідки:
- Arduino – огляд посилань, 6 квітня 2012 р.
- CooCox CoIDE, 2012 – непогане IDE було на свій час.
Інше
Продовження...Сучасні плати для IBM PC/XT
Виявилося,нові плати оновлення та інше обладнання для ретрокомп’ютерів, розробляють та продають досі. При тому, IBM PC, певне, навіть не найпопулярніша платформа.
Коротко розповім про деякі плати, які або вже використовую, або хотів би мати – не намагаючись досягнути повноти. Власне, це було б важко – список лише на Tindie справляє враження.
Продовження...AST Rampage
Огляд
Один із моїх улюблених костилів епохи IBM PC – EMS. Причому, її емуляція на 286+ – не так цікаво, хочеться для справжнього 8086/88-комп’ютера – IBM-XT-подібного. Плат із такою пам’яттю було помітно більше, ніж “Дивних плат оновлення”, тому придбати їх на ebay реально, хоча й вимагало певної терплячості, поки з’являється лоти із прийнятними цінами.
Моя AST Rampage. На фото – 256 Кб RAM. На жаль, роз’єм для Daughter board не розпаяний. |
Дивні плати оновлення із 1980-х
“DOS: Beyond 640K”
Останні роки, замість художньої літератури, часто читаю старі комп’ютерні книжки. Про деякі вже писав, про інші ще планую. Поміж них трапилася “DOS: Beyond 640K” by James S. Forney, 2nd ed., 1992 року. Читати її було жахливо. Автор знову і знову повторював одне і те ж, трішки різними словами, а коли дістало так, що написав комусь поскаржитися, на наступній сторінці автор буквально сказав: “Повторю ще раз” і скопіював попередній абзац. Навіщо ж я її читав? Це хороший спосіб зануритися в атмосферу тодішніх “персоналок” – часто дуже відмінну від сучасного світу.
Поміж іншого, там були описані плати оновлення (upgrade) для тогочасних комп’ютерів. І карти ті були настільки, для наших часів, незвичні, що я вирішив про них написати.
Продовження...COBOL під CP/M на Osborne Executive
- Огляд
- Microsoft COBOL
- Micro Focus COBOL
- Nevada COBOL
- Підсумок
- Додаток – образи дисків, використані в цьому пості
- Виноски
Огляд
COBOL – мова дуже давня, але асоціюється з великими машинами, тому для мене було великим сюрпризом зустріти її для CP/M і комп’ютерів класу Osborne.
Продовження...Дебагери для CP/M та Osborne Executive
Короткий огляд дебагерів, з якими зіткнувся, поки експериментував із асемблерами – не прагнучи до повноти.
Продовження...Інструменти програмування на асемблері для CP/M та Osborne Executive
- Огляд
- CP/M Macro Assembler
- CP/M Assembler
- CP/M Relocatable Macro Assembler
- Microsoft M80
- SLR Systems Z80ASM
- 2500 A.D. SOFTWARE ASM
- MITEK Relocating Macro Assembler
- ZSM / Z80ASMUK
- Підсумок
- Додаток – образи дисків, використані в цьому пості
- Додаток – порівняння мнемонік Z80 та i8080
- Виноски
Огляд
CP/M існує для кількох сімейств процесорів. Поміж восьмибітових це Z80, i8080 та i8085. Для випробувань асемблерів використовую два варіанти – чисто для i8080 і з мнемоніками Z80. Різниця між їх системами команд та мнемоніками описана, наприклад, в: “8080A/Z80 compatibility”.
Приклад, на якому буду випробовувати – тривіальний ‘‘Hello, world’’, який виводить текст за допомогою славнозвісний1 системний виклик 9 – ‘‘Output string’’, код якого передається регістром C, адреса стрічки в DE, а стрічка має закінчуватися символом ‘$’.
-
'’Ask Bill [Gates] why the string in [MS-DOS] function 9 is terminated by a dollar sign. Ask him, because he can’t answer. Only I know that.’’, цитуючи за “Bill Gates: Of Mind and Money”, “Seattle Post-Intelligencer” Newspaper, May 8, 1991. Цей системний виклик з 1970-х, відтворений DOS 1.00 в 1981, все ще вивчали в деяких провідних ВИШах не пізніше 2020-го… ↩
Текстовий редактор te
- te
- Портування te під Osborne Executive
- Портування te під Osborne 1
- Компілювання te
- Особливості te
- Виноски
te
Важливий інструмент для ‘‘реконструкторських’’ експериментів – текстовий редактор. Працювати з ED.COM я поки не готовий. Хоча редагувати файли із кодом можна в WordStar – кажуть, у свій час його для того і використовували, мені не дуже сподобалося – він громіздкий. Пошуки виявили сучасну альтернативу – текстовий редактор te для CP/M, від MiguelVis – великого ентузіаста CP/M.
Продовження...Посилання стосовно CP/M
Поки менш-більш хаотично – оскільки не раз доводилося їх знову і знову шукати, але колись може впорядкую.
Продовження...Коротка інструкція до CP/M
- Огляд
- Файлова система з точки зору користувача
- Вбудовані команди
- Стандартні транзієнтні команди
- Виноски
Книжок по CP/M1 було багато – навіть в документації до Osborne-ів є детальна інструкція, тому тут лише коротка ‘‘шпаргалка’’.
-
Control Program/Monitor або Control Program for Microcomputers. ↩
Інші емулятори CP/M систем
MAME – емулятор взагалі всього, включаючи Осборни
MAME
Шукав емулятори для Osborne, спеціалізованих не знайшов, але виявив, що MAME їх підтримує. Трохи недолюблюю цей емулятор1, але корисність його беззаперечна!
Osborne 1 підтримується нормально. Osborne Executive помічено як такий, що не працює, але, хоча у нього є свої проблеми2, в цілому – використовувати можна. Osborne Vixen теж підтримується, хоча ретельно не тестував.
RunCPM – емулятор узагальненої CP/M-системи
RunCPM
Існують емулятори конкретних систем, на яких можна виконувати код CP/M, портованих для них. Але існують і генералізовані емулятори, що дозволяють працювати з CP/M безпосередньо, емулюючи тим чи іншим способом диски та інші засоби комунікації з залізом.
Вони дуже корисні для розробки під цю ОС.
Не претендуючи на повноту охоплення, після тривалих пошуків і випробування кількох варіантів, зупинився на RunCPM.
Продовження...Робота із образами дисків CP/M
Огляд проблеми
IBM PC-сумісні комп’ютери1 трохи стандартизували формати дискет, тому, для комп’ютерів цієї епохи домінують побайтові образи – й так зрозуміло, що сектор 512 байт, формат визначається BPB у бут-секторі, а де не визначається (для дисків епохи DOS 1.xx) – можна вгадати за розміром. Ілюстрація – плагін для Total Commander-а, який працює лише із ‘‘плоскими’’ образами, відкриває абсолютну більшість образів дискет, скачаних із сайтів з ретро-софтом.
Звичайно, залишалися нестандартні формати, дискети із захистом від копіювання, формати інших операційних систем – не сімейства MS-DOS і похідних від них. Завдяки низькорівневій природі апаратури дисководів, можливими були безліч варіацій. Для роботи із ними було створено спеціалізоване програмне забезпечення. Великого поширення набули Teledisk (типове розширення .td0) та Imagedisk (.imd) – у своїх образах вони зберігають службову інформацію, дозволяючи відтворити такі ‘‘хитрі’’ образи2.
Однак, із CP/M ситуація інша. Різні комп’ютери обладнувалися різними, часто не сумісними між собою, дисководами. Вони різні за розміром – 8”, 5.25”, 3.5”, 3”; різні за принципами – soft sectors vs hard sectors; кількістю сторін (іншими словами – магнітних голівок), кількістю треків, розміром секторів, skewing-ом тощо.
-
Писав трішки про початок цієї епохи: MS/PC DOS 1.0, MS/PC DOS 1.XX в емуляторах, MS/PC DOS 1.XX “Ось ти який, північний олень!”, DOS FCB. ↩
-
Заради лаконічності, і щоб не втонути у настільки широкій темі, свідомо дуже спрощую. В сучасному світі за подробицями можна заглянути сюди, сюди або сюди, чи, хоча б, на Wiki та глави ‘‘Sector-level organization’’ і ‘‘Floppy disk representation’’ інструкції MAME. На щастя, з Осборном так низько (по рівнях абстракції) опускатися не довелося ↩
Портативні комп’ютери Osborne
Огляд
Osborne Executive – нащадок Osborne 1, який вважають першим масовим портативним комп’ютером. Як компроміс між переписуванням із відкритих джерел і бажанням мати всю необхідну інформацію під руками, наведу тут лише основні характеристики – найбільш загальні, або ті, що знадобилися в процесі роботи.
Продовження...Ретрокомп’ютинг
Вітаю у розділі, присвячена ретрокомп’ютингу. Тут розповідатиму про свої блукання комп’ютерною історією.
- Огляд
- Ретрокомп’ютерні книги
- CP/M
- MS/PC-DOS
- OS/2
- 16-бітні Windows
- Інші OS
- IBM PC-сумісні комп’ютери
- x86
- Інше
cpm
COBOL під CP/M на Osborne Executive
- Огляд
- Microsoft COBOL
- Micro Focus COBOL
- Nevada COBOL
- Підсумок
- Додаток – образи дисків, використані в цьому пості
- Виноски
Огляд
COBOL – мова дуже давня, але асоціюється з великими машинами, тому для мене було великим сюрпризом зустріти її для CP/M і комп’ютерів класу Osborne.
Продовження...Дебагери для CP/M та Osborne Executive
Короткий огляд дебагерів, з якими зіткнувся, поки експериментував із асемблерами – не прагнучи до повноти.
Продовження...Інструменти програмування на асемблері для CP/M та Osborne Executive
- Огляд
- CP/M Macro Assembler
- CP/M Assembler
- CP/M Relocatable Macro Assembler
- Microsoft M80
- SLR Systems Z80ASM
- 2500 A.D. SOFTWARE ASM
- MITEK Relocating Macro Assembler
- ZSM / Z80ASMUK
- Підсумок
- Додаток – образи дисків, використані в цьому пості
- Додаток – порівняння мнемонік Z80 та i8080
- Виноски
Огляд
CP/M існує для кількох сімейств процесорів. Поміж восьмибітових це Z80, i8080 та i8085. Для випробувань асемблерів використовую два варіанти – чисто для i8080 і з мнемоніками Z80. Різниця між їх системами команд та мнемоніками описана, наприклад, в: “8080A/Z80 compatibility”.
Приклад, на якому буду випробовувати – тривіальний ‘‘Hello, world’’, який виводить текст за допомогою славнозвісний1 системний виклик 9 – ‘‘Output string’’, код якого передається регістром C, адреса стрічки в DE, а стрічка має закінчуватися символом ‘$’.
-
'’Ask Bill [Gates] why the string in [MS-DOS] function 9 is terminated by a dollar sign. Ask him, because he can’t answer. Only I know that.’’, цитуючи за “Bill Gates: Of Mind and Money”, “Seattle Post-Intelligencer” Newspaper, May 8, 1991. Цей системний виклик з 1970-х, відтворений DOS 1.00 в 1981, все ще вивчали в деяких провідних ВИШах не пізніше 2020-го… ↩
Текстовий редактор te
- te
- Портування te під Osborne Executive
- Портування te під Osborne 1
- Компілювання te
- Особливості te
- Виноски
te
Важливий інструмент для ‘‘реконструкторських’’ експериментів – текстовий редактор. Працювати з ED.COM я поки не готовий. Хоча редагувати файли із кодом можна в WordStar – кажуть, у свій час його для того і використовували, мені не дуже сподобалося – він громіздкий. Пошуки виявили сучасну альтернативу – текстовий редактор te для CP/M, від MiguelVis – великого ентузіаста CP/M.
Продовження...Посилання стосовно CP/M
Поки менш-більш хаотично – оскільки не раз доводилося їх знову і знову шукати, але колись може впорядкую.
Продовження...Коротка інструкція до CP/M
- Огляд
- Файлова система з точки зору користувача
- Вбудовані команди
- Стандартні транзієнтні команди
- Виноски
Книжок по CP/M1 було багато – навіть в документації до Osborne-ів є детальна інструкція, тому тут лише коротка ‘‘шпаргалка’’.
-
Control Program/Monitor або Control Program for Microcomputers. ↩
Інші емулятори CP/M систем
MAME – емулятор взагалі всього, включаючи Осборни
MAME
Шукав емулятори для Osborne, спеціалізованих не знайшов, але виявив, що MAME їх підтримує. Трохи недолюблюю цей емулятор1, але корисність його беззаперечна!
Osborne 1 підтримується нормально. Osborne Executive помічено як такий, що не працює, але, хоча у нього є свої проблеми2, в цілому – використовувати можна. Osborne Vixen теж підтримується, хоча ретельно не тестував.
RunCPM – емулятор узагальненої CP/M-системи
RunCPM
Існують емулятори конкретних систем, на яких можна виконувати код CP/M, портованих для них. Але існують і генералізовані емулятори, що дозволяють працювати з CP/M безпосередньо, емулюючи тим чи іншим способом диски та інші засоби комунікації з залізом.
Вони дуже корисні для розробки під цю ОС.
Не претендуючи на повноту охоплення, після тривалих пошуків і випробування кількох варіантів, зупинився на RunCPM.
Продовження...Робота із образами дисків CP/M
Огляд проблеми
IBM PC-сумісні комп’ютери1 трохи стандартизували формати дискет, тому, для комп’ютерів цієї епохи домінують побайтові образи – й так зрозуміло, що сектор 512 байт, формат визначається BPB у бут-секторі, а де не визначається (для дисків епохи DOS 1.xx) – можна вгадати за розміром. Ілюстрація – плагін для Total Commander-а, який працює лише із ‘‘плоскими’’ образами, відкриває абсолютну більшість образів дискет, скачаних із сайтів з ретро-софтом.
Звичайно, залишалися нестандартні формати, дискети із захистом від копіювання, формати інших операційних систем – не сімейства MS-DOS і похідних від них. Завдяки низькорівневій природі апаратури дисководів, можливими були безліч варіацій. Для роботи із ними було створено спеціалізоване програмне забезпечення. Великого поширення набули Teledisk (типове розширення .td0) та Imagedisk (.imd) – у своїх образах вони зберігають службову інформацію, дозволяючи відтворити такі ‘‘хитрі’’ образи2.
Однак, із CP/M ситуація інша. Різні комп’ютери обладнувалися різними, часто не сумісними між собою, дисководами. Вони різні за розміром – 8”, 5.25”, 3.5”, 3”; різні за принципами – soft sectors vs hard sectors; кількістю сторін (іншими словами – магнітних голівок), кількістю треків, розміром секторів, skewing-ом тощо.
-
Писав трішки про початок цієї епохи: MS/PC DOS 1.0, MS/PC DOS 1.XX в емуляторах, MS/PC DOS 1.XX “Ось ти який, північний олень!”, DOS FCB. ↩
-
Заради лаконічності, і щоб не втонути у настільки широкій темі, свідомо дуже спрощую. В сучасному світі за подробицями можна заглянути сюди, сюди або сюди, чи, хоча б, на Wiki та глави ‘‘Sector-level organization’’ і ‘‘Floppy disk representation’’ інструкції MAME. На щастя, з Осборном так низько (по рівнях абстракції) опускатися не довелося ↩
Портативні комп’ютери Osborne
Огляд
Osborne Executive – нащадок Osborne 1, який вважають першим масовим портативним комп’ютером. Як компроміс між переписуванням із відкритих джерел і бажанням мати всю необхідну інформацію під руками, наведу тут лише основні характеристики – найбільш загальні, або ті, що знадобилися в процесі роботи.
Продовження...CP/M
COBOL під CP/M на Osborne Executive
- Огляд
- Microsoft COBOL
- Micro Focus COBOL
- Nevada COBOL
- Підсумок
- Додаток – образи дисків, використані в цьому пості
- Виноски
Огляд
COBOL – мова дуже давня, але асоціюється з великими машинами, тому для мене було великим сюрпризом зустріти її для CP/M і комп’ютерів класу Osborne.
Продовження...Дебагери для CP/M та Osborne Executive
Короткий огляд дебагерів, з якими зіткнувся, поки експериментував із асемблерами – не прагнучи до повноти.
Продовження...Інструменти програмування на асемблері для CP/M та Osborne Executive
- Огляд
- CP/M Macro Assembler
- CP/M Assembler
- CP/M Relocatable Macro Assembler
- Microsoft M80
- SLR Systems Z80ASM
- 2500 A.D. SOFTWARE ASM
- MITEK Relocating Macro Assembler
- ZSM / Z80ASMUK
- Підсумок
- Додаток – образи дисків, використані в цьому пості
- Додаток – порівняння мнемонік Z80 та i8080
- Виноски
Огляд
CP/M існує для кількох сімейств процесорів. Поміж восьмибітових це Z80, i8080 та i8085. Для випробувань асемблерів використовую два варіанти – чисто для i8080 і з мнемоніками Z80. Різниця між їх системами команд та мнемоніками описана, наприклад, в: “8080A/Z80 compatibility”.
Приклад, на якому буду випробовувати – тривіальний ‘‘Hello, world’’, який виводить текст за допомогою славнозвісний1 системний виклик 9 – ‘‘Output string’’, код якого передається регістром C, адреса стрічки в DE, а стрічка має закінчуватися символом ‘$’.
-
'’Ask Bill [Gates] why the string in [MS-DOS] function 9 is terminated by a dollar sign. Ask him, because he can’t answer. Only I know that.’’, цитуючи за “Bill Gates: Of Mind and Money”, “Seattle Post-Intelligencer” Newspaper, May 8, 1991. Цей системний виклик з 1970-х, відтворений DOS 1.00 в 1981, все ще вивчали в деяких провідних ВИШах не пізніше 2020-го… ↩
Текстовий редактор te
- te
- Портування te під Osborne Executive
- Портування te під Osborne 1
- Компілювання te
- Особливості te
- Виноски
te
Важливий інструмент для ‘‘реконструкторських’’ експериментів – текстовий редактор. Працювати з ED.COM я поки не готовий. Хоча редагувати файли із кодом можна в WordStar – кажуть, у свій час його для того і використовували, мені не дуже сподобалося – він громіздкий. Пошуки виявили сучасну альтернативу – текстовий редактор te для CP/M, від MiguelVis – великого ентузіаста CP/M.
Продовження...Посилання стосовно CP/M
Поки менш-більш хаотично – оскільки не раз доводилося їх знову і знову шукати, але колись може впорядкую.
Продовження...Коротка інструкція до CP/M
- Огляд
- Файлова система з точки зору користувача
- Вбудовані команди
- Стандартні транзієнтні команди
- Виноски
Книжок по CP/M1 було багато – навіть в документації до Osborne-ів є детальна інструкція, тому тут лише коротка ‘‘шпаргалка’’.
-
Control Program/Monitor або Control Program for Microcomputers. ↩
Інші емулятори CP/M систем
MAME – емулятор взагалі всього, включаючи Осборни
MAME
Шукав емулятори для Osborne, спеціалізованих не знайшов, але виявив, що MAME їх підтримує. Трохи недолюблюю цей емулятор1, але корисність його беззаперечна!
Osborne 1 підтримується нормально. Osborne Executive помічено як такий, що не працює, але, хоча у нього є свої проблеми2, в цілому – використовувати можна. Osborne Vixen теж підтримується, хоча ретельно не тестував.
RunCPM – емулятор узагальненої CP/M-системи
RunCPM
Існують емулятори конкретних систем, на яких можна виконувати код CP/M, портованих для них. Але існують і генералізовані емулятори, що дозволяють працювати з CP/M безпосередньо, емулюючи тим чи іншим способом диски та інші засоби комунікації з залізом.
Вони дуже корисні для розробки під цю ОС.
Не претендуючи на повноту охоплення, після тривалих пошуків і випробування кількох варіантів, зупинився на RunCPM.
Продовження...Робота із образами дисків CP/M
Огляд проблеми
IBM PC-сумісні комп’ютери1 трохи стандартизували формати дискет, тому, для комп’ютерів цієї епохи домінують побайтові образи – й так зрозуміло, що сектор 512 байт, формат визначається BPB у бут-секторі, а де не визначається (для дисків епохи DOS 1.xx) – можна вгадати за розміром. Ілюстрація – плагін для Total Commander-а, який працює лише із ‘‘плоскими’’ образами, відкриває абсолютну більшість образів дискет, скачаних із сайтів з ретро-софтом.
Звичайно, залишалися нестандартні формати, дискети із захистом від копіювання, формати інших операційних систем – не сімейства MS-DOS і похідних від них. Завдяки низькорівневій природі апаратури дисководів, можливими були безліч варіацій. Для роботи із ними було створено спеціалізоване програмне забезпечення. Великого поширення набули Teledisk (типове розширення .td0) та Imagedisk (.imd) – у своїх образах вони зберігають службову інформацію, дозволяючи відтворити такі ‘‘хитрі’’ образи2.
Однак, із CP/M ситуація інша. Різні комп’ютери обладнувалися різними, часто не сумісними між собою, дисководами. Вони різні за розміром – 8”, 5.25”, 3.5”, 3”; різні за принципами – soft sectors vs hard sectors; кількістю сторін (іншими словами – магнітних голівок), кількістю треків, розміром секторів, skewing-ом тощо.
-
Писав трішки про початок цієї епохи: MS/PC DOS 1.0, MS/PC DOS 1.XX в емуляторах, MS/PC DOS 1.XX “Ось ти який, північний олень!”, DOS FCB. ↩
-
Заради лаконічності, і щоб не втонути у настільки широкій темі, свідомо дуже спрощую. В сучасному світі за подробицями можна заглянути сюди, сюди або сюди, чи, хоча б, на Wiki та глави ‘‘Sector-level organization’’ і ‘‘Floppy disk representation’’ інструкції MAME. На щастя, з Осборном так низько (по рівнях абстракції) опускатися не довелося ↩
Портативні комп’ютери Osborne
Огляд
Osborne Executive – нащадок Osborne 1, який вважають першим масовим портативним комп’ютером. Як компроміс між переписуванням із відкритих джерел і бажанням мати всю необхідну інформацію під руками, наведу тут лише основні характеристики – найбільш загальні, або ті, що знадобилися в процесі роботи.
Продовження...ibm_pc_compat
Материнська плата Juko ST – ще одна XT-машина
Материнська плата XT-класу, Juko ST (SuperTurbo) з’явилася в мене кілька років тому, завдяки віртуальному музею комп’ютерного андеграунду, але якщо сумісні з 8-бітовими ISA VGA картки в мене знайшлися, то працездатні контролери вводу-виводу – не вдавалося добути. Так і стояла вона ‘‘безхозною’’.
В Інтернеті практично тотожні плати трапляються під іменем Unique UX-12. На жаль, я поки не зміг розібратися, чи це клон – і тоді, хто чий клон, чи просто інша назва? Виглядає, що була доволі популярною – в Інеті, зокрема, на Vogons – багато постів про неї (1, 2, 3 – лише як початок).
З появою PicoMEM, зміг трохи з нею побавитися – підкинула пару цікавинок.
Продовження...PicoMEM – крутезна сучасна плата для IBM PC/XT/AT
Нещодавно завелася в мене PicoMEM – крутезна плата оновлення, зовсім недавно створена. Я все ще під враження, то ж запрошую познайомитися і читачів.
Опис
Згадуючи попередній мій огляд плат оновлення, PicoMEM, заміняє більшість з них, при чому – одночасно. Базується на Raspberry Pi Zero, з мікроконтролером RP2040. На момент написання1 вміє наступне:
-
Серпень 2024. Автор називає її “програмно визначена ISA-плата”, з часом функціонал доповнюється або змінюється. ↩
Amstrad PC1640
Попередні машини, про які тут писав1 – пафосні, їх мало хто міг собі дозволити. А зараз хотів би розповісти вам про значно більш скромний комп’ютер – entry level, як його називали в тогочасних оглядах – Amstrad PC16402.
Це перший мій нетривіальний “брендовий” ретрокомп’ютер3 – придбав його на початку 2014, і дуже давно планував про нього написати – але не дуже вмів. Останнім часом вже боюся, що він почне ревнувати – я все про інших пишу, та й зламається.
Фото з інструкції. Зауважте, картинка на екрані – плюс-мінус реалістична, хоч і трішки прикрашена. |
Увага, багато фото, часто – технічно сумнівної якості!
-
Osborne Executive, Tandy 1400LT, Compaq portable III та 386. ↩
-
В США відомий як PC6400. Його попередник, теж доволі відомий – PC1512. ↩
-
До того були ще пара ноутбуків початку 90-х та AST Power Premium 4/25s – машинки симпатичні, але вже помітно більш однорідні, ніж XT-клони середини 80-х. ↩
Compaq Portable III (з 286) та Portable 386
Знову ж, завдяки учаснику спільноти ретрокомп’ютерщиків – засновнику Віртуального музею комп’ютерного андеграунду маємо два варіанти Compaq Portable III, з 286 та Compaq Portable 386.
Перший мій, другий – Львівського Музею Комп’ютерних Технологій.
Вони дуже схожі, насправді. Згідно Вікі, компанія поспішала випустити на ринок портативний комп’ютер, а в наявності мала хіба материнські плати 286-го, тому спершу випустила варіант з ними, до готовності новішої плати. Тому, далі в тексті я буду їх розрізняти за типом процесора – 386 чи 286.
Обережно – далі 20 Мб фотографій, більшість з яких, на жаль, неякісні або й жахливі.
- Загальний опис
- Налаштування та продуктивність
- Досвід експлуатації
- Підсумок
- Посилання
- Виноски
Compaq Portable III, 286, фото з журналу “Australian Personal Computer”, Volume 8, Number 6, June 1987. Мій зараз помітно жовтіший. Зверніть увагу на розкладку клавіатури. |
Лептоп Tandy 1400 LT
Завдяки одному учаснику спільноти ретрокомп’ютерщиків у мене з’явився цей ноутбук, а завдяки іншому – він ще й запрацював! Оскільки машинка дуже мила, коротко розкажу про неї та покажу свої експерименти1. Забігаючи наперед, вдалося отримати 630 Кб вільної основної пам’яті – не так погано для системи без XMS чи EMS2, і це з завантаженим DOSKEY та драйвером мишки3.
Tandy 1400 LT, фото з вікі. |
- Апаратне забезпечення
- DOS
- UMB
- Приклади використання програмного забезпечення
- Підсумок
- Посилання
- Виноски
-
На жаль, традиційно, якість фото більш ніж сумнівна, але вибір – або такі, або взагалі ніякі, то я вирішив – хай будуть. ↩
-
Думаю, наступна ітерація буде про 8086 з EMS – видатний ж костиль, а потім – 286 з ним же. ↩
-
Чітерство, зізнаюся, як в рекламі солі без ГМО – якщо є UMB, все що у ній, не займатиме основної пам’яті. ↩
Пошук-1
Моїм першим комп’ютером був “Пошук-1”1. В середині 90-х, навіть у нас, це була глибоко застаріла машина. Тому, про Pentium MMX-200, який з’явився в 1999-му2, часто кажу “мій перший справжній комп’ютер”. Але і з “Пошуком-1” пов’язано багато спогадів – перші спроби бути користувачем, перші спроби програмувати, колупатися в файлових системах, писати віруси тощо.
Написано про цю машину немало: wiki і посилання там, зокрема: “ПК Поиск” та всілякий софт – поки до того навряд чи зможу щось додати, тому пост – більше ностальгічний.
-
Купили в 1994, ввімкнути його вдалося в 1995 і до 1999 він залишався єдиним. ↩
-
Він глючив – за використання відеорежимів за межами стандартних VGA, регулярно в Blue screen вилітав. Тому, коли з’явився потужніший, продав його. Жив тоді у Жидачеві, продав у Львові. Було дуже кумедно, коли, через кілька тижнів, сусідських хлопчина попросив мого брата подивитися до його нового комп’ютера і це виявився щойно проданий мій – на материнській платі був характерний надлам. ↩
Сучасні плати для IBM PC/XT
Виявилося,нові плати оновлення та інше обладнання для ретрокомп’ютерів, розробляють та продають досі. При тому, IBM PC, певне, навіть не найпопулярніша платформа.
Коротко розповім про деякі плати, які або вже використовую, або хотів би мати – не намагаючись досягнути повноти. Власне, це було б важко – список лише на Tindie справляє враження.
Продовження...AST Rampage
Огляд
Один із моїх улюблених костилів епохи IBM PC – EMS. Причому, її емуляція на 286+ – не так цікаво, хочеться для справжнього 8086/88-комп’ютера – IBM-XT-подібного. Плат із такою пам’яттю було помітно більше, ніж “Дивних плат оновлення”, тому придбати їх на ebay реально, хоча й вимагало певної терплячості, поки з’являється лоти із прийнятними цінами.
Моя AST Rampage. На фото – 256 Кб RAM. На жаль, роз’єм для Daughter board не розпаяний. |
Дивні плати оновлення із 1980-х
“DOS: Beyond 640K”
Останні роки, замість художньої літератури, часто читаю старі комп’ютерні книжки. Про деякі вже писав, про інші ще планую. Поміж них трапилася “DOS: Beyond 640K” by James S. Forney, 2nd ed., 1992 року. Читати її було жахливо. Автор знову і знову повторював одне і те ж, трішки різними словами, а коли дістало так, що написав комусь поскаржитися, на наступній сторінці автор буквально сказав: “Повторю ще раз” і скопіював попередній абзац. Навіщо ж я її читав? Це хороший спосіб зануритися в атмосферу тодішніх “персоналок” – часто дуже відмінну від сучасного світу.
Поміж іншого, там були описані плати оновлення (upgrade) для тогочасних комп’ютерів. І карти ті були настільки, для наших часів, незвичні, що я вирішив про них написати.
Продовження...comp_eng
Список літератури з проектування мікрочіпів та електроніки від лабораторії Лампа
Продовження...Лабораторія “Лампа” розповсюджує дуже класні матеріали, поміж них – списки літератури. Оскільки Фейсбук – річ ефемерна, з дозволу автора, дублюю в себе. Текст далі – належить “Відкритій лабораторії електроніки Lampa”.
Всі права в авторів і вся вдячність – їм же!
Підходи до керування буферами в API різних операційних систем
Розповідаю студентам про низькорівневі API POSIX-сумісних систем – системні виклики та функції libc. Для порівняння зачіпаю підходи MS Windows та FreeRTOS. Та й місцями сам дивуюся зоопарку різноманітних непослідовностей у цих засобах. Більшість зумовлені історичними причинами разом із потребою підтримувати зворотну сумісність, частина – технічними, які я не розумію через недостатній досвід у відповідних сферах1, щось ще, певне, аналогом дрейфу генів із теорії еволюції…
Один із найпрямолінійніших прикладів такої заплутаності – менеджмент пам’яті під буфер, де операційна система (ОС) має покласти якусь інформацію. Розповідаючи про функції нижче, наголошую студентам – завчати нюанси конкретних функцій не потрібно. Якщо будете щодня з тим стикатися – саме осяде в голові. Пам’ятайте спектр ідей – щоб розуміти прочитане правильно (а не додумувати згідно своїх фантазій – поширена цитата: “я думав/ла воно ж само якось виділить/звільнить/знайде?”) та обов’язково звіряйтеся із документацією. Але після підготовки до відповідних пар вирішив, свіжими слідами, записати типові приклади.
-
Книга Brian Kernighan “UNIX: A History and a Memoir”, 2019 трохи прояснила деякі нюанси. Все ж, в цікаві часи живемо – творці технологій, письменники та науковці, чиї твори та відкриття формували той світ із яким я, та багато хто із мого оточення, взаємодіють, часто ще живі. Керніган книгу спогадів випустив, Том Рей (так, я нахабно хвалюся) відгук на роботу моєму дипломнику написав – про цю роботу ще писатиму, студентка враженнями від спілкування із Tim Berners-Lee ділиться тощо Однак, повчальнішими є технічні книжки тих часів. Charles Petzold, “Programming Windows” 1988-го року – ще про Windows 2.0, разом із “Extending DOS” by Ray Duncan et. al” та “Эндрю Шульман – Неофициальная Windows 95”, “The Old New Thing” від Raymond Chen і парою книг про OS/2, сильно прояснюють, чому MS Windows є таким, як є. Старі видання Таненбаума та “Operating systems” by Harvey Deitel and Paul Deitel, прояснили те ж стосовно інших ОС (зрозуміло – менш глибоко). Читається, як художні (історично-детективні) романи – коли вже твердо знаєш, що було далі. Іноді хочеться посміятися над наївністю, але частіше дивуєшся прозорливістю – коли пишуть щось, що через десяток років назвали новим проривом. Або коли бачиш (поза-)попередній виток спіралі технологій – типу обіцянки штучного інтелекту, голосових інтерфейсів та розпізнання мови, автоматичних перекладачів у книжках 60-х. Головне, написано дуже схоже на тексти в сучасних. Приклад: “Дитяча енциклопедія, том 03, числа і фігури, речовина і енергія”, 1959 російською/1963 українською, розділ про ЕОМ. Хоча, аж зараз, здається, ці обіцянки стають реальністю. ↩
Огляд floating point – комп’ютерних чисел з рухомою крапкою
- Ілюстрації проблеми
- Комп’ютерні дробові числа
- IEEE 754
- IEEE 754 в програмуванні
- FP8
- Підсумок
- Додатки
- Посилання
- Виноски
Floating point numbers – числа із рухомою крапкою1. Давайте розглянемо, як їх представляють в комп’ютерах і які це має наслідки для обчислень.
Ілюстрації проблеми
Рекурентна послідовність Мюллера
Перш ніж перейти до подробиць, спробуйте обчислити таку рекурентну послідовність, де всі змінні – floating point2, з допомогою будь-якої мови програмування – Python, C, C++, Rust, Lua тощо:
fn(x, y) := 108 - (815 - 1500/y)/x
v_0 = 4
v_1 = 4.25
v_i = fn(v_{i-1}, v_{i-2})
Чергове збочене використання С++
Прикол
Люблю С++, використовую її цілу вічність, викладаю тривалий час. Звичайно, усвідомлюю недоліки – як то кажуть, “ти змушуєш мою голову битися частіше”, періодами за це ненавиджу. Але, все ж, значна частина складнощів – не через саму мову. Свій вклад дає давня історія, багаж зворотної сумісності і безлічі застарілих практик1. Однак, підозрюю, вагому роль відіграє також щось схоже на переляк – внаслідок заплутаності через складність мови і безлічі правил.
Наштовхнув мене на цю думку код, який трапився в дипломній роботі мого студента – дуже потужного.
-
Останніх особливо важко позбутися – через безліч згадок в Інтернеті, відсутність потреби оновлювати свої знання в багатьох досвідчених розробників, та й через згадану зворотну сумісність. ↩
Комп’ютерна інженерія
Вітаю у розділі узагальнено кажучи, комп’ютерної інженерії. Створюється, в основному, за матеріалами мого викладання на Факультеті прикладних наук УКУ та роботи із кластером ІФКС.
- C++
- Основи – “Принципи організації комп’ютера”
- Високопродуктивні обчислення та “Архітектура комп’ютерних систем”
- Операційні системи
- Embedded
- Інше
C++
Методичні матеріали
- Книги по C++ – загальні міркування, 2013
- Деякі “загрози” вже потроху відходять в минуле, але текст все ще актуальний.
- Книги по C++ – список літератури, 2018 – найновіший, на цей час, але потребує оновлення. Нижче – стара версія цього списку.
- Онлайн інструменти для С++, 2020
- Навіщо розуміти комп’ютер, якщо сучасні мови та їх бібліотеки такі потужні? – все почалося із максимально збоченого способу перевірити значення біта, яке побачив в коді студентів. Приклад використання онлайн-інструментів С++.
Статті
- C/C++, стандарти, компілятори, оптимізація…, 2013 – дещо наївний текст про те, що знакове переповнення – невизначена поведінка.
- Містить опис різних кодувань від’ємних чисел.
- Мікро-оптимізація, 2015 – есей про оптимізації обчислювальної програми, доволі наївний. Треба буде перевірити, але маю надію, що зараз компілятори краще справляються.
- Чергове збочене використання С++, 2023.
Бібліотеки
Основи – “Принципи організації комп’ютера”
- Література до принципів організації комп’ютера – книги, 2017
- Огляд floating point – комп’ютерних чисел з рухомою крапкою
Високопродуктивні обчислення та “Архітектура комп’ютерних систем”
Методичні матеріали
- Вимірювання часу роботи коду, 2017
- Уроки захищеного режиму x86. Весь цикл разом
- Планую перенести код на git, а текст сюди, додати як 64-бітний захищений режим, так і 16-бітний, можливо – засоби підтримки віртуалізації.
Застарілі тексти
Операційні системи
Файлові системи
Дещо застаріла серія статей про Lustre (2011)
- Огляд Lustre, кластерної файлової системи
- Інсталяція Lustre 2.0
- Іграшкова Lustre
- Перевірка ФС Lustre на цілісність
- Квоти в Lustre
- Зміна NID серверів Lustre
- Не такі часті питання з приводу Lustre
- Міграція OSS в Lustre
Embedded
Методичні матеріали
- GPIO мікроконтролерів STM32F303 з використанням HAL, 2016 – методичні рекомендації до виконання лабораторних.
- Планую переписати на цьому хостингу, модульно – для спрощення використання та оновлення.
- Зовсім просто про semihosting, 2017
- SemiHosting без дебаггера, 2017
- Досьє на плати сімейства STM32 Discovery, 2017
- STM Studio – монітор змінних STM32
- Зовсім просто про Virtual COM Port поверх USB плати STM32F3Discovery – методичні рекомендації до використання USB під час лабораторних.
- Дисплей Nokia 5110 на контролері PCD8544 - огляд – дуже простий дисплей, який використовуємо із студентами.
- Дисплей Nokia 5110 на контролері PCD8544 - бібліотека для STM32 – бібліотека вульгарна та дуже проста, давно планую оновити…
- Гігрометри DHT11 і DHT22
Далекомір HC-SR04
- Далекомір HC-SR04 – зміст
- Далекомір HC-SR04 – огляд.
- Далекомір HC-SR04 – використовуючи GPIO/CMSIS
- Далекомір HC-SR04 – використовуючи GPIO/SPL
- Далекомір HC-SR04 – використовуючи GPIO/CoX
- Далекомір HC-SR04 – використовуючи GPIO/HAL/STM32CubeMX
- Далекомір HC-SR04 – GPIO/C++
- Далекомір HC-SR04 – GPIO/висновки
- Далекомір HC-SR04 – два таймери/CMSIS
- Далекомір HC-SR04 – два таймери/HAL
- Далекомір HC-SR04 – один таймер/CMSIS
- Далекомір HC-SR04 – один таймер/HAL
- Далекомір HC-SR04 – зовнішні переривання EXTI/CMSIS
- Далекомір HC-SR04 – зовнішні переривання EXTI/HAL
- ”Зовсім просто про далекомір HC-SR04 із GPIO/HAL”
Таймери STM32
-2. Відлік часу без таймерів -1. Мікросекундні затримки та відлік мікросекунд для STM32
- Таймер SysTick
- Таймери STM32 – огляд
- Таймери STM32 – відлік часу/CMSIS
- Таймери STM32 – відлік часу/HAL
- Таймери STM32 – ШІМ/CMSIS
Розповідається, що таке ШІМ, і як попросити таймер генерувати його на одному із своїх каналів. Розгляд відбувається на класичному прикладі керування яскравістю світлодіода. - Таймери STM32 – ШІМ/HAL
- Таймери STM32 – зовнішнє тактування/CMSIS
- Таймери STM32 – зовнішнє тактування/HAL
- Таймери STM32 – внутрішні тригери/CMSIS
- Таймери STM32 – внутрішні тригери/HAL
Те ж, засобами HAL. Розглянуто, як HAL керує налаштуванням генерацією TRGO (функція HAL_TIMEx_MasterConfigSynchronization()) та внутрішнім тактуванням (HAL_TIM_SlaveConfigSynchronization()) - Таймери STM32 – автоматична зупинка/CMSIS
- Таймери STM32 – автоматична зупинка/HAL
- Таймери STM32 – захоплення вводу/CMSIS
- Таймери STM32 – захоплення вводу/HAL
- Таймери STM32 – захоплення ШІМ/CMSIS
- Таймери STM32 – захоплення ШІМ/HAL
- Таймери STM32 – одноімпульсний режим/CMSIS
- Таймери STM32 – одноімпульсний режим/HAL
- Таймери STM32 – remapping/CMSIS
- Таймери STM32 – порівняння розмірів коду для CMSIS i HAL
Статті
- Помилка оптимізації GCC-AVR, 29 березня 2013 р.
- Надіюся, зараз такого менше.
- Стандартна бібліотека C та SemiHosting (на прикладі STM32 і CoIDE), 2015,
- C++ із ARM GCC + STM32 (+ CoIDE),2015
- Планую повторити таке дослідження стану справ для сучасних компіляторів та пакетів програм, але в цілому – ситуація із підтримкою С++ якісно покращилася, більшість таких “костилів” більше не потрібні. Однак, стаття може бути корисною, щоб краще зрозуміти затрати на різні засоби С++.
- libcxxrt в ролі libsupc++ – бібліотеки підтримки мовних засобів часу виконання, 2015 – доповнення до попередньої статті, спроба економніше обробляти виключення. Тоді я так і не розібрався, зараз шанси більші, але поки не варту необхідних витрат часу і сил.
- Мікро-реалізація стандартної бібліотеки C++ – uClibc++, 2015 – доволі дискусійна бібліотека, та й суттєво краще з 2015 до 2022 року не стало, а останній комміт – 2020-06-04.
- Огляд STM32 (ARM Cortex-M від STMicroelectronics), 15 жовтня 2012 р. – трохи застарілий і трохи наївний текст.
- Помилка в ARM CMSIS, 6 квітня 2013 р.
I2C EEPROM – 24CXX
Перша моя серія статей про Embedded – виконувалося із дуже обмеженим доступом до обладнання і взагалі без попередніх знань. Можливо, колись оновлю.
- Робота з EEPROM пам’яттю 24CXX – огляд – зокрема, огляд I2C.
- Робота з EEPROM пам’яттю 24CXX – Arduino Wire
- Робота з EEPROM пам’яттю 24CXX – Software, Arduino
- Робота з EEPROM пам’яттю 24CXX – Soft, AVR8
Застарілі тексти
Залишаю їх для колекції та для довідки:
- Arduino – огляд посилань, 6 квітня 2012 р.
- CooCox CoIDE, 2012 – непогане IDE було на свій час.
Інше
Продовження...dos
Звідна таблиця версій DOS – work in progress
Поки писав про DOS 4.00, Tandy 1400LT тощо, регулярно мусив уточнювати всілякі подробиці щодо можливостей різних версій DOS. При чому, в різних джерелах є різнобій. То вирішив зібрати все в одному місці і потроху уточнювати.
Продовження...До релізу джерельних текстів DOS 4.0x та матеріалів European DOS 4
Два місяці тому1 Microsoft відкрила (майже) повні джерельні тексти MS DOS 4.00 та частину славнозвісно загадкового Multitasking чи European MS DOS 4.02, приблизно еквівалентну OEM Adaptation Kit (OAK)3. Звичайно, я зразу захотів спробувати скомпілювати та подивитися, що там із SYS.COM. Але, хоча, з підказками спільноти, це вдалося швидко, через звичну безліч справ з студентами і взагалі в УКУ, описати свої знахідки тоді не вдавалося і пишу, вкотре, безнадійно відставши від першовідкривачів.
Отож, експериментуємо.
-
26 квітня 2024 року. ↩
-
Базується на DOS 2.0, працює в реальному режимі, не має відношення до “справжнього” MS DOS 4.0. Див. також Wiki: MS-DOS 4.0 (multitasking) та ‘‘The History of Multitasking MS-DOS’’. ↩
-
Джерельні тексти та об’єктні файли, які Microsoft надавала OEM-виробникам для адаптації під їх комп’ютери. Див, наприклад: Microsoft MS-DOS OEM Adaption Kit 3.x, [MS-DOS 2.0 OEM Adaptation Kit (February 8, 1983)] (https://archive.org/details/msdos-2.0-oak). Зазвичай, IO.SYS, FORMAT.COM чи SYS.COM постачалися як джерельні тексти, а MSDOS.SYS, як умовно-платформонезалежний, постачався як набір об’єктних файлів. ↩
SYS.COM з 86-DOS 1.10
Поки возився з SYS.COM з 86-DOS версій 0.11 та 0.34, випадково дизасемблював цю ж утиліту з 86-DOS 1.10. Тож, вирішив доповнити колекцію статей про неї.
Продовження...SYS.COM з 86-DOS 0.11 та 0.34
Насправді, ця стаття – трішки обман. Все почалося з того, що до 86-DOS я поліз, щоб глянути на їх SYS.COM, який багато раз дизасемблював для різних версій MS/PC-DOS.
Продовження...86-DOS 0.11 та 0.34
Знайдені нові старі версії 86-DOS – 0.11 та 0.34, спричинили цілу хвилю публікацій. Десь на десятку побачених, вирішив і я спробувати їх.
- Емуляція
- Формат диску – FAT12, з 16-байтовими записами каталогу
- Вміст дисків та експерименти
- Посилання
- Виноски
pok
Список літератури з проектування мікрочіпів та електроніки від лабораторії Лампа
Продовження...Лабораторія “Лампа” розповсюджує дуже класні матеріали, поміж них – списки літератури. Оскільки Фейсбук – річ ефемерна, з дозволу автора, дублюю в себе. Текст далі – належить “Відкритій лабораторії електроніки Lampa”.
Всі права в авторів і вся вдячність – їм же!
Огляд floating point – комп’ютерних чисел з рухомою крапкою
- Ілюстрації проблеми
- Комп’ютерні дробові числа
- IEEE 754
- IEEE 754 в програмуванні
- FP8
- Підсумок
- Додатки
- Посилання
- Виноски
Floating point numbers – числа із рухомою крапкою1. Давайте розглянемо, як їх представляють в комп’ютерах і які це має наслідки для обчислень.
Ілюстрації проблеми
Рекурентна послідовність Мюллера
Перш ніж перейти до подробиць, спробуйте обчислити таку рекурентну послідовність, де всі змінні – floating point2, з допомогою будь-якої мови програмування – Python, C, C++, Rust, Lua тощо:
fn(x, y) := 108 - (815 - 1500/y)/x
v_0 = 4
v_1 = 4.25
v_i = fn(v_{i-1}, v_{i-2})
popular
Мюонна аномалія
Причепилися тут недавно до бідних мюонів, а в мене все руки не доходили написати… Постараюся максимально коротко.
Продовження...Цей текст взято з поста в Facebook з мінімальними змінами, тому дату поставив відповідну.
physics
Мюонна аномалія
Причепилися тут недавно до бідних мюонів, а в мене все руки не доходили написати… Постараюся максимально коротко.
Продовження...Цей текст взято з поста в Facebook з мінімальними змінами, тому дату поставив відповідну.
other
Вітаю в новому домі свого блогу!
З 2011 року веду блог: http://indrekis2.blogspot.com/, однак, з цією платформою є купа проблем. Через них, враховуючи недостачу сил, до написання та публікації доходить все рідше – зараз вже є кілька десятків напівготових статей. Але й возитися з налаштуванням власної CMS бракувало і сил та часу і натхнення. Вирішив просто створити репозиторій на GitHub і писати там – що теж має купу недоліків, в тому числі для читачів, але якраз тоді колега показав, що Jekyll, який дружить з GitHub pages, зовсім просто налаштовується. Так і з’явився цей хостинг для блогу.
Продовження...disk images
Робота із образами дисків CP/M
Огляд проблеми
IBM PC-сумісні комп’ютери1 трохи стандартизували формати дискет, тому, для комп’ютерів цієї епохи домінують побайтові образи – й так зрозуміло, що сектор 512 байт, формат визначається BPB у бут-секторі, а де не визначається (для дисків епохи DOS 1.xx) – можна вгадати за розміром. Ілюстрація – плагін для Total Commander-а, який працює лише із ‘‘плоскими’’ образами, відкриває абсолютну більшість образів дискет, скачаних із сайтів з ретро-софтом.
Звичайно, залишалися нестандартні формати, дискети із захистом від копіювання, формати інших операційних систем – не сімейства MS-DOS і похідних від них. Завдяки низькорівневій природі апаратури дисководів, можливими були безліч варіацій. Для роботи із ними було створено спеціалізоване програмне забезпечення. Великого поширення набули Teledisk (типове розширення .td0) та Imagedisk (.imd) – у своїх образах вони зберігають службову інформацію, дозволяючи відтворити такі ‘‘хитрі’’ образи2.
Однак, із CP/M ситуація інша. Різні комп’ютери обладнувалися різними, часто не сумісними між собою, дисководами. Вони різні за розміром – 8”, 5.25”, 3.5”, 3”; різні за принципами – soft sectors vs hard sectors; кількістю сторін (іншими словами – магнітних голівок), кількістю треків, розміром секторів, skewing-ом тощо.
-
Писав трішки про початок цієї епохи: MS/PC DOS 1.0, MS/PC DOS 1.XX в емуляторах, MS/PC DOS 1.XX “Ось ти який, північний олень!”, DOS FCB. ↩
-
Заради лаконічності, і щоб не втонути у настільки широкій темі, свідомо дуже спрощую. В сучасному світі за подробицями можна заглянути сюди, сюди або сюди, чи, хоча б, на Wiki та глави ‘‘Sector-level organization’’ і ‘‘Floppy disk representation’’ інструкції MAME. На щастя, з Осборном так низько (по рівнях абстракції) опускатися не довелося ↩
cpp
Чергове збочене використання С++
Прикол
Люблю С++, використовую її цілу вічність, викладаю тривалий час. Звичайно, усвідомлюю недоліки – як то кажуть, “ти змушуєш мою голову битися частіше”, періодами за це ненавиджу. Але, все ж, значна частина складнощів – не через саму мову. Свій вклад дає давня історія, багаж зворотної сумісності і безлічі застарілих практик1. Однак, підозрюю, вагому роль відіграє також щось схоже на переляк – внаслідок заплутаності через складність мови і безлічі правил.
Наштовхнув мене на цю думку код, який трапився в дипломній роботі мого студента – дуже потужного.
-
Останніх особливо важко позбутися – через безліч згадок в Інтернеті, відсутність потреби оновлювати свої знання в багатьох досвідчених розробників, та й через згадану зворотну сумісність. ↩
os
Підходи до керування буферами в API різних операційних систем
Розповідаю студентам про низькорівневі API POSIX-сумісних систем – системні виклики та функції libc. Для порівняння зачіпаю підходи MS Windows та FreeRTOS. Та й місцями сам дивуюся зоопарку різноманітних непослідовностей у цих засобах. Більшість зумовлені історичними причинами разом із потребою підтримувати зворотну сумісність, частина – технічними, які я не розумію через недостатній досвід у відповідних сферах1, щось ще, певне, аналогом дрейфу генів із теорії еволюції…
Один із найпрямолінійніших прикладів такої заплутаності – менеджмент пам’яті під буфер, де операційна система (ОС) має покласти якусь інформацію. Розповідаючи про функції нижче, наголошую студентам – завчати нюанси конкретних функцій не потрібно. Якщо будете щодня з тим стикатися – саме осяде в голові. Пам’ятайте спектр ідей – щоб розуміти прочитане правильно (а не додумувати згідно своїх фантазій – поширена цитата: “я думав/ла воно ж само якось виділить/звільнить/знайде?”) та обов’язково звіряйтеся із документацією. Але після підготовки до відповідних пар вирішив, свіжими слідами, записати типові приклади.
-
Книга Brian Kernighan “UNIX: A History and a Memoir”, 2019 трохи прояснила деякі нюанси. Все ж, в цікаві часи живемо – творці технологій, письменники та науковці, чиї твори та відкриття формували той світ із яким я, та багато хто із мого оточення, взаємодіють, часто ще живі. Керніган книгу спогадів випустив, Том Рей (так, я нахабно хвалюся) відгук на роботу моєму дипломнику написав – про цю роботу ще писатиму, студентка враженнями від спілкування із Tim Berners-Lee ділиться тощо Однак, повчальнішими є технічні книжки тих часів. Charles Petzold, “Programming Windows” 1988-го року – ще про Windows 2.0, разом із “Extending DOS” by Ray Duncan et. al” та “Эндрю Шульман – Неофициальная Windows 95”, “The Old New Thing” від Raymond Chen і парою книг про OS/2, сильно прояснюють, чому MS Windows є таким, як є. Старі видання Таненбаума та “Operating systems” by Harvey Deitel and Paul Deitel, прояснили те ж стосовно інших ОС (зрозуміло – менш глибоко). Читається, як художні (історично-детективні) романи – коли вже твердо знаєш, що було далі. Іноді хочеться посміятися над наївністю, але частіше дивуєшся прозорливістю – коли пишуть щось, що через десяток років назвали новим проривом. Або коли бачиш (поза-)попередній виток спіралі технологій – типу обіцянки штучного інтелекту, голосових інтерфейсів та розпізнання мови, автоматичних перекладачів у книжках 60-х. Головне, написано дуже схоже на тексти в сучасних. Приклад: “Дитяча енциклопедія, том 03, числа і фігури, речовина і енергія”, 1959 російською/1963 українською, розділ про ЕОМ. Хоча, аж зараз, здається, ці обіцянки стають реальністю. ↩
os2
Огляд книг ‘‘Inside OS/2’’ та ‘‘Advanced Os/2 Programming’’ з кінця 1980-х
Продовжуючи серію ретро-літоглядів, хочу розповісти про дві книги, присвячені OS/21: “Inside OS/2” by Gordon Letwin, 1988 та “Advanced Os/2 Programming” by Ray Duncan, 1989.
Вони зовсім протилежні за призначенням. Друга – глибоко прагматична, а перша – навпаки, більше про ідею і принципи. Іншими словами, вони взаємно доповнюють одна одну.
Предмет книг
Дуже коротко про тему цих книг, OS/2. Це багатозадачна однокористувацька операційна система. Розпочалася як плід дружби IBM та Microsoft, потім розвивалася IBM, але з часом програла іншим ОС загального використання. Існує досі, як спеціалізована, з назвою ArcaOS.
Поміж іншого, була чи не першою масовою ОС з підтримкою потоків – напишу про це окремо.
Розпочинала своє життя як 16-бітова система для 286 – через дивні тогочасні ідеї IBM. Такими залишалися версії 1.xx – 2.xx і наступні вже були 32-бітовими2. Обидві книги стосуються якраз 16-бітових варіантів OS/2 – 32-бітова з’явилася вже в 1991-1992.
- “Inside OS/2” згадує лише версію 1.00 (грудень 1987).
- “Advanced Os/2 Programming” вже знає про 1.10 (листопад 1988, при тому, що книжка містить передмову від грудня 1988) – ту, що з GUI, але говорити про GUI автор уникає.
Переходимо до огляду книг.
-
Ця система один час мала для мене певну містичну привабливість – в юності багато про неї чув, але не бачив, за межами книжки3, прочитаної щоб здати курс “Операційних систем” на екстернаті в “Львівській політехніці”. ↩
-
16-бітовий код залишався, для зворотної сумісності, як і в Windows 9x. ↩
-
Російський переклад (1991-го) “Inside OS/2 : the complete programmer’s reference”, J. Campbell, 1988. ↩