Подключить монитор к микроконтроллеру

Устройство и ремонт LCD монитора

Для того чтобы починить ЖК монитор своими руками, необходимо в первую очередь понимать, из каких основных электронных узлов и блоков состоит данное устройство и за что отвечает каждый элемент электронной схемы. Начинающие радиомеханики в начале своей практики считают, что успех в ремонте любого прибора заключается в наличии принципиальной схемы конкретного аппарата. Но на самом деле, это ошибочное мнение и принципиальная схема нужна не всегда.

Итак, вскроем крышку первого попавшегося под руку ЖК монитора и на практике разберёмся в его устройстве.

Первым делом, перед прочтением данного материала рекомендуем прочитать статью о разборке ЖК монитора.

ЖК монитор. Основные функциональные блоки.

Жидкокристаллический монитор состоит из нескольких функциональных блоков, а именно:

Как подключить матрицу 7″ к универсальному скалеру

ЖК-панель

Жидкокристаллическая панель представляет собой завершённое устройство. Сборкой ЖК-панели, как правило, занимается конкретный производитель, который кроме самой жидкокристаллической матрицы встраивает в ЖК-панель люминесцентные лампы подсветки, матовое стекло, поляризационные цветовые фильтры и электронную плату дешифраторов, формирующих из цифровых сигналов RGB напряжения для управления затворами тонкоплёночных транзисторов (TFT).

Рассмотрим состав ЖК-панели компьютерного монитора ACER AL1716. ЖК-панель является завершённым функциональным устройством и, как правило, при ремонте разбирать её не надо, за исключением замены вышедших из строя ламп подсветки.

Маркировка ЖК-панели: CHUNGHWA CLAA170EA

На тыльной стороне ЖК-панели расположена довольно большая печатная плата, к которой от основной платы управления подключен многоконтактный шлейф. Сама печатная плата скрыта под металлической планкой.

ЖК-панель монитора

ЖК-панель компьютерного монитора Acer AL1716

На печатной плате установлена многовыводная микросхема NT7168F-00010. Данная микросхема подключается к TFT матрице и участвует в формировании изображения на дисплее. От микросхемы NT7168F-00010 отходит множество выводов, которые сформированы в десять шлейфов под обозначением S1-S10. Эти шлейфы довольно тонкие и на вид как бы приклеены к печатной плате, на которой находиться микросхема NT7168F.

Печатная плата ЖК-панели

Печатная плата ЖК-панели и её элементы

Плата управления

Плату управления по-другому называют основной платой (Main board). На основной плате размещены два микропроцессора. Один из них управляющий 8-битный микроконтроллер SM5964 с ядром типа 8052 и 64 кбайт программируемой Flash-памяти.

Микропроцессор SM5964 выполняет довольно небольшое число функций. К нему подключена кнопочная панель и индикатор работы монитора. Этот процессор управляет включением/выключением монитора, запуском инвертора ламп подсветки. Для сохранения пользовательских настроек к микроконтроллеру по шине I 2 C подключена микросхема памяти. Обычно, это восьмивыводные микросхемы энергонезависимой памяти серии 24LCxx.

Основная плата (Main board)

Основная плата (Main board) ЖК-монитора

Вторым микропроцессором на плате управления является так называемый мониторный скалер (контроллер ЖКИ) TSU16AK. Задач у данной микросхемы много. Она выполняет большинство функций, связанных с преобразованием и обработкой аналогового видеосигнала и подготовке его к подаче на панель ЖКИ.

В отношении жидкокристаллического монитора нужно понимать, что это по своей сути цифровое устройство, в котором всё управление пикселями ЖК-дисплея происходит в цифровом виде. Сигнал, приходящий с видеокарты компьютера является аналоговым и для его корректного отображения на ЖК матрице необходимо произвести множество преобразований. Для этого и предназначен графический контроллер, а по-другому мониторный скалер или контроллер ЖКИ.

В задачи контроллера ЖКИ входят такие как пересчёт (масштабирование) изображения для различных разрешений, формирование экранного меню OSD, обработка аналоговых сигналов RGB и синхроимпульсов. В контроллере аналоговые сигналы RGB преобразуются в цифровые посредством 3-х канальных 8-битных АЦП, которые работают на частоте 80 МГц.

