#!/bin/csh # $Header$ #set verbose echo ######################################################################## # options par defaut pour la commande make ######################################################################## set dim="72x45x19" set physique=lmd set phys="PHYS=$physique" set include='-I$(LIBF)/grid -I$(LIBF)/bibio -I. ' set ntrac = 4 set filtre=filtrez set grille=reg ######################################################################## # path a changer contenant les sources et les objets du modele ######################################################################## ###### VERSION LMDZ.3.3 # set LMDGCM=$HOME/LMDZ.3.3 # setenv localdir "`pwd`" set MODIPSL=0 echo $localdir | grep modipsl >& /dev/null if ( ! $status ) then set MODIPSL=1 setenv LMDGCM $localdir cd ../.. setenv LIBOGCM "`pwd`/lib" setenv IOIPSLDIR $LIBOGCM setenv MODIPSLDIR $LIBOGCM cd $localdir if ( `hostname` == rhodes ) then set NCDFINC=`grep sxnec ../../util/AA_make.gdef| grep NCDF_INC|sed -e "s/^.* =//"` set NCDFLIB=`grep sxnec ../../util/AA_make.gdef| grep NCDF_LIB|sed -e 's/^.* =//'` else if ( `hostname` == nymphea0 ) then set NCDFINC=`grep fjvpp ../../util/AA_make.gdef| grep NCDF_INC|sed -e "s/^.* =//"` set NCDFLIB=`grep fjvpp ../../util/AA_make.gdef| grep NCDF_LIB|sed -e 's/^.* =//'` else echo 'Probleme de definition des variables NCDFINC et NCDFLIB' endif endif # si modipsl c'est couple??? et LMDZ+SECHIBA alors \cp -p libf/phylmd/oasis.F libf/phylmd/oasis.dummy \cp -p libf/phylmd/oasis.true libf/phylmd/oasis.F else if ( ! $?LMDGCM ) then echo You must initialize the variable LMDGCM in your environnement echo for instance: "setenv LMDGCM /usr/myself/supergcm" in .cshrc exit endif if ( ! $?LIBOGCM ) then set LIBOGCM=$LMDGCM/libo endif if ( ! $?IOIPSLDIR ) then echo You must initialize the variable IOIPSLDIR in your environnement echo for instance: "setenv IOIPSLDIR /usr/myself/ioipsl" in .cshrc exit else setenv MODIPSLDIR $IOIPSLDIR endif if ( ! $?NCDFLIB ) then echo You must initialize the variable NCDFLIB in your environnement echo for instance: "setenv NCDFLIB /usr/myself/netcdf" in .cshrc exit endif if ( ! $?NCDFINC ) then echo You must initialize the variable NCDFINC in your environnement echo for instance: "setenv NCDFINC /usr/myself/netcdf" in .cshrc exit endif endif set model=$LMDGCM set libo=$LIBOGCM #Force/couple set COUPLE=0 set ocean=`grep '^ parameter (ocean' $LMDGCM/libf/phylmd/physiq.F | awk -F\' '{print $2}'` banner $ocean if ($ocean == couple) then set COUPLE=1 endif #veget ou non set veget=`grep '^ parameter (ok_veget' $LMDGCM/libf/phylmd/physiq.F | awk -F. '{print $2}'` if ($veget == true) then banner orchidee endif ######################################################################## # Les differentes platformes reconnues ######################################################################## set HP=0 set IBM=0 set SUN=0 set VPP=0 set CRAY=0 set DEC=0 set LINUX=0 set NEC=0 set XNEC=0 if ( `uname` == HP-UX ) then set machine=HP set HP=1 else if (`uname` == UNIX_System_V ) then set machine=VPP set VPP=1 else if (`uname` == SunOS ) then set machine=SUN set SUN=1 else if ( `uname` == AIX ) then set machine=IBM set IBM=1 else if ( `uname` == OSF1 ) then set machine=ALPHA set DEC=1 else if ( `uname` == Linux ) then set machine=LINUX set LINUX=1 else if ( `hostname` == atlas || `hostname` == axis || `hostname` == etoile ) then set machine=CRAY set CRAY=1 else if ( `uname` == SUPER-UX ) then set machine=NEC set NEC=1 else if ( `hostname` == rhodes) then set machine=XNEC set XNEC=1 else echo Vous travaillez sur une machine non prevue par le reglement exit endif if ( ! -d $libo ) then mkdir $libo endif if $VPP then set netcdf=netcdf_v else set netcdf=netcdf endif ######################################################################## # Quelques initialisations de variables du shell. ######################################################################## set dyn= set opt_link="" set adjnt="" set opt_dep="" set optim="" set optimbis="" set optim90="" set oplink="" ######################################################################## # Optimisations par defaut suivant les machines ######################################################################## echo "Optimisations par defaut suivant les machines" set libf=$model/libf #setenv localdir "LOCAL_DIR=`pwd`" #setenv localdir "`pwd`" cd $model if $CRAY then # set optim="-Wf'-ei' -dp -Wf'-a static'" set optimbis=" -DCRAY " set optim90="-Wp'-P' -DCRAY -p$IOIPSLDIR "'-p$(LIBO) -eiv ' set optim="$optim90" set oplink="-Wl'-DSTACK=128 -f indef' -L$IOIPSLDIR -lioipsl -L$NCDFLIB -lnetcdf " set mod_loc_dir=" " set mod_suffix=" " else if $SUN then set optim=" -fast " # set optim=" -g " set optimbis=" " set optim90=" -fast -fixed " set optimtru90=" -fast -free " set opt_link="-lf77compat -L$MODIPSLDIR -lsechiba -lparameters -lstomate -lioipsl -L$NCDFLIB -lnetcdf " set mod_loc_dir=$localdir set mod_suffix=mod else if $HP then set optim=" +U77 -O +E1 " set optimbis=" " else if $IBM then set optim=" -O3 -qtune=pwr2 -qarch=pwr2" set optimbis=" " else if $VPP then # set optim="-Dasuxm -On, -g -Ad -Potilax -Eciplume -Si" # set optimbis=" -Wv,-m3 -Wp,-DVPP -Z $LMDGCM/listage" set optimbis=" -Wp,-DNC_DOUBLE -Ad -Z $LMDGCM/listage" set optim90="$optim $optimbis -X9 -w" if $COUPLE then set opt_link="-Wg,-c $MODIPSLDIR/liboasis2.4_mpi2.a /usr/lang/mpi2/lib64/libmpi.a /usr/lang/mpi2/lib64/libmp.a /usr/local/lib/lib64/libnetcdf_cc.a -L$MODIPSLDIR -lioipsl" set oplink="-Wl,-t,-P,-dy " else set opt_link="-Wg,-c /usr/local/lib/lib64/libnetcdf_cc.a -L$MODIPSLDIR -lioipsl" set oplink="-Wl,-t,-dy " endif set mod_loc_dir=$MODIPSLDIR set mod_suffix=mod else if $DEC then set optim=" " set optimbis=" " else if $LINUX then set optim="-fast " set optim90=" -fast " set optimtru90=" -fast -c -Mfree -module $MODIPSLDIR " set opt_link=" -Mfree -L /usr/local/pgi/linux86/lib -lpgf90 -lpgftnrtl -lpghpf -lpghpf2 -L$MODIPSLDIR -lsechiba -lparameters -lstomate -L$NCDFLIB -lnetcdf -lioipsl -Wl,-Bstatic -L/usr/lib/gcc-lib/i386-linux/2.95.2/" set mod_loc_dir=$MODIPSLDIR set mod_suffix=mod else if $NEC then set optim90=' -clear -C hopt -float0 -ew -P stack -Wf,"-pvctl fullmsg noassume "' set optimtru90=' -clear -f4 -C hopt -float0 -ew -P stack -Wf,"-pvctl fullmsg noassume "' set optim="$optim90" set optimbis=" " set opt_link=" -C hopt -float0 -ew -P stack -L$MODIPSLDIR -lioipsl -L/u/rech/psl/rpsl003/IOIPSL -lnetcdf_i8r8_v " set mod_loc_dir="." set mod_suffix="mod" else if $XNEC then # set optim90=' -clear -C debug -float0 -ew -R5 -P stack -Wf,-init stack=nan, ' # set optim90=' -clear -C vsafe -float0 -ew -eC -R5 -P stack ' set optim90=' -clear -C vsafe -float0 -ew -R5 -P stack ' # set optimtru90=' -clear -f4 -C debug -float0 -ew -R5 -P stack -Wf,-init stack=nan, ' set optimtru90=' -clear -f4 -C vsafe -float0 -ew -R5 -P stack ' # set optimtru90=' -clear -f4 -C vsafe -float0 -ew -eC -R5 -P stack ' # set optimtru90=' -clear -c -f4 -ew -sx5 -eab -R5 -P stack -Wl,-h lib_cyclic,-h muldefs -Cvsafe -eb ' set optim="$optim90" set optimbis=" " if $MODIPSL then if $COUPLE then set opt_link="-L$MODIPSLDIR -lsxioipsl -loasis2.4_mpi2 -Wl,-f nan, -float0 -ew -P stack -I$NCDFINC $NCDFLIB " set opt_link="-L$MODIPSLDIR -lsxsechiba -lsxparameters -lsxstomate -lsxioipsl -loasis2.4_mpi2 -float0 -ew -P stack -I$NCDFINC $NCDFLIB " # set opt_link="-L$IOIPSLDIR -lsxioipsl -loasis2.4_mpi2 -float0 -ew -eC -P stack -I$NCDFINC $NCDFLIB " else set opt_link="-L$MODIPSLDIR -lsxioipsl -float0 -ew -P stack -I$NCDFINC $NCDFLIB " endif set mod_loc_dir="./" else set opt_link=" -C hopt -float0 -ew -P stack -L$MODIPSLDIR -lsxsechiba -lsxparameters -lsxstomate -lsxioipsl -L /home/rech/psl/rpsl003/IOIPSL_I8R8 -lnetcdf_i8r8_v -I$NCDFINC " set mod_loc_dir="." endif set mod_suffix="mod" else set optim="" set optimbis=" " endif set nomlib=$machine ######################################################################## # lecture des options de mymake ######################################################################## top: if ($#argv > 0) then switch ($1:q) case -h: ######################################################################## # Manuel en ligne ######################################################################## more <> tmp end set suf= foreach i ( `sort tmp | uniq ` ) set suf=$suf$i end if ( ! $IBM ) then set nomlib="$nomlib$suf" endif if ( $DEC ) then set nomlib=DEC endif if ( $IBM ) then set dim=`echo $dim | sed -en 's/[^0-9]/ /g'` set dim_=`echo $dim | sed -en 's/[^0-9]/_/g'` else if ( $SUN ) then set dim=`echo $dim | sed -e 's/[^0-9]/ /g'` set dim_=`echo $dim | sed -e 's/[^0-9]/_/g'` else set dim=`echo $dim | sed -n -e 's/[^0-9]/ /gp'` set dim_=`echo $dim | sed -n -e 's/[^0-9]/_/gp'` endif set nomlib=${nomlib}_${dim_}_t${ntrac}_$grille ## M-A-F nomlib trop long sur CRAY pour ar if ( $CRAY ) then set nomlib=F90_${dim_}_t${ntrac} endif if ( $NEC || $XNEC ) then set nomlib=F90_${dim_}_t${ntrac} endif echo calcul de la dimension set dimc=`echo $dim | wc -w` if ( "$dimc" == "2" ) then set include="$include "'-I$(LIBF)/dyn2d ' set dimh=$dim else set include="$include "'-I$(LIBF)/dyn3d ' set dimh=`echo $dim | awk ' { print $1 "." $2 } '` endif echo $dimc ######################################################################## # path pour les #include ######################################################################## set include="$include -I$NCDFINC -I$IOIPSLDIR" echo $include ######################################################################## # Gestion des dimensions du modele. # on cree ou remplace le fichier des dimensions/nombre de traceur ######################################################################## cd $libf/grid if ( -f dimensions.h ) then echo 'ATTENTION: vous etes sans doute en train de compiler le modele par ailleurs' echo "Attendez que la premiere compilation soit terminee pour relancer la suivante." echo "Si vous etes sur que vous ne compilez pas le modele par ailleurs," echo vous pouvez continuer en repondant oui. echo "Voulez-vous vraiment continuer?" if ( $< == "oui" ) then \rm $libf/grid/dimensions.h else exit endif endif cd dimension makdim $ntrac $dim cat $libf/grid/dimensions.h cd $LMDGCM set libo=$libo/$nomlib if ( ! -d $libo ) then mkdir $libo cd $model endif ######################################################################## # Differentes dynamiques (3d, 2d, 1d) ######################################################################## set dimension=`echo $dim | wc -w` echo dimension $dimension if ( $dimension == 1 ) then echo pas de dynamique set dyn="L_DYN= DYN= L_FILTRE= DIRMAIN=phy$physique " endif endif cd $model if ( $dimension == 3 ) then cd libf/grid \rm fxyprim.h cp -p fxy_${grille}.h fxyprim.h endif ###################################################################### # Traitement special pour le nouveau rayonnement de Laurent Li. ###################################################################### if ( -f $libf/phy$physique/raddim.h ) then if ( -f $libf/phy$physique/raddim.$dimh.h ) then \rm $libf/phy$physique/raddim.h cp -p $libf/phy$physique/raddim.$dimh.h $libf/phy$physique/raddim.h echo $libf/phy$physique/raddim.$dimh.h cat $libf/phy$physique/raddim.$dimh.h cat $libf/phy$physique/raddim.h else echo On peut diminuer la taille de l executable en creant echo le fichier $libf/phy$physique/raddim.$dimh.h \cp -p $libf/phy$physique/raddim.defaut.h $libf/phy$physique/raddim.h endif endif ###################################################################### # Gestion du filtre qui n'existe qu'en 3d. ###################################################################### if ( `expr $dimc \> 2` == 1 ) then set filtre="FILTRE=$filtre" else set filtre="FILTRE= L_FILTRE= " endif echo MACRO FILTRE $filtre echo $dimc ######################################################################## # Avant de lancer le make, on recree le makefile si necessaire ######################################################################## # c'est a dire dans 3 cas: # 1. si la liste des fichiers .F et .h a ete modifiee depuis la # derniere creation du makefile # 2. si le fichier contenant cette liste "liste_des_sources" # n'existe pas. # 3. Si le makefile n'existe pas. ######################################################################## cd $model find libf -name '*.[Fh]' -print >! tmp77 find libf -name '*.[Fh]' -exec egrep -i " *use *ioipsl" {} \; -print >! tmp90 find libf -name '*.[Fh]90' -print >> tmp90 if ( `diff tmp77 liste_des_sources_f77 | wc -w` \ || `diff tmp90 liste_des_sources_f90 | wc -w` \ || ! -f makefile \ || ! -f liste_des_sources_f90 \ || ! -f liste_des_sources_f77 ) then echo les fichiers suivants ont ete crees ou detruits echo ou les fichiers suivants sont passes ou ne sont plus en Fortran 90 diff liste_des_sources_f77 tmp77 diff liste_des_sources_f90 tmp90 \cp tmp77 liste_des_sources_f77 \cp tmp90 liste_des_sources_f90 echo On recree le makefile ./create_make_gcm >! tmp \mv tmp makefile echo Nouveau makefile cree. endif ######################################################################## # Execution de la comande make ######################################################################## echo PHYSIQUE $phys echo dynamique $dyn $dimension echo OPTIM="$optim" $filtre LIBO=$libo $dyn PHYS=$phys DIM=$dimc PROG=$code echo PATH pour les fichiers INCLUDE $include echo OPLINK="$oplink" if $HP then set f77='fort77 +OP' set f90='jensaisrien' set opt_link="$opt_link -lm" else if $VPP then set f77=frt set f90=$f77 else if $CRAY then set f77=f90 set f90=f90 else if $LINUX then set f77=pgf90 set f90=pgf90 else if $SUN then set f77=f90 set f90=f90 else if $NEC then set f77=f90 set f90=f90 else if $XNEC then set f77=sxmpif90 set f90=sxmpif90 else set f77=f77 set f90=f90 endif cd $model if $VPP then set make="gmake RANLIB=ls" else if $CRAY then set make="make RANLIB=ls" else if $NEC then set make="make RANLIB=ls" else if $LINUX then set make="make -k RANLIB=ranlib" else if $XNEC then set make="gmake RANLIB=ls" else set make="make RANLIB=ranlib" endif # # les deux test suivants sont "temporaires" pour pallier des "faiblesses" du # compilateur fortran Sun: f90: SC4.0 11 Sep 1995 FORTRAN 90 1.1 # #if ($code == 'create_limit' && $SUN) then # set link=f77 # set opt_link="-L$NCDFLIB -lnetcdf" #endif #if ($code == 'create_etat0' && $SUN) then # if ( ! -f $libo/libdyn3d.a ) then # echo "Priere de compiler gcm en premier pour des raisons d'optimisation" # \rm $libf/grid/dimensions.h # exit # endif # set optim=" -dalign " # set optim90=" -dalign -fixed " # set opt_link="-L$IOIPSLDIR -lioipsl -L$NCDFLIB -lnetcdf" # set link="$f90 $optim90" # touch $LMDGCM/libf/dyn3d/startvar.F # touch $LMDGCM/libf/dyn3d/etat0_netcdf.F #endif # # Encore un test temporaire: probleme de compilation sur VPP # l'optimisation de startvar se passe mal # if ($code == 'create_etat0' && $VPP) then if ( ! -f $libo/libdyn3d.a ) then echo "Priere de compiler gcm en premier pour des raisons d'optimisation" \rm $libf/grid/dimensions.h exit endif set optim=" -Wv,-Of,-ilfunc" set optimbis=" -Psia -Aa -Wv,-m3 -Wp,-DVPP -Z $LMDGCM/listage" set optim90="$optim""$optimbis"" -X9 -w" set opt_link="-L$IOIPSLDIR -lioipsl -L$NCDFLIB -lnetcdf" touch $LMDGCM/libf/dyn3d/startvar.F touch $LMDGCM/libf/dyn3d/etat0_netcdf.F endif # # etat0_netcdf a besoin d'info de la physique # A revoir set include="$include"' -I$(LIBF)/phylmd' ################################################################# # Execution de la comande make... ENFIN! ################################################################# if $VPP then set optim90=" $optim90 -Am -M$libo" set optimtru90="$optim90" \cp $IOIPSLDIR/*.mod $libo else if $SUN then set optim90=" $optim90 -M$libo -M$MODIPSLDIR " set optimtru90=" $optimtru90 -M$libo -M$MODIPSLDIR " set optim="$optim90" \cp $IOIPSLDIR/*.mod $libo else if $NEC then set optim90=" $optim90 -I$libo " else if $XNEC then set optim90=" $optim90 -I$libo " set optimtru90=" $optimtru90 -I$libo " else if $LINUX then set optim90=" $optim90 -module $libo " set optim="$optim90" set mod_loc_dir=$libo \cp /d3/fairhead/sechiba/ioipsl/*.mod $libo \cp $IOIPSLDIR/*.mod $libo endif set link="$f90 $optim90" set ar=ar if $XNEC then set link="sxld $opt_link" set link="$f90 " # set ar=sxar endif cd $localdir echo $make -f $LMDGCM/makefile \ OPTION_DEP="$opt_dep" OPTION_LINK="$opt_link" \ OPTIM90="$optim90" \ OPTIMTRU90="$optimtru90" \ OPTIM="$optim$optimbis" \ INCLUDE="$include" \ $filtre \ LIBO=$libo \ $dyn \ $phys \ DIM=$dimc \ L_ADJNT="$adjnt" \ LOCAL_DIR="$localdir" \ F77="$f77" \ F90="$f90" \ OPLINK="$oplink" \ LINK="$link" \ GCM="$LMDGCM" \ MOD_LOC_DIR=$mod_loc_dir \ MOD_SUFFIX=$mod_suffix \ AR=$ar \ PROG=$code $make -f $LMDGCM/makefile \ OPTION_DEP="$opt_dep" OPTION_LINK="$opt_link" \ OPTIM90="$optim90" \ OPTIMTRU90="$optimtru90" \ OPTIM="$optim$optimbis" \ INCLUDE="$include" \ $filtre \ LIBO=$libo \ $dyn \ $phys \ DIM=$dimc \ L_ADJNT="$adjnt" \ LOCAL_DIR="$localdir" \ F77="$f77" \ F90="$f90" \ OPLINK="$oplink" \ LINK="$link" \ GCM="$LMDGCM" \ MOD_LOC_DIR=$mod_loc_dir \ MOD_SUFFIX=$mod_suffix \ AR=$ar \ PROG=$code \rm $libf/grid/dimensions.h if $MODIPSL then \cp -p libf/phylmd/oasis.F libf/phylmd/oasis.true \cp -p libf/phylmd/oasis.dummy libf/phylmd/oasis.F endif