Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Использование SWDIO & SWCLK пинов как GPIO
Форум разработчиков электроники ELECTRONIX.ru > Сайт и форум > В помощь начинающему > ARM, 32bit
ivainc1789
STM32F030F4P6, IAR v7.60.1, Jet-Link Ultra.
Уже в который раз попадаю на одни и те же грабли: если внутри main делаю попытку переинициализировать SWDIO и SWCLK как выход в лог 1 / выход в лог 0 соответственно, то отладчик более не может подключиться к MCU. Странно, но код переинициализации выводов расположен после точки останова main - то есть по сбросу должны быть активны дебажные свойства пинов.
Лечится это тяжело, и у меня - только в Иаре, если в опциях стоит "подключаться во время сброса". Замыкаем вывод сброса на землю и отпускаем одновременно с запуском дебага. В этом случае, с ...дцатой попытки удается подключиться к кристаллу и стереть его, после чего можно нормально шить правленной прошивкой.
Прошу помощи: кто и как организует работу с этими выводами, чтобы и отлаживать можно было, и коннектился дебаггер нормально, и после отладки и прога могла нормально работать с переиниц выводами? Сейчас у меня они выведены на разъем без пуллапов и пулдаунов (по идее должны использоваться внутренние...).
ViKo
А в программе есть вначале сброс оговоренных ног в состояние по умолчанию?
ivainc1789
Цитата(ViKo @ May 9 2016, 14:45) *
А в программе есть вначале сброс оговоренных ног в состояние по умолчанию?
Так по сбросу же и есть дебажные свойства выводов по умолчанию! А Иар рапортует, что не может подключиться, хотя еще даже до main точки останова не дошли... Как я понимаю, Иар коннектится во время сброса, подключает дебаггер и встает на main. То, что где то далее произойдет переиниц выводов он еще не знает... Так ведь?
ViKo
Не знаю, как в 030. У меня в другом была включена защита. И тогда доступиться до этих ножек можно было только при сбросе.
adnega
Цитата(ivainc1789 @ May 9 2016, 14:27) *
Замыкаем вывод сброса на землю и отпускаем одновременно с запуском дебага

