реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> MSP430-GCC makefile для сборки .elf из .c файла(+), MSP430-GCC
amok
сообщение Oct 8 2005, 06:51
Сообщение #1


Участник
*

Группа: Новичок
Сообщений: 31
Регистрация: 26-08-05
Пользователь №: 7 994



MSP430-GCC makefile для сборки .elf из .c файла:
Кто нибудь может подсказать человеческий makefile для сборки ELF файла из исходника на Си?
Желательно чтобы был похож на makefile для helloworld программ на Си.
Makefile из Руководства непонятен.

С Уважением, Amok.
Go to the top of the page
 
+Quote Post
Shootnik
сообщение Oct 19 2005, 12:46
Сообщение #2





Группа: Новичок
Сообщений: 4
Регистрация: 7-09-05
Пользователь №: 8 310



Могу слить на мыло дабы не загромождать кодом топик.
Go to the top of the page
 
+Quote Post
amok
сообщение Oct 19 2005, 16:02
Сообщение #3


Участник
*

Группа: Новичок
Сообщений: 31
Регистрация: 26-08-05
Пользователь №: 7 994



Сделайте если не трудно.
Спасибо.

С Уважением, Андрей.
Go to the top of the page
 
+Quote Post
emark
сообщение Oct 22 2005, 13:54
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 34
Регистрация: 2-10-05
Пользователь №: 9 146



Цитата(amok @ Oct 8 2005, 12:51)
MSP430-GCC makefile для сборки .elf из .c файла:
Кто нибудь может подсказать человеческий makefile для сборки ELF файла из исходника на Си?
Желательно чтобы был похож на makefile для helloworld программ на Си.
Makefile из Руководства непонятен.

С Уважением, Amok.
*



Вот простенький Makefile с автоматическим построением зависимостей для случая , когда все свалено в один каталог.

Код
NAME            = name
CPU             = msp430x149

ASFLAGS         = -mmcu=${CPU} -D_GNU_ASSEMBLER_ -Wa,-gstabs -g
CFLAGS          = -mmcu=${CPU} -O2 -Wall -g

CC          = msp430-gcc
AS          = msp430-gcc

CLEANEXTS    := *.bak *.tmp *.o *.d *.elf *.a43 *.l43 *.s

sources    = $(wildcard *.c) $(wildcard *.S)
objects    = $(addsuffix .o,$(basename $(sources)))
depends    = $(objects:.o=.d)


.PHONY: all clean

all:  ${NAME}.elf ${NAME}.hex ${NAME}.l43

build:    clean all

${NAME}.elf: ${objects}
    ${CC} -mmcu=${CPU} -o $@ $^

${NAME}.hex: ${NAME}.elf
    msp430-objcopy -O ihex $^ $@

${NAME}.l43: ${NAME}.elf
    msp430-objdump -dStl $^ >$@

clean:
    rm -f $(CLEANEXTS)
%.o: %.c
    $(CC) $(CFLAGS) -c -o $@ $<

%.o: %.S
    $(AS) $(ASFLAGS) -c -o $@ $<

%.d: %.c
    @echo "Making depends for $<"
    $(CC) -MM $(CPPFLAGS) $(CFLAGS) $< 1>$@
%.d: %.S
    @echo "Making depends for $<"
    $(CC) -MM $(CPPFLAGS) $(ASFLAGS) $< 1>$@

dep: $(depends)

include $(depends)
Go to the top of the page
 
+Quote Post
emark
сообщение Oct 22 2005, 14:04
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 34
Регистрация: 2-10-05
Пользователь №: 9 146



Блин, все табуляции сожрало angry.gif
Замени <tab> на символ табуляции.
Замени name на свое название elf файла.
Положи в каталог с исходниками и выполни make


Код
NAME            = name
CPU             = msp430x149

ASFLAGS         = -mmcu=${CPU} -D_GNU_ASSEMBLER_ -Wa,-gstabs -g
CFLAGS          = -mmcu=${CPU} -O2 -Wall -g

CC          = msp430-gcc
AS          = msp430-gcc

CLEANEXTS    := *.bak *.tmp *.o *.d *.elf *.a43 *.l43 *.s

sources    = $(wildcard *.c) $(wildcard *.S)
objects    = $(addsuffix .o,$(basename $(sources)))
depends    = $(objects:.o=.d)


.PHONY: all clean

all:  ${NAME}.elf ${NAME}.hex ${NAME}.l43

build:    clean all

${NAME}.elf: ${objects}
<tab>    ${CC} -mmcu=${CPU} -o $@ $^

${NAME}.hex: ${NAME}.elf
<tab>    msp430-objcopy -O ihex $^ $@

${NAME}.l43: ${NAME}.elf
    msp430-objdump -dStl $^ >$@

clean:
<tab>    rm -f $(CLEANEXTS)

%.o: %.c
<tab>    $(CC) $(CFLAGS) -c -o $@ $<

%.o: %.S
<tab>    $(AS) $(ASFLAGS) -c -o $@ $<

%.d: %.c
<tab>    @echo "Making depends for $<"
<tab>    $(CC) -MM $(CPPFLAGS) $(CFLAGS) $< 1>$@

%.d: %.S
<tab>    @echo "Making depends for $<"
<tab>    $(CC) -MM $(CPPFLAGS) $(ASFLAGS) $< 1>$@

dep: $(depends)

include $(depends)
Go to the top of the page
 
+Quote Post
amok
сообщение Oct 22 2005, 14:58
Сообщение #6


Участник
*

Группа: Новичок
Сообщений: 31
Регистрация: 26-08-05
Пользователь №: 7 994



Спасибо за помощь.

С Уважением, Андрей.
Go to the top of the page
 
+Quote Post
emark
сообщение Oct 23 2005, 18:46
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 34
Регистрация: 2-10-05
Пользователь №: 9 146



Небольшая поправочка.

Код
%.o: %.c
<tab>$(CC) -MMD $(CFLAGS) -c -o $@ $<

%.o: %.S
<tab>$(AS) -MMD $(ASFLAGS) -c -o $@ $<


вместо

Код
%.o: %.c
<tab>$(CC)  $(CFLAGS) -c -o $@ $<

%.o: %.S
<tab>$(AS)  $(ASFLAGS) -c -o $@ $<
Go to the top of the page
 
+Quote Post
spf
сообщение Oct 24 2005, 05:47
Сообщение #8


Странник
****

Группа: Свой
Сообщений: 766
Регистрация: 29-08-05
Из: Екатеринбург
Пользователь №: 8 051



Цитата(amok @ Oct 8 2005, 11:51)
Makefile из Руководства непонятен.
*


Почитай достаточно понятную статью Игнатова
"Эффективное использование GNU Make."
http://www.linux.org.ru/books/GNU/Gmake.htm


--------------------
"Как много есть на свете вещей, которые мне не нужны!" Сократ
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 28th July 2025 - 04:59
Рейтинг@Mail.ru


Страница сгенерированна за 0.01416 секунд с 7
ELECTRONIX ©2004-2016