Legath
May 11 2012, 11:04
Можно ли как то запустить версию порта от cortex-m3?
AHTOXA
May 11 2012, 11:09
Можно, работает без каких-либо доработок.
Можете взять
примеры для STM32F2XX (GCC), они вообще должны заработать сразу.
ЗЫ. Естественно, плавучку использовать можно только в одной задаче.
Legath
May 11 2012, 12:51
Цитата(AHTOXA @ May 11 2012, 15:09)

Можно, работает без каких-либо доработок.
Можете взять
примеры для STM32F2XX (GCC), они вообще должны заработать сразу.
ЗЫ. Естественно, плавучку использовать можно только в одной задаче.
А скрипт линковки какой взять? Из примеров платы или от ОС?
AHTOXA
May 11 2012, 13:59
От ОС конечно. Прямо целиком пример берите.
Ну или могу выложить мигалку светодиодами непосредственно для STM32F4DISCOVERY. Надо?
Legath
May 11 2012, 15:31
Цитата(AHTOXA @ May 11 2012, 17:59)

От ОС конечно. Прямо целиком пример берите.
Ну или могу выложить мигалку светодиодами непосредственно для STM32F4DISCOVERY. Надо?
Благодарю, не надо. Это были уточняющие вопросы. Огромное Спасибо!
AHTOXA
May 11 2012, 17:52
Всегда пожалуйста

