No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

guide.tex 9.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. \documentclass[11pt]{paper}
  2. \usepackage[frenchb]{babel}
  3. \usepackage[T1]{fontenc}
  4. \usepackage{graphicx}
  5. \usepackage{amssymb}
  6. \usepackage{amstext}
  7. \usepackage{amsmath}
  8. \usepackage{a4wide,color}
  9. \usepackage[utf8]{inputenc}
  10. \usepackage{xspace}
  11. \usepackage{anysize}
  12. \usepackage{tabularx}
  13. \usepackage{multirow}
  14. \usepackage{fancybox}
  15. \usepackage{fancyhdr}
  16. \usepackage{bbding}
  17. \setlength{\parskip}{1ex plus 0.5ex minus 0.2ex}
  18. \usepackage{threeparttable}
  19. \usepackage{color}
  20. \usepackage{float}
  21. \usepackage[toc,page]{appendix}
  22. \usepackage{lscape}
  23. \usepackage{xspace}
  24. \usepackage{placeins}
  25. \usepackage{listingsutf8}
  26. \usepackage{todonotes}
  27. \lstset{% general command to set parameter(s)
  28. basicstyle=\footnotesize, % print whole listing small
  29. keywordstyle=\color{magenta}\bfseries, % underlined bold black keywords
  30. identifierstyle=, % nothing happens
  31. commentstyle=\color{black}, % white comments
  32. stringstyle=\ttfamily, % typewriter type for strings
  33. showstringspaces=false % no special string spaces
  34. }
  35. \lstdefinelanguage{aald}
  36. {morekeywords={system, implementation},
  37. sensitive=false,
  38. morecomment=[l]{//},
  39. morecomment=[s]{/*}{*/},
  40. morestring=[b]",
  41. }
  42. \usepackage[colorlinks=true]{hyperref}
  43. \usepackage[normalem]{ulem}
  44. \usepackage{color}
  45. \definecolor{Fond}{gray}{0.9}
  46. \renewcommand{\floatpagefraction}{.99}
  47. \renewcommand{\textfraction}{.01}
  48. \newcommand{\modif}[1]{\textcolor{red}{\uline{#1}}}
  49. \newcounter{cptreq}
  50. \newcommand{\req}[1]{
  51. \stepcounter{cptreq}
  52. \noindent\fcolorbox{black}{Fond}{% couleur du texte, couleur du fond
  53. \begin{minipage}[t]{\textwidth}
  54. {\bf Fonctionnalité \thecptreq}\, : #1
  55. \end{minipage}
  56. }
  57. }
  58. \newcommand{\raspi}{Raspberry Pi\xspace}
  59. \pagestyle{fancy}
  60. \fancyhf{}
  61. \fancyhead[RE,RO]{\thepage}
  62. \fancyhead[LE]{}
  63. \fancyhead[LO]{Programmation et conception de systémes temps réel -- 4éme année AE/IR}
  64. \fancyfoot[LO]{INSA Toulouse — P.-E. Hladik}
  65. \fancypagestyle{plain}{%
  66. \fancyhf{} % get rid of headers
  67. \renewcommand{\headrulewidth}{0pt} % and the line
  68. }
  69. \newenvironment{maliste}%
  70. { \begin{list}%
  71. {\ArrowBoldRightStrobe}%
  72. {\setlength{\labelwidth}{30pt}%
  73. \setlength{\leftmargin}{35pt}%
  74. \setlength{\itemsep}{\parsep}}}%
  75. { \end{list} }
  76. \renewcommand{\appendixtocname}{Annexes}
  77. \renewcommand{\appendixpagename}{Annexes}
  78. \title{{\Huge Projet De Stijl 2.0}
  79. {\small : Plateforme pour robots mobiles}\\
  80. {\scriptsize Programmation et conception de systémes temps réel -- 4éme année AE/IR}\\
  81. {\scriptsize Institut National des Sciences Appliquées de Toulouse}\\
  82. ---\\
  83. Guide des outils de développement \\
  84. {\large Version 1.0.1 (\today)}\\
  85. {\scriptsize Référent pédagogique : P.-E. Hladik (\texttt{pehladik@insa-toulouse.fr})}\\
  86. {\scriptsize Référents plateforme : S. Di Mercurio (\texttt{dimercur@insa-toulouse.fr})}\\
  87. ---
  88. }
  89. \begin{document}
  90. \maketitle
  91. %%%%%%%%%%%%%%%%%%%%
  92. \section{Configurer Netbeans pour C/C++}
  93. \label{sec:git}
  94. %%%%%%%%%%%%%%%%%%%%
  95. Depuis la version 11 de Netbeans, il est nécessaire que chaque utilisateur configure son environnement avec le plugin C/CC++. Pour cela, il faut :
  96. \begin{itemize}
  97. \item ouvrir le menu \og Tools > Plugins \fg
  98. \item aller dans l'onglet \og Settings \fg,
  99. \item cocher \og Netbeans 8.2 plugins Portal \fg,
  100. \item aller dans l'onglet \og Available \fg et rafraichir,
  101. \item puis choisir C/C++ et suivre le guide...
  102. \end{itemize}
  103. %%%%%%%%%%%%%%%%%%%%
  104. \section{Code initial du projet}
  105. \label{sec:git}
  106. %%%%%%%%%%%%%%%%%%%%
  107. Le code du projet est disponible sur un dépôt git hébergé sur GitHub. Pour le récupérer, placer vous le répertoire cible et exécuter la commande\\ \indent\indent {\tt git clone https://github.com/INSA-GEI/dumber.git}\\
  108. Tout le code relatif au projet est disponible, cependant vous n'aurez besoin que des codes présents dans les répertoires :
  109. \begin{itemize}
  110. \item {\tt ./dumber/software/raspberry/superviseur-robot} : ce répertoire contient un projet Netbeans avec l'ensemble du code source pour le projet initial,
  111. \item {\tt ./dumber/software/monitor/monitor} : ce répertoire contient un projet Mono contenant l'ensemble du code source pour le moniteur.\\
  112. \end{itemize}
  113. Le répertoire {\tt superviseur-robot} est constitué des fichiers suivants :
  114. \begin{itemize}
  115. \item {\tt /destijl\_init/main.cpp} qui contient le main de l'application et lance la création des objets et leur exécution,
  116. \item {\tt /destijl\_init/src/tasks.h} qui contient l'entête des différentes fonctions,
  117. \item {\tt /destijl\_init/src/tasks.cpp} qui contient l'implémentation des fonctions de création des objets (tâches, sémaphores, mutex, etc.) ainsi que les fonctions de traitement.
  118. \end{itemize}
  119. %%%%%%%%%%%%%%%%%%%%
  120. \section{Compilation d'une application distante}
  121. %%%%%%%%%%%%%%%%%%%%
  122. L'application étant sur une \raspi, il vous faut compiler le programme pour cette architecture. Nous vous proposons d'utiliser Netbeans pour écrire votre code et faire la compilation distante. Cela signifie que votre code est stocké sur votre compte INSA, que vous éditez le code sur la machine de TP, que ce code est ensuite automatiquement chargé sur la \raspi puis compilé (Netbeans permet de faire tout cela).
  123. Pour commencer, lancez Netbeans et ouvrez le projet {\tt superviseur-robot}.
  124. Avant de compiler, il vous faut configurer la cible sur laquelle la compilation va se faire:
  125. \begin{enumerate}
  126. \item Cliquez droit sur le projet et choisir {\tt Properties},
  127. \item Allez dans l'onglet {\tt Build},
  128. \item Choisir {\tt ...} pour {\tt Build Host},
  129. \item Cliquez sur {\tt Add},
  130. \item Remplir {\tt Hostname} avec {\tt 10.105.1.x} l'adresse de la \raspi,
  131. \item Cliquez {\tt Next},
  132. \item Saisir {\tt pi} pour le {\tt login},
  133. \item Cliquez {\tt Next},
  134. \item Attendre l'ouverture de la communication,
  135. \item Saisir {\tt insa} comme mot de passe,
  136. \item Sélectionner {\tt SFTP} pour {\tt Access project files via},
  137. \item Cliquez {\tt Finish},
  138. \item Cliquez {\tt OK},
  139. \item Cliquez {\tt Apply},
  140. \item Cliquez {\tt OK}.
  141. \end{enumerate}
  142. Pour compiler, il suffit ensuite de cliquer sur l'icône en forme de marteau. Vous pourrez voir dans le terminal les étapes de compilation qui commencent par le transfert des fichiers suivi de la compilation proprement dite.
  143. {\bf Remarque} : la première compilation est un peu longue, mais devrait ensuite se fluidifier avec la compilation incrémentale.
  144. %%%%%%%%%%%%%%%%%%%%
  145. \section{Exécution du superviseur}
  146. \label{sec:utilisation}
  147. %%%%%%%%%%%%%%%%%%%%
  148. Pour exécuter l'application sur le superviseur, il faut avoir mis en place un terminal distant (voir ci-dessous) puis démarrer l'exécution avec la commande {\tt sudo ./path/app} où {\tt path} est le chemin du répertoire où se trouve l'application et {\tt app} est le nom de votre application. Attention les droits {\tt sudo} sont nécessaires pour des questions d'accès à certains services Xenomai de gestion de la mémoire.
  149. Si vous utilisez Netbeans, le répertoire dans lequel est compilée l'application se trouve dans l'arboressence commençant par {\tt .netbeans} (attention au "." au début). Il faut descendre dans cette arboressence jusqu'à une bifurcation, puis choisir le répertoire {\tt dist} et aller jusqu'au bout. L'application se trouve au bout de cette branche.
  150. %%%%%%%%%%%%%%%%%%%%
  151. \section{Mise en place d'un terminal distant avec la \raspi}
  152. \label{sec:ssh}
  153. %%%%%%%%%%%%%%%%%%%%
  154. Pour se connecter à la \raspi, vous aurez besoin de créer un accès via ssh. Pour cela, depuis un PC d'une salle informatique utilisez la commande :\\ \indent\indent{\tt ssh pi@10.105.1.x}\\
  155. avec {\tt x} le numéro sur le boitier de la \raspi.
  156. Le mot de passe est : insa.
  157. %%%%%%%%%%%%%%%%%%%%
  158. \section{Exécution du moniteur}
  159. \label{sec:utilisation}
  160. %%%%%%%%%%%%%%%%%%%%
  161. Pour exécuter le moniteur, il suffit depuis votre PC de travail de se placer dans le répertoire {\tt ./dumber/software/monitor/monitor} et de lancer {\tt ./monitor}.
  162. {\bf Attention} : avant de lancer la première fois l'application, il vous faut ouvrir l'environnement de développement MonoDevelop et ouvrir le projet {\tt ./dumber/software/monitor/monitor} et l'exécuter (cela recompile le projet et permet de faire les liens avec les librairies de votre PC). Cette étape ne sera plus à faire par la suite.
  163. %%%%%%%%%%%%%%%%%%%%
  164. \section{Comprendre la structuration du code}
  165. \label{sec:code}
  166. %%%%%%%%%%%%%%%%%%%%
  167. L'ensemble du code du projet initial est contenu dans le répertorie {\tt superviseur-robot}. Les bibliothèques de traitement sont disponibles dans le repertoire {\tt lib}. Vous n'aurez pas à modifier ces bibliothèques, par contre vous devrez les utiliser. La documentation est directement écrite dans le code source.
  168. Les seuls fichiers que vous allez avoir à modifier sont les fichiers {\tt tasks.h} et {\tt tasks.cpp}. La classe {\tt Tasks} a pour attributs privés l'ensemble des structures constituant l'application (tâches, mutex, sémarphores, ressources, etc.). Les fonctions de traitement associées aux tâches sont déclarées comme des méthodes privées de {\tt Tasks}.
  169. La classe {\tt Tasks} propose quatre méthodes publiques :
  170. \begin{itemize}
  171. \item {\tt Init()} qui crée les structures de l'application,
  172. \item {\tt Run()} qui lance les tâches,
  173. \item {\tt Stop()} qui termine les tâches,
  174. \item {\tt Join()} qui suspend l'exécution du {\tt main}.\\
  175. \end{itemize}
  176. Pour ajouter des structures à l'application, il suffit de les déclarer dans le fichier {\tt tasks.h} puis de s'assurer qu'elles sont bien instanciées dans les méthodes adéquates de {\tt tasks.cpp}. Pour une tâche, il faut en plus déclarer une nouvelle méthode privée dans {tasks.h} et fournir son implémentation dans {tasks.cpp}. Cette nouvelle méthode sera le point d'entrée de la tâche.
  177. Toute la documentation de Xenomai se trouve en ligne (attention c'est Xenomai 3) et nous utilisons l'\href{https://xenomai.org/documentation/xenomai-3/html/xeno3prm/group__alchemy.html}{API alchemy}.
  178. \end{document}