Мониторный скалер TSU16AK взаимодействует с управляющим микроконтроллером SM5964 по цифровой шине. Для работы ЖК-панели графический контроллер формирует сигналы синхронизации, тактовой частоты и сигналы инициализации матрицы.

Микроконтроллер TSU16AK через шлейф связан с микросхемой NT7168F-00010 на плате ЖК-панели.

При неисправностях графического контроллера у монитора, как правило появляются дефекты, связанные с правильным отображением картинки на дисплее (на экране могут появляться полосы и т.п). В некоторых случаях дефект можно устранить пропайкой выводов скалера. Особенно это актуально для мониторов, которые работают круглосуточно в жёстких условиях.

При длительной работе происходит нагрев, что плохо сказывается на качестве пайки. Это может привести к неисправностям. Дефекты, связанные с качеством пайки нередки и встречаются и у других аппаратов, например, DVD плееров. Причиной неисправности служит деградация либо некачественная пайка многовыводных планарных микросхем.

Блок питания и инвертор ламп подсветки

Наиболее интересным в плане изучения является блок питания монитора, так как назначение элементов и схемотехника легче в понимании. Кроме того, по статистике неисправности блоков питания, особенно импульсных, занимают лидирующие позиции среди всех остальных. Поэтому практические знания устройства, элементной базы и схемотехники блоков питания непременно будут полезны в практике ремонта радиоаппаратуры.

Блок питания ЖК монитора состоит из двух. Первый – это AC/DC адаптер или по-другому сетевой импульсный блок питания (импульсник). Второй – DC/AC инвертор. По сути это два преобразователя. AC/DC адаптер служит для преобразования переменного напряжения сети 220 В в постоянное напряжение небольшой величины.

Обычно на выходе импульсного блока питания формируются напряжения от 3,3 до 12 вольт.

Инвертор DC/AC наоборот преобразует постоянное напряжение (DC) в переменное (AC) величиной около 600 — 700 В и частотой около 50 кГц. Переменное напряжение подаётся на электроды люминесцентных ламп, встроенных в ЖК-панель.

Вначале рассмотрим AC/DC адаптер. Большинство импульсных блоков питания строится на базе специализированных микросхем контроллеров (за исключением дешёвых зарядников для мобильного, например).

Еще по теме:  Как старый монитор использовать

Так в блоке питания ЖК монитора Acer AL1716 применена микросхема TOP245Y. Документацию (datasheet) по данной микросхеме легко найти из открытых источников. Если не знаете, как найти datasheet, то обязательно прочитайте статью о поиске информации об импортных полупроводниковых элементах.

В документации на микросхему TOP245Y можно найти типовые примеры принципиальных схем блоков питания. Это можно использовать при ремонте блоков питания ЖК мониторов, так как схемы во многом соответствуют типовым, которые указаны в описании микросхемы.

Вот несколько примеров принципиальных схем блоков питания на базе микросхем серии TOP242-249.

Принципиальная схема блока питания

Рис 1 .Пример принципиальной схемы блока питания

В следующей схеме применены сдвоенные диоды с барьером Шоттки (MBR20100). Аналогичные диодные сборки (SRF5-04) применены в рассматриваемом нами блоке монитора Acer AL1716.

Схема блока на базе микросхем TOP242-249

Рис 2. Принципиальная схема блока питания на базе микросхемы из серии TOP242-249

Заметим, что приведённые принципиальные схемы являются примерами. Реальные схемы импульсных блоков могут несколько отличаться.

Микросхема TOP245Y представляет собой законченный функциональный прибор, в корпусе которого имеется ШИМ – контроллер и мощный полевой транзистор, который переключается с огромной частотой от десятков до сотен килогерц. Отсюда и название — импульсный блок питания.

Блок питания ЖК монитора

Блок питания ЖК монитора (AC/DC адаптер)

Схема работы импульсного блока питания сводится к следующему:

Выпрямление переменного сетевого напряжения 220В.

