From aa12df5609c34abe5f7b53a5d5fa7eda4db2e082 Mon Sep 17 00:00:00 2001
From: Juan ESCOBAR <juan.escobar@aero.obs-mip.fr>
Date: Mon, 16 Oct 2023 15:09:46 +0200
Subject: [PATCH] Juan 16/10/2023:Rules.LXarm.mk, add debug + OPENACCDEFONLY +
 BITREP options

---
 src/Rules.LXarm.mk | 50 ++++++++++++++++++++++++++++++++++++----------
 1 file changed, 40 insertions(+), 10 deletions(-)

diff --git a/src/Rules.LXarm.mk b/src/Rules.LXarm.mk
index e517a95b0..029d4cea8 100644
--- a/src/Rules.LXarm.mk
+++ b/src/Rules.LXarm.mk
@@ -14,13 +14,16 @@ GFV=123
 #
 #OBJDIR_PATH=/home/escj/azertyuiopqsdfghjklm/wxcvbn/azertyuiopqsdfghjklmwxcvbn
 #
-OPT_BASE  =  -g -fno-backslash
+OPT_BASE  =  -g -fPIC -fno-backslash -gdwarf-4
 #OPT_BASE  =  -g -fPIC  -fno-backslash
 #
-OPT_PERF0 = -O0  -mcpu=native
-OPT_PERF2 = -O2  -mcpu=native
+#TP= -mcpu=native
+TP ?= -mcpu=neoverse-n1
+
+OPT_PERF0 = -O0 $(TP) 
+OPT_PERF2 = -O2 $(TP) 
 # -mcpu=thunderx2t99 neoverse-n1
-OPT_PERF3 = -O3  -mcpu=native
+OPT_PERF3 = -O3  $(TP)
 #-mcpu=thunderx2t99 -ffp-contract=fast
 OPT_CHECK = 
 OPT_I8    = -i8 
@@ -50,6 +53,13 @@ OPT       = $(OPT_BASE) $(OPT_PERF2)
 OPT0      = $(OPT_BASE) $(OPT_PERF0) 
 OPT_NOCB  = $(OPT_BASE) $(OPT_PERF2)
 #
+# Source to compile without 'simd' or 'fma' for bit-reproductibility
+BJS_REPROD= spll_mode_sum_ll.o mode_sum_ll.mod  spll_mode_repro_sum.o mode_repro_sum.mod
+#
+# BITREP flags <-> use BR_ routines
+#
+MNH_BITREP = NO
+#
 ifeq "$(OPTLEVEL)" "DEBUG"
 OPT       = $(OPT_BASE) $(OPT_PERF0) $(OPT_CHECK)
 OPT0      = $(OPT_BASE) $(OPT_PERF0) $(OPT_CHECK)
@@ -57,6 +67,14 @@ OPT_NOCB  = $(OPT_BASE) $(OPT_PERF0)
 CFLAGS    += -g -O0
 endif
 #
+ifeq "$(OPTLEVEL)" "OPENACCDEFONLY"
+CPPFLAGS    += -DMNH_OPENACC -D_FAKEOPENACC
+OPT       = $(OPT_BASE) $(OPT_NOOPENACC) $(OPT_PERF2)
+OPT0      = $(OPT_BASE) $(OPT_NOOPENACC) $(OPT_PERF0)
+OPT_NOCB  = $(OPT_BASE) $(OPT_NOOPENACC) $(OPT_PERF2)
+CXXFLAGS = -Kieee -Mnofma $(OPT_NOOPENACC) 
+$(OBJS_REPROD) : OPT = $(OPT_BASE) $(OPT_NOOPENACC) $(OPT_PERF2) -ffp-contract=off
+endif
 ifeq "$(OPTLEVEL)" "O3"
 OPT       = $(OPT_BASE) $(OPT_PERF3)
 OPT0      = $(OPT_BASE) $(OPT_PERF0) 
@@ -65,6 +83,7 @@ endif
 #
 #  
 CC = armclang
+CXX = armclang++
 FC = armflang
 ifeq "$(VER_MPI)" "MPIAUTO"
 F90 = mpif90
@@ -94,7 +113,15 @@ CPPFLAGS_NEWLFI    = -DSWAPIO -DLINUX -DLFI_INT=${LFI_INT}
 CPPFLAGS_MNH       = -DMNH -DSFX_MNH
 CPPFLAGS_MNH       += -imacros MNH_OPENACC_NV_CR.CPP
 CPPFLAGS_MNH       += -DMNH_EXPAND
-
+#
+# BITREP flags
+#
+#if MNH_BITREP exists => compile with the BITREP library
+MNH_BITREP ?= YES
+ifeq "$(MNH_BITREP)" "YES"
+CPPFLAGS_MNH += -DMNH_BITREP
+endif
+#
 ifdef VER_GA
 CPPFLAGS_SURCOUCHE += -DMNH_GA
 INC                += -I${GA_ROOT}/include
@@ -103,7 +130,9 @@ endif
 #
 # Netcdf/HDF5 flags
 #
-HDF_CONF= CFLAGS=-std=c99
+#HDF_CONF= CFLAGS=-std=c99
+NETCDF_OPT ?= $(TP) -fPIC -gdwarf-4
+HDF_OPT ?= $(TP) -fPIC -std=c99 -gdwarf-4
 #
 ## LIBTOOLS flags
 #
@@ -134,6 +163,8 @@ MNH_COMPRESS=yes
 #             if set to yes: use grib_api (deprecated library)
 #
 MNH_GRIBAPI=no
+ECCODES_FFLAGS= $(TP) -gdwarf-4
+ECCODES_CFLAGS= $(TP) -gdwarf-4
 #
 ##########################################################
 #                                                        #
@@ -162,11 +193,10 @@ OBJS_I4=spll_modd_netcdf.o
 $(OBJS_I4) : OPT = $(OPT_BASE_I4)
 endif
 
-ifeq ($(shell test $(GFV) -le 482 ; echo $$?),0)
 ifneq "$(OPTLEVEL)" "DEBUG"
-OBJS_O0= spll_lima_phillips_integ.o
-$(OBJS_O0) : OPT = $(OPT_BASE) $(OPT_PERF0)
-endif
+OBJS_O1= spll_modd_pack_gr_field_n.o modd_pack_gr_field_n.mod spll_modd_les_n.o modd_les_n.mod spll_write_lfifm1_for_diag.o
+$(OBJS_O1) : OPT = $(OPT_BASE) $(OPT_PERF1)
 endif
 
+
 SPLL = spll_new
-- 
GitLab