Оглавление:
2025 Автор: John Day | [email protected]. Последнее изменение: 2025-01-13 06:58
Микропроцессор 6502 впервые появился в 1975 году и был разработан небольшой командой под руководством Чака Педдла для MOS Technology. Тогда он использовался в видеоприставках и домашних компьютерах, включая Atari, Apple II, Nintendo Entertainment System, BBC Micro, Commodore VIC20 и 64. В то время он был одним из самых дешевых на рынке. Он никогда не исчезал, и теперь он используется любителями и профессионалами для многих приложений.
Я использую версию W65C02S6TPG-14, произведенную Western Design Center и потребляющую в десять раз меньше энергии, чем оригинал. Его особенность заключается в том, что он не должен работать на частоте 1 МГц, как оригинальный чип. Он может работать намного медленнее или использоваться для пошагового выполнения программы и даже увеличиваться до 14 МГц. Технические характеристики чипа объясняют его возможности. Другие чипы 6502 не имеют такой возможности и не будут работать таким образом. Чипы в настоящее время доступны на Ebay, а также в других источниках.
Запасы
Все используемые детали в настоящее время доступны на Ebay, AliExpress и других.
Шаг 1: концепция
Я черпал вдохновение у Бена Етера, который выпустил на YouTube серию видеороликов о 6502 и многих других аспектах создания компьютеров и схем. Первоначально программа была написана им, и я изменил ее и некоторые из его проектов, чтобы создать эту инструкцию. Еще одним человеком, который вдохновил меня, был Эндрю Джейкобс, у которого есть раздел на GitHub, где он использует микроконтроллер PIC для управления своим 6502.
Как и Бен, я использую Arduino MEGA для мониторинга 6502. Я также использую MEGA для обеспечения тактового сигнала, в отличие от Бена. В настоящее время я не использую ни EEPROM, ни RAM.
Шаг 2: требования
Для сборки этого «компьютера» список элементов выглядит следующим образом:
1 х Arduino MEGA
1 х Западный проектный центр W65C02S6TPG-14
1 x 74HC00N IC (четырехканальный логический элемент NAND с 2 входами) или аналогичный
1 x 74HC373N IC (восьмеричная прозрачная защелка D-типа) или аналогичный
Макетные доски 2 x 830 отверстий (1 в крайнем случае)
Различные штекеры Dupont - штекерные выводы и соединительные провода
2 светодиода (я использовал синий 5 мм, так как вы можете обойтись без резисторов)
1 x 12 мм мгновенный тактильный кнопочный переключатель, установленный на печатной плате SPST или аналогичный
1 резистор 1 кОм
2 керамических конденсатора по 0,1 мкФ
1 x 8-полосный водяной световой шатер 5 мм, красный светодиод (как указано выше) или 8 светодиодов и резисторы
ПРИМЕЧАНИЕ. Если у вас есть непаянный комплект, вы можете вставить светодиоды неправильно, чтобы они были общим катодом. Я прикрепляю поводок (вместо булавки), чтобы его можно было легко подключить в другом месте. VCC теперь становится Ground. Вы, конечно, можете перевернуть светодиоды (на собранном элементе) и перепаять их, но это много баффа! В настоящее время наборы доступны на AliExpress.
Шаг 3: Собираем все вместе
Мне было проще использовать новые провода DuPont, которые не были отделены от ленты, для шины адреса и данных.
Подключите контакт 9 (A0) 6502 к контакту 52 MEGA, контакт 10 (A1) модуля 6502 к контакту 50 и т. д.
до
Подключите контакт 25 (A15) 6502 к контакту 22 MEGA.
На данный момент 16 подключений.
так же
Подключите контакт 26 (D7) 6502 к контакту 39 MEGA, контакт 27 (D6) модуля 6502 к контакту 41 и т. д.
до
Подключите контакт 33 (D0) 6502 к контакту 53 MEGA.
Еще 8 подключений.
Подключите контакт 8 (VDD) к 5 В на MEGA.
Конденсатор 0,1 мкФ, подключенный от контакта 8 к Gnd макетной платы, может быть здесь полезен, но не обязателен.
Подключите контакт 21 (VSS) к Gnd на MEGA.
Контакты 2, 4, 6, 36 и 38 можно подключить к 5 В
Подключите контакт 37 (Clock) к контактам 2 и 7 MEGA.
Подключите контакт 34 (RWB) к контакту 3 MEGA.
Подключите контакт 40 (сброс), как показано на схеме выше.
Шаг 4: Тестирование схемы
На этом этапе 6502 будет работать, и можно будет использовать программу program1. Если вы используете 8-стороннюю рамку (как указано выше), ее можно вставить прямо в макетную плату, а вывод заземлить, или вы можете использовать 8 светодиодов и резисторы. Светодиоды покажут, что находится на шине данных.
На этом этапе было бы также установить задержки в Loop () на 500 или более, чтобы следить за тем, что происходит.
Вы должны получить аналогичный вывод на последовательном мониторе, как показано выше. При нажатии кнопки Reset процессор выполняет 7 циклов, а затем ищет запуск программы в ячейках $ FFFC и $ FFFD. Поскольку у 6502 нет физических адресов для чтения, мы должны предоставить их от MEGA.
В приведенных выше выходных данных 6502 считывает $ FFFC и $ FFFD и получает $ 00 и $ 10 (младший байт, старший байт), что является началом программы на уровне $ 1000. Затем процессор начинает выполнение программы в ячейке $ 1000 (как указано выше). В этом случае он читает $ A9 и $ 55, то есть LDA # $ 55 (загрузить 85 в аккумулятор). Опять же, поскольку нет места в физической памяти, MEGA имитирует то, что считывается с шины данных.
$ 55 (85) дает двоичный шаблон 01010101, а при повороте на 1 бит влево дает $ AA (170) 10101010.
Программа показывает, что процессор работает правильно, но вскоре приедается, так что переходим к следующей части.
Шаг 5: следующий шаг
Вышеупомянутая «стопка спагетти», вероятно, будет чем-то вроде того, что у вас будет после этого этапа.
Затем вам нужно добавить микросхемы 74HC373N и 74HC00N на макетную плату.
К сожалению, контакты 373 не совпадают с шиной данных, поэтому их необходимо подсоединить проводами.
Подключите 5 В к контакту 20.
Подключите заземление к контакту 10.
Подключите контакт 33 (D0) 6502 к контакту 3 (D0) 74HC373N.
и то же самое со штырями от D1 до D7.
От Q0 до Q7 - это выходы, которые необходимо подключить к светодиодной панели или отдельным светодиодам и резисторам.
С 74HC00 требуется только 2 его ворот.
Подключите 5 В к контакту 14.
Подключите заземление к контакту 7.
Подключите контакт 17 (A8) 6502 к контакту 1 (1A) 74HC00.
Подключите контакт 25 (A15) 6502 к контакту 2 (1B) 74HC00.
Подключите контакт 34 (R / W) 6502 к контакту 5 (2B) 74HC00.
Подключите контакт 3 (1Y) 74HC00 к контакту 4 (2A) 74HC00.
Подключите контакт 6 (2Y) 74HC00 к контакту 11 (LE) 74HC373N.
Подключите контакт 11 (LE) 74HC373N к контакту 1 (OE) 74HC373N.
Вы можете подключить синий светодиод к 1Y и заземлению, а также 2Y к земле, это будет указывать, когда ворота активны.
Наконец, измените строку в процедуре onClock с program1 на program2
setDataPins (программа2 [смещение]);
Шаг 6: Программа
Программа 6502-Monitor содержит две процедуры 6502, описанные выше.
Программа все еще находится в стадии разработки и немного неопрятна.
При запуске program2 задержки в loop () могут быть 50 или меньше и даже полностью удалены. Комментирование строк Serial.print () также ускоряет работу 6502. Отсоединение контакта 1 (OE) 373 от контакта 11 (LE) дает разные результаты. Отсоединение контактов 1 и 11 микросхемы 373 от логических элементов NAND позволяет вам видеть, что находится на шине данных в каждом тактовом цикле.
Возможно, вам придется связать OE с землей, а не оставлять его плавающим, поскольку 8 выходных линий отключаются, если этот вывод становится высоким. Когда на выводе LE высокий уровень, выходные контакты такие же, как и входы. Низкий уровень на контакте LE фиксирует выходы, т.е. если входные контакты меняются, выходы остаются прежними.
Я постарался сделать программу максимально простой, чтобы ее было легче понять.
Экспериментируя с задержками, вы сможете точно следить за тем, что делает 6502.
Ниже приведены две программы (обе работают по адресу $ 1000) на ассемблере 6502:
program1
LDA № 55
NOP
ROL
1010 канадских долларов
JMP $ 1000
ROL поворачивает содержимое аккумулятора на один бит влево, что означает, что теперь $ 55 становится $ AA.
В машинном коде (шестнадцатеричный): A9 55 EA 2A 8D 10 10 4C 00 10
program2
LDA # $ 01
STA $ 8100
АЦП # $ 03
STA $ 8100
1005 японских долларов
В машинном коде (шестнадцатеричный): A9 01 8D 00 81 69 03 8D 00 81 4C 05 10
В программе program2 теперь есть физический адрес $ 8100, по которому 74HC373 находится на адресной шине.
то есть A15 из 6502 составляет 32768 (8000 долларов США), а A8 - 256 (0100 долларов США) = 33024 (8100 долларов США).
Таким образом, когда 6502 записывает в 8100 долларов (STA 8100 долларов), R / W 6502 имеет низкий уровень, и данные на шине данных 6502 фиксируются, когда 373 LE переходит на низкий уровень. Из-за 74HC00 NAND Gate сигналы меняются местами.
На приведенном выше снимке экрана вторая запись увеличилась на 3 (ADC # $ 03) - с 7F до 82 долларов.
В действительности, для конкретного местоположения 373. Это единственный физический адрес из возможных 65536, он демонстрирует, как работает адресная шина. Вы можете поэкспериментировать с разными адресными контактами и поместить их в другое место. Конечно, вам нужно будет изменить операнды STA на новое место. например Если бы вы использовали адресные строки A15 и A9, адрес был бы 8200 долларов (32768 + 512).
Шаг 7: Заключение
Я попытался продемонстрировать, насколько легко запустить 6502.
Я не являюсь экспертом в этой области, поэтому буду приветствовать любые конструктивные комментарии или информацию.
Вы можете продолжить это развитие, и мне было бы интересно, что вы сделали.
Я намерен добавить в проект EEPROM, SRAM и 6522, а в будущем поставить его на стрип-плате.