Эту операцию выполняет диодный мост и фильтрующий конденсатор. После выпрямления на конденсаторе напряжение чуть больше чем сетевое. На фото показан диодный мост, а рядом фильтрующий электролитический конденсатор (82 мкФ 450 В) – синий бочонок.

Преобразование напряжения и его понижение с помощью трансформатора.

Коммутация с частотой в несколько десятков – сотен килогерц постоянного напряжения (>220 B) через обмотку высокочастотного импульсного трансформатора. Эту операцию выполняет микросхема TOP245Y. Импульсный трансформатор выполняет ту же роль, что и трансформатор в обычных сетевых адаптерах, за одним исключением. Работает он на более высоких частотах, во много раз больше, чем 50 герц.

Поэтому для изготовления его обмоток требуется меньшее число витков, а, следовательно, и меди. Но необходим сердечник из феррита, а не из трансформаторной стали как у трансформаторов на 50 герц. Те, кто не знает, что такое трансформатор и зачем он применяется, сперва ознакомьтесь со статьёй про трансформатор.

В результате трансформатор получается очень компактным. Также стоит отметить, что импульсные блоки питания очень экономичны, у них высокий КПД.

Выпрямление пониженного трансформатором переменного напряжения.

Эту функцию выполняют мощные выпрямительные диоды. В данном случае применены диодные сборки с маркировкой SRF5-04.

Для выпрямления токов высокой частоты используют диоды Шоттки и обычные силовые диоды с p-n переходом. Обычные низкочастотные диоды для выпрямления токов высокой частоты менее предпочтительны, но используются для выпрямления больших напряжений (20 – 50 вольт). Это нужно учитывать при замене дефектных диодов.

У диодов Шоттки есть некоторые особенности, которые нужно знать. Во-первых, эти диоды имеют малую ёмкость перехода и способны быстро переключаться – переходить из открытого состояния в закрытое. Это свойство и используется для работы на высоких частотах. Диоды Шоттки имеют малое падения напряжения около 0,2-0,4 вольт, против 0,6 – 0,7 вольт у обычных диодов. Это свойство повышает их КПД.

Есть у диодов с барьером Шоттки и нежелательные свойства, которые затрудняют их более широкое использование в электронике. Они очень чувствительны к превышению обратного напряжения. При превышении обратного напряжения диод Шоттки необратимо выходит из строя.

Обычный же диод переходит в режим обратимого пробоя и может восстановиться после превышения допустимого значения обратного напряжения. Именно это обстоятельство и является ахиллесовой пятой, которое служит причиной выгорания диодов Шоттки в выпрямительных цепях всевозможных импульсных блоках питания. Это стоит учитывать в проведении диагностики и ремонте.

Для устранения опасных для диодов Шоттки всплесков напряжения, образующихся в обмотках трансформатора на фронтах импульсов, применяются так называемые демпфирующие цепи. На схеме обозначена как R15C14 (см.рис.1).

При анализе схемотехники блока питания ЖК монитора Acer AL1716 на печатной плате также обнаружены демпфирующие цепи, состоящие из smd резистора номиналом 10 Ом (R802, R806) и конденсатора (C802, C811). Они защищают диоды Шоттки (D803, D805).

Демпфирующая цепь

Демпфирующие цепи на плате блока питания

Также стоит отметить, что диоды Шоттки используются в низковольтных цепях с обратным напряжением, ограниченным единицами – несколькими десятками вольт. Поэтому, если требуется получение напряжения в несколько десятков вольт (20-50), то применяются диоды на основе p-n перехода. Это можно заметить, если просмотреть datasheet на микросхему TOP245, где приводятся несколько типовых схем блоков питания с разными выходными напряжениями (3,3 B; 5 В; 12 В; 19 В; 48 В).

Диоды Шоттки чувствительны к перегреву. В связи с этим их, как правило, устанавливают на алюминиевый радиатор для отвода тепла.

Отличить диод на основе p-n перехода от диода на барьере Шоттки можно по условному графическому обозначению на схеме.

Условное обозначение диода с барьером Шоттки.

Условное обозначение диода на основе p-n перехода.

