######################################################################## # Copyright(c) 2011-2017 Intel Corporation All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # * Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # * Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in # the documentation and/or other materials provided with the # distribution. # * Neither the name of Intel Corporation nor the names of its # contributors may be used to endorse or promote products derived # from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE # 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 = \ 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\gf_vect_mul_sse.obj \ bin\gf_vect_mul_avx.obj \ bin\gf_vect_dot_prod_sse.obj \ bin\gf_vect_dot_prod_avx.obj \ bin\gf_vect_dot_prod_avx2.obj \ bin\gf_2vect_dot_prod_sse.obj \ bin\gf_3vect_dot_prod_sse.obj \ bin\gf_4vect_dot_prod_sse.obj \ bin\gf_5vect_dot_prod_sse.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_2vect_mad_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_gen_avx.obj \ bin\xor_gen_avx.obj \ bin\pq_gen_avx2.obj \ bin\xor_gen_avx512.obj \ bin\pq_gen_avx512.obj \ bin\raid_multibinary.obj \ bin\crc16_t10dif_01.obj \ bin\crc16_t10dif_by4.obj \ bin\crc16_t10dif_02.obj \ bin\crc16_t10dif_by16_10.obj \ bin\crc16_t10dif_copy_by4.obj \ bin\crc16_t10dif_copy_by4_02.obj \ bin\crc32_ieee_01.obj \ bin\crc32_ieee_02.obj \ bin\crc32_ieee_by4.obj \ bin\crc32_ieee_by16_10.obj \ bin\crc32_iscsi_01.obj \ bin\crc32_iscsi_00.obj \ bin\crc32_iscsi_by16_10.obj \ bin\crc_multibinary.obj \ bin\crc64_multibinary.obj \ bin\crc64_ecma_refl_by8.obj \ bin\crc64_ecma_refl_by16_10.obj \ bin\crc64_ecma_norm_by8.obj \ bin\crc64_ecma_norm_by16_10.obj \ bin\crc64_iso_refl_by8.obj \ bin\crc64_iso_refl_by16_10.obj \ bin\crc64_iso_norm_by8.obj \ bin\crc64_iso_norm_by16_10.obj \ bin\crc64_jones_refl_by8.obj \ bin\crc64_jones_refl_by16_10.obj \ bin\crc64_jones_norm_by8.obj \ bin\crc64_jones_norm_by16_10.obj \ bin\crc32_gzip_refl_by8.obj \ bin\crc32_gzip_refl_by8_02.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_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_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_06.obj \ bin\mem_zero_detect_avx512.obj \ bin\mem_zero_detect_avx2.obj \ bin\mem_zero_detect_avx.obj \ bin\mem_zero_detect_sse.obj \ bin\mem_multibinary.obj INCLUDES = -I./ -Ierasure_code/ -Iraid/ -Icrc/ -Iigzip/ -Iprograms/ -Imem/ -Iinclude/ -Itests/fuzz/ -Iexamples/ec/ # Modern asm feature level, consider upgrading nasm/yasm before decreasing feature_level FEAT_FLAGS = -DHAVE_AS_KNOWS_AVX512 -DAS_FEATURE_LEVEL=10 CFLAGS_REL = -O2 -DNDEBUG /Z7 /Gy CFLAGS_DBG = -Od -DDEBUG /Z7 LINKFLAGS = -nologo -incremental:no -debug CFLAGS = $(CFLAGS_REL) -nologo -D_USE_MATH_DEFINES $(FEAT_FLAGS) $(INCLUDES) $(D) AFLAGS = -f win64 $(FEAT_FLAGS) $(INCLUDES) $(D) CC = cl # or CC = icl -Qstd=c99 AS = nasm lib: bin static dll static: bin isa-l_static.lib isa-l.h dll: bin isa-l.dll isa-l.h bin: ; -mkdir $@ isa-l_static.lib: $(objs) lib -out:$@ @<< $? << !IF [rc] == 0 isa-l.dll: isa-l.res !ELSE !MESSAGE Optionally install rc to set file version info !ENDIF isa-l.dll: $(objs) link -out:$@ -dll -def:isa-l.def $(LINKFLAGS) @<< $? << isa-l.res: isa-l.h rc /fo $@ isa-l.rc {erasure_code}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? {erasure_code}.asm.obj: $(AS) $(AFLAGS) -o $@ $? {raid}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? {raid}.asm.obj: $(AS) $(AFLAGS) -o $@ $? {crc}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? {crc}.asm.obj: $(AS) $(AFLAGS) -o $@ $? {igzip}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? {igzip}.asm.obj: $(AS) $(AFLAGS) -o $@ $? {programs}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? {programs}.asm.obj: $(AS) $(AFLAGS) -o $@ $? {mem}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? {mem}.asm.obj: $(AS) $(AFLAGS) -o $@ $? # Examples 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 {examples\ec}.c.obj: $(CC) $(CFLAGS) /c -Fo$@ $? ex: lib $(ex) $(ex): $(@B).obj .obj.exe: link /out:$@ $(LINKFLAGS) isa-l.lib $? # Check tests checks = \ gf_vect_mul_test.exe \ erasure_code_test.exe \ gf_inverse_test.exe \ erasure_code_update_test.exe \ xor_gen_test.exe \ pq_gen_test.exe \ xor_check_test.exe \ pq_check_test.exe \ crc16_t10dif_test.exe \ crc16_t10dif_copy_test.exe \ crc64_funcs_test.exe \ crc32_funcs_test.exe \ igzip_rand_test.exe \ igzip_wrapper_hdr_test.exe \ checksum32_funcs_test.exe \ mem_zero_detect_test.exe checks: lib $(checks) $(checks): $(@B).obj check: $(checks) !$? # Unit tests tests = \ gf_vect_mul_base_test.exe \ gf_vect_dot_prod_base_test.exe \ gf_vect_dot_prod_test.exe \ gf_vect_mad_test.exe \ erasure_code_base_test.exe tests: lib $(tests) $(tests): $(@B).obj # Performance tests perfs = \ gf_vect_mul_perf.exe \ gf_vect_dot_prod_perf.exe \ gf_vect_dot_prod_1tbl.exe \ erasure_code_perf.exe \ erasure_code_base_perf.exe \ erasure_code_update_perf.exe \ xor_gen_perf.exe \ pq_gen_perf.exe \ crc16_t10dif_perf.exe \ crc16_t10dif_copy_perf.exe \ crc16_t10dif_op_perf.exe \ crc32_ieee_perf.exe \ crc32_iscsi_perf.exe \ crc64_funcs_perf.exe \ crc32_gzip_refl_perf.exe \ adler32_perf.exe \ mem_zero_detect_perf.exe perfs: lib $(perfs) $(perfs): $(@B).obj progs = \ igzip.exe progs: lib $(progs) igzip.exe: programs\igzip_cli.obj link /out:$@ $(LINKFLAGS) isa-l.lib $? isa-l.h: @echo /**>> $@ @echo * @file isa-l.h>> $@ @echo * @brief Include for ISA-L library>> $@ @echo */>> $@ @echo.>> $@ @echo #ifndef _ISAL_H_>> $@ @echo #define _ISAL_H_>> $@ @echo.>> $@ @echo #define ISAL_MAJOR_VERSION 2 >> $@ @echo #define ISAL_MINOR_VERSION 30 >> $@ @echo #define ISAL_PATCH_VERSION 0 >> $@ @echo #define ISAL_MAKE_VERSION(maj, min, patch) ((maj) * 0x10000 + (min) * 0x100 + (patch))>> $@ @echo #define ISAL_VERSION ISAL_MAKE_VERSION(ISAL_MAJOR_VERSION, ISAL_MINOR_VERSION, ISAL_PATCH_VERSION)>> $@ @echo.>> $@ @echo #ifndef RC_INVOKED>> $@ @echo #include ^>> $@ @echo #include ^>> $@ @echo #include ^>> $@ @echo #include ^>> $@ @echo #include ^>> $@ @echo #include ^>> $@ @echo #include ^>> $@ @echo #endif // RC_INVOKED>> $@ @echo #endif //_ISAL_H_>> $@ clean: -if exist *.obj del *.obj -if exist bin\*.obj del bin\*.obj -if exist isa-l_static.lib del isa-l_static.lib -if exist *.exe del *.exe -if exist *.pdb del *.pdb -if exist isa-l.lib del isa-l.lib -if exist isa-l.dll del isa-l.dll -if exist isa-l.exp del isa-l.exp -if exist isa-l.res del isa-l.res zlib.lib: igzip_perf.exe: zlib.lib igzip_inflate_test.exe: zlib.lib