Makefile

pom -  
 Radek -
Bonjour, je ne sais pas trop où mettre mon message alors je le mets sur ce forum car mon programme est en C... J'ai un pb pour faire mon Makefile. Je désire paralléliser mon code et je ne sais pas trop où modifier mon Makefile. Pour compiler, je dois écrire la ligne suivante (en supposant que mon prgm n'est constitué que d'un seul fichier main.c) :

mpicc.mpich main.c -o out


(out est le nom de mon exécutable) et pour exéctuer mon code sur 10 machines je dois écrire

mpirun.mpich -np 10 out


Donc où dois modifier mon Makefile pour compiler et exécuter mon prgm ? Je vous envoie mon Makefile qui correspond à mon code séquentiel.

# inspire de https://gl.developpez.com/tutoriel/outil/makefile/

# compilateur utilise
CC=gcc #CPP pour le C++ et CC pour le C

CFLAGS=-Wall -W -O

LDFLAGS=-Wall -O2 -lm -static

# on inclut tous les headers
INCLUDE_DIR1=../include/includeCVode
INCLUDE_DIR2=../include/myinclude

# EXEC contient le nom des executables a generer.
EXEC=out

# Fichiers sources
SRC= $(wildcard ../source/sourceCVode/*.c) $(wildcard ../source/mysource/*.c) main.c

# Fichiers objets le .c est remplace par un .o
OBJ=$(SRC:.c=.o)

# Regles de compilation:
all: $(EXEC)

out: $(OBJ)
	@$(CC) -o $@ $^ $(LDFLAGS)

# Creation des .o a  partir des .c qui se verront appeles par defaut.
%.o: %.c
	@$(CC) -o $@ -c $< -I$(INCLUDE_DIR1) -I$(INCLUDE_DIR2) $(CFLAGS)

clean:
	@rm -rfv $(EXEC) $(OBJ) *~


Merci
Configuration: Susr Pro 9.3

3 réponses

  1. poof65
     
    Tu rajoutes
    [tab]mpirun.mpich -np 10 out
    en dessous de la ligne qui commence par all:

    Pour compiler et exécuter il suffira de taper "make"
    0
    1. pom
       
      OK, merci, je vais essayer ça.
      0
    2. pom
       
      Re salut, j'ai donc essayé ce que tu m'as dit. La compilation s'effectue très bien mais il y a un pb lors de l'exécution. J'ai le message d'erreur

      main.o: In function `main':main.c:(.text+0xdb): undefined reference to `MPI_Init'
      :main.c:(.text+0xe9): undefined reference to `ompi_mpi_comm_world'
      :main.c:(.text+0xee): undefined reference to `MPI_Comm_rank'
      :main.c:(.text+0xfc): undefined reference to `ompi_mpi_comm_world'
      :main.c:(.text+0x101): undefined reference to `MPI_Comm_size'
      :main.c:(.text+0x91f): undefined reference to `ompi_mpi_comm_world'
      :main.c:(.text+0x924): undefined reference to `MPI_Barrier'
      :main.c:(.text+0x929): undefined reference to `MPI_Finalize'
      collect2: ld returned 1 exit status
      make: *** [out] Error 1
      


      La fonction MPI_Init est pourtant la toute première fonction à écrire (initialisation de l'environement MPI pour le calcul parallèle). J'ai bien mis mon #include "mpi.h" avant.
      Ce qui est bizarre est que sur un prgm tout bête (envoi et réception d'un taleau) MPI_Init marche...

      D'où pourrait provenir le problème ?
      Merci.
      0
      1. Radek > pom
         
        C'est au moment du link que ca plante ta compile. Donc tu as tout simplement oublié ta librarie MPI ou bien tu ne prends pas le bon compilo !
        0
  2. poof65
     
    Ca c'est pas un problème d'exécution mais un problème de compilation, plus précisément un problème de linkage.

    Tu n'auras pas oublié le chemin de la librairie MPI sur la ligne de compilation ?

    Il y a aussi un problème dans ton makefile.
    Tu n'indiques nulle part que tu génère l'exécutable out.
    0
    1. Radek
       
      Tu n'indiques nulle part que tu génère l'exécutable out.

      Je ne vois pas ce que tu veux dire, son Makefile est correct. Enfin il me semble !!
      0
  3. pom
     
    Re bonjour,
    Tu n'indiques nulle part que tu génère l'exécutable out.
    Je ne suis pas un roi du Makefile, alors c'est sûrement possible. En tout cas, le makefile que je vous ai envoyé (1e post) est correct (enfin... il marche).

    Vous avez sûrement raison : je n'ai dit nul part le chemin de la librairie pour l'environnement MPI. Mais où dois-je le mettre dans le Makefile ? A quelle ligne ? Avec quelle syntaxe (en supposant que le chemin soit chemin/mpi) ?

    Merci de votre patience
    0
    1. Radek
       
      Remplace ta ligne :
      LDFLAGS=-Wall -O2 -lm -static

      par
      LDFLAGS=-Wall -O2 -lm -lmpi -static

      Dans un premier temps et si il te dit qu'il ne trouve pas ta librairie rajoute le chemin avec l'option -L :
      LDFLAGS=-Wall -O2 -lm -L/chemin/MPI -lmpi -static


      Mais vérifi avant si tu doit vraiment compiler avec gcc !!!
      Parce que selon les systèmes tu peux avoir des compilos prévus pour MPI (par exemple mpicc par exemple)
      Tu es sous quel OS ?
      0
      1. pom > Radek
         
        Oui effectivement, pour compiler je tape la commande
        mpicc.mpich main.c -o out
        


        dans le cas où je n'ai qu'un fichier main.c à compiler. Mais n'est-ce pas le compilateur gcc (version parallélisée) ? Dois-je remplacer ma ligne
        CC=gcc
        


        par

        CC=mpicc
        


        Merci encore.
        0
    2. Radek
       
      Un conseil : utilise la commande man.
      man gcc
      ou : man makefile
      ou : man make
      ou eventuellement : man gmake
      ...


      C'est peut etre penible, mais tu en apprendras bien plus et tu retiendras mieux que si tu demande sans chercher par toi-même !
      C'est un conseil pour pouvoir évoluer dans la programmation.
      Maintenant si tu ne comprends pas certaines choses tu peux demander,
      tu trouveras tjrs qq pour t'aider !
      ;-)

      Bon courage pour ton debuggage en // !!
      C'est pas facile tu veras !
      0
      1. pom > Radek
         
        Oui, tu as raison. J'ai appris le C "sur le terrain" (j'ai chopé sur le net plein de cours et je vais sur des forums). Pour le Makefile, j'ai aussi chopé des exemples sur le net. Maispour la programmation parallèle, je débute et suis un peu perdu...
        0