Имеется несколько устройств с контроллерами STM32F103,имеется отлаженный hex-файл прошивки, хотел загрузить прошивку в контроллеры через программатор J-Link используя программу-монитор фирмы Segger.
В мониторе видно, что происходит подключение к процессору, отрабатывается команда h (стоп) и ..... кроме точек сказать нечего, потому что дальнейшие команды игнорируются.
Может кто подсказать, какая последовательность команд монитора должна подаваться для прошивки контроллера J-Link-ом ?
Повторюсь, что подключаю контроллер, вижу его, подаю стоп h , а дальше?
Цитата(NikP @ Jan 18 2018, 15:05)

Может кто подсказать, какая последовательность команд монитора должна подаваться для прошивки контроллера J-Link-ом ?
Не очень понятно что за монитор Вы имеете в виду?
Готовый hex (или какой другой формат) легко шьётся с помощью JFlash.exe.
Предварительно в нём конечно нужно настроить подключение (SWD/JTAG, частоту, тип сброса, МК и т.п.).
Я пробовал работать с программой JLink.exe ( J-Link Commander), про неё собственно и вопрос. С JFlash.exe не пробовал , но если Вы кратко опишете как её настроить и работать (просто последовательность команд) - буду весьма благодарен.
Цитата(NikP @ Jan 18 2018, 15:59)

Я пробовал работать с программой JLink.exe ( J-Link Commander), про неё собственно и вопрос. С JFlash.exe не пробовал , но если Вы кратко опишете как её настроить и работать (просто последовательность команд) - буду весьма благодарен.
А Вы её запустите хотя-бы.

Там интуитивно-понятный интерфейс.
А в описании есть интуитивно понятные буквы.
Когда я запустил JFlash.exe и попытался стереть флэш контроллера, то вывалилось сообщение "интуитивно понятными буквами" о том, что у меня нет лицензии и за её приобретением надо обратиться на sales@segger.com. Так что пока хотелось использовать бесплатные варианты.
Поэтому возвращаюсь к началу темы.
При запуске JLink.exe ( J-Link Commander-а) я подключаюсь к контроллеру, читаю флэш с адреса 0х00000000 для того, чтоб убедиться что реально подключился. Флэш читается (вижу реальную прошивку). Далее подаю команду стоп (h) и стирание флэш(erase); программа сообщает, что стирание выполнено, но реально эта команда не выполнена (опять же читаю начало флэш).
В чём причина? Может надо перед командой стирания ещё какие-то действия предпринять?
И большая просьба ко всем - пишите по делу, или не пишите вообще. Я понимаю, что задаю глупые вопросы (а когда разберусь и сам пойму, что тут никаких проблем нет), но пока не разобрался - для меня это актуально.
AlexandrY
Jan 19 2018, 09:04
Цитата(NikP @ Jan 19 2018, 09:29)

то вывалилось сообщение "интуитивно понятными буквами" о том, что у меня нет лицензии
Интуитивно как бы понятно, что если нет лицензии на программирование, то и через монитор не дадут программировать.
Можно пробовать IDE типа IAR или Keil и программировать через них.
Цитата(AlexandrY @ Jan 19 2018, 12:04)