Неужели программатор этого не умеет делать?
ST-Link v2 с легкостью рулит ногой RST.
Сергей Борщ
QUOTE (ivainc1789 @ May 9 2016, 14:27) *
Странно, но код переинициализации выводов расположен после точки останова main - то есть по сбросу должны быть активны дебажные свойства пинов.
Не знаю, как это организовано при работе с кортексами, но старые ARM7TDMI работать при активном сигнале сброса не могли и с ними работа происходила примерно так: Отпускается сброс, (процессор при этом начинает работать и успевает кое-что сделать), отладчик дает команду halt, останавливает ядро, расставляет точки останова (если стоит галочка - ставит точку останова на входе в main()) , ставит счетчик команд на первую команду и запускает выполнение (если стояла галочка "бежать до main()). Так вот, если процессор от отпускания сброса до halt успевал запретить JTAG или поломать тактирование - ситуация была в точности ваша. Производителями отладчиков рекомендовалось в отладочной версии программы в самое начало стартапа ставить задержку из пустого цикла, чтобы за время исполнения этой задержки отладчик успевал выполнить команду halt. Возможно, для кортексов у отладчиков в режиме без галочки "подключаться с зажатым Reset" алгоритм работы такой же. Для стирания такого кристалла можно перед сбросом зажать ногу BOOT0 - тогда кристалл запустится в режиме встроенного загрузчика, swd останется активным и сможет стереть кристалл.
ivainc1789
Сейчас подпаял RESET пин и проблема решилась - теперь возможно автоматом соединиться. Получается, для SWD подсоединение к пину RESET необходимо, если выводы SWDIO и/или SWCLK будут переинициализированы как GPIO позже. Или видимо лучше как вариант, сделать у RESET пина контактную площадку для отладки, чтобы не тянуть антенну к разъему...
В итоге, как мы не пытаемся прийти к минимальному кол-ву пинов в SWD - все равно получается от 4 до 5-ти...
adnega
Цитата(ivainc1789 @ May 9 2016, 22:44) *
В итоге, как мы не пытаемся прийти к минимальному кол-ву пинов в SWD - все равно получается от 4 до 5-ти...

Если для прошивки на производстве, то в некоторых случаях достаточно SWDIO и SWCLK, т.к.
запитать и получить землю можно через разъем питания.
Aner
QUOTE (adnega @ May 10 2016, 08:24) *
Если для прошивки на производстве, то в некоторых случаях достаточно SWDIO и SWCLK, т.к.
запитать и получить землю можно через разъем питания.

Мы для прошивки на производстве пользуем двух-проводной RS, но все равно те же 6 пино-проводов.
После программирования через RS он используется по назначению в устройстве. И все Cool w/o SWDIO & SWCLK!
adnega
Цитата(Aner @ May 10 2016, 10:47) *
Мы для прошивки на производстве пользуем двух-проводной RS, но все равно те же 6 пино-проводов.
После программирования через RS он используется по назначению в устройстве. И все Cool w/o SWDIO & SWCLK!

А как же ножки BOOT ?
Aner
QUOTE (adnega @ May 10 2016, 13:16) *
А как же ножки BOOT ?

Понятно что не догнал, еще разок ... 6 пинов это +; -; Reset; Boot0; Rx;Tx
adnega
Цитата(Aner @ May 10 2016, 13:08) *
Понятно что не догнал, еще разок ... 6 пинов это +; -; Reset; Boot0; Rx;Tx

Обсуждалась минимизация числа проводников.
Цитата
В итоге, как мы не пытаемся прийти к минимальному кол-ву пинов в SWD - все равно получается от 4 до 5-ти...

Можно, конечно, сделать джампер "BOOT0" и кнопку "Reset", а для прошивки использовать существующий в некоторых изделиях UART/RS232/422-порт.
Кста, я тоже везде стараюсь выводить эти самые 6 пинов (uart используется как отладочная консоль).
den1234567
Всех приветствую!
Схожая ситуация, но с другой стороны. На таком же камне. После отладки проги по SWD, активировал РА13 и РА14 на выход (так должно быть по задумке) - не работают. Дебагер тоже перастает работать, но так и должно быть! Снял инициализацию РА13 и РА14, все вернулось. Нужно что бы заработали ноги РА13 и РА14. Может кто сталкивался? Может компилятор ставит какой затык? Или подпалил ноги пока отлаживал прогу?
adnega
Цитата(den1234567 @ Jun 6 2018, 23:39) *
Нужно что бы заработали ноги РА13 и РА14. Может кто сталкивался? Может компилятор ставит какой затык? Или подпалил ноги пока отлаживал прогу?

Все прекрасно работает. Нужно записать правильное значение в GPIOA->MODER (пины 13 и 14 в MODE_OUTPUT).
Код
GPIOA->MODER = 0
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN0)        // ( 6) LCD1602_RS
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN1)        // ( 7) LCD1602_E
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN2)        // ( 8) LCD1602_D4
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN3)        // ( 9) LCD1602_D5
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN4)        // (10) LCD1602_D6
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN5)        // (11) LCD1602_D7
        | (GPIO_MODE_INPUT      << GPIO_MODER_PIN6)        // (12) ENC_A
        | (GPIO_MODE_INPUT      << GPIO_MODER_PIN7)        // (13) ENC_B
        | (GPIO_MODE_ALTERNATE  << GPIO_MODER_PIN9)        // (17) CON_TX. USART1_TX
        | (GPIO_MODE_ALTERNATE  << GPIO_MODER_PIN10)       // (18) CON_RX. USART1_RX
        | (GPIO_MODE_INPUT      << GPIO_MODER_PIN11)       // (17) free
        | (GPIO_MODE_INPUT      << GPIO_MODER_PIN12)       // (18) free
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN13)       // (19) TXEN [SWDIO (debug)]
        | (GPIO_MODE_OUTPUT    << GPIO_MODER_PIN14);       // (20) WL [SWCLK (debug)]
Эдди
Цитата(Aner @ May 10 2016, 13:08) *
6 пинов это +; -; Reset; Boot0; Rx;Tx

Можно сделать хитрый PCB-разъем (навроде камаковских разъемов или ISA): пока вставляете, закоротится сначала Boot0, потом Reset, потом отпустится Boot0 и отпустится Reset. В итоге от платы к компьютеру только 4 проводочка идти будет…
Сам прошиваю STM32 только через бутлоадер (т.к. это очень удобно: после прошивки этот же преобразователь USB<->TTL используется для отладки), но Boot и Reset делаю в виде кнопочек и жму их вручную.
den1234567
Спасибо, разобрался! Надо приучить себя сначала обнулить регистр, а потом писать в него. А я просто, ниже других пинов, дописал инициализацию РА13, РА14 на выход. В результате, в сумме в регистре MODER получилась фигня!
Obam
Цитата(Сергей Борщ @ May 9 2016, 16:36) *
Не знаю, как это организовано при работе с кортексами, но старые ARM7TDMI работать при активном сигнале сброса не могли...

Более того, коннект при сбросе это свойство только STM32 wink.gif Atmelы, к примеру, не умеют так (выход - стирать).
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2024 Invision Power Services, Inc.