build: Add auto regenerate of nmake file

Change-Id: Icaa64aa35697c87779df18c3941d3df0f3256546
Signed-off-by: Greg Tucker <greg.b.tucker@intel.com>
This commit is contained in:
Greg Tucker 2020-03-06 17:43:39 -07:00
parent 794413ddd2
commit 7c0ab1d459
3 changed files with 246 additions and 97 deletions

View File

@ -1,5 +1,5 @@
######################################################################## ########################################################################
# Copyright(c) 2011-2016 Intel Corporation All rights reserved. # Copyright(c) 2011-2017 Intel Corporation All rights reserved.
# #
# Redistribution and use in source and binary forms, with or without # Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions # modification, are permitted provided that the following conditions
@ -27,126 +27,141 @@
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
######################################################################## ########################################################################
# This file can be auto-regenerated with $make -f Makefile.unx Makefile.nmake
objs = \ objs = \
bin\ec_base.obj \ bin\ec_base.obj \
bin\raid_base.obj \
bin\crc_base.obj \
bin\crc64_base.obj \
bin\igzip.obj \
bin\hufftables_c.obj \
bin\igzip_base.obj \
bin\igzip_icf_base.obj \
bin\adler32_base.obj \
bin\flatten_ll.obj \
bin\encode_df.obj \
bin\igzip_icf_body.obj \
bin\huff_codes.obj \
bin\igzip_inflate.obj \
bin\mem_zero_detect_base.obj \
bin\ec_highlevel_func.obj \ bin\ec_highlevel_func.obj \
bin\ec_multibinary.obj \ bin\gf_vect_mul_sse.obj \
bin\gf_2vect_dot_prod_avx.obj \ bin\gf_vect_mul_avx.obj \
bin\gf_2vect_dot_prod_avx2.obj \ bin\gf_vect_dot_prod_sse.obj \
bin\gf_2vect_dot_prod_avx512.obj \
bin\gf_2vect_dot_prod_sse.obj \
bin\gf_2vect_mad_avx.obj \
bin\gf_2vect_mad_avx2.obj \
bin\gf_2vect_mad_avx512.obj \
bin\gf_2vect_mad_sse.obj \
bin\gf_3vect_dot_prod_avx.obj \
bin\gf_3vect_dot_prod_avx2.obj \
bin\gf_3vect_dot_prod_avx512.obj \
bin\gf_3vect_dot_prod_sse.obj \
bin\gf_3vect_mad_avx.obj \
bin\gf_3vect_mad_avx2.obj \
bin\gf_3vect_mad_avx512.obj \
bin\gf_3vect_mad_sse.obj \
bin\gf_4vect_dot_prod_avx.obj \
bin\gf_4vect_dot_prod_avx2.obj \
bin\gf_4vect_dot_prod_avx512.obj \
bin\gf_4vect_dot_prod_sse.obj \
bin\gf_4vect_mad_avx.obj \
bin\gf_4vect_mad_avx2.obj \
bin\gf_4vect_mad_avx512.obj \
bin\gf_4vect_mad_sse.obj \
bin\gf_5vect_dot_prod_avx.obj \
bin\gf_5vect_dot_prod_avx2.obj \
bin\gf_5vect_dot_prod_sse.obj \
bin\gf_5vect_mad_avx.obj \
bin\gf_5vect_mad_avx2.obj \
bin\gf_5vect_mad_sse.obj \
bin\gf_6vect_dot_prod_avx.obj \
bin\gf_6vect_dot_prod_avx2.obj \
bin\gf_6vect_dot_prod_sse.obj \
bin\gf_6vect_mad_avx.obj \
bin\gf_6vect_mad_avx2.obj \
bin\gf_6vect_mad_sse.obj \
bin\gf_vect_dot_prod_avx.obj \ bin\gf_vect_dot_prod_avx.obj \
bin\gf_vect_dot_prod_avx2.obj \ bin\gf_vect_dot_prod_avx2.obj \
bin\gf_vect_dot_prod_avx512.obj \ bin\gf_2vect_dot_prod_sse.obj \
bin\gf_vect_dot_prod_sse.obj \ bin\gf_3vect_dot_prod_sse.obj \
bin\gf_vect_mad_avx.obj \ bin\gf_4vect_dot_prod_sse.obj \
bin\gf_vect_mad_avx2.obj \ bin\gf_5vect_dot_prod_sse.obj \
bin\gf_vect_mad_avx512.obj \ bin\gf_6vect_dot_prod_sse.obj \
bin\gf_2vect_dot_prod_avx.obj \
bin\gf_3vect_dot_prod_avx.obj \
bin\gf_4vect_dot_prod_avx.obj \
bin\gf_5vect_dot_prod_avx.obj \
bin\gf_6vect_dot_prod_avx.obj \
bin\gf_2vect_dot_prod_avx2.obj \
bin\gf_3vect_dot_prod_avx2.obj \
bin\gf_4vect_dot_prod_avx2.obj \
bin\gf_5vect_dot_prod_avx2.obj \
bin\gf_6vect_dot_prod_avx2.obj \
bin\gf_vect_mad_sse.obj \ bin\gf_vect_mad_sse.obj \
bin\gf_vect_mul_avx.obj \ bin\gf_2vect_mad_sse.obj \
bin\gf_vect_mul_sse.obj \ bin\gf_3vect_mad_sse.obj \
bin\gf_4vect_mad_sse.obj \
bin\gf_5vect_mad_sse.obj \
bin\gf_6vect_mad_sse.obj \
bin\gf_vect_mad_avx.obj \
bin\gf_2vect_mad_avx.obj \
bin\gf_3vect_mad_avx.obj \
bin\gf_4vect_mad_avx.obj \
bin\gf_5vect_mad_avx.obj \
bin\gf_6vect_mad_avx.obj \
bin\gf_vect_mad_avx2.obj \
bin\gf_2vect_mad_avx2.obj \
bin\gf_3vect_mad_avx2.obj \
bin\gf_4vect_mad_avx2.obj \
bin\gf_5vect_mad_avx2.obj \
bin\gf_6vect_mad_avx2.obj \
bin\ec_multibinary.obj \
bin\gf_vect_dot_prod_avx512.obj \
bin\gf_2vect_dot_prod_avx512.obj \
bin\gf_3vect_dot_prod_avx512.obj \
bin\gf_4vect_dot_prod_avx512.obj \
bin\gf_5vect_dot_prod_avx512.obj \
bin\gf_6vect_dot_prod_avx512.obj \
bin\gf_vect_mad_avx512.obj \
bin\gf_2vect_mad_avx512.obj \
bin\gf_3vect_mad_avx512.obj \
bin\gf_4vect_mad_avx512.obj \
bin\gf_5vect_mad_avx512.obj \
bin\gf_6vect_mad_avx512.obj \
bin\xor_gen_sse.obj \
bin\pq_gen_sse.obj \
bin\xor_check_sse.obj \
bin\pq_check_sse.obj \ bin\pq_check_sse.obj \
bin\pq_gen_avx.obj \ bin\pq_gen_avx.obj \
bin\pq_gen_avx2.obj \
bin\pq_gen_avx512.obj \
bin\pq_gen_sse.obj \
bin\raid_base.obj \
bin\raid_multibinary.obj \
bin\xor_check_sse.obj \
bin\xor_gen_avx.obj \ bin\xor_gen_avx.obj \
bin\pq_gen_avx2.obj \
bin\xor_gen_avx512.obj \ bin\xor_gen_avx512.obj \
bin\xor_gen_sse.obj \ bin\pq_gen_avx512.obj \
bin\raid_multibinary.obj \
bin\crc16_t10dif_01.obj \ bin\crc16_t10dif_01.obj \
bin\crc16_t10dif_by4.obj \ bin\crc16_t10dif_by4.obj \
bin\crc16_t10dif_02.obj \ bin\crc16_t10dif_02.obj \
bin\crc16_t10dif_by16_10.obj \
bin\crc16_t10dif_copy_by4.obj \ bin\crc16_t10dif_copy_by4.obj \
bin\crc16_t10dif_copy_by4_02.obj \ bin\crc16_t10dif_copy_by4_02.obj \
bin\crc32_ieee_01.obj \ bin\crc32_ieee_01.obj \
bin\crc32_ieee_02.obj \ bin\crc32_ieee_02.obj \
bin\crc32_ieee_by4.obj \ bin\crc32_ieee_by4.obj \
bin\crc32_iscsi_00.obj \ bin\crc32_ieee_by16_10.obj \
bin\crc32_iscsi_01.obj \ bin\crc32_iscsi_01.obj \
bin\crc64_base.obj \ bin\crc32_iscsi_00.obj \
bin\crc64_ecma_norm_by8.obj \
bin\crc64_ecma_refl_by8.obj \
bin\crc64_iso_norm_by8.obj \
bin\crc64_iso_refl_by8.obj \
bin\crc64_jones_norm_by8.obj \
bin\crc64_jones_refl_by8.obj \
bin\crc64_multibinary.obj \
bin\crc_base.obj \
bin\adler32_base.obj \
bin\crc_multibinary.obj \ bin\crc_multibinary.obj \
bin\huff_codes.obj \ bin\crc64_multibinary.obj \
bin\hufftables_c.obj \ bin\crc64_ecma_refl_by8.obj \
bin\igzip.obj \ bin\crc64_ecma_refl_by16_10.obj \
bin\igzip_base.obj \ bin\crc64_ecma_norm_by8.obj \
bin\igzip_body.obj \ bin\crc64_ecma_norm_by16_10.obj \
bin\igzip_decode_block_stateless_01.obj \ bin\crc64_iso_refl_by8.obj \
bin\igzip_decode_block_stateless_04.obj \ bin\crc64_iso_refl_by16_10.obj \
bin\igzip_finish.obj \ bin\crc64_iso_norm_by8.obj \
bin\flatten_ll.obj \ bin\crc64_iso_norm_by16_10.obj \
bin\encode_df.obj \ bin\crc64_jones_refl_by8.obj \
bin\encode_df_04.obj \ bin\crc64_jones_refl_by16_10.obj \
bin\proc_heap.obj \ bin\crc64_jones_norm_by8.obj \
bin\igzip_icf_body_h1_gr_bt.obj \ bin\crc64_jones_norm_by16_10.obj \
bin\igzip_icf_finish.obj \
bin\igzip_icf_base.obj \
bin\igzip_inflate.obj \
bin\igzip_inflate_multibinary.obj \
bin\igzip_multibinary.obj \
bin\igzip_update_histogram_01.obj \
bin\igzip_update_histogram_04.obj \
bin\rfc1951_lookup.obj \
bin\crc32_gzip_refl_by8.obj \ bin\crc32_gzip_refl_by8.obj \
bin\crc32_gzip_refl_by8_02.obj \ bin\crc32_gzip_refl_by8_02.obj \
bin\crc32_gzip_refl_by16_10.obj \ bin\crc32_gzip_refl_by16_10.obj \
bin\igzip_body.obj \
bin\igzip_finish.obj \
bin\igzip_icf_body_h1_gr_bt.obj \
bin\igzip_icf_finish.obj \
bin\rfc1951_lookup.obj \
bin\adler32_sse.obj \ bin\adler32_sse.obj \
bin\adler32_avx2_4.obj \ bin\adler32_avx2_4.obj \
bin\igzip_multibinary.obj \
bin\igzip_update_histogram_01.obj \
bin\igzip_update_histogram_04.obj \
bin\igzip_decode_block_stateless_01.obj \
bin\igzip_decode_block_stateless_04.obj \
bin\igzip_inflate_multibinary.obj \
bin\encode_df_04.obj \
bin\encode_df_06.obj \
bin\proc_heap.obj \
bin\igzip_deflate_hash.obj \ bin\igzip_deflate_hash.obj \
bin\igzip_gen_icf_map_lh1_04.obj \
bin\igzip_gen_icf_map_lh1_06.obj \ bin\igzip_gen_icf_map_lh1_06.obj \
bin\igzip_gen_icf_map_lh1_04.obj \
bin\igzip_set_long_icf_fg_04.obj \ bin\igzip_set_long_icf_fg_04.obj \
bin\igzip_set_long_icf_fg_06.obj \ bin\igzip_set_long_icf_fg_06.obj \
bin\igzip_icf_body.obj \
bin\mem_zero_detect_avx.obj \ bin\mem_zero_detect_avx.obj \
bin\mem_zero_detect_base.obj \ bin\mem_zero_detect_sse.obj \
bin\mem_multibinary.obj \ bin\mem_multibinary.obj
bin\mem_zero_detect_sse.obj
INCLUDES = -I./ -Ierasure_code/ -Iraid/ -Icrc/ -Iigzip/ -Iinclude/ -Imem/ INCLUDES = -I./ -Ierasure_code/ -Iraid/ -Icrc/ -Iigzip/ -Iprograms/ -Imem/ -Iinclude/ -Itests/fuzz/ -Iexamples/ec/
LINKFLAGS = /nologo LINKFLAGS = /nologo
CFLAGS = -O2 -D NDEBUG /nologo -D_USE_MATH_DEFINES -Qstd=c99 $(INCLUDES) $(D) CFLAGS = -O2 -D NDEBUG /nologo -D_USE_MATH_DEFINES -Qstd=c99 $(INCLUDES) $(D)
AFLAGS = -f win64 $(INCLUDES) $(D) AFLAGS = -f win64 $(INCLUDES) $(D)
@ -189,13 +204,27 @@ $?
{igzip}.asm.obj: {igzip}.asm.obj:
$(AS) $(AFLAGS) -o $@ $? $(AS) $(AFLAGS) -o $@ $?
{programs}.c.obj:
$(CC) $(CFLAGS) /c -Fo$@ $?
{programs}.asm.obj:
$(AS) $(AFLAGS) -o $@ $?
{mem}.c.obj: {mem}.c.obj:
$(CC) $(CFLAGS) /c -Fo$@ $? $(CC) $(CFLAGS) /c -Fo$@ $?
{mem}.asm.obj: {mem}.asm.obj:
$(AS) $(AFLAGS) -o $@ $? $(AS) $(AFLAGS) -o $@ $?
# Examples # Examples
ex = xor_example.exe crc_simple_test.exe crc64_example.exe igzip_example.exe igzip_sync_flush_example.exe ex = \
xor_example.exe \
crc_simple_test.exe \
crc64_example.exe \
igzip_example.exe \
igzip_sync_flush_example.exe \
ec_simple_example.exe \
ec_piggyback_example.exe
ex: lib $(ex) ex: lib $(ex)
$(ex): $(@B).obj $(ex): $(@B).obj
@ -215,10 +244,11 @@ checks = \
pq_check_test.exe \ pq_check_test.exe \
crc16_t10dif_test.exe \ crc16_t10dif_test.exe \
crc16_t10dif_copy_test.exe \ crc16_t10dif_copy_test.exe \
crc32_funcs_test.exe \
crc64_funcs_test.exe \ crc64_funcs_test.exe \
igzip_wrapper_hdr_test.exe \ crc32_funcs_test.exe \
igzip_rand_test.exe \ igzip_rand_test.exe \
igzip_wrapper_hdr_test.exe \
checksum32_funcs_test.exe \
mem_zero_detect_test.exe mem_zero_detect_test.exe
checks: lib $(checks) checks: lib $(checks)
@ -244,21 +274,29 @@ perfs = \
gf_vect_dot_prod_1tbl.exe \ gf_vect_dot_prod_1tbl.exe \
erasure_code_perf.exe \ erasure_code_perf.exe \
erasure_code_base_perf.exe \ erasure_code_base_perf.exe \
erasure_code_sse_perf.exe \
erasure_code_update_perf.exe \ erasure_code_update_perf.exe \
xor_gen_perf.exe \ xor_gen_perf.exe \
pq_gen_perf.exe \ pq_gen_perf.exe \
crc16_t10dif_perf.exe \ crc16_t10dif_perf.exe \
crc16_t10dif_copy_perf.exe \
crc16_t10dif_op_perf.exe \
crc32_ieee_perf.exe \ crc32_ieee_perf.exe \
crc32_iscsi_perf.exe \ crc32_iscsi_perf.exe \
igzip_perf.exe \ crc64_funcs_perf.exe \
igzip_sync_flush_perf.exe \
crc32_gzip_refl_perf.exe \ crc32_gzip_refl_perf.exe \
adler32_perf.exe \
mem_zero_detect_perf.exe mem_zero_detect_perf.exe
perfs: lib $(perfs) perfs: lib $(perfs)
$(perfs): $(@B).obj $(perfs): $(@B).obj
progs = \
igzip.exe
progs: lib $(progs)
igzip.exe: programs\igzip_cli.obj
link /out:$@ $(LINKFLAGS) isa-l.lib $?
clean: clean:
-if exist *.obj del *.obj -if exist *.obj del *.obj
-if exist bin\*.obj del bin\*.obj -if exist bin\*.obj del bin\*.obj
@ -268,4 +306,5 @@ clean:
-if exist isa-l.dll del isa-l.dll -if exist isa-l.dll del isa-l.dll
zlib.lib: zlib.lib:
igzip_perf.exe: zlib.lib
igzip_inflate_test.exe: zlib.lib igzip_inflate_test.exe: zlib.lib