Забыл написать. Если захотите использовать плюшки M4F, и станете компилить для cortex-m4 (-mcpu=cortex-m4), то в OS_Target.h заругается на вот этой проверке:
Код
#ifndef __ARM_ARCH_7M__
#error "This file must be compiled for ARMv7-M (Cortex-M3) processor only."
#endif
Пока можно просто закомментировать её.
А потом, (я надеюсь, что скоро) появится нормальный порт для M4.
Legath
May 17 2012, 20:51
еще глупый вопрос: почему когда в скрипте линковки ставлю величину ram в 192к (сколько есть в контроллере) - сразу улетаю в дефолтный хендлер? я чего то не учитываю?
AHTOXA
May 18 2012, 03:58
Видимо потому, что верхние 64К - это некая CCM (core coupled memory), которая не присоединена к bus matrix. То есть, любая попытка DMA-доступа к ней обречена на провал.
Кроме того, в RCC_AHB1ENR есть бит CCMDATARAMEN, возможно это означает, что надо включить тактирование этой CCM перед её использованием.
AHTOXA
May 18 2012, 16:39
На STM32F4DISCOVERY кварц 8МГц, а в примерах (они для платы TE-STM32Fx07) - 25МГц. Это задаётся в makefile, строка
Код
HSE_VALUE = 25000000
, поменяйте на 8000000.
А в sysinit.cpp, чтобы заработало на 168МГц, надо задать:
Код
#define PLL_M 8
#define PLL_N 336
// SYSCLK = PLL_VCO / PLL_P
#define PLL_P 2
// USB OTG FS, SDIO and RNG Clock = PLL_VCO / PLLQ
#define PLL_Q 7
Ну и включить high performance mode:
Код
static inline void init_clocks()
{
RCC->CR |= RCC_CR_HSEON;
while (!(RCC->CR & RCC_CR_HSERDY));
// Enable high performance mode, System frequency up to 168 MHz
RCC->APB1ENR |= RCC_APB1ENR_PWREN;
PWR->CR |= PWR_CR_PMODE;
...
Legath
May 18 2012, 18:26
Огромное спасибо за оперативную помощь по переходу!
AHTOXA
Nov 30 2012, 04:21
Цитата(AHTOXA @ May 11 2012, 19:59)

Ну или могу выложить мигалку светодиодами непосредственно для STM32F4DISCOVERY. Надо?
Меня тут в личке попросили всё же выложить пример. Выкладываю.
Нажмите для просмотра прикрепленного файла
Цитата(AHTOXA @ Nov 30 2012, 06:21)

Меня тут в личке попросили всё же выложить пример. Выкладываю.
Нажмите для просмотра прикрепленного файлаЭто я просил.
Спасибо огромное.
Думаю будет, Вам, общая благодарность, если найдете время допилить порт под F4.
Еще раз Спасибо.
Цитата(Pat @ Nov 30 2012, 14:31)

Думаю будет, Вам, общая благодарность, если найдете время допилить порт под F4.
Могу вас порадовать, порт уже задышал. На днях постараюсь выложить в репозиторий.
viktory_93
Jun 15 2014, 21:01
Цитата(AHTOXA @ Nov 30 2012, 08:21)

Меня тут в личке попросили всё же выложить пример. Выкладываю.
Нажмите для просмотра прикрепленного файлаДобрый день. Впервые пытаюсь запустить проекты на scmRTOS, использую Eclipse + Sourcey G++ Lite, получаю следующее:
c:\!Botva\8semestr\kursach\scmRTOS_stm32f4_sample\HelloLed>make
--- building HelloLed. defines: -DSTM32F4XX -DVER_MAJOR=0 -DVER_MINOR=1 -DHSE_VALUE=8000000
Ошибка в синтаксисе команды.
Ошибка в синтаксисе команды.
Ошибка в синтаксисе команды.
Ошибка в синтаксисе команды.
--- compiling ./src/sysinit.cpp...
"LC_MESSAGES" не является внутренней или внешней
командой, исполняемой программой или пакетным файлом.
make[1]: *** [obj/sysinit.o] Error 1
make: *** [all] Error 2
причем ошибки не подсвечиваются и никак не выделяются. Подскажите, что это может быть и как с этим бороться, пожалуйста
AHTOXA
Jun 16 2014, 04:58
У Sourcery make называется cs-make. Исправьте в настройках проекта.
Кстати, в репозитории есть
более свежие примеры.
viktory_93
Jun 19 2014, 14:48
Получилось примерно следущее в CoIDE
GCC HOME: C:\Program Files (x86)\GNU Tools ARM Embedded\4.8 2014q1\bin
compile:
[mkdir] Created dir: C:\CooCox\CoIDE\workspace\start_this\start_this\Debug\bin
[mkdir] Created dir: C:\CooCox\CoIDE\workspace\start_this\start_this\Debug\obj
[cc] 200
[cc] 9 total files to be compiled.
[cc] arm-none-eabi-gcc -mcpu=cortex-m4 -mthumb -Wall -ffunction-sections -g -O0 -c -DSTM32F407VG -DSTM32F4XX -DSUPPORT_CPLUSPLUS -DUSE_STDPERIPH_DRIVER -D__ASSEMBLY__ -IC:\CooCox\CoIDE\workspace\start_this -IC:\CooCox\CoIDE\workspace\start_this\cmsis_boot -IC:\CooCox\CoIDE\workspace -IC:\CooCox\CoIDE C:\CooCox\CoIDE\workspace\start_this\OS_Kernel.cpp C:\CooCox\CoIDE\workspace\start_this\startup-stm32f4xx.c C:\CooCox\CoIDE\workspace\start_this\sys.c C:\CooCox\CoIDE\workspace\start_this\main.cpp C:\CooCox\CoIDE\workspace\start_this\OS_Target_asm.S C:\CooCox\CoIDE\workspace\start_this\OS_Services.cpp C:\CooCox\CoIDE\workspace\start_this\usrlib.cpp C:\CooCox\CoIDE\workspace\start_this\sysinit.cpp C:\CooCox\CoIDE\workspace\start_this\OS_Target_cpp.cpp
[cc] Starting link
[cc] arm-none-eabi-gcc -mcpu=cortex-m4 -mthumb -g -Wl,-Map=start_this.map -O0 -Wl,--gc-sections -LC:\CooCox\CoIDE\configuration\ProgramData\start_this -Wl,-TC:\CooCox\CoIDE\configuration\ProgramData\start_this/arm-gcc-link.ld -g -o start_this.elf ..\obj\OS_Kernel.o ..\obj\startup-stm32f4xx.o ..\obj\sys.o ..\obj\main.o ..\obj\OS_Target_asm.o ..\obj\OS_Services.o ..\obj\usrlib.o ..\obj\sysinit.o ..\obj\OS_Target_cpp.o -lm -lgcc -lc -lrdimon -lstdc++
[cc] ..\obj\sys.o: In function `__cxa_pure_virtual':
[cc] C:\CooCox\CoIDE\workspace\start_this/sys.c:15: multiple definition of `__dso_handle'
[cc] c:/program files (x86)/gnu tools arm embedded/4.8 2014q1/bin/../lib/gcc/arm-none-eabi/4.8.3/armv7e-m/crtbegin.o:(.data+0x0): first defined here
[cc] ..\obj\startup-stm32f4xx.o:(.isr_vector+0x0): undefined reference to `_estack'
[cc] ..\obj\startup-stm32f4xx.o: In function `__Init_Data':
[cc] C:\CooCox\CoIDE\workspace\start_this/startup-stm32f4xx.c:257: undefined reference to `__ctors_start__'
[cc] C:\CooCox\CoIDE\workspace\start_this/startup-stm32f4xx.c:257: undefined reference to `__ctors_end__'
[cc] ..\obj\main.o: In function `Pin<(char)68, 12, (char)72, (PinSpeed)3>::SetPullUp(PullUpMode)':
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 12, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 12, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 12, (char)72, (PinSpeed)3>::BBBits'
[cc] ..\obj\main.o: In function `Pin<(char)68, 13, (char)72, (PinSpeed)3>::SetPullUp(PullUpMode)':
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 12, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 13, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 13, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 13, (char)72, (PinSpeed)3>::BBBits'
[cc] ..\obj\main.o: In function `Pin<(char)68, 14, (char)72, (PinSpeed)3>::SetPullUp(PullUpMode)':
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 13, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 14, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 14, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 14, (char)72, (PinSpeed)3>::BBBits'
[cc] ..\obj\main.o: In function `Pin<(char)68, 15, (char)72, (PinSpeed)3>::SetPullUp(PullUpMode)':
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 14, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 15, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 15, (char)72, (PinSpeed)3>::BBBits'
[cc] C:\CooCox\CoIDE\workspace\start_this/pin_stm32F4xx.h:471: undefined reference to `Pin<(char)68, 15, (char)72, (PinSpeed)3>::BBBits'
[cc] ..\obj\main.o: In function `run':
[cc] C:\CooCox\CoIDE\workspace\start_this/OS_Kernel.h:646: undefined reference to `Pin<(char)68, 15, (char)72, (PinSpeed)3>::BBBits'
[cc] ..\obj\main.o: In function `OS::process<(OS::TPriority)2, 600u>::exec()':
[cc] C:\CooCox\CoIDE\workspace\start_this/main.cpp:67: undefined reference to `Pin<(char)68, 12, (char)72, (PinSpeed)3>::GPIOx'
[cc] C:\CooCox\CoIDE\workspace\start_this/main.cpp:67: undefined reference to `Pin<(char)68, 13, (char)72, (PinSpeed)3>::GPIOx'
[cc] C:\CooCox\CoIDE\workspace\start_this/main.cpp:67: undefined reference to `Pin<(char)68, 14, (char)72, (PinSpeed)3>::GPIOx'
[cc] C:\CooCox\CoIDE\workspace\start_this/main.cpp:67: undefined reference to `Pin<(char)68, 15, (char)72, (PinSpeed)3>::GPIOx
[cc] collect2.exe: error: ld returned 1 exit status
[cc] '
BUILD FAILED
Total time: 2 seconds
помогите исправить, пожалуйста
AHTOXA
Jun 19 2014, 18:01
Я не знаком с CoIDE. Судя по всему, в проект кроме стартапа от примера включен стартап от CooCox. Вот они и дерутся.
Нужно настроить проект на линковку без использования какого-либо стартапа.
И скрипт линкера не тот.
Ну а вообще, чтобы минимально зависеть от используемой IDE, надо делать так (только что проделал это на голой Win XP в виртуалке):
- Качаем и ставим свежий gcc-arm-embedded.
(не забываем поставить птичку "добавить путь в PATH" или что-то типа того)
- Качаем нужные части из msys (не знаю, зачем они нашинковали их на столько кусочков, но уж как есть.):
Распаковываем их все в папку "C:\Program Files\GNU Tools ARM Embedded\4.8 2014q2\"
То есть, make.exe, sh.exe и прочие утилиты должны попасть в папку "C:\Program Files\GNU Tools ARM Embedded\4.8 2014q2\bin"
- Качаем и ставим svn.
- Пуск - выполнить - cmd.
Там пишем:
Код
C:
cd C:\
mkdir test
cd test
svn checkout http://svn.code.sf.net/p/scmrtos/code/trunk/Samples/CortexM4F/GCC/STM32F4XX STM32F4XX
cd STM32F4XX
switch.bat
cd 1-EventFlag
make
(Я всё это делаю в файловом менеджере Far, там работать с командной строкой значительно удобнее)
- Убеждаемся в том, что компиляция проходит без ошибок.
- Теперь настраиваем любую интегрированную среду разработки на использование makefile. Всё.
viktory_93
Jun 20 2014, 04:29
Ура! Билдится! Спасибо
Знать бы теперь как отладку запустить(
IgorKossak
Jun 20 2014, 08:02
Я бы не стал ставить утилиты пакета MSYS в несвойственное им место. Тулчейн может обновиться. Другие среды и тулчейны могут использовать эти утилиты в своих целях. Мало ли ещё какие причины могут быть?
Лучше проинсталлировать
MSYS стандартным способом с сохранением пути к нему в переменной PATH. А вот путь к тулчейну я в переменной PATH не сохраняю, а указываю в Project->Properties->C/C++ Build->Environment в переменной PATH (у меня Eclipse Luna, но и в других аналогичных IDE есть похожее). Так удобнее и при экспериментах с разными тулчейнами и с переносимостью проекта лучше.
Сергей Борщ
Jun 20 2014, 08:34
Цитата(IgorKossak @ Jun 20 2014, 11:02)

а указываю в Project->Properties->C/C++ Build->Environment в переменной PATH
А у меня путь к самому свежему компилятору прописан в PATH (что позволяет его вызывать из командной строки без полного указания пути), но при необходимости можно в makefile добавить в начало PATH путь к любому другому (подсмотрел у
ReAl):
Код
# add $(TOOLCHAIN)/bin to PATH
ifneq ($(strip $(TOOLCHAIN)),)
ifeq (,$(findstring;,$(PATH)))
PATH := $(subst :,,/$(TOOLCHAIN)/bin):$(PATH)
else
PATH := $(subst /,\,$(TOOLCHAIN)/bin);$(PATH)
endif
export PATH
endif
AHTOXA
Jun 20 2014, 10:03
Цитата(IgorKossak @ Jun 20 2014, 14:02)

Я бы не стал ставить утилиты пакета MSYS в несвойственное им место. Тулчейн может обновиться. Другие среды и тулчейны могут использовать эти утилиты в своих целях. Мало ли ещё какие причины могут быть?
Да, конечно лучше в отдельную папку. Просто я описывал как покороче.
Цитата(IgorKossak @ Jun 20 2014, 14:02)

Лучше проинсталлировать
MSYS стандартным способом с сохранением пути к нему в переменной PATH.
Дело в том, что я не нашёл на сайте mingw нормального инсталлятора MSYS. Самый последний инсталлятор - msys-1.0.11, от 2008 года. Дальше просто куча частей, разложенная в кучу архивов. Я решил, что лучше взять компоненты поновее.
Цитата(IgorKossak @ Jun 20 2014, 14:02)

А вот путь к тулчейну я в переменной PATH не сохраняю, а указываю в Project->Properties->C/C++ Build->Environment в переменной PATH (у меня Eclipse Luna, но и в других аналогичных IDE есть похожее). Так удобнее и при экспериментах с разными тулчейнами и с переносимостью проекта лучше.
Считаю, что makefile должен работать самостоятельно, на завися от эклипсы. Поэтому все параметры сборки проекта - в нём. Это и для переносимости в том числе.
При экспериментах ничто не мешает мне задать в makefile путь к любому тулчейну, если занадобится. А дефолтные тулчейны - в PATH.
Цитата(Сергей Борщ @ Jun 20 2014, 14:34)

А у меня путь к самому свежему компилятору прописан в PATH (что позволяет его вызывать из командной строки без полного указания пути), но при необходимости можно в makefile добавить в начало PATH путь к любому другому (подсмотрел у ReAl)
А чем это лучше, вот такого варианта:
Код
TOOL = arm-none-eabi-
CC = $(TOOL)gcc
CXX = $(TOOL)g++
LD = $(TOOL)g++
(при необходимости заменяем на:
Код
TOOL = /path/to/another/toolchain/arm-none-eabi-
CC = $(TOOL)gcc
...
)?
Сергей Борщ
Jun 20 2014, 10:16
Цитата(AHTOXA @ Jun 20 2014, 13:03)

А чем это лучше, вот такого варианта:
Тем, что не надо перечислять все используемые программы тулчейна, вероятно.
AHTOXA
Jun 20 2014, 11:09
Так их в любом случае придётся перечислять, из-за префикса
arm-none-eabi-
IgorKossak
Jun 20 2014, 11:26
Цитата(AHTOXA @ Jun 20 2014, 13:03)

Дело в том, что я не нашёл на сайте mingw нормального инсталлятора MSYS. Самый последний инсталлятор - msys-1.0.11, от 2008 года. Дальше просто куча частей, разложенная в кучу архивов. Я решил, что лучше взять компоненты поновее.
mingw-get-setup.exe Можно выбрать то, что нужно.
Цитата(AHTOXA @ Jun 20 2014, 13:03)

Считаю, что makefile должен работать самостоятельно, на завися от эклипсы. Поэтому все параметры сборки проекта - в нём. Это и для переносимости в том числе.
При экспериментах ничто не мешает мне задать в makefile путь к любому тулчейну, если занадобится. А дефолтные тулчейны - в PATH.
Это безусловно, если собирать из командной строки. Но если в проект входят ещё и настройки среды (файлы .project, .cproject, что в последнее время сполошь и рядом делается), что удобно для индексатора и discovering, то на мой взгляд лучше по-моему.
Кроме того, "дефолтные тулчейны - в PATH" могут подложить свинью, поскольку оттуда трудно отследить какие именно инструменты вызываются. Например, у меня установлены две версии тулчейна от GCC ARM Embedded и один от CodeSourcery. Чтобы переключиться с одного на другой в Вашем варианте надо поменять переменную PATH и перелогиниться в системе (у меня по крайней мере так). В то время как используя мой вариант, не нужно даже среду перезапускать, а достаточно подправить переменную PATH в среде, при этом автоматически осуществляется редискаверинг и реиндексация.
Мне так показалось удобнее, но я не настаиваю.
AHTOXA
Jun 20 2014, 12:55
Цитата(IgorKossak @ Jun 20 2014, 17:26)

mingw-get-setup.exe Можно выбрать то, что нужно.
О, спасибо, я как-то проглядел. Хотя не люблю я эти веб-инсталляторы

Цитата(IgorKossak @ Jun 20 2014, 17:26)

Это безусловно, если собирать из командной строки. Но если в проект входят ещё и настройки среды (файлы .project, .cproject, что в последнее время сполошь и рядом делается), что удобно для индексатора и discovering, то на мой взгляд лучше по-моему.
В этом случае сложнее перетащить проект в другую IDE. В моём же варианте - настройки сборки проекта - в makefile, настройки среды - в .project, .cproject.
Цитата(IgorKossak @ Jun 20 2014, 17:26)

Кроме того, "дефолтные тулчейны - в PATH" могут подложить свинью, поскольку оттуда трудно отследить какие именно инструменты вызываются. Например, у меня установлены две версии тулчейна от GCC ARM Embedded и один от CodeSourcery. Чтобы переключиться с одного на другой в Вашем варианте надо поменять переменную PATH и перелогиниться в системе (у меня по крайней мере так).
Нет, я говорил немного о другом. Я говорил о вызове с полным указанием пути к тулчейну.
То есть, дефолтный компилятор вызывается как arm-none-eabi-gcc, а компилятор из другого тулчейна - как C:/tools/cs/2011.09-69/arm-none-eabi-gcc.
При этом никаких изменений в PATH вносить не надо.
Впрочем, я тоже не настаиваю на этом варианте
IgorKossak
Jun 20 2014, 13:16
Цитата(AHTOXA @ Jun 20 2014, 15:55)

То есть, дефолтный компилятор вызывается как arm-none-eabi-gcc, а компилятор из другого тулчейна - как C:/tools/cs/2011.09-69/arm-none-eabi-gcc.
О! Почти пришли к общему знаменателю. За исключением лишь того, что я не пользуюсь понятием "дефолтного" тулчейна, ибо не понимаю этой сущности. У меня тулчейн всегда конкретный, записанный с полным путём (в переменной PATH среды разработки, в системной же PATH - никаких путей к тулчейнам). Что же касается makefile, то указывать там полный путь, на мой взгляд - моветон, ибо совершенно не переносимо.
AHTOXA
Jun 20 2014, 15:24
Цитата(IgorKossak @ Jun 20 2014, 19:16)

О! Почти пришли к общему знаменателю.
Да, мы близки к этому

Дефолтный тулчейн - это, скажем, текущий стабильный. Вышел новый gcc-arm-embedded - я его протестировал, убедился в его работоспособности, и прописал в PATH. И с этого момента все проекты компилируются им.
Вам же, чтобы откомпилировать старые проекты новым тулчейном -- придётся менять настройки
для каждого проекта.
(Хотя может быть вы как раз наоборот, не станете менять, ибо раз проект разработан с конкретной версией компилятора, то пусть с ней и сопровождается. В этом случае всё нормально.)
Что касаемо указания полного пути в makefile, то это делается только на время эксперимента, потом убирается. Так что на переносимость не влияет.
mdmitry
Jun 20 2014, 15:38
Цитата(IgorKossak @ Jun 20 2014, 17:16)

О! Почти пришли к общему знаменателю. За исключением лишь того, что я не пользуюсь понятием "дефолтного" тулчейна, ибо не понимаю этой сущности. У меня тулчейн всегда конкретный, записанный с полным путём (в переменной PATH среды разработки, в системной же PATH - никаких путей к тулчейнам). Что же касается makefile, то указывать там полный путь, на мой взгляд - моветон, ибо совершенно не переносимо.
Можно вызывать сборку и так:
Код
make ARCH=ARM CROSS_COMPILE=path_to_cross_compiler
У меня в Makefile есть такой кусок:
Код
# Toolchain specific options
CROSS_COMPILE = /opt/gcc-arm-none-eabi-4_7-2013q1/bin
# Toolchain prefix (arm-none-eabi- -> arm-none-eabi-gcc.exe)
TCHAIN_PREFIX = arm-none-eabi-
ifndef CROSS_COMPILE
CROSS_TOOLS = $(TCHAIN_PREFIX)
else
CROSS_TOOLS = $(CROSS_COMPILE)/$(TCHAIN_PREFIX)
endif
CC = $(CROSS_TOOLS)gcc
...
Под Eclipse лень править вызовы для проекта с внешним makefile в Builder Settings, поэтому явно указан CROSS_COMPILE.
Можно убрать (закомментировать) путь к кросс-компилятору и использовать тот, который указан в путях (у меня нет такого).
По поводу переносимости - невелика правка, хуже когда весь проект даже в другую директорию переносится с усилием (по опыту работы с средствами разработки от TI).
P.S. А не следует ли кусок обсуждения про настройку makefile перенести в раздел GNU/OpenSource средства разработки для avr/arm/mips, где это собственно уже и имеется. Для полноты картины?
IgorKossak
Jun 20 2014, 16:28
Цитата(mdmitry @ Jun 20 2014, 18:38)

P.S. А не следует ли кусок обсуждения про настройку makefile перенести в раздел GNU/OpenSource средства разработки для avr/arm/mips, где это собственно уже и имеется. Для полноты картины?
Хорошо бы, но это может сделать модератор именно этого раздела.