Из вопроса понятно, что нужна автоматическая генерация зависимостей.
Поможет нечто типа:*************
%.d: %.c
@echo "## depend $<"
@set -e; $(CC) -M $(CFLAGS) $< \
| sed 's@\($*\)\.o[ :]*@\1.o $@ : @g' > $@; [ -s $@ ] || $(RM) $@
%.o: %.c
$(CC) -c $(CCFLAGS) -o $@ $<
SOURCEFILES=file1.c file2.c file3.c
DEPFILES=$(SOURCEFILES:.c=.d)
OBJFILES=$(SOURCEFILES:.o=.d)
all: proga
proga: $(OBJFILES)
$(LD) $(LDFLAGS) -o $@ $<
-include $(DEPFILES)
*************
Единственно что для цели clean (которой в приведенном примере нету)
нужно оный '-include' отрубить, иначе он перед очисткой будет .d-файлики
генерировать - что явно не требуется.
Вообще аналогичный пример, весьма подробно разобранный, есть в документации
на GNU make.