Можно пробовать IDE типа IAR или Keil и программировать через них.
Дело в том, что через IDE всё прекрасно программируется и отлаживается. Но возникла необходимость поменять прошивку в приборах, которые отдали заказчикам. У них есть программатор, и хотелось бы отправить только готовый hex для непосредственной прошивки прибора, а не ехать в другой город и заморачиваться с установкой там Keil-а или тащить с собой ноут с IDE .
С JLink.exe вроде всё должно быть просто: подключается, видит процессор, читает содержимое флэш (и лицензию не просит) - а вот стирать ( и соответственно программировать) флэш не хочет. Самое главное, что скорее всего здесь действительно какой-то команды не хватает. Но уж вроде все варианты перепробовали, а результат ноль.
редактор
Jan 19 2018, 17:43
Цитата
С JLink.exe вроде всё должно быть просто: подключается, видит процессор, читает содержимое флэш (и лицензию не просит) - а вот стирать ( и соответственно программировать) флэш не хочет. Самое главное, что скорее всего здесь действительно какой-то команды не хватает. Но уж вроде все варианты перепробовали, а результат ноль.
Простой команды записи флешь не существует.Тот же Сеггер в доках на J-link указывает, что разные камни имеют разные алгоритмы прошивки (адресация, размер стираемой страницы, тайминги). Поэтому используется "универсальный алгоритм" как в KEIL. Под камень (или серию МК) создается загрузчик, который работает в ОЗУ. Этот загрузчик записывается в МК, затем принимает прошивку (по частям) и записывает во флешь МК. Можно посоветовать такой алгоритм (если не получается штатными средствами)
1.Создать проект, который работает из ОЗУ, берет данные (1-8 кБ) по фиксированному адресу и записывает их во флешь. (данные тоже в ОЗУ располагаются).
2.Разбить прошивку (которая должна быть записана) на "порции" (те же 1-8 кБ)
3.Записать в МК проект из п.1. записать данные (порцию) по фиксированному адресу. Запустить на выполнение прошивку из п.1.
4.Повторить п.3 для каждой порции данных.
5.Считать всю прошивку и сравнить с исходным файлом.
Как то так.
Так вроде понятно. То есть "лёгкой" жизни ждать не приходится : надо сделать то же , что сделано в IDE.
Спасибо, попробуем.
Цитата(редактор @ Jan 19 2018, 19:43)

1.Создать проект, который работает из ОЗУ, берет данные (1-8 кБ) по фиксированному адресу и записывает их во флешь. (данные тоже в ОЗУ располагаются).
...
5.Считать всю прошивку и сравнить с исходным файлом.
Иээх! Нелегка жизнь в командной строке! Живём под JFlash и не знаем всей правды жизни!...
Подключились к контроллеру через JFlash. Но программа выдаёт сообщение "Could not find CFI-compliant flash device". Можно ли подружить JFlash с конкретным контроллером и что для этого нужно?
esaulenka
Jan 22 2018, 08:20
Для этого нужно, как ни странно, в свойствах проекта (options -> project settings) выбрать соответствующий контроллер. Вам же внутрь 103-ей STM'ки надо прошивку залить?
К сожалению, не в STM103. У нас Миландровский контроллер (у них просто написано, что близкий аналог STM103), ядро Cortex-M1.
В списке контроллеров JFlash для этого ядра выбора практически нет - только одна строчка: Cortex-M1.
Когда работаем с Keil, то в каталог этой среды копируем библиотечный файл Миландра и всё отлично идёт.
Corvus
Jan 23 2018, 09:19
Цитата(NikP @ Jan 22 2018, 13:09)

