2016-12-07 8 views
1

Это мой makefile.makefile всегда вызывает последнюю цель

#starts here 
#Openssl constants 
Openssl_include=-I/usr/local/openssl/include 
Openssl_lib=-L/usr/local/openssl/lib -lcrypto -ldl 
#Wolfssl constants 
Wolfssl_include=-I/usr/local/wolfssl/include -LLIBDIR -DWOLFSSL_SHA512 
Wolfssl_lib=-L/usr/local/wolfssl/lib -lwolfssl 
#Mbedssl constants 
Mbedssl_include=-I/usr/local/mbedssl/include 
Mbedssl_lib=-L/usr/local/mbedssl/lib -lmbedcrypto 

SRC=CAL_aes.c CAL_sha.c CAL_cmac.c CAL_rsa.c 
OBJ=$(patsubst %.c,%.o,$(SRC)) 
M_OBJ=$(patsubst %.c,M_%.o,$(SRC)) 
M_fpic_OBJ=$(patsubst %.c,M_fpic_%.o,$(SRC)) 

O_OBJ=$(patsubst %.c,O_%.o,$(SRC)) 
O_fpic_OBJ=$(patsubst %.c,O_fpic_%.o,$(SRC)) 

W_OBJ=$(patsubst %.c,W_%.o,$(SRC)) 
W_fpic_OBJ=$(patsubst %.c,W_fpic_%.o,$(SRC)) 

.PHONY: clean Openssl Wolfssl Mbedssl compile_openssl compile_wolfssl compile_mbedssl 
compile_openssl: $(OBJ) 
%.o: %.c 
    cc -c $^ -o $(patsubst [email protected],[email protected],[email protected]) $(Openssl_include) $(Openssl_lib) 
    cc -c -fpic $^ -o $(patsubst [email protected],[email protected],[email protected]) $(Openssl_include) $(Openssl_lib) 
Openssl: compile_openssl 
    ar rc libO_CAL_crypto.a $(O_OBJ) 
    cc -shared -o libO_CAL_crypto.so $(O_fpic_OBJ) 
compile_wolfssl: $(OBJ) 
%.o: %.c 
    cc -c $^ -o $(patsubst [email protected],[email protected],[email protected]) $(Wolfssl_include) $(Wolfssl_lib) 
    cc -c -fpic $^ -o $(patsubst [email protected],[email protected],[email protected]) $(Wolfssl_include) $(Wolfssl_lib) 
Wolfssl: compile_wolfssl 
     ar rc libW_CAL_crypto.a $(W_OBJ) 
     cc -shared -o libW_CAL_crypto.so $(W_fpic_OBJ) 
compile_mbedssl: $(OBJ) 
    %.o: %.c 
     cc -c $^ -o $(patsubst [email protected],[email protected],[email protected]) $(Mbedssl_include) $(Mbedssl_lib) 
     cc -c -fpic $^ -o $(patsubst [email protected],[email protected],[email protected]) $(Mbedssl_include) $(Mbedssl_lib) 
Mbedssl: compile_mbedssl 
     ar rc libM_CAL_crypto.a $(M_OBJ) 
     cc -shared -o libM_CAL_crypto.so $(M_fpic_OBJ) 
    #ends here 

Независимо от того, звоню ли я, чтобы сделать Openssl, сделайте Wolfssl или сделайте Mbedssl. Всегда назначается цель Make Mbedssl. Я попытался переставить цели, и все время цель в последней позиции получает вызов независимо от цели, которую я передал, чтобы сделать из командной строки. Спасибо.

ответ

5

Вы, кажется, пытаетесь объявить несколько экземпляров шаблона правила %.o : %.c, чтобы они имели разные аффекты в зависимости от того, где они появляются в make-файле. Это невозможно. Сначала сначала считывает весь файл makefile, прежде чем он начнет обрабатывать любые цели, и он имеет только одну «область» для всех правил.

Если вы переопределили правило шаблона %.o : %.c, тогда старое правило будет удалено, и новое правило вступит в силу для всех поисковых запросов.

Таким образом, последний экземпляр шаблона %.o : %.c является тем, который действует для всех поисков .o целей, и все предыдущие правила удаляются.

Я рекомендую вам изучить target-specific variables, который может помочь вам в реализации.

+0

Спасибо, я использовал разные шаблоны, это сработало. Большое спасибо. – sg777