eddy_em: (Костерок)
eddy_em ([personal profile] eddy_em) wrote2017-01-20 12:02 am

Решена проблема деления на STM32F042

В попытке выяснить, кто же виноват, и что с этим делать, я собрал в кучу заголовочные файлы от ST с инициализацией от opencm3 и сделал "безбиблиотечную" среду.
Для проверки деления набросал «мыргалку», которая либо равномерно мигает диодом с периодом 4 секунды (если надета перемычка между землей и PA12), либо морзянит "SOS".
arm-none-eabi-gcc, собираемый кроссдевом в генте на этом примере обломался: как только я снимал перемычку, микроконтроллер уходил в глубокие раздумья.

Гугол подсказал мне, что эта проблема возникала далеко не у меня одного. И решения ее стандартным gcc просто нет! Но есть пропатченные тулчейны. Отсюда я скачал тулчейн, распаковал директорию в /opt и попробовал.
Теперь в директории arm-none-eabi/lib/thumb появились раздельные библиотеки для разных архитектур ARM. Вот эта строчка Makefile
LDLIBS		+= $(shell $(CC) $(CFLAGS) -print-libgcc-file-name)
позволяет слинковаться с правильной библиотекой (v6-m/libgcc.a). В итоге деление работает без проблем!

Жаль, что в генте так плохо с разработкой под микроконтроллеры!

[identity profile] mbr.livejournal.com 2017-01-20 06:32 am (UTC)(link)
Там есть другие проблемы, более серьезные.

Вообще странно, потому как у меня 4.8 работает без проблем, был достаточно сложный дизайн, там всяко было деление. А есть подробная ссылка на issue?

[identity profile] eddy-em.livejournal.com 2017-01-20 06:43 am (UTC)(link)
Ты как собирал? Я простым crossdev -t arm-none-eabi. Версия arm-none-eabi-4.7.3, с 5.4.0 еще не пробовал. Возможно, там нет этого бага.

Уже и не помню, что там за функция вызывалась, что-то вроде __udiv_from_thumb. По ней гугол и выдал кучу матов народа, у которого деление вызывало hardfault.

Сейчас сравнить не могу: дома компилял.
Edited 2017-01-20 06:46 (UTC)

[identity profile] mbr.livejournal.com 2017-01-20 06:47 am (UTC)(link)
Я не собирал, я ж не гентушник :) Взял собранный arm-none-eabi в ppa.

Hardfault у меня в ртоси отслеживается и вываливает корку. Такого не было. Ты на 0 проверял? В аппаратном делении тоже hardfault при /0, там нужно предварительно пару флагов поставить, чтобы оно вызывало usage fault. Вот я подозреваю что там криво сделана эмуляция и всего то.

[identity profile] eddy-em.livejournal.com 2017-01-20 06:53 am (UTC)(link)
У тебя в /usr/arm-none-eabi/lib/thumb есть поддиректории под разные архитектуры? Вот в моей сборке они отсутствуют!
Кстати, в этом не сам gcc виноват, а newlib. У меня версия 2.0.0.

> Ты на 0 проверял?
Не проверял. Но, судя по дизассемблеру, ничего страшного быть не должно.

Обновил newlib до 2.5.0. Ничего не изменилось: железякозависимые версии библиотеки не собрались. В общем, этот crossdev хрень какую-то генерит!
Edited 2017-01-20 07:02 (UTC)

[identity profile] mbr.livejournal.com 2017-01-20 01:26 pm (UTC)(link)
> Не проверял. Но, судя по дизассемблеру, ничего страшного быть не должно.

Далпаеб. Там даже системный флаг есть, который по такому условию hard/usage fault делает. Возможно где-то могли и эмулировать.