После выпрямительных диодов ставятся электролитические конденсаторы, служащие для сглаживания пульсаций напряжения. Далее с помощью полученных напряжений 12 В; 5 В; 3,3 В запитываются все блоки LCD монитора.

Инвертор DC/AC

По своему назначению инвертор схож с электронными пуско-регулирующими аппаратами (ЭПРА), которые нашли широкое применение в осветительной технике для питания бытовых осветительных люминесцентных ламп. Но, между ЭПРА и инвертором ЖК монитора есть существенные различия.

Инвертор ЖК монитора, как правило, построен на специализированной микросхеме, что расширяет набор функций и повышает надёжность. Так, например, инвертор ламп подсветки ЖК монитора Acer AL1716 построен на базе ШИМ контроллера OZ9910G. Микросхема контроллера смонтирована на печатной плате планарным монтажом.

Еще по теме:  Превратить монитор в телевизор как

Микросхема контроллера OZ9910G

Микросхема контроллера OZ9910G

Инвертор преобразует постоянное напряжение, значение которого составляет 12 вольт (зависит от схемотехники) в переменное 600-700 вольт и частотой 50 кГц.

Контроллер инвертора способен изменять яркость люминесцентных ламп. Сигналы для изменения яркости ламп поступают от контроллера ЖКИ. К микросхеме-контроллеру подключены полевые транзисторы или их сборки. В данном случае к контроллеру OZ9910G подключены две сборки комплементарных полевых транзисторов AP4501SD (На корпусе микросхемы указано только 4501S).

Сборка полевых транзисторов AP4501SD

Сборка полевых транзисторов AP4501SD и её цоколёвка

Также на плате блока питания установлено два высокочастотных трансформатора, служащих для повышения переменного напряжения и подачи его на электроды люминесцентных ламп. Кроме основных элементов, на плате установлены всевозможные радиоэлементы, служащие для защиты от короткого замыкания и неисправности ламп.

Плата инвертора и её элементы

Плата инвертора и её элементы

Информацию по ремонту ЖК мониторов можно найти в специализированных журналах по ремонту. Так, например, в журнале “Ремонт и сервис электронной техники” №1 2005 года (стр.35 – 40), подробно рассмотрено устройство и принципиальная схема LCD-монитора “Rover Scan Optima 153”.

Среди неисправностей мониторов довольно часто встречаются такие, которые легко устранить своими руками за несколько минут. Например, уже упомянутый ЖК монитор Acer AL1716 пришёл на стол ремонта по причине нарушения контакта вывода розетки для подключения сетевого шнура. В результате монитор самопроизвольно выключался.

После разборки ЖК монитора было обнаружено, что на месте плохого контакта образовывалась мощная искра, следы которой легко обнаружить на печатной плате блока питания. Мощная искра образовывалась ещё и потому, что в момент контакта заряжается электролитический конденсатор в фильтре выпрямителя. Причина неисправности — деградация пайки.

Деградация пайки

Деградация пайки, вызвавщая неисправность монитора

Также стоит заметить, что порой причиной неисправности может служить пробой диодов выпрямительного диодного моста.

Источник: go-radio.ru

Подключение LCD на базе HD44780 к ATmega16 (LM016L LCD 16×2)

Как подключить LСD дисплей на базе HD44780 к ATmega16 или его цифровой аналог LM016L 16×2 в Proteus

Подключение HD44780 к ATmega16 - LM016L LCD 16x2 (3)

При работе с Arduino, Atmega, PIC или с другим микроконтроллером часто возникает необходимость вывести какие-либо текстовые данные на дисплей. С цифрами проще, можно использовать 7 сегментный индикатор, а для вывода текста необходимо использовать LCD-дисплеи (ЖКИ). В данной статьи мы рассмотрим подключение LCD-дисплея на базе контроллера HD44780 к ATmega16.

