summaryrefslogtreecommitdiffstats
path: root/util/bincfg/Makefile.mk
blob: 0f5f442fd1a12796d867ee679ae005a55de5681d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
## SPDX-License-Identifier: GPL-2.0-only
bincfg_obj := bincfg.lex.o bincfg.tab.o

BINCFG_FLAGS += -I$(top)/util/bincfg -I$(objutil)/bincfg

$(objutil)/bincfg:
	mkdir -p $@

$(objutil)/bincfg/.generated: $(objutil)/bincfg
	touch $@

$(objutil)/bincfg/%.o: util/bincfg/%.c | $(objutil)/bincfg/.generated
	printf "    HOSTCC     $(subst $(obj)/,,$(@))\n"
	$(HOSTCC) $(BINCFG_FLAGS) $(HOSTCFLAGS) -c -o $@ $<

$(objutil)/bincfg/%.o: $(objutil)/bincfg/%.c
	printf "    HOSTCC     $(subst $(obj)/,,$(@))\n"
	$(HOSTCC) $(BINCFG_FLAGS) $(HOSTCFLAGS) -c -o $@ $<

ifeq ($(CONFIG_UTIL_GENPARSER),y)
$(top)/util/bincfg/bincfg.lex.c_shipped: $(top)/util/bincfg/bincfg.l
	printf "    FLEX       $(subst $(top)/,,$(@))\n"
	flex -L -o $@ $<

# the .c rule also creates .h
$(top)/util/bincfg/bincfg.tab.h_shipped: $(top)/util/bincfg/bincfg.tab.c_shipped
$(top)/util/bincfg/bincfg.tab.c_shipped: $(top)/util/bincfg/bincfg.y
	printf "    BISON      $(subst $(top)/,,$(@))\n"
	bison -l --defines=$(top)/util/bincfg/bincfg.tab.h_shipped -o $@ $<
endif

$(objutil)/bincfg/bincfg.lex.o: $(objutil)/bincfg/bincfg.tab.h

$(objutil)/bincfg/%: $(top)/util/bincfg/%_shipped
	mkdir -p $(dir $@)
	cp $< $@

$(objutil)/bincfg/bincfg: $(addprefix $(objutil)/bincfg/,$(bincfg_obj))
	printf "    HOSTCC     $(subst $(obj)/,,$(@)) (link)\n"
	$(HOSTCC) $(BINCFG_FLAGS) -o $@ $(addprefix $(objutil)/bincfg/,$(bincfg_obj))

$(addprefix $(objutil)/bincfg/,$(bincfg_obj)) : $(objutil)/bincfg/bincfg.tab.h $(objutil)/bincfg/bincfg.tab.c $(objutil)/bincfg/bincfg.lex.c