К сожалению, не в STM103. У нас Миландровский контроллер (у них просто написано, что близкий аналог STM103), ядро Cortex-M1.
У STM32F103 ядро Cortex-M3, а не М1. Техподдержку "Миландр" спрашивали?
Цитата
Техподдержку "Миландр" спрашивали?
В техподдержке Миландра посоветовали воспользоваться OpenOCD (эта тема оказалась актуальной для достаточного количества пользователей).
Цитата
А это не подходит ?
2-я ссылка не идёт -у меня программатор J-Link.
А вот первая - очень интересная. Я её поиском не находил, надо будет попробовать.
Всем спасибо за информацию и полезное обсуждение.
Да, ещё приношу извинения за некорректную формулировку, если б сразу написал про Миландр, то сразу была бы понятна суть проблемы.
2-я ссылка не идёт -у меня программатор J-Link.
Это как раз про JLink - надо внимательно прочитать текст (не только название)
Alexashka
Jan 24 2018, 05:40
Если речь о 1986ВЕ9х, то мы их программируем по UART бесплатной утилитой от Milandr (1986WSD). Такой вариант удобен тем, что в нашем устройстве UART итак выведен наружу в виде RS485 для штатного обмена, поэтому для перепрошивки не нужно вскрывать корпус, нужно только надеть спец.разъем, который помимо подключения RS485 ещё переводит линии MODE в режим UART-загрузчика.
Цитата
Это как раз про JLink - надо внимательно прочитать текст (не только название)
Есть у меня такой недостаток
Единственно, что Keil у меня работает с Миландром без проблем - файлы *.FLM были предоставлены на диске из отладочного комплекта. Тут как раз хотелось разобраться, можно ли без Keil-а готовый хекс залить при помощи JLink.exe. Вывод : без заморочек - никак.
Проблема возникла из-за необходимости перепрошивки готовых изделий в другом городе. Не хотелось тащить с собой ноут со всем соответствующим ПО. Так можно было бы запустить JLink.exe на ПК у заказчиков. Но не судьба, много мороки.
По UART прошить не получится, он просто не предусмотрен, наружу выведен SWD . Прибор в удалённом доступе, связь (и перепрошивка) только по CAN, SWD на крайний случай (который и возник).
На сайте сеггера есть инструкция как сделать файл с описанием для JLink. Надо прочитать внимательно и сделать. Конечно гуру программирования из Миландра могли бы это сделать сами для своих чудесных процессоров с 2012 года, но видимо другие проблемы их занимают.
Цитата
На сайте сеггера есть инструкция...
Вот это интересно. Правда, от нас уже уехал человек с ноутбуком, но попробуем сделать . Такое может пригодиться в другой раз.
Цитата(NikP @ Jan 24 2018, 09:34)

Единственно, что Keil у меня работает с Миландром без проблем - файлы *.FLM были предоставлены на диске из отладочного комплекта. Тут как раз хотелось разобраться, можно ли без Keil-а готовый хекс залить при помощи JLink.exe. Вывод : без заморочек - никак.
Не знаю как в Keil-е (не пользую его), но в IAR-е в проект можно включить любой произвольный бинарный файл, который будет добавлен "как есть" в образ прошивки.
Если уж не судьба никак с JFlash, то можно тогда обойтись IAR-ом: сделать пустой проект, содержащий только .bin-файл с прошивкой, указать с какого адреса его надо располагать и всё.
Дальше - в том проекте где ваши программёры генерят hex, сделать дополнительную генерацию bin-файла. И его уже отсылать в другой город вместе с указанным выше проектом, но без исходных файлов программ.
Наверняка и в Keil-е подобная возможность есть.
Если ваши программёры имеют
хотя-бы среднюю квалификацию, то так сделать им не составит никакого труда.
Цитата(NikP @ Jan 24 2018, 13:00)

Вот это интересно. Правда, от нас уже уехал человек с ноутбуком, но попробуем сделать . Такое может пригодиться в другой раз.
На всех один ноутбук ?!
Остальные на калькуляторах программируют ?
Или на счётах ?
Цитата
На всех один ноутбук ?!
Дело не в количестве, а в том, что тащить надо))) + морока с вносом-выносом.
редактор
Jan 24 2018, 17:35
Вот еще одна ссылка на форум. segger + готовое ПО (есть во вложениях при обсуждении) так же решают вашу проблему
Обсуждение J-Flash
Цитата(редактор @ Jan 24 2018, 20:35)

Вот еще одна ссылка на форум. segger + готовое ПО (есть во вложениях при обсуждении) так же решают вашу проблему
Обсуждение J-FlashСпасибо, это то что я искал. Уже попробовал, Миландровский контроллер подключается, стирается и заливается прошивка без проблем!
Ещё раз спасибо за подсказку.
Для просмотра полной версии этой страницы, пожалуйста,
пройдите по ссылке.