Для подключения LCD-дисплея на базе HD44780 к ATmega16 нам нужно использовать 12 выводов, можно и все 16, но не на всех контроллерах это удастся сделать, ибо физически невозможно, а программно — да:

  • 1 — Vss, земля -> GND
  • 2 — Vdd, питание -> +5 В
  • 3 — Vo (Vee), управление контрастностью напряжением -> выход потенциометра
  • 4 — RS, выбор регистра
  • 5 — R/W, чтение/запись -> земля (режим записи)
  • 6 — E, он же Enable, cтроб по спаду
  • 7-10 — DB0-DB3, младшие биты 8-битного интерфейса; не подключены
  • 11-14 — DB4-DB7, старшие биты интерфейса
  • 15 — A, питание для подсветки -> +5 В
  • 16 — K, земля для подсветки -> GND

Пример программы в Atmel Studio 7

LCD.h

#ifndef LCD_H_ #define LCD_H_ #define LCDDATAPORT PORTB // Порт и пины, #define LCDDATADDR DDRB // к которым подключены #define LCDDATAPIN PINB // сигналы D4-D7. #define LCD_D4 3 #define LCD_D5 4 #define LCD_D6 5 #define LCD_D7 6 #define LCDCONTROLPORT PORTB // Порт и пины, #define LCDCONTROLDDR DDRB // к которым подключены #define LCD_RS 0 // сигналы RS, RW и E. #define LCD_RW 1 #define LCD_E 2 #define LCD_STROBEDELAY_US 5 // Задержка строба #define LCD_COMMAND 0 #define LCD_DATA 1 #define LCD_CURSOR_OFF 0 #define LCD_CURSOR_ON 2 #define LCD_CURSOR_BLINK 3 #define LCD_DISPLAY_OFF 0 #define LCD_DISPLAY_ON 4 #define LCD_SCROLL_LEFT 0 #define LCD_SCROLL_RIGHT 4 #define LCD_STROBDOWN 0 #define LCD_STROBUP 1 #define DELAY 1 void lcdSendNibble(char byte, char state); char lcdGetNibble(char state); char lcdRawGetByte(char state); void lcdRawSendByte(char byte, char state); char lcdIsBusy(void); void lcdInit(void); void lcdSetCursor(char cursor); void lcdSetDisplay(char state); void lcdClear(void); void lcdGotoXY(char str, char col); void lcdDisplayScroll(char pos, char dir); void lcdPuts(char *str); void lcdPutsf(char *str); void lcdPutse(uint8_t *str); void lcdLoadCharacter(char code, char *pattern); void lcdLoadCharacterf(char code, char *pattern); void lcdLoadCharactere(char code, char *pattern); #endif /* LCD_H_ */

LCD.c

// Подключение LCD на базе HD44780 к ATmega16 (LM016L LCD 16×2) // сайт http://micro-pi.ru #define F_CPU 8000000UL #include #include #include #include #include #include «LCD.h» /* Отправляет младшую половину байта byte в LCD. Если state == 0, то передаётся как команда, если нет, то как данные. */ void lcdSendNibble(char byte, char state) < // Пины управления — на выход LCDCONTROLDDR |= 1else < LCDCONTROLPORT // Взводим строб LCDCONTROLPORT |= 1 // byte в порт вывода данных if (byte <2)) < LCDDATAPORT |= 1<if (byte <1)) < LCDDATAPORT |= 1<if (byte <0)) < LCDDATAPORT |= 1<// Пауза _delay_us(LCD_STROBEDELAY_US); // Опускаем строб.

Полубайт ушёл LCDCONTROLPORT /* Читает половину байта из LCD. Если state == 0, то читается команда, если нет, то данные. */ char lcdGetNibble(char state) < char temp = 0; // Пины управления — на выход LCDCONTROLDDR |= 1else < LCDCONTROLPORT // Взводим строб LCDCONTROLPORT |= 1 if (LCDDATAPIN if (LCDDATAPIN if (LCDDATAPIN // возвращаем прочитанное return temp; > /* Читает байт из LCD.