View File

@ -51,5 +51,6 @@ endif
lib_name := bin/isa-l.a lib_name := bin/isa-l.a
include make.inc include make.inc
include tools/gen_nmake.mk
VPATH = . $(units) include tests/fuzz examples/ec VPATH = . $(units) include tests/fuzz examples/ec

109
tools/gen_nmake.mk Normal file
View File

@ -0,0 +1,109 @@
FORCE:
Makefile.nmake: FORCE
@echo Regenerating $@
@echo '########################################################################' > $@
@cat LICENSE | sed -e 's/^/#/ ' >> $@
@echo '########################################################################' >> $@
@echo '' >> $@
@echo '# This file can be auto-regenerated with $$make -f Makefile.unx $@' >> $@
@echo '' >> $@
@echo -n 'objs =' >> $@
@$(foreach o, $(subst /,\\,$(objs:.o=.obj)), printf " %s\n\t%s" \\ $(o) >> $@; )
@echo '' >> $@
@echo '' >> $@
@echo 'INCLUDES = $(INCLUDE)' >> $@
@echo 'LINKFLAGS = /nologo' >> $@
@echo 'CFLAGS = -O2 -D NDEBUG /nologo -D_USE_MATH_DEFINES -Qstd=c99 $$(INCLUDES) $$(D)' >> $@
@echo 'AFLAGS = -f win64 $$(INCLUDES) $$(D)' >> $@
@echo 'CC = icl' >> $@
@echo 'AS = yasm' >> $@
@echo '' >> $@
@echo 'lib: bin static dll' >> $@
@echo 'static: bin isa-l_static.lib' >> $@
@echo 'dll: bin isa-l.dll' >> $@
@echo '' >> $@
@echo 'bin: ; -mkdir $$@' >> $@
@echo '' >> $@
@echo 'isa-l_static.lib: $$(objs)' >> $@
@echo ' lib -out:$$@ @<<' >> $@
@echo '$$?' >> $@
@echo '<<' >> $@
@echo '' >> $@
@echo 'isa-l.dll: $$(objs)' >> $@
@echo ' link -out:$$@ -dll -def:isa-l.def @<<' >> $@
@echo '$$?' >> $@
@echo '<<' >> $@
@echo '' >> $@
@$(foreach b, $(units), \
printf "{%s}.c.obj:\n\t\$$(CC) \$$(CFLAGS) /c -Fo\$$@ \$$?\n{%s}.asm.obj:\n\t\$$(AS) \$$(AFLAGS) -o \$$@ \$$?\n\n" $(b) $(b) >> $@; )
@echo '' >> $@
ifneq (,$(examples))
@echo "# Examples" >> $@
@echo -n 'ex =' >> $@
@$(foreach ex, $(notdir $(examples)), printf " %s\n\t%s.exe" \\ $(ex) >> $@; )
@echo '' >> $@
@echo '' >> $@
@echo 'ex: lib $$(ex)' >> $@
@echo '' >> $@
@echo '$$(ex): $$(@B).obj' >> $@
endif
@echo '' >> $@
@echo '.obj.exe:' >> $@
@echo ' link /out:$$@ $$(LINKFLAGS) isa-l.lib $$?' >> $@
@echo '' >> $@
@echo '# Check tests' >> $@
@echo -n 'checks =' >> $@
@$(foreach check, $(notdir $(check_tests)), printf " %s\n\t%s.exe" \\ $(check) >> $@; )
@echo '' >> $@
@echo '' >> $@
@echo 'checks: lib $$(checks)' >> $@
@echo '$$(checks): $$(@B).obj' >> $@
@echo 'check: $$(checks)' >> $@
@echo ' !$$?' >> $@
@echo '' >> $@
@echo '# Unit tests' >> $@
@echo -n 'tests =' >> $@
@$(foreach test, $(notdir $(unit_tests)), printf " %s\n\t%s.exe" \\ $(test) >> $@; )
@echo '' >> $@
@echo '' >> $@
@echo 'tests: lib $$(tests)' >> $@
@echo '$$(tests): $$(@B).obj' >> $@
@echo '' >> $@
@echo '# Performance tests' >> $@
@echo -n 'perfs =' >> $@
@$(foreach perf, $(notdir $(perf_tests)), printf " %s\n\t%s.exe" \\ $(perf) >> $@; )
@echo '' >> $@
@echo '' >> $@
@echo 'perfs: lib $$(perfs)' >> $@
@echo '$$(perfs): $$(@B).obj' >> $@
@echo '' >> $@
@echo -n 'progs =' >> $@
@$(foreach prog, $(notdir $(bin_PROGRAMS)), printf " %s\n\t%s.exe" \\ $(prog) >> $@; )
@echo '' >> $@
@echo '' >> $@
@echo 'progs: lib $$(progs)' >> $@
@$(foreach p, $(notdir $(bin_PROGRAMS)), \
printf "%s.exe: %s\n\tlink /out:\$$@ \$$(LINKFLAGS) isa-l.lib \$$?\n" $(p) $(subst /,\\,$(programs_$(p)_SOURCES:.c=.obj)) >> $@; )
@echo '' >> $@
@echo 'clean:' >> $@
@echo ' -if exist *.obj del *.obj' >> $@
@echo ' -if exist bin\*.obj del bin\*.obj' >> $@
@echo ' -if exist isa-l_static.lib del isa-l_static.lib' >> $@
@echo ' -if exist *.exe del *.exe' >> $@
@echo ' -if exist isa-l.lib del isa-l.lib' >> $@
@echo ' -if exist isa-l.dll del isa-l.dll' >> $@
@echo '' >> $@
$(if $(findstring igzip,$(units)),@echo 'zlib.lib:' >> $@ )
@cat $(foreach unit,$(units), $(unit)/Makefile.am) | sed \
-e '/: /!d' \
-e 's/\([^ :]*\)[ ]*/\1.exe /g' \
-e :c -e 's/:\(.*\).exe/:\1/;tc' \
-e 's/\.o[ $$]/.obj /g' \
-e 's/\.o\.exe[ ]:/.obj:/g' \
-e '/CFLAGS_.*+=/d' \
-e '/:.*\%.*:/d' \
-e 's/ :/:/' \
-e 's/LDLIBS *+=//' \
-e 's/-lz/zlib.lib/' \
-e 's/ $$//' \
>> $@