#26 2025-08-21 01:05:23

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

MikeM пише:

Там виводиться байт 0b01010101 молодшим бітом вперед

При константному значенні цей код компілиться в пари ldi/out. Кожна з цих інструкцій на atmega328p виконується за один такт. При 16 МГц один біт за 125 нс, 8 біт за 1 мкс за 937.5 нс.
Як давно осцилограф калібрували?  wink
Або може у вас якийсь китайський емулятор атмеги на 32-бітному ядрі та 72 МГц, таке теж трапляється.

Остання редакція dimich (2025-08-21 01:14:59)

Неактивний

#27 2025-08-21 01:42:40

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

Ще може бути, що ваш компілятор виявився розумніший, і згенерував щось типу

        ldi r24,lo8(1)
        out 0x5,r24
        out 0x5,__zero_reg__
        out 0x5,r24
        out 0x5,__zero_reg__
        out 0x5,r24
        out 0x5,__zero_reg__
        out 0x5,r24
        out 0x5,__zero_reg__

Це 8 біт за 0.5 мкс. Але ж це константні дані. Для знакогенерації чи інших фіксованих картинок ок, для довільного зображення вже так не буде.

Остання редакція dimich (2025-08-21 02:18:30)

Неактивний

#28 2025-08-21 04:55:39

jokeer
Гість

Re: Регістрова змінна

китайський емулятор атмеги на 32-бітному ядрі та 72 МГц

Blue pill? Так в ньому інша система команд повинна бути  wink і gpio трохи інакше влаштовано мабуть.

Можна подивитися як влаштована ліба для адресних світлодіодів, там досить швидко біти виводяться. І на форумі був пост про генерацію відео,  але там було stm32.

#29 2025-08-21 06:30:55

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

jokeer пише:

Blue pill? Так в ньому інша система команд повинна бути  wink і gpio трохи інакше влаштовано мабуть.

Нє, Blue Pill - то ж наче STM32.
Колись попалась в руки "атмега", корпус явно перемаркований, таймінги дивні, не відповідають даташиту. Деякі фʼюзи не шились, ще якісь дивності з периферією були. Міряв споживання в різних режимах - на атмегу зовсім не схоже, і пульсації струму 72 МГц. Хоча шилась по-AVRівськи і AVRівський байткод виконувала. Потім перестала по ISP відповідати. Думав, може SPIEN фʼюз злетів. Вирішив 12-вольтовим програматором до неї достукатись, вона і згоріла нафіг.

jokeer пише:

Можна подивитися як влаштована ліба для адресних світлодіодів, там досить швидко біти виводяться.

Для довільних даних швидше як 2 такта на біт все одно не отримати. А якщо чисто програмно, не використовуючи SPI чи UART, то ще час на завантаження саміх даних в регістри.

Мені вдавалось колись генерувати зображення на атмезі, і VGA, і PAL. Але фіксовані фрагменти по пікселю за такт, або довільні дані по 2 такта. При тактовій 20 МГц це було щось біля 300 з чимось пікселів по горизонталі.

jokeer пише:

І на форумі був пост про генерацію відео,  але там було stm32.

Там була генерація апаратним LTDC.

Остання редакція dimich (2025-08-21 06:48:55)

Неактивний

#30 2025-08-21 07:30:32

MikeM
Учасник
З Київ
Зареєстрований: 2017-11-03
Повідомлень: 173

Re: Регістрова змінна

dimich пише:

Ще може бути, що ваш компілятор виявився розумніший, і згенерував щось типу

Схоже, що це найкраще пояснення того, що відбувається. Дякую за думку

Неактивний

#31 2025-08-21 07:45:41

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

MikeM пише:

Схоже, що це найкраще пояснення того, що відбувається.

Але приведений вами код в такі інструкції не скомпілиться, бо у вас же пишеться весь регістр PORTB. Компілятор не знає, що з нього потрібен тільки один біт, а решта ігнорується. Хіба що значення після кожного зсуву заздалегідь завантажились в 7 регістрів.
Можливо, компілювався схожий, але дещо відмінний від цього код. Потрібно дивитись дизасемблером, що там відбувається насправді.

Неактивний

#32 2025-08-21 08:15:52

jokeer
Гість

Re: Регістрова змінна

Хм. Виводити дані через spi, порахувати такти, щоб наступний байт завантажувався зразу після вивантаження- тоді можна або без розривів, або з мінімальними.  Але проблема- пам'яті не вистачить.
Хіба що кілька рядків виводити.

#33 2025-08-21 08:33:44

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

jokeer пише:

Хм. Виводити дані через spi, порахувати такти, щоб наступний байт завантажувався зразу після вивантаження- тоді можна або без розривів, або з мінімальними.

