Как прошить 25 флеш память
Решил на досуге чем-то себя развлечь, а заодно поупражняться в программировании, но немного увлёкся, и вот родился этот проект. Не как обычно какая-нибудь ненужная безеделушка, коих у меня насобиралось в закромах целая куча, а вполне полезная вещь - USB программатор для микроконтроллеров AVR, SPI Flash 25 серии и I2C EEPROM 24ХХ.
"Сердцем" программатора является stm32f103c8t6, многим известный по китайской платке blue pill. Подключен он к компьютеру через USB-UART конвертер (мой любимый CH340G). Кто-то сразу справедливо заметит, что в данном микроконтроллере есть аппаратный USB и можно спокойно реализовать виртуальный COM порт на нём (HID CDC устройство). Но! в "железном" конвертере есть один немаловажный плюс, там есть все линии COM порта, которые (в моём случае DTR) можно использовать для управления микроконтроллером. В соей схеме линия DTR управляет сбросом (NRST) микроконтроллера. Также большой плюс в том, что не возникает проблемы "яйца и курицы" при создании программатора (то есть, чем прошить сам программатор?). Добрые инженеры ST-microelectronics позаботились о нас и добавили USART bootloader в свои контроллеры. А так как на моей плате уже есть подключенный к USART1 STM-ки usb-usart конвертер, то остаётся только скачать STM-овскую программку STMFlashLoadDemonstratot, поставить перемычку "boot" (на моей плате ещё нужно закоротить вывод "reset" ISP разъёма AVR на плюс или минус того же разъёма просто, boot1 - PB0 у меня подключен на данный разъём, а при программировании через встроенный bootloder он не должен болтаться в воздухе) и прошить микроконтроллер готовой прошивкой.
Забежав вперёд, скажу, попутно я начал переделывать программатор на аппаратный USB, который я заблаговременно развёл на плате. USB у меня настроен как Custom HID. Скорость, конечно в 2-3 раза выше, но получить стабильной работы пока не удалось. Одиночные пакеты передаются туда-обратно без проблем, а вот при сплошном потоке во время операций чтения-записи прошивок пакеты иногда теряются. Но я над этим работаю.
Принцип работы моего программатора следующий: хост отправляет микроконтроллеру пакет с запросом, микроконтроллер отправляет пакет с ответом. Сам микроконтроллер без спроса ничего хосту не шлёт, кроме единственного случая - аппаратного сброса (отправляет пакет присутствия программатора). Также в обмене нет отправки пакетов через временные задержки, что могло бы вызвать зависание софта. Только запрос-ответ. Далее пакеты как со стороны хоста, так и со стороны "железа" обрабатываются в конструкции "switch-case" в зависимости от маркерного байта.
Длину пакета я сделал фиксированную (23 байта). Это компромисс между количеством полезной информации в пакете и скоростью его передачи в случае служебных пакетов, несущих всего один полезный байт. Подробно пакет разбирать не буду, скажу только, что полезных байт в нем 16 (то есть тех, которые передают данные прошивок), остальные байты служебные (старт и стоп байты для проверки целостности пакета, маркер пакета, адрес). Конечно, было бы более эффективно сделать пакет не фиксированной длины, но это сильно усложнило бы софт и прошивку "железа".
Скорость обмена выбрал максимальную для CH340G - 2 мегабода. STM-ка на данной скорости работает без проблем. В итоге скорость обмена получилась приемлемая. Читать-писать AVR и I2C EEPROM очень комфортно, а вот SPI Flash - не очень. Уж сильно они ёмкие. Флешка на один мегабайт (не путать с мегабитом) пишется или читается примерно минуты четыре-пять. Соответственно 8 мегабайт будет читаться или писаться порядка 16-20 минут. Благо, что пакеты обмениваются стабильно и ошибок или обрывов при записи/чтении не возникает. В принципе, можно сходить попить чаю, пока пишется (шучу).
Теперь познакомимся по ближе с минимальной схемой программатора:
Минимальная схема представляет из себя микроконтроллер с минимальной обвязкой, USB-USART конвертером также в минимальной обвязке и разъёмами для программирования. В принципе, можно использовать туже плату Blue pill, подключая на проводах программируемое устройство, единственное что нужны подтяжки к плюсу 3v3 линий SCL и SDA I2C1 для программирования EEPROM.
Почему схема минимальная? Потому что изначально устройство разрабатывалось на самодельной оценочной плате с выведенными портами микроконтроллера. И этого было достаточно для программирования "на проводах" перечисленные микросхемы памяти и МК. А вообще, я ещё планировал поддержку микроконтроллеров PIC. Для этого в окончательной плате у меня ещё присутствует преобразователь напряжения на 12 вольт, схема управления питающими напряжениями, и преобразователь уровней 3v3 - 5v для ножек PGC, PGD и PGM PIC контроллеров.
Скажу сразу, с пиками у меня пока не срослось. На поверку они оказались редкостными уб. детьми без отца. Как оказалось в каждой линейке PIC есть куча подсемейств, которые отличаются не только набором команд, но и алгоритмами программирования и ещё кучей параметров. А ещё HEX файлы для PIC разных семейств также отличаются кардинально. В них содержаться и программа, и EEPROM, и биты конфигурации. И всё это по разным адресам и в разных количествах у разных моделей. Например PIC16F84 и PIC16F84A имеют разные алгоритмы записи и стирания, а также у них отличаются несколько команд. В общем, ни о какой стандартизации даже и речи быть не может, такое чувство, что инженеры PIC соревновались, кто сделает сложнее и хуже. Максимум, что я смог выжать из имеющегося у меня PIC16F73 это получить ячейку с ID. И то не совсем корректное, хотя читается стабильно (если кто-то имеет опыт программирования PIC, не написания программ, а именно алгоритмов прошивки, можете поделиться опытом, попробую реализовать хотя бы пару линеек 16-х).
Для полноты картины приведу также схему преобразователя напряжения на 12 вольт:
Это MCP34063 в типовом включении.
А также схему преобразователей уровней и управления напряжениями 5 вольт и 12 вольт:
Преобразователи уровней двунаправленные, сделаны на полевых n-mosfet. Работают в оба направления, так как ножки микроконтроллера, на которых они висят сконфигурированы как Open Drain. А в данном режиме у STM32 даже если пин сконфигурирован как выход, всегда можно прочитать его текущий логический уровень. Получается такой своеобразный псевдо-двунаправленный порт. Очень удобная штука. Полезная для реализации двунаправленных шин (например, 1-Wire).
Ключи для управления напряжениями 5в и 12в я скопировал из схемы программатора К-150. Они сделаны через два элемента "НЕ" микросхемы 74ls06 (у меня работает на 74als05) и транзисторах BC856.
На разъём программирования ICSP для PIC я планирую в ближайшее время ещё повесить Microwire EEPROM. У них с пиками очень похожие протоколы программирования и как раз многие модели требуют именно 5 вольт. Так что, если с пиками не получится, то разъём будет полезен для этих EEPROM.
Основная "фишка" программы - возможность добавления моделей программируемых устройств. Для этого в каталоге с программой есть три xml файла, в которые очень легко добавить новую модель. Для AVR достаточно скачать datasheet на нужную модель. Найти раздел Memory Programming. Найти там количество страниц памяти, объём страницы памяти (16 битных слов), объём EEPROM в байтах и три байта ID микроконтроллера. Также нужны начальные настройки Fuse bits, их можно найти в online калькуляторах, например, AVR fuse calculator. Затем, в соответствующем xml файле (avr.xml) копируем один однотипный блок, вставляем его выше или ниже и подправляем данные. Сделать это можно в простом блокноте "notepad". Пример блока для AVR:
Добавлять модели I2C EEPROM нет необходимости, так как микросхемы разных производителей программируются однотипно. А основные модели до 24х256 уже внесены. А вот новые модели SPI Flash вносятся аналогично AVR. Из datashet необходимо узнать объём флешки в байтах, объём одной страницы данных и количество страниц. Также можно узнать ID, но его можно просто прочитать программатором, а затем внести в xml файл.
Есть некоторые особенности программирования AVR и SPI Flash. Если AVR новый или его fuse bits настроены на внутренний генератор и низкую частоту тактирования, то он не будет реагировать на комманды программатора. Для этого во вкладке настроек необходимо выставить скорость SPI на "6" или ниже - это низкоскоростной Soft SPI, затем прошить фузы и можно лить прошивку на более высокой скорости. Но не рекомендую для AVR ставить скорость больше "8", он просто не справится с ней. Также не напортачьте с Fuse битами, выставляйте внимательно их значения. Если в соответствующих окнах будут установлены неправильные символы (кирилица или символы, кроме 0-9 и A-F), то биту будут программироваться как 0xFF. Значение битов вносится в шестнадцатиричном виде два символа без приставки "0x" или постфикса "h", регистр не важен. Будьте внимательны, неправильные Fuse биты могут окирпичить ваш микроконтроллер. При установленных Lock Bits их сброс производится стиранием чипа. Не забывайте, что в AVR биты инверсные: 0 - запрограммирован, 1 - не запрограммирован.
Во вкладке "SPI Flash" функция чтения/записи Sreg1 и Sreg2 регистров. Это регистры настроек и флагов. Если в них установлены биты защиты, то некоторые или все блоки памяти будут доступны только для чтения и вы не сможете их стереть или записать. Для этого читаем значения Sreg, запоминаем или записываем на бумажку, вводим в оба поля по два нуля, записываем. После этого можно стирать и записывать флешку. После того как записали, возвращаем обратно значения Sreg, если нужно.
При работе с I2C EEPROM - никаких особенностей, только правильно выбирайте модель, иначе при чтении можно повесить шину I2C и она выдаст ошибку. Это связано с разной адресацией байт в EEPROM разного объёма.
Есть общая особенность функции сравнения записанной прошивки для всех устройств: перед проверкой сначала нужно прочитать микросхему. Потому что при нажатии на кнопку "Сравнить" автоматически чтения не происходит. Об этом, если что, напомнят всплывающие MessageBox-ы.
Программа принимает для записи файлы формата intel-HEX или любые другие файлы в сыром виде. Сохраняет только в формате BIN. То есть вы можете записать обычный HEX, при этом он предварительно конвертируется в массив байт или открыть любой другой файл в виде набора байт, например записать на флешку картинку или текстовый файл.
Кстати , в процессе разработки программы родился побочный проект - HEX-to-BIN конвертер. Он конвертирует 16 битные hex в BIN файлы. Его я также выложу вместе с софтом программатора в конце статьи (особых коммерческих надежд на проект я не возлагаю, пользуйтесь на здоровье).
Напоследок - фото готового устройства. Напомню, это "полная" схема со всеми преобразователями, которые не нужны для перечисленных трёх видов программируемых микросхем, а сделаны "на будущее" для возможности добавления новых функций.
Качество платы, конечно не заводское, плата односторонняя с кучей перемычек, но для домашних поделок - пойдёт.
P.S: Софт довольно сырой. Могут возникать не обрабатываемые исключения и программа может завершаться с ошибкой. Всё протестировать я не успел. Из имевшихся у меня AVR а пробовал работать с ATMEGA8, ATMEGA328, ATMEGA128, ATTINY2313. Также подключал AT90USB162, но я не уверен в корректности работы с его Flash памятью из-за bootloader-а. Фузы программируются правильно.
Из флешек я пробовал WINBOND W25Q80, W25Q64, также менее ёмкие AC25512 и мегабитную от MXIC (не помню маркировку).
EEPROM были проверены со всеми вариантами адресации (у меня были в наличии AT24C01, AT24C02, 24C08, 24C16, 24C32 и 24C256).
Разводку платы я также выложу в конце статьи в формате Sprint Layout. Я постарался подписать все элементы на плате, там где не поместилось - подписал в свойствах деталей. У меня есть такая фишка на платах, я рисую и резисторы и конденсаторы макросами конденсаторов, потому что макросы резисторов в спринте очень крупные по сравнению с конденсаторами того же типоразмера, так что не удивляйтесь. Плата сделана под SMD компоненты, самые маленькие - размером 0603, да и у STM-ки ножки очень мелкие. Я делаю платы фоторезистом, поэтому это не проблема. Но если делать ЛУТ, то надо очень постараться. Не каждый возьмётся за такие мелкие детали.
Микросхемы флеш-памяти eeprom серии 25xxx широко применяются в микроэлектронике. В частности, в современных телевизорах и материнских платах в 25xxx хранится прошивка биоса. Перепрошивка 25xxx осуществляется по интерфейсу SPI, в чем и заключается отличие этих микросхем от флеш-памяти семейства 24xxx, которые шьются по i2c(квадратная шина).
Соответственно, для чтения/стирания/записи 25xxx нужен SPI-программатор. Одним из самых дешевых вариантов программаторов для этой цели является USBasp, который стоит смешные деньги- с доставкой всего около 2$ на ебее. В свое время я купил себе такой для программирования микроконтроллеров. Теперь мне понадобилось прошить не микроконтроллер, а SPI-флеш и решено было им воспользоваться.
Забегая вперед скажу, что прошивка от Tifa работает, микросхемы 25xxx шьются. Кстати, кроме 25xxx, модифицированный программатор рассчитан на работу с 24xxx и Microwire.
1. Перепрошивка USBasp
Сначала нужно замкнуть контакты J2:
Лично я не просто замкнул, а впаял в контакты переключатель:
При замкнутых контактах J2 (это у меня переключатель в положении вправо) USBasp переходит в режим готовности к перепрошивке.
Сам себя USBap перепрошить не может, поэтому нужен еще один программатор. USBasp как бы оказывается в положении хирурга, который не может сам себе вырезать аппендикс и просит друга помочь. Для перепрошивки USBasp я использовал самодельный программатор AVR910, но для одного раза можно по-быстрому за пару минут спаять программатор «5 проводков», который состоит всего-лишь из одного разъема LPT и 5 резисторов.
Подключаем программатор к USBasp:
Теперь идем на форум альтернативной прошивки от Tifa, в самом верхнем посте находим и качаем архив с последней прошивкой и ПО.
Находим там файл mega8.hex, это и есть альтернативная прошивка для USBasp.
Запускаем CodeVisionAvr (я использую версию 2.0.5), выставляем настройки программатора: Settings-> Programmer.
Устанавливаем настройки записи: Tools->Chip programmer. Выбираем чип Atmega8L, именно такой стоит на USBasp. Фьюзы не выставляем- те, что надо, уже прошиты в чипе. Остальные настройки оставляем по умолчанию.
Стираем старую программу USBasp: Program-> Erase chip.
Открываем файл прошивки mega8.hex: File-> Load flash.
Перепрошиваем USBasp: Program-> Flash.
Теперь проверим, видит ли Windows 7 x86 этот программатор. Вставляем USBasp в USB и… система пишет «USBasp не удалось найти драйвер». Понятно, нужно установить драйвер. Но драйверов в скачанном на форуме архиве нет, их нужно скачать на родном сайте USBasp тут, оригинальные драйвера подходят и для модифицированного программатора. Скачали, установили, Win7 увидела программатор, все ок. Впрочем, я программирую микроэлектронику на ноутбуке с WinXP, она тоже после установки драйверов видит программатор.
2. Площадка для подключения USBasp к микросхеме 25xxx DIP
Теперь нужно подготовить площадку для программирования 25xxx. Я это сделал на макетной плате по такой схеме:
3. Прошивка микросхем 25xxx через USBasp
Для прошивки 25xxx через модифицированный USBasp используется программа AsProgrammer, которая тоже есть в архиве.
Для примера, поработаем с микросхемой Winbond 25×40. Запускаем AsProgrammer, ставим режим работы SPI и выбираем тип микросхемы: Микросхема-> SPI-> Winbond->…
… и видим, что W25X40 в списке нет. Что же, тогда заполним параметры микросхемы вручную. Находим мануал на Winbond 25X40 и там на странице 4 видим такие параметры:
Эти параметры вносим сюда:
Подключаем USBasp к компьютеру и микросхеме Winbond 25×40:
С помощью кнопок «прочитать», «записать», «стереть», проверяем работу программатора:
Только нужно учесть, что перед тем, как что-то записать в микросхему, сначала нужно выставить: Настройки-> Проверка записи, что бы после записи прошивки в микросхему была выполнена проверка на соответствие того, что писали тому, что в итоге записали. Это немаловажная вещь, потому что если прошивку делать не на очищенный чип, в него запишется чёрт-те что. Поэтому сначала нужно стереть микросхему, а затем только проводить ее запись.
Благодаря прошивке от Tifa дешевый китайский программатор USBasp теперь умеет работать с микросхемами flash-памяти eeprom 25xxx. Теоретически еще может работать c 24xxx и Microwire, но я проверил только работу с 25xxx.
UPD1:
Оказывается, такую же прошивку можно записать и в программатор AVR910. Тогда он тоже будет работать с flash-памятью 25xxx: Программатор ISP памяти из AVR910.
Еще вот купил себе небольшой программатор. Шикарная вещь мне для работы, да и не только!
Для примера, вот только некоторые типы микросхем с чем может работать:
В базе 450 чипов:
COMMON 25X005 25X80 25X256
EON EN2SB05 EN25F10 EN25LF20 EN25T80
EN25Q16 EN2ST16 M2SQ32 EN2SB64
ES
ES25P10 ES25M80A ES2SM16A
ESMT E25L04UA E25L16PA
gigadevice
GD25Q512 GD25Q80 GD25Q32
KH
KH2514006E
hexflash
HX2SP10 NX2SP32
25X05 25X10 25X20 25X40
25X16 25X32 25X64 25X128
25X512 25X1024 25X2048
EN25F05 EN25B05T EN25P05 EN25LF05
EN25P10 EN25D10 EN25LF10 EN25D20
EN25F20 EN25F40 EN25D40 EN25LF40
EN25D80 EN25Q80 EN25F80 EN25P80
EN25H16 EN25B16T EN25F16 EN25D16
EN25B16 EN25F32 EN25P32 EN25B32
EN25832T EN25B64T EN25Q64 EN25F64
EN25F128 EN25Q128
ES25P20 ES25M40 ES25M40A ES25P40
ES25M80 ES25P80 ES25P16 ES25M16
ES25P32
F25L004A F25L08PA F25L008A F25L016A
F25L32PA F25L32QA F25L64PA
GD25Q10
G025D80
GD25Q64
KH25L80360
MS25X10
MS25X32
GD2SQ20
GD25F80
GD25Q128
GD2SD40
GD25T80
GD25F40
GD25Q16
KH25L8006E(OTP) KH25L1606E(OTP)
MS25X20
MS25X64
MS25X40
MS25X128
MS25X80
MX25L512 MX25V4035 MX25V8005
MX25U803S<otp) MX25L1608CKOTP) MX25L1636D
MX25L3205D MX25L3208E(OTP) MX25L6406E(OTP)
MX25L12835E MX25L12845E(OTP)
MX25L1005 MX25L2005
MX25L4005A MX25V400S
MX25U8033E MX25L8036E
MX2 5 L8006E(OTP) MX25L1636E
MX25L1635E MX25L3225D
MX25U3235E MX25L6455E MX25L6445E(OTP)
MX25L12836E(OTP) MX25112805D(OTP)
MX25U1635E
MX25L3237D
MX25L3208CXOTP)
MX25L6408CXOTP)
MX25L6405D
MX25U12835F
MX25L2026
MX25L8005
MX25V8035
MX2SL1606E(OTP) MX25L1605D MX25L3236D MX25L3235D
MX25L6465E(OTP) MX25L6436E(OTP) MX25L12835F(OTP)
MX25L2563SE(otp)
NX25P20
NX25P40
NX25P80
NX25P16
ST
SA25F010
SA25F320
S25FL040
S25FL016
S25FL256
SST25VF512
SST25VF040B
SST25VF032B
SA25F020
S25FL002
S25FL032
S25FL512
SA25F040
S25FL004
S25FL064
SA25F080
S25FL008
S25FL128
SST25VF010A
SST25VF040
SST25VF064C
SST25VF010
SST25VF040A
SST25VF020
SST25VF080B
M25P05A M25P40 M25PE16 M25PE32
M25PE10 M25PE40 M25P16 M25P64
M25P10A M25PX80 M25PX16 M25PE64
M25PE20 M25PE80 M25PX32 M25PX64
M25P20 M25P80 M25P32 M25P128
WINBOND
W25P10 W25X20A W25Q40BV W25P40 W25X80AL
W25Q16V W25Q328V W25Q128BV W25X10A W25X20L
W25X40 W25P80 W25Q80V W25P16 W25Q64BV W2SQ256FV
W25X10AL W25X20 W25X40AL W25Q80BV W25X80 W25P32
W25X64 W25X10L W25X20AL W25X40L W25X80L W25X16
W25Q32V W25P64 W25X10 W25P20 W25X40A W25X80A
W2SQ166V W25X32 W2SQ128FV
= ATMEL
AT24C01B AT24C01
AT24C02B AT24C04B
AT24C08B AT24C08
AT24C32B AT24C32A
AT24C64B AT24C128
AT24C256 AT24C256B
AT24C1024 AT24C1024A
CATALYST
CAT24C01
CAT24WC04
CAT24WC32
CAT24WC128
CAT24C1024
CAT24WC01
CAT24WC08
CAT24C32
CAT24C256
CAT24WC1024
AT24C01A
AT24C04
AT24C16
AT24C32
AT24C128A
AT24C512B
AT24C1024B
CAT24C02
CAT24C08
CAT24WC64
CAT24WC256
AT24C02
AT24C04A
AT24C16A
AT24C64
AT24C128B
AT24C512A
CAT24WC02
CAT24WC16
CAT24C64
CAT24C512
AT24C02A
AT24C08A
AT24C16B
AT24C64A
AT24C256A
AT24C512
CAT24C04
CAT24C16
CAT24C128
CAT24WC512
COMMON
24C01 3V 24C01 5V 24C02 3V
24C04 5V 24C08 3V 24C08 5V
24C32 5V 24C32 3V 24C64 5V
24C128 3V 24C256 5V 24C256 3V
24C1024 3V 24C1024 5V 24C2048 5V
24C4096 3V
FAIRCHILD
FM24C01L FM24C02L FM24C03L
FM24C08L FM24C09L FM24C17L
FM24C64L FM24C128L FM24C256L
HOLTEK
HT24C01 HT24LC01 HT24LC02
HT24LC04 HT24C08 HT24LC08
HT24LC32 HT24C32 HT24LC64
HT24LC128 HT24LC256 HT24C2S6
HT24C1024 HT24LC1024
ISSI
IS24C01 IS24C02 IS24C04
IS24C32 IS24C64 IS24C128
IS24C1024
24C02 5V 24C16 5V 24C64 3V 24C512 5V 24C2048 3V
FM24C05L
FM24C16L
FM24C512L
HT24C02
HT24C16
HT24C64
HT24LC512
24C04 3V 24C16 3 V 24C128 5V 24C512 3V 24C4096 5V
FM24C04L
FM24C32L
FM24C1
HT24C04
HT24LC16
HT24C128
HT24C512
IS24C08
IS24C256
IS24C16
IS24C512
XICOR
X24C01
X24C02 X24C04
X24C08 X24C16
Короче штука класс. Прикупил еще пару переходничков чтоб не впаивать микрухи в программатор, а просто вставил-зашил-вытащил.
Переходник с dip8 на sop8:
Для 150mil ( 24c04 24c16 и тд )
Для 200mil ( 25q32 25q64 и тд)
Для теста я взял просто материнскую плату с дохлым биосом. Достал чип. Сунул в программатор. Затер его полностью. Скачал прошивку с офф. сайта производителя материнки. И ура =) она ожила! Читает и шьет довольно быстро. Я рад.
Далее надо будет прикупить программатор посерьезней =)
Чтоб те же самые ЭБУ оживлять после кривой прошивки.
Элементная база Января 5.1 — 41:
DA1 HIP9010 микроконтроллер датчика детонации
DA2 TLE4729G Драйвер управления 2х фазным шаговым мотором (РХХ)DA3 TPS2814D Драйвер зажигания
DA4 LM1815 Адаптивный управляемый усилитель
DA5 TLE5216G Драйвер управления сильноточными устройствами (сажает цепь на землю)
DA6 HIP0045 Power Driver с сериал-бас управлением (для программируемой подачи питания на элементы cхемы)
DA7 TLE5216G Драйвер управления сильноточными устройствами (сажает цепь на землю)
DA8?
DA9?
DA11 TLE4267G управляемый стабилизатор +5в. С ресет-генератором. при подаче сигнала от замка зажигания дает внутрисхемное питание +5в. и вырабатывает сигнал сброса на схему. (RESI)
DD2 AM29F010 Flash 1 Mbit (128K x 8)
DD3 74HC573 параллельный регистр на 8
DD4 SAF80C509 однокристальная микро ЭВМ
DD5 MC33199D Драйвер ISO 9141 (K and L Interface)
DD6 NM24C04 Последовательный (2-wire serial) EEPROM 4K (512 x 8)
DD7 74HC14 6 шт. инверторов
CH341A Programmer
версия: 1.3.4
Последнее обновление программы в шапке: 25.07.2020
Так же, в «Диспетчер устройств», Windows определил его как «Неизвестное USB-Устройство (сбой запроса дескриптора устройства)»,
а в свойствах, пишет об ошибке «Система Windows остановила это устройство, так как оно сообщило о возникновении неполадок.
(Код 43)» и конечно же, неправильно определен VID и PID (VID_0000&PID_0002).
Открыв документацию на CH341A и посмотрев примеры принципиальных схем, можно увидеть что везде используется кварц на 12 МГц.
А на самом программаторе CH341A, установлен кварц на 27.120 MГц
Берем паяльник и выпаиваем неправильный кварц 27.120 МГц и впаиваем, новый на 12 МГц.
Подключаем программатор CH341A к компьютеру и видим, что в ОС появилось новое устройство с вином VID и PID (VID_1A86&PID_5512)
Как подключить Atmega контроллер на примере USBAsp Если у вас не записывается чип но при этом считываетсяПрошивает микросхемы 24 серии
Прошивает микросхемы 25 серии
Прошивает микросхемы 26 серии Поддерживаемые программатором CH341A Pro микросхемы 24 серии
ATMEL
AT24C01B AT24C01 AT24C01A AT24C02 AT24C02A AT24C02B AT24C04B AT24C04 AT24C04A AT24C08A AT24C08B AT24C08 AT24C16 AT24C16A AT24C16B AT24C32B AT24C32A AT24C32 AT24C64 AT24C64A AT24C64B AT24C128 AT24C128A AT24C128B AT24C256B AT24C256 AT24C256A AT24C512B AT24C512A AT24C512 AT24C1024 AT24C1024A AT24C1024B
CATALYST
CAT24C01 CAT24WC01 CAT24WC02 CAT24C02 CAT24C04 CAT24WC04 CAT24WC08 CAT24C08 CAT24WC16 CAT24C16 CAT24WC32 CAT24C32 CAT24WC64 CAT24C64 CAT24WC128 CAT24C128 CAT24WC256 CAT24C256 CAT24C512 CAT24WC512 CAT24C1024 CAT24WC1024
COMMON
24C01 3V 24C01 5V 24C02 3V 24C02 5V 24C04 5V 24C04 3V 24C08 3V 24C08 5V 24C16 5V 2406 3V 24C32 5V 24C32 3V 24C64 5V 24C64 3V 24028 5V 24C128 3V 24C256 5V 24C256 3V 24C512 5V 24C512 3V 240024 3V 24C1024 5V 24C2048 5V 24C2048 3V 24C4096 5V 24C4096 3V
FAIRCHILD
FM24C01L FM24C02L FM24C03L FM24C04L FM24C05L FM24C08L FM24C09L FM24C17L FM24C16L FM24C32L FM24C64L FM24C128L FM24C256L FM24C512L FM
HOLTEK
HT24C01 HT24LC01 HT24CD2 HT24LC02 HT24C04 HT24LC04 HT24C08 HT24LC08 HT24C16 HT24LC16 HT24LC32 HT24C32 HT24LC64 HT24C64 HT24C128 HT24LC128 HT24C256 HT24LC256 HT24LC512 HT24C512 HT24C1024 HT24LC1024
ISSI
IS24O01 IS24C02 IS24C04 IS24C08 IS24C16 IS24C32 IS24C64 IS24C128 IS24C256 IS24C512 IS24C1024
MICROCHIP
MIC24LC014 MIC24AA01 MIC24AA014 MIC24LC01B MIC24LC02B MIC24AA02 MIC24C02C MIC24AA025 MIC24AA04 MIC24LC04B MIC24LC024 MIC24AA024 MIC24LC025 MIC24LC08B MIC24AA08 MIC24LC16B MIC24AA16 MIC24LC32 MIC24AA32 MIC24LC64 MIC24FC64 MIC24AA64 MIC24FC128 MIC24AA128 MIC24LC128 MIC24AA256 MIC24LC256 MIC24FC256 MIC24AA512 MIC24LC512 MIC24FC512 MIC24AA1024
NSC
NSC24C02L NSC24C02 N5C24C64
RAMTRON
FM24CL04 FM24C04A FM24CL16 FM24C16A FM24CL64 FM24C64 FM24C256 FM24CL256 FM24C512
ROHM
BR24L01 BR24C01 BR24L02 BR24C02 BR24L04 BR24C04 BR24L08 BR24C08 BR24L16 BR24C16 BR24L32 BR24C32 BR24C64 BR24L64
ST
ST24C01 ST24C32 ST24C02 ST24C64 ST24C04 ST24C08 ST24C16
XICOR
X24O01 X24C02 X24C04 X24C08 X24C16
AMIC
A25L512 A25L05P A25L10P A25L010 A25L020 A25L20P A25L40P A25L040 A25L080 A25L80P A25L016 A25L16P A25L032
ATMEL
AT25F512 AT25F512B AT25F512A AT25FS010 AT25F1024 AT25F1024A AT25F2048 AT25DF021 AT25F4096 AT25FS040 AT25DF041A AT25DF321A AT26DF321 AT25DF321 AT25DF641
COMMON
25X005 25X05 25X10 25X20 25X40 25X80 25X16 25X32 25X64 25X128 25X256 25X512 25X1024 25X2048
EON
EN25F05 EN25P05 EN25LF05 EN25F10 EN25LF10 EN25D10 EN25P10 EN25F20 EN25D20 EN25LF20 EN25F40 EN25D40 EN25LF40 EN25Q80 EN25D80 EN25F80 EN25P80 EN25T80 EN25B16T EN25T16 EN25B16 EN25D16 EN25F16 EN25Q16 EN25P32 EN25Q32 EN25F32 EN25B32 EN25B32T EN25Q64 EN25B64 EN25F64 EN25B64T EN25F128 EN25Q128
ES
ES25P10 ES25P20 ES25M40A ES25M40 ES25P40 ES25M80 ES25P16 ES25M80A ES25P32 ES25P80 ES25M16 ES25M16A
ESMT (только чтение)
F25L04UA F25L16PA F25L004A F25L32QA F25L08PA F25L32PA F25L008A F25L016A
GIGADEVICE
GD25Q512 GD25Q10 GD25Q20 GD25F40 GD25D40 GD25Q80 GD25D80 GD25T80 GD25F80 GD25Q16 GD25Q32 GD25Q64 GD25Q128
MXIC
MX25V512 MX25L4005A MX25L1635D MX25L3237D MX25L6455E MX25L12845E MX25L512 MX25V4035 MX25L1605D MX25L3225D MX25L6408D MX25L1005 MX25V4005 MX25L1608D MX25L3205D MX25L6406E MX25L2005 MX25V8005 MX25L3235D MX25L3206E MX25L6445E MX25L8035 MX25L8005 MX25L3208D MX25L6405D MX25L12805D
NEXFLASH
NX25P10 NX25P20 NX25P40 NX25P80 NX25P16 NX25P32
NSHINE
MS25X05 MS25X16 MS25X10 MS25X32 NS25X20 MS25X64 NS25X40 MS25X128 MS25X80
PMC
PM25LV512A PM25LV016B PM25LV010A PM25LV020 PM25LV040 PM25LV080B
SAIFUN
SA25F005 SA25F160 SA25F010 SA25F320 SA25F020 SA25F040 SA25F080
SPANSION
S25FL004A S25FL032A S25FL040A S25FL064A S25FL008A S25FL128P S25FL160 S25FL129P S25FL016A S25FL128A
ST
M25P05A M25PE10 M25P10A M25P20 M25PE20 M25PE40 M25P40 M25PE80 M25P80 M25PX80 M25PX16 M25P16 M25PE16 M25P32 M25PE32 M25PX32 M25PX64 M25P64 M25PE64 M25P128
WINBOND
W25X10 W25X10L W25P10 W25X10AL W25X10A W25P20 W25X20AL W25X20A W25X20 W25X20L W25X40A W25P40 W25Q40BV W25X40L W25X40 W25X40AL W25Q80BV W25Q80V W25X80 W25P80 W25X80A W25X80L W25X80AL W25P16 W25Q16BV W25Q16V W25X16 W25Q32BV W25Q32V W25X32 W25P32 W25Q64BV W25X64 W25Q128BV
Микросхемы памяти серий 24хх (EEPROM), 25хх (Serial Flash) широко используются в электронике. Такие чипы присутствуют в составе практически любой конструкции современной бытовой и промышленной аппаратуры, где есть процессоры и/или микроконтроллеры. Данный программатор имеет возможность работы с обоими типами памяти.
В комплект поставки входят сам программатор и переходная плата с двумя посадочными местами под микросхемы памяти в SOIC корпусе.
Они дублируют имеющиеся на нижней стороне платы программатора, и если на плату программатора микросхемы памяти нужно обязательно припаивать, на переходнике можно попробовать прижать микросхему прищепкой или держателем для бумаг.
Так-же на переходнике есть посадочное место для разьема PLD-8 (в комплект не входит, я впаял 2хPLS-4), предназначенного для подключения прищепки или шлейфа программирования.
Аппаратная часть (Hardware).
Программатор выполнен на базе микроконтроллера «USB Bus Convert Chip» серии CH341A. Он рассчитан на физическое подключение к порту USB 2.0 компьютера, при подключении через хаб-удлиннитель программатор у меня работал с ошибками (может у меня хаб такой). Модуль программирования памяти собран на плате размерами 63х27мм (без учета USB разьема, с разьемом 84х27мм) из черного стеклотекстолита.
В распоряжении автора есть два экземпляра этого программатора, приобретенные в разное время, визуально их можно отличить по названию, один (более ранний) называется "CH341A Mini Programmer", второй "CH341A MinProgramment". Схемы одинаковые, различаются только цветом светодиода "RUN". На первом зеленый, на втором желтый.
Некоторые схемные обозначения на конкретном программаторе могут немного отличаться, например самовосстанавливающийся предохранитель F1 (fuse) может обозначаться как R1. В инете встречались упоминания, что в эту позицию иногда ставят резистор нулевого сопротивления т.е. перемычку. У меня как и положено на обоих стоят предохранители
400mA, сопротивление 0,92Ом, маркировка на корпусе «5». Также на плате часто отсутствует схемное обозначение резисторной сборки PR1. Более грамотное обозначение схемных элементов программатора можно посмотреть на изображении верхней стороны платы от магазина WAVGAT (на AliExpress):
Особых отличий от даташита схема не имеет, разве что на блокировочных конденсаторах по питанию сильно экономили. Питание 5V от USB подается на вывод 28, на выходе 9 внутреннего стабилизатора блокировочный конденсатор.
Т.к. на выводах ввода/вывода напряжение соответствует 5V уровням, в основном это устройство на 5V, правда в инете много упоминаний и о программировании им микросхем на 3.3V без каких либо ошибок и отрицательных последствий. Выход отдельного стабилизатора AMS1117-3.3 в схеме не задействован и просто выведен на выходной ZIF разьем и на контакт боковой гребенки SPI.
В даташите указан способ сделать уровни на выходах совместимыми с 3.3V. Для этого необходимо соединить выводы 28 и 9 и подать на них 3.3V, при этом внутренний стабилизатор просто не используется. Но при этом 3.3V уровни также будут на на переходнике USB <-> RS232, что иногда не приемлемо. Также на Ali сушествует другая версия этого программатора, скомпонованная немного по другому и выполненая на зеленом текстолите. Читал, что там на вывод 28 подается 3.3V от внешнего стабилизатора, но выводы 28 и 9 не соединены, и это нормально работает. В любом случае, уровни на переходнике USB <-> RS232 и здесь будут 3.3V.
Если планируется программирование флешек 1.8V через основной разьем необходимо дополнительно приобрести модуль 1.8V-adapter. Бонусом является то, что переделать его для поддержки и уровней 3.3V несложно, надо лишь закоротить вход/выход стабилизатора 1.8V дополнительным джампером.
Теперь при наличии джампера адаптер работает с логическими уровнями 3.3V, при отсутствии — 1.8V.
Минус тут в том, что стоимость адаптера не намного меньше, чем самого программатора. Но если он уже есть, почему бы его не использовать по полной?
Если для программирования будет использована боковая гребенка SPI, можно поступить проще. На Ali много предложений 4-канального двунаправленного преобразователя уровней на МОП транзисторах за очень небольшие деньги.
Работа этого преобразователя подробно описана в статье "Согласование логических уровней 5В и 3.3В устройств". Схема отличается от рассмотренной в статье только номиналами резисторов (сопротивление меньше — увеличено быстродействие и энергопотребление). За счет добавления дополнительных джампера J1 и двух кремниевых диодов, можно будет программировать как 3.3V, так и 1.8V флешки.
Программная часть (Software), драйвер.
Перед применением программатора необходимо инсталировать в Windows его драйвер(а), легко находятся в инете, я брал из архива программы AsProgrammer. Программатор поддерживает два режима, они переключаются аппаратно джампером J1. Применен интересный прием, при переключении джампера у чипа меняется Device ID на шине USB. Это вынуждает Windows найти подходящий по VID/PID драйвер и подключить его.
При джампере в положении «1-2» по VID_1A86&PID_5512 подгружается драйвер "USB-EPP/I2C… CH341A". Он создает в диспетчере устройств раздел "Interface" в который и устанавливается.
В этом случае чтение, верификация, запись чипов памяти должны осуществляться непосредственно через ZIF-панель программатора CH341A или через боковой разьем Р2 с интерфейсом SPI.
При джампере в положении «2-3» по VID_1A86&PID_5523 подгружается драйвер "USB-SERIAL CH341A". В диспетчере устройств найти его можно в разделе "Порты (COM и LPT)". Там же можно посмотреть и номер присвоенного СОМ порта.
При этом программирование может производиться только через интерфейс RS232 TTL на разьеме Р1 (там же где и джампер), если целевое устройство поддерживает такой способ (встроенный загрузчик или монитор).
Программная часть (Software), программа прошивальщик.
Программа не требует установки, включает в архив драйверы для обоих режимов программирования СН341А.
Log-файл работы программы с флешкой W25Q128FW, 16Мб, 1.8V через "1.8V-adapter":
Используется программатор: CH341
Sreg: 00000000(0x00), 00000010(0x02), 01100000(0x60)
Используется программатор: CH341
Читаю флэшку…
Готово
Время выполнения: 0:02:49
Используется программатор: CH341
Стираю флэшку…
Готово
Время выполнения: 0:01:03
Используется программатор: CH341
Записываю флэшку с проверкой…
Готово
Время выполнения: 0:24:45
5 вариантов BIOS) ни одного сбоя или ошибки.
Линуксоидам использовать стороннюю программу нет необходимости, стандартный прошивальщик Flashrom полностью поддерживает данный программатор (должен быть собран с поддержкой ключа "-ch341a").
WARNING: If the /WP or /HOLD pins are tied directly to the power supply or ground during standard SPI or Dual SPI operation, the QE bit should never be set to a 1.
Как по мне, проще сделать это на переходнике 1.8V-adapter, если задействовать его вторую незанятую половину разьема. Тем более при применении адаптера переделка на плате программатора становится бесполезной, порты у трансмиттера используются как однонаправленные.
Доработка 2. Увеличение кол-ва блокировочных конденсаторов по питанию.
Участник сообщества «AlexX1810» предложил добавить на плату программатора три блокировочных конденсатора 0.1 мкФ. По его словам улучшается стабильность работы программатора.
Если ориентироваться по схеме, первый конденсатор между 6-7 контактами разьема Р1 (5V), второй между 5-6 контактами разьема Р2 (3.3V), третий между 15-16 контактами ZIF панельки (7-8 контакты разьема I2C, 3.3V). Все впаяны со стороны контактов.
У меня во время использования программатора сбоев не было, но хуже во всяком случае не будет.
Читайте также: