########################################################################
#  Copyright(c) 2011-2024 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.
#
#  SPDX-License-Identifier: BSD-3-Clause
########################################################################

# 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_mad_avx2_gfni.obj \
	bin\gf_2vect_mad_avx2_gfni.obj \
	bin\gf_3vect_mad_avx2_gfni.obj \
	bin\gf_4vect_mad_avx2_gfni.obj \
	bin\gf_5vect_mad_avx2_gfni.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_dot_prod_avx512_gfni.obj \
	bin\gf_vect_dot_prod_avx2_gfni.obj \
	bin\gf_2vect_dot_prod_avx2_gfni.obj \
	bin\gf_3vect_dot_prod_avx2_gfni.obj \
	bin\gf_2vect_dot_prod_avx512_gfni.obj \
	bin\gf_3vect_dot_prod_avx512_gfni.obj \
	bin\gf_4vect_dot_prod_avx512_gfni.obj \
	bin\gf_5vect_dot_prod_avx512_gfni.obj \
	bin\gf_6vect_dot_prod_avx512_gfni.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\gf_vect_mad_avx512_gfni.obj \
	bin\gf_2vect_mad_avx512_gfni.obj \
	bin\gf_3vect_mad_avx512_gfni.obj \
	bin\gf_4vect_mad_avx512_gfni.obj \
	bin\gf_5vect_mad_avx512_gfni.obj \
	bin\gf_6vect_mad_avx512_gfni.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\crc64_rocksoft_refl_by8.obj \
	bin\crc64_rocksoft_refl_by16_10.obj \
	bin\crc64_rocksoft_norm_by8.obj \
	bin\crc64_rocksoft_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
perf: $(perfs)
	!$?

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 31 >> $@
	@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 ^<isa-l/crc.h^>>> $@
	@echo #include ^<isa-l/crc64.h^>>> $@
	@echo #include ^<isa-l/erasure_code.h^>>> $@
	@echo #include ^<isa-l/gf_vect_mul.h^>>> $@
	@echo #include ^<isa-l/igzip_lib.h^>>> $@
	@echo #include ^<isa-l/mem_routines.h^>>> $@
	@echo #include ^<isa-l/raid.h^>>> $@
	@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