Саме так і реалізується.

jokeer пише:

Але проблема- пам'яті не вистачить.

Якщо виводити текст, то багато пам'яті не потрібно: шрифт на флешці лежить. За 16 тактів можна багато чого встигнути smile

Неактивний

#34 2025-08-21 10:13:42

jokeer
Гість

Re: Регістрова змінна

Все одно є сумніви в доцільності. Хіба що для ачівки з ненормального програмування.  Якщо це повноцінний дисплей- ціна більш підходящої мікросхеми не грає ніякої ролі.  Якщо OSD - тим більше, max7456 все рішає.

#35 2025-08-21 17:38:35

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

Щодо практичної доцільності - то автору видніше. А щодо ненормальності я би посперечався. Якраз такі задачі дають розуміння нутрощів як конкретної платформи, так і в загальному. І розуміння предметної області. Без такого розуміння тільки скетчі ліпити з готових бібліотек за вказівками AI.
Та й порція ендогенного дофамінчику природнім шляхом - це приємно.

Неактивний

#36 2025-08-21 22:10:35

MikeM
Учасник
З Київ
Зареєстрований: 2017-11-03
Повідомлень: 173

Re: Регістрова змінна

Трохи розвію туман. Пристрій повинен приймати послідовні 32-розрядні слова і відображати на моніторі їх декодований вміст у вигляді 24 текестових рядків (виключно цифри) довжиною по 25...30 символів. Ідей є кілька. Вирішив почати з Arduino. Прийом інформації вже реалізовано - для цього вистачило періоду і тривалості рядкових синхроімпульсів. Наразі триває боротьба за формування відеосигналу в форматі 640*480*60 Гц

Остання редакція MikeM (2025-08-21 22:12:05)

Неактивний

#37 2025-08-21 23:59:18

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

MikeM пише:

Прийом інформації вже реалізовано - для цього вистачило періоду і тривалості рядкових синхроімпульсів.

Якщо девайс сам обирає коли приймати, тобто є мастером шини, то такий варіант цілком робочий.

MikeM пише:

Наразі триває боротьба за формування відеосигналу в форматі 640*480*60 Гц

Для атмеги є реалізації, наприклад.
Нажаль, свою реалізацію навряд чи вже знайду, грався з цим років 20 тому.
Є цікаві рішення і на інших платформах.

Розглядали інші варіанти? Будь-яка козявка з апаратним HDMI-контролером значно спростила би реалізацію. А якщо потреба відображати саме на VGA, то можна через готовий перехідник.

Остання редакція dimich (2025-08-22 00:01:06)

Неактивний

#38 2025-08-22 00:21:01

MikeM
Учасник
З Київ
Зареєстрований: 2017-11-03
Повідомлень: 173

Re: Регістрова змінна

А можна приклад козявки з HDMI?

Неактивний

#39 2025-08-22 01:23:39

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

MikeM пише:

А можна приклад козявки з HDMI?

Raspberry Pi Zero?

Неактивний

#40 2025-08-22 05:56:14

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

Хм, здається, я здогадуюсь, чому так мало козявок з HDMI. Це ж проприєтарний стандарт. За кожний розʼєм на виробі потрібно ліцензійний збір сплачувати.

Неактивний

#41 2025-08-22 14:01:36

MikeM
Учасник
З Київ
Зареєстрований: 2017-11-03
Повідомлень: 173

Re: Регістрова змінна

dimich пише:

Raspberry Pi Zero?

Як на мене, то це занадто.
Я спробував виводити послідовний код через SPI. Виводить 8 біт за мікросекунду, а потім ще мікросекунду чекає. Чи можна вплинути на цю зайву затримку?

Неактивний

#42 2025-08-22 18:47:04

dimich
Учасник
Зареєстрований: 2023-12-01
Повідомлень: 613

Re: Регістрова змінна

MikeM пише:

Я спробував виводити послідовний код через SPI. Виводить 8 біт за мікросекунду, а потім ще мікросекунду чекає. Чи можна вплинути на цю зайву затримку?

Так покажіть код, яким виводите. Мабуть же там ще якісь інструкції виконуються.
На "звичайному" SPI завжди будуть проміжки в один чи два такта між байтами. Принаймні мені так і не вдалось їх позбутись. Але не ціла мікросекунда, то щось не так в коді.
Щоб отримати безперервний потік, потрібно виводити через USART в режимі SPI. Звісно, вивод буде на TX пін, а не на MOSI.

Остання редакція dimich (2025-08-22 19:37:10)

Неактивний

Швидке повідомлення

Введіть повідомлення і натисніть Надіслати

Підвал форуму