Если state == 0, то читается команда, если нет, то данные. */ char lcdRawGetByte(char state) < char temp = 0; temp |= lcdGetNibble(state); temp = temp/* Отравляет байт в LCD. Если state == 0, то передаётся как команда, если нет, то как данные. */ void lcdRawSendByte(char byte, char state) < lcdSendNibble((byte>>4), state); lcdSendNibble(byte,state); > /* Читает состояние LCD, возвращает 0xff, если флаг занятости установлен, и 0x00, если нет. */ char lcdIsBusy(void) < /* TODO if (lcdRawGetByte(LCD_COMMAND) <7)) return 0xff; else return 0x00; */ _delay_ms(DELAY); return 0x00; >/* Выполняет начальную инициализацию дисплея.

Еще по теме:  Как отключить фрисинк на мониторе

Четырёхбитный режим. */ void lcdInit(void) < while (lcdIsBusy()) ; lcdSendNibble(0b0010, LCD_COMMAND); while (lcdIsBusy()) ; lcdRawSendByte(0b00101000, LCD_COMMAND); while (lcdIsBusy()) ; lcdRawSendByte(0b00000001, LCD_COMMAND); while (lcdIsBusy()) ; lcdRawSendByte(0b00000110, LCD_COMMAND); while (lcdIsBusy()) ; lcdRawSendByte(0b00001100, LCD_COMMAND); >/* Устанавливает режим курсора: 0 — выключен, 2 — включен, 3 — моргает. Если на момент запуска LCD был выключен (lcdSetDisplay), то он будет включен. */ void lcdSetCursor(char cursor) < while (lcdIsBusy()); lcdRawSendByte((0b00001100 | cursor), LCD_COMMAND); >/* Включает или выключает отображение символов LCD.

При каждом вызове выключает курсор. */ void lcdSetDisplay(char state) < while (lcdIsBusy()); lcdRawSendByte((0b00001000 | state), LCD_COMMAND); >/* Очищает LCD. */ void lcdClear(void) < while (lcdIsBusy()) ; lcdRawSendByte(0b00000001, LCD_COMMAND); >/* Устанавливает курсор в заданную позицию. */ void lcdGotoXY(char str, char col) < while (lcdIsBusy()); lcdRawSendByte((0b10000000 | ((0x40 * str) + col)), LCD_COMMAND); >/* Сдвигает область отображения на указанное количество символов вправо или влево. */ void lcdDisplayScroll(char pos, char dir) < while (pos)< while (lcdIsBusy()) ; lcdRawSendByte((0b00011000 | dir), LCD_COMMAND); pos—; >> /* Выводит строку из RAM в позицию курсора. */ void lcdPuts(char *str) < while (*str)< while (lcdIsBusy()) ; lcdRawSendByte(*str++, LCD_DATA); >> /* Выводит строку из flash в позицию курсора. */ void lcdPutsf(char *str) < while (pgm_read_byte(str))< while (lcdIsBusy()) ; lcdRawSendByte(pgm_read_byte(str++), LCD_DATA); >> /* Выводит строку из eeprom в позицию курсора. */ void lcdPutse(uint8_t *str) < while (eeprom_read_byte(str))< while (lcdIsBusy()) ; lcdRawSendByte((char)(eeprom_read_byte(str++)), LCD_DATA); >> /* Загружает символ в знакогенератор. */ void lcdLoadCharacter(char code, char *pattern) < while (lcdIsBusy()); lcdRawSendByte((code<<3) | 0b01000000, LCD_COMMAND); for (char i = 0; i <= 7; i++)< while (lcdIsBusy()) ; lcdRawSendByte(*pattern++, LCD_DATA); >while (lcdIsBusy()); lcdRawSendByte(0b10000000, LCD_COMMAND); > /* Загружает символ из flash в знакогенератор. */ void lcdLoadCharacterf(char code, char *pattern) < while (lcdIsBusy()); lcdRawSendByte((code<<3) | 0b01000000, LCD_COMMAND); for (char i = 0; i <= 7; i++)< while (lcdIsBusy()); lcdRawSendByte(pgm_read_byte(pattern++), LCD_DATA); >while (lcdIsBusy()); lcdRawSendByte(0b10000000, LCD_COMMAND); > /* Загружает символ из eeprom в знакогенератор. */ void lcdLoadCharactere(char code, char *pattern) < while (lcdIsBusy()); lcdRawSendByte((code<<3) | 0b01000000, LCD_COMMAND); for (char i = 0; i <= 7; i++)< while (lcdIsBusy()) ; lcdRawSendByte(eeprom_read_byte(pattern++), LCD_DATA); >while (lcdIsBusy()) ; lcdRawSendByte(0b10000000, LCD_COMMAND); >

