[petsc-users] Error with file linking
Satish Balay
balay at mcs.anl.gov
Wed May 12 12:56:59 CDT 2010
try the attached makefile. If you have problems copy/paste the
*complete* make session from your terminal.
Satish
On Thu, 13 May 2010, Wee-Beng TAY wrote:
> Hi Satish,
>
> I tried to run it, with the -c present and absent. However, nothing happened.
> I run using "make". I also specified "export
> PETSC_DIR=/home/svu/g0306332/codes/petsc-3.1-p0/" and "export
> PETSC_ARCH=atlas5-mpi-nodebug" before that.
>
> Did I miss out something?
>
> Also supposed that I have the same flag for all sources. In that case, how can
> I build them?
>
> Thank you very much and have a nice day!
>
> Yours sincerely,
>
> Wee-Beng Tay
>
>
> On 13/5/2010 1:27 AM, Satish Balay wrote:
> > Attaching the modified makefile. It might need a couple of iterations
> > of fixing.
> >
> > Hopefully its clear why it would work. Note - if not for different
> > flags required for different sources (opt/opt2/opt3) - you can build
> > all petsc/non-petsc sources with petsc makefile targets.
> >
> >
> > > In my fortran files, do I simply use petsc.h or I have to use specific *.h
> > > depending on what petsc commands are used?
> > >
> > With petsc-3.1 you just have to use petsc.h for all F77 interface stuff, and
> > petsc.h90 for all f90 interface stuff [like VecGetArrayF90()]
> >
> > Satish
> >
> > On Thu, 13 May 2010, Wee-Beng TAY wrote:
> >
> >
> > > Hi Satish,
> > >
> > > Sorry for the confusion.
> > >
> > > I have attached my makefile. This was used to compile and link my code
> > > before
> > > I used PETSc 3.1.
> > >
> > > I have several fortran files. Some contain PETSc commands and need to use
> > > PETSc include files. Other do not. In the end, they all have to be linked
> > > to
> > > form my final code. I used to copy part of the compiling and linking
> > > command
> > > from "make ex1f" to compile my code:
> > >
> > > /app1/mvapich2/current/bin/mpif90 -c -O3
> > > -I/home/svu/g0306332/codes/petsc-3.1-p0/atlas5-mpi-nodebug/include
> > > -I/home/svu/g0306332/codes/petsc-3.1-p0/include
> > > -I/home/svu/g0306332/lib/hypre-2.6.0b_atlas5/include
> > > -I/app1/mvapich2/1.4/include -I/app1/mvapich2/current/include
> > > -I/home/svu/g0306332/codes/petsc-3.1-p0/atlas5-mpi-nodebug/include
> > > -I/home/svu/g0306332/lib/hypre-2.6.0b_atlas5/include
> > > -I/app1/mvapich2/1.4/include -I/app1/mvapich2/current/include -o ex1f.o
> > > ex1f.F
> > >
> > > /app1/mvapich2/current/bin/mpif90 -O3 -o ex1f ex1f.o
> > > -Wl,-rpath,/home/svu/g0306332/codes/petsc-3.1-p0/atlas5-mpi-nodebug/lib
> > > -L/home/svu/g0306332/codes/petsc-3.1-p0/atlas5-mpi-nodebug/lib -lpetsc
> > > -Wl,-rpath,/home/svu/g0306332/lib/hypre-2.6.0b_atlas5/lib
> > > -L/home/svu/g0306332/lib/hypre-2.6.0b_atlas5/lib -lHYPRE -lmpichcxx
> > > -lstdc++
> > > -Wl,-rpath,/app1/intel/mkl/10.0.5.025/lib/em64t
> > > -L/app1/intel/mkl/10.0.5.025/lib/em64t -lmkl_lapack -lmkl -lguide
> > > -lpthread
> > > -L/app1/mvapich2/1.4/lib -L/usr/lib/gcc/x86_64-redhat-linux/4.1.2 -ldl
> > > -lmpich
> > > -lpthread -lrdmacm -libverbs -libumad -lrt -lgcc_s -lmpichf90
> > > -L/app1/intel/Compiler/11.0/074/lib/intel64 -lifport -lifcore -limf -lsvml
> > > -lm
> > > -lipgo -lirc -lirc_s -lm -lmpichcxx -lstdc++ -lmpichcxx -lstdc++ -ldl
> > > -lmpich
> > > -lpthread -lrdmacm -libverbs -libumad -lrt -lgcc_s -ldl
> > >
> > > However, it doesn't seem to work now. I tried to look at chapter 14 but I
> > > don't really understand since I know very little about makefiles.
> > >
> > > Can you give a rough guide for my case? I will try to read up on the
> > > manual to
> > > get more info.
> > >
> > > Moreover, I am confused by the use of:
> > >
> > > #include "finclude/petsc.h" etc.
> > >
> > > In my fortran files, do I simply use petsc.h or I have to use specific *.h
> > > depending on what petsc commands are used?
> > >
> > > Thank you very much and have a nice day!
> > >
> > > Yours sincerely,
> > >
> > > Wee-Beng Tay
> > >
> > >
> > > On 12/5/2010 9:55 AM, Satish Balay wrote:
> > >
> > > > Lets step back and deal with this primary issue.
> > > >
> > > > Have you attempted to use makefiles in petsc format? What problems
> > > > have you encountered? Perhaps they are fixable.
> > > >
> > > > The reason to use this format is to make your makefile as portable as
> > > > possible [and avoid such issues].
> > > >
> > > > Satish
> > > >
> > > > On Tue, 11 May 2010, Satish Balay wrote:
> > > >
> > > >
> > > >
> > > > > Why not use petsc makefiles - and avoid these hasseles?
> > > > >
> > > > >
> > > > >
> > > >
> > > >
-------------- next part --------------
ALL: a.out
# PETSC_DIR and PETSC_ARCH should be set either in env or in this makeifle
PETSC_DIR=/home/svu/g0306332/codes/petsc-3.1-p0
PETSC_ARCH=atlas5-mpi-nodebug
CFLAGS =
FFLAGS = -r8 -132 -fPIC -g -w90 -w -w95 -O3 # instead of opt2 add these flags to default petsc compile target for .F/.f
CPPFLAGS =
FPPFLAGS =
CLEANFILES = a.out
include ${PETSC_DIR}/conf/variables
include ${PETSC_DIR}/conf/rules
opt = -r8 -w95 -c -O3
opt3 = -w95 -c -O3
libs =/home/svu/g0306332/lib/tecio64.a /home/svu/g0306332/lib/linux64.a
OBJS = global.o grid.o flux_area.o bc.o bc_impl.o bc_semi.o set_matrix.o inter_step.o mom_disz.o poisson.o petsc_sub.o cell_data.o fractional.o ns2d_c.o
a.out : $(OBJS)
$(FLINKER) -o a.out $(OBJS) $(libs) $(PETSC_LIB)
#compiled these sources with default petsc targets
global.o : global.F
petsc_sub.o : petsc_sub.F poisson.o
ns2d_c.o : ns2d_c.f90 cell_data.o fractional.o
# sources compiled separately - as they need different opt/opt3 compiler flags.
grid.o : grid.f90 global.o
$(FC) $(opt3) grid.f90
flux_area.o : flux_area.f90 global.o
$(FC) $(opt) flux_area.f90
bc.o : bc.f90 flux_area.o
$(FC) $(opt) bc.f90
bc_impl.o : bc_impl.f90 bc.o
$(FC) $(opt) bc_impl.f90
bc_semi.o : bc_semi.f90 bc.o
$(FC) $(opt) bc_semi.f90
set_matrix.o : set_matrix.f90 bc_semi.o bc_impl.o
$(FC) $(opt) set_matrix.f90
inter_step.o : inter_step.f90 bc_impl.o
$(FC) $(opt) inter_step.f90
mom_disz.o : mom_disz.f90 bc_impl.o bc_semi.o set_matrix.o
$(FC) $(opt) mom_disz.f90
poisson.o : poisson.f90 set_matrix.o
$(FC) $(opt) poisson.f90
cell_data.o : cell_data.f90 grid.o set_matrix.o
$(FC) $(opt) cell_data.f90
fractional.o : fractional.f90 mom_disz.o petsc_sub.o inter_step.o
$(FC) $(opt) fractional.f90
More information about the petsc-users
mailing list