main.c

// Подключение LCD на базе HD44780 к ATmega16 (LM016L LCD 16×2) // сайт http://micro-pi.ru #define F_CPU 8000000UL #include #include #include #include «LCD.h» int main(void)

Схема подключения LCD на базе HD44780 к ATmega16 в ISIS 7 Professional — Proteus. Симуляция.

Схема подключения HD44780 к ATmega16 - LM016L LCD 16x2 (1)

Вам также потребуется добавить резистор номиналом 100-150 Ом к 15-му контакту, чтобы индикатор подсветки не вышел из строя.

Источник: micro-pi.ru

Простая самодельная VGA видеокарта

Компьюлента Orion - Hi-Tech новости со всего света

Насколько мне известно, довольно многим интересно подключить микроконтроллер к обычному монитору и попробовать что-либо вывести на экран. В этой статье пойдёт речь о создании простейшей VGA-видеокарты на базе микроконтроллера atmega168-20.
Вообще говоря, этому проекту сто лет в обед. Но когда-то я обещал рассказать про эту видеокарту и здесь, но всё было лень. Теперь пришло время исполнить обещанное.
Данная видеокарта выдаёт картинку разрешением 254×240 точек при 256 цветах. Работает вся эта штука в стандартном VGA режиме 640×480 при 60 Гц развёртки. Испытывал я эту видеокарту с 6 мониторами (1 ЭЛТ и 5 ЖК), при этом на всех мониторах карта работала, за исключением монитора фирмы Acer. Чем ему не понравился сигнал, я так и не понял.

В макетном исполнении видеокарта выглядит вот так:

Видеокарта состоит из двух модулей: модуля памяти и модуля ЦАП’а.
Модуль памяти просто формирует сигналы синхронизации (HS, VS) и гашения луча (BL) и выдаёт наружу код цвета (D0. D7), который модуль ЦАП’а преобразует в уровень 0-0.7 В и подаёт на монитор. Микроконтроллер модуля памяти просто перебирает адреса статического ОЗУ, а данные из ОЗУ и есть цвета точек. С использованием микроконтроллера Atmega168 с частотой 20 МГц требуется 2 такта на одну точку, поэтому эта часть программы написана на ассемблере и развёрнута в повторяющийся фрагмент для каждой точки строки. Я позволю себе не описывать развёртку VGA-сигнала во времени, тем более, что в интернете полно информации на этот счёт (хоть и часто не совпадающей друг с другом), а я за давностью лет уже порядком подзабыл, какую временную диаграмму я реализовал в этой видеокарте.

Схема модуля памяти (открыв в новом окне можно увеличить).

Модуль ЦАП’а состоит из трёх обычных R-2R ЦАП’ов с ключами и выходным эмиттерным повторителем (из-за которого несколько «зарезается» диапазон цветов). Если кто придумает, как дёшево и сердито исправить это «зарезание» — милости прошу в комментарии. На радиокоте мне посоветовали заменить эмиттерный повторитель на истоковый, но я этот совет так и не проверил. Как видно из схемы, я отвёл 3 бита на красный, 3 бита на зелёный и 2 бита на синий цвет. Транзисторы я взял КТ-315.

Что именно будет отображать видеокарта определяет управляющий контроллер. Его задача — выставлять адрес на шину адреса (A0. A15), выставлять данные на шину данных (D0. D7), выставлять сигналы WR (запись по низкому уровню), OE (разрешение вывода данных при низком уровне) и выставлять сигнал A/B (переключение памяти на работу с управляющим контроллером по низкому уровню). Управляющий контроллер получает от платы памяти сигнал гашения луча (BL), который может быть использован для синхронизации записи в память видеокарты.

Работает такая видеокарта вот так:

Удачи в развитии проекта!

Источник: orion-int.ru

Оцените статью
Добавить комментарий