diff --git a/README.md b/README.md
index 36192d1..448a537 100644
--- a/README.md
+++ b/README.md
@@ -12,5 +12,8 @@ Cryptographie - Outils et algorithmes
 - cm : [Chiffrements par bloc, algorithmes à clefs publiques](cours/crypto.pdf). 
 - tp : [Substitution-Permutation-Network](td_tp/tp2)
 
+#### Semaine 3
+- cm : [Algorithmes à clefs publiques](cours/crypto.pdf). 
+- tp : [Diffie-Hellman](td_tp/tp3)
 
 
diff --git a/cours/crypto.pdf b/cours/crypto.pdf
index 1113bd8..515a4e6 100644
Binary files a/cours/crypto.pdf and b/cours/crypto.pdf differ
diff --git a/td_tp/tp3/README.md b/td_tp/tp3/README.md
new file mode 100644
index 0000000..92a331a
--- /dev/null
+++ b/td_tp/tp3/README.md
@@ -0,0 +1,103 @@
+## TP3 
+
+> Le but du tp est de mettre en oeuvre une communication sécurisée entre
+> un client et un serveur, en deux phases :
+> - Echange d'une clé.
+> - Cryptage de la communication par un algorithme de chiffrement
+>   symétrique à l'aide de la clé echangée. (XTEA pour ce tp)
+
+[Rappel de cours](../cours/crypto.pdf)
+
+### Diffie-Hellman
+<div align="center">
+<img src="./dh.png">
+</div>
+
+
+
+Le système (et sa sécurité) de Diffie-Hellman repose sur la difficulté
+pratique, pour des grands nombres, de calculer le logarithme discret
+dans un groupe multiplicatif $\mathbb{Z}_{p}^{*}$ avec $p$
+premier.
+
+On rappelle que lorsque $p$ est premier, $\mathbb{Z}_{p}^{*}$ est cyclique. Si $g$ est un générateur,
+tout élément $x\in \mathbb{Z}_{p}^{*}$ s'écrit (de manière
+unique) sous la forme 
+\[
+x=g^a,\ \ 1\leq a \leq p-1
+\]
+
+<!--\\((\\mathbb{Z}_{p}^{\*},.)\\) est ismorphe au groupe additif
+\\((\\mathbb{Z}_{p-1},+)\\)-->
+
+Par définition, $a$ est le logarithme (discret) de $x$ dans la
+base $g$ noté 
+\[
+a=\log_{g}(x)
+\]
+
+Le schéma en haut de la page illustre comment deux entités peuvent
+échangés une clef. Alice génére $p$, un générateur $g$. Il
+choisit un nombre aléatoire $a$  ($2\leq a\leq p-2$), et envoie
+à Bob le triplet $((p,g,g^a)$. Bob recoit le triplet, et choisit un
+nombre $b$. Il envoie à Alice $g^b$. La clé calculée par Alice,
+et Bob est 
+
+\|
+(g^a)^b = (g^b)^a= g^{ab}
+\]
+
+Pour calculer la clé, il faut connaître $ab$. Or seuls $g^a$ et
+$g^b$ ont été échangés. Ce qui nous ramène au problème du
+logarithme discret qui est difficile en pratique pour des grands
+nombres.
+
+##### Votre travail
+
+Le but du tp est d'écrire un client/serveur TCP :
+
+-   Le client et le serveur utilise Diffie-Hellman pour échanger une clé
+    sur 16 octets. On utilisera des nombres premiers de Sophie Germain.
+-   Le client saisit un message de l'utilisateur, le chiffre avec XTEA,
+    et envoit le message chiffré.
+-   Le serveur reçoit le message chiffré, le déchiffre, et l'affiche.
+
+1.  Trouver un générateur peut-être long. En effet, tout ce qu'on l'on
+    sait sur l'ordre d'un élément de $\mathbb{Z}_p^{*}$, c'est
+    qu'il divise l'ordre du groupe, i.e $p-1$. Pour que la
+    vérification soit plus rapide, on s'interesse aux nombres premiers
+    dit de Sophie Germain. Ils ont la particularité d'être sous la
+    forme $2q+1$, avec $q$ premier. Ainsi, l'odre de
+    $\mathbb{Z}_{p}^{*}$ est $2q$. L'odre possible d'un
+    élément ne peut être que $2$, $q$ ou $2q$. Ce qui fait peu (combien) de
+    test à effectuer quand on cherche un générateur.
+
+    Ecrire un script à l'aide de la commande `primesieve` qui donne
+    tous les nombres premiers de Sophie Germain dans
+    $[2^{62},2^{62}+20000]$. (il faut quelques minutes. Assurez-vous
+	que votre shell permet de représenter de tels nombres. Comment ?)
+
+2.  Ecrire les [fonctions](src/df.c) suivantes :
+	```c
+	typedef unsigned __int128 uint128;
+	typedef unsigned long long int uint64;
+
+	uint64 expm(uint64 m, uint64 e, uint64 n);
+	// calcule m^e modulo n
+	uint64 generateur(uint64 p);
+	// calcule un generateur de (Zp)*
+	// en supposant que p est un nombre premier 
+	// de Sophie Germain
+	```
+    Testez ([test_df.c](src/test_df.c)) avec $p = 4611686018427402023$ pour trouver un
+    générateur.
+
+
+
+Remarque : pour la génération d'un grand nombre
+premier, utilisez le programme `primesieve` qsui se trouve dans
+
+```
+/export/documents/is1+2/asr
+```
+.
diff --git a/td_tp/tp3/dh.png b/td_tp/tp3/dh.png
new file mode 100644
index 0000000..ab7fdc0
Binary files /dev/null and b/td_tp/tp3/dh.png differ
diff --git a/td_tp/tp3/dh.svg b/td_tp/tp3/dh.svg
new file mode 100644
index 0000000..12f91ab
--- /dev/null
+++ b/td_tp/tp3/dh.svg
@@ -0,0 +1,294 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/ svg10.dtd">
+<svg
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   version="1.0"
+   width="820"
+   height="450"
+   id="svg2">
+  <defs
+     id="defs4" />
+  <g
+     transform="translate(-46.31577,-632.20074)"
+     id="layer1">
+    <path
+       d="M 318.11284,802.35195 L 581.38211,802.35195 L 580.10046,798.35195 L 596.15877,803.93363 L 580.10046,809.51532 L 581.38211,805.51532 L 318.11284,805.51532 L 318.11284,802.35195 z"
+       id="rect3239"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+    <rect
+       width="262.83951"
+       height="365.70755"
+       rx="38.638252"
+       ry="37.143986"
+       x="47.13364"
+       y="676.1059"
+       transform="matrix(1,0,7.79566e-3,0.9999696,0,0)"
+       id="rect2453"
+       style="opacity:1;fill:#ffff7f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0.75401145;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+    <rect
+       width="262.83951"
+       height="365.70755"
+       rx="38.638252"
+       ry="37.143986"
+       x="590.46265"
+       y="676.1059"
+       transform="matrix(1,0,7.7956625e-3,0.9999696,0,0)"
+       id="rect3225"
+       style="opacity:1;fill:#ffff7f;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0.75401145;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+    <rect
+       width="151.51535"
+       height="61.515339"
+       rx="0"
+       ry="0"
+       x="383.09946"
+       y="773.17596"
+       id="rect3227"
+       style="opacity:1;fill:#ffffbf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0.66723782;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+    <path
+       d="M 596.22925,904.80102 L 332.95998,904.80102 L 334.24163,908.80102 L 318.18332,903.21934 L 334.24163,897.63765 L 332.95998,901.63765 L 596.22925,901.63765 L 596.22925,904.80102 z"
+       id="path3244"
+       style="fill:#000000;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+    <rect
+       width="151.51535"
+       height="61.515339"
+       rx="0"
+       ry="0"
+       x="383.09946"
+       y="872.46167"
+       id="rect3229"
+       style="opacity:1;fill:#ffffbf;fill-opacity:1;fill-rule:nonzero;stroke:#000000;stroke-width:0.66723782;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1" />
+    <text
+       x="135.3013"
+       y="744.38751"
+       id="text3266"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="135.3013"
+         y="744.38751"
+         id="tspan3268"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">a, g, p</tspan></text>
+    <text
+       x="446.49091"
+       y="916.10413"
+       id="text3278"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="446.49091"
+         y="916.10413"
+         id="tspan3280"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">B</tspan></text>
+    <text
+       x="406.237"
+       y="813.03033"
+       id="text3282"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="406.237"
+         y="813.03033"
+         id="tspan3284"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">g, p, A</tspan></text>
+    <text
+       x="718.12823"
+       y="751.3045"
+       id="text3294"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="718.12823"
+         y="751.3045"
+         id="tspan3296"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">b</tspan></text>
+    <text
+       x="146.97318"
+       y="665.97028"
+       id="text3302"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="146.97318"
+         y="665.97028"
+         id="tspan3304"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">Alice</tspan></text>
+    <text
+       x="695.94464"
+       y="665.97028"
+       id="text3308"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="695.94464"
+         y="665.97028"
+         id="tspan3310"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">Bob</tspan></text>
+    <text
+       x="83.419472"
+       y="814.86749"
+       id="text3270"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="83.419472"
+         y="814.86749"
+         id="tspan3272"
+         style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">A = g  mod p</tspan></text>
+    <text
+       x="169.43015"
+       y="794.96851"
+       id="text3312"
+       xml:space="preserve"
+       style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+         x="169.43015"
+         y="794.96851"
+         id="tspan3314"
+         style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">a</tspan></text>
+    <text
+       x="79.051758"
+       y="1073.0292"
+       id="text3352"
+       xml:space="preserve"
+       style="font-size:22px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+         x="79.051758"
+         y="1073.0292"
+         id="tspan3354"
+         style="font-size:22px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">K = A  mod p = (g  mod p)  mod p = g   mod p = (g  mod p)  mod p = B  mod p</tspan></text>
+    <g
+       transform="translate(-8.573848,79.690866)"
+       id="g3322">
+      <text
+         x="88.644684"
+         y="834.67328"
+         id="text3324"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+           x="88.644684"
+           y="834.67328"
+           id="tspan3326"
+           style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">K = B  mod p</tspan></text>
+      <text
+         x="176.65536"
+         y="814.77429"
+         id="text3328"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+           x="176.65536"
+           y="814.77429"
+           id="tspan3330"
+           style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">a</tspan></text>
+      <text
+         x="139.62561"
+         y="980.89594"
+         id="text3356"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="139.62561"
+           y="980.89594"
+           id="tspan3358"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">b</tspan></text>
+      <text
+         x="259.09045"
+         y="979.78265"
+         id="text3360"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="259.09045"
+           y="979.78265"
+           id="tspan3362"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">a</tspan></text>
+      <text
+         x="339.73691"
+         y="980.89594"
+         id="text3364"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="339.73691"
+           y="980.89594"
+           id="tspan3366"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">b</tspan></text>
+      <text
+         x="451.09045"
+         y="980.89594"
+         id="text3368"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="451.09045"
+           y="980.89594"
+           id="tspan3370"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">ab</tspan></text>
+      <text
+         x="574.79761"
+         y="980.89594"
+         id="text3372"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="574.79761"
+           y="980.89594"
+           id="tspan3374"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">b</tspan></text>
+      <text
+         x="653.44403"
+         y="979.78265"
+         id="text3376"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="653.44403"
+           y="979.78265"
+           id="tspan3378"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">a</tspan></text>
+      <text
+         x="768.09045"
+         y="979.78265"
+         id="text3380"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Arial;-inkscape-font-specification:Arial"><tspan
+           x="768.09045"
+           y="979.78265"
+           id="tspan3382"
+           style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">a</tspan></text>
+    </g>
+    <g
+       transform="translate(534.75505,81.360788)"
+       id="g3332">
+      <text
+         x="88.644684"
+         y="834.67328"
+         id="text3334"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+           x="88.644684"
+           y="834.67328"
+           id="tspan3336"
+           style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">K = A  mod p</tspan></text>
+      <text
+         x="174.65536"
+         y="814.77429"
+         id="text3338"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+           x="174.65536"
+           y="814.77429"
+           id="tspan3340"
+           style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">b</tspan></text>
+    </g>
+    <g
+       transform="translate(536.75896,-18.135855)"
+       id="g3342">
+      <text
+         x="88.644684"
+         y="834.67328"
+         id="text3344"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+           x="88.644684"
+           y="834.67328"
+           id="tspan3346"
+           style="font-size:36px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">B = g  mod p</tspan></text>
+      <text
+         x="174.65536"
+         y="814.77429"
+         id="text3348"
+         xml:space="preserve"
+         style="font-size:12px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;fill:#000000;fill-opacity:1;stroke:none;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1;font-family:Times New Roman;-inkscape-font-specification:Times New Roman"><tspan
+           x="174.65536"
+           y="814.77429"
+           id="tspan3350"
+           style="font-size:18px;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;text-align:start;line-height:100%;writing-mode:lr-tb;text-anchor:start;font-family:Arial;-inkscape-font-specification:Arial">b</tspan></text>
+    </g>
+  </g>
+</svg>
diff --git a/td_tp/tp3/src/Makefile b/td_tp/tp3/src/Makefile
new file mode 100644
index 0000000..306953a
--- /dev/null
+++ b/td_tp/tp3/src/Makefile
@@ -0,0 +1,13 @@
+all : test_df 
+
+./lib_tea/tea.o : ./lib_tea/tea.c
+	gcc -c ./lib_tea/tea.c -o ./lib_tea/tea.o
+
+df.o : df.c
+	gcc -c df.c
+
+test_df.o : test_df.c
+	gcc -c test_df.c
+
+test_df : test_df.o df.o ./lib_tea/tea.o
+	gcc -o test_df df.o test_df.o ./lib_tea/tea.o
diff --git a/td_tp/tp3/src/df.c b/td_tp/tp3/src/df.c
new file mode 100644
index 0000000..1e2ffa5
--- /dev/null
+++ b/td_tp/tp3/src/df.c
@@ -0,0 +1,23 @@
+#include "df.h"
+
+uint64 expm(uint64 m, uint64 e, uint64 mod)
+{
+	uint128 _r=1;
+	uint128 _m=(uint128)m;
+	uint128 _mod = (uint128)mod;
+
+
+	// TODO
+
+	return (uint64)_r;
+}
+
+uint64 generateur(uint64 p)
+{
+	uint64 g=2;
+	uint64 r=1;
+
+	// TODO
+}
+
+
diff --git a/td_tp/tp3/src/df.h b/td_tp/tp3/src/df.h
new file mode 100644
index 0000000..0aba99a
--- /dev/null
+++ b/td_tp/tp3/src/df.h
@@ -0,0 +1,15 @@
+#ifndef _DF_H
+#define _DF_H
+
+typedef unsigned __int128 uint128;
+typedef unsigned long long int uint64;
+
+uint64 expm(uint64 m, uint64 e, uint64 n);
+// calcule m^e modulo n
+
+uint64 generateur(uint64 p);
+// calcule un generateur de (Zp)*
+// en supposant que p est un nombre premier 
+// de Sophie Germain
+
+#endif
diff --git a/td_tp/tp3/src/lib_tea/tea.c b/td_tp/tp3/src/lib_tea/tea.c
new file mode 100644
index 0000000..f541848
--- /dev/null
+++ b/td_tp/tp3/src/lib_tea/tea.c
@@ -0,0 +1,39 @@
+#include "tea.h"
+#include<string.h>
+#define TOUR 32
+
+void encrypt_tea (uint32_t * v, uint32_t* k) 
+{
+	uint32_t v0=v[0], v1=v[1], sum=0, i;           /* initialisation */
+	uint32_t delta=0x9e3779b9;                     /* constantes de clef */
+	uint32_t k0=k[0], k1=k[1], k2=k[2], k3=k[3];   /* mise en cache de la clef */
+	for (i=0; i < TOUR; i++) {                       /* boucle principale */
+		sum += delta;
+		v0 += ((v1<<4) + k0) ^ (v1 + sum) ^ ((v1>>5) + k1);
+		v1 += ((v0<<4) + k2) ^ (v0 + sum) ^ ((v0>>5) + k3);
+	}
+	v[0]=v0; v[1]=v1;
+}
+
+void decrypt_tea (uint32_t* v, uint32_t* k) 
+{
+	uint32_t v0=v[0], v1=v[1], sum=0xC6EF3720, i;  /* initialisation */
+	uint32_t delta=0x9e3779b9;                     /* constantes de clefs */
+	uint32_t k0=k[0], k1=k[1], k2=k[2], k3=k[3];   /* mise en cache de la clef */
+	for (i=0; i<TOUR; i++) {                         /* boucle principale */
+		v1 -= ((v0<<4) + k2) ^ (v0 + sum) ^ ((v0>>5) + k3);
+		v0 -= ((v1<<4) + k0) ^ (v1 + sum) ^ ((v1>>5) + k1);
+		sum -= delta;
+	}
+	v[0]=v0; v[1]=v1;
+}
+
+uint64_t hash_block_tea(char b[24])
+{
+	uint32_t v[2];
+	uint32_t k[4];
+	memcpy(v,b,2*sizeof(uint32_t));
+	memcpy(k,b+2*sizeof(uint32_t),4*sizeof(uint32_t));
+	encrypt_tea(v,k);
+	return ((uint64_t)v[0])<<32 | v[1];
+}
diff --git a/td_tp/tp3/src/lib_tea/tea.h b/td_tp/tp3/src/lib_tea/tea.h
new file mode 100644
index 0000000..ba07355
--- /dev/null
+++ b/td_tp/tp3/src/lib_tea/tea.h
@@ -0,0 +1,8 @@
+#ifndef _TEA_H
+#define _TEA_H
+#include <stdint.h>
+void  encrypt_tea (uint32_t* v, uint32_t* k);
+void  decrypt_tea (uint32_t* v, uint32_t* k);
+uint64_t hash_block_tea(char b[24]);
+#endif
+
diff --git a/td_tp/tp3/src/lib_tea/xtea.c b/td_tp/tp3/src/lib_tea/xtea.c
new file mode 100644
index 0000000..769af64
--- /dev/null
+++ b/td_tp/tp3/src/lib_tea/xtea.c
@@ -0,0 +1,34 @@
+#include "xtea.h"
+#include<string.h>
+#define TOUR 32
+
+void encrypt_xtea(uint32_t v[2], uint32_t const key[4]) {
+    unsigned int i;
+    uint32_t v0=v[0], v1=v[1], sum=0, delta=0x9E3779B9;
+    for (i=0; i < TOUR; i++) {
+        v0 += (((v1 << 4) ^ (v1 >> 5)) + v1) ^ (sum + key[sum & 3]);
+        sum += delta;
+        v1 += (((v0 << 4) ^ (v0 >> 5)) + v0) ^ (sum + key[(sum>>11) & 3]);
+    }
+    v[0]=v0; v[1]=v1;
+}
+void decrypt_xtea(uint32_t v[2], uint32_t const key[4]) {
+    unsigned int i;
+    uint32_t v0=v[0], v1=v[1], delta=0x9E3779B9, sum=delta*TOUR;
+    for (i=0; i < TOUR; i++) {
+        v1 -= (((v0 << 4) ^ (v0 >> 5)) + v0) ^ (sum + key[(sum>>11) & 3]);
+        sum -= delta;
+        v0 -= (((v1 << 4) ^ (v1 >> 5)) + v1) ^ (sum + key[sum & 3]);
+    }
+    v[0]=v0; v[1]=v1;
+}
+uint64_t hash_block_xtea(char b[24])
+{
+	uint32_t v[2];
+	uint32_t k[4];
+	memcpy(v,b,2*sizeof(uint32_t));
+	memcpy(k,b+2*sizeof(uint32_t),4*sizeof(uint32_t));
+	encrypt_xtea(v,k);
+	return ((uint64_t)v[0])<<32 | v[1];
+
+}
diff --git a/td_tp/tp3/src/lib_tea/xtea.h b/td_tp/tp3/src/lib_tea/xtea.h
new file mode 100644
index 0000000..8007875
--- /dev/null
+++ b/td_tp/tp3/src/lib_tea/xtea.h
@@ -0,0 +1,8 @@
+#ifndef _TEA_H
+#define _TEA_H
+#include <stdint.h>
+void  encrypt_xtea (uint32_t* v, uint32_t const  k[]);
+void  decrypt_xtea (uint32_t* v, uint32_t const  k[]);
+uint64_t hash_block_xtea(char b[24]);
+#endif
+
diff --git a/td_tp/tp3/src/reseau/Makefile b/td_tp/tp3/src/reseau/Makefile
new file mode 100644
index 0000000..41ec6bf
--- /dev/null
+++ b/td_tp/tp3/src/reseau/Makefile
@@ -0,0 +1,13 @@
+all : clt srv
+
+clt.o:clt.c
+	gcc -c clt.c
+clt: clt.o
+	gcc -o clt clt.o
+srv.o : srv.c
+	gcc -c srv.c
+srv : srv.o
+	gcc -o srv srv.c
+
+
+
diff --git a/td_tp/tp3/src/reseau/clt.c b/td_tp/tp3/src/reseau/clt.c
new file mode 100644
index 0000000..048dbce
--- /dev/null
+++ b/td_tp/tp3/src/reseau/clt.c
@@ -0,0 +1,70 @@
+#include <sys/socket.h>
+#include <netinet/in.h>
+#include <arpa/inet.h>
+
+#include <netinet/tcp.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <resolv.h>
+#include <fcntl.h>
+#include <sys/time.h>
+#include <assert.h>
+#define MAXBUFF 4096 
+
+int main(int argc, char * argv[]) {
+	int sock,  z=0, fd;
+	char buff[MAXBUFF];
+	struct sockaddr_in server_addr;
+	int addrlen; 
+
+	if (argc != 4) {
+		printf("Usage: %s <IP-address> <port number> <file to send>\n",argv[0]);
+		exit(1);
+	}
+
+	sock = socket(AF_INET, SOCK_STREAM, 0);
+	assert(sock != -1);
+
+	bzero(&server_addr, sizeof(server_addr));
+	server_addr.sin_family = AF_INET;
+	server_addr.sin_port = htons(atoi(argv[2]));
+
+	assert( inet_aton(argv[1], (struct in_addr*)&server_addr.sin_addr.s_addr) != 0 );
+
+	addrlen = sizeof(server_addr);
+
+	fd = open(argv[3],O_RDONLY,0666); 
+	assert(fd != -1);
+
+	assert(connect(sock,(struct sockaddr *)&server_addr, addrlen) != -1);
+
+	while(1) {
+		
+		ssize_t mbytes, nbytes;
+
+		nbytes=read(fd,buff,MAXBUFF);
+
+		if (nbytes==-1) {
+			perror("read");
+			exit(1);
+		}
+		if (nbytes==0) {
+			break;
+		}
+
+		mbytes = write(sock,buff,nbytes);
+		if (mbytes == -1) {
+			perror("write");
+			exit(1);
+		}
+		z=z+mbytes;
+	}
+
+	printf("file %s sent (%d bytes)",argv[3],z);
+
+	close(sock);
+	exit(0);
+}
diff --git a/td_tp/tp3/src/reseau/clt_echo.c b/td_tp/tp3/src/reseau/clt_echo.c
new file mode 100644
index 0000000..75d9d96
--- /dev/null
+++ b/td_tp/tp3/src/reseau/clt_echo.c
@@ -0,0 +1,73 @@
+#include <sys/socket.h>
+#include <netinet/in.h>
+#include <arpa/inet.h>
+
+#include <netinet/tcp.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <string.h>
+#include <sys/socket.h>
+#include <resolv.h>
+#include <fcntl.h>
+#include <sys/time.h>
+#include <assert.h>
+#define MAXBUFF 4096 
+
+int main(int argc, char * argv[]) {
+	int sock,  z=0, fd;
+	char buff[MAXBUFF];
+	struct sockaddr_in server_addr;
+	int addrlen; 
+
+	if (argc != 4) {
+		printf("Usage: %s <IP-address> <port number> <file to send>\n",argv[0]);
+		exit(1);
+	}
+
+	sock = socket(AF_INET, SOCK_STREAM, 0);
+	assert(sock != -1);
+
+	bzero(&server_addr, sizeof(server_addr));
+	server_addr.sin_family = AF_INET;
+	server_addr.sin_port = htons(atoi(argv[2]));
+
+	assert( inet_aton(argv[1], (struct in_addr*)&server_addr.sin_addr.s_addr) != 0 );
+
+	addrlen = sizeof(server_addr);
+
+	//fd = open(argv[3],O_RDONLY,0666); 
+	//assert(fd != -1);
+
+	assert(connect(sock,(struct sockaddr *)&server_addr, addrlen) != -1);
+
+	while(1) {
+		
+		ssize_t mbytes, nbytes;
+
+		nbytes=read(0,buff,MAXBUFF);
+
+		if (nbytes==-1) {
+			perror("read");
+			exit(1);
+		}
+		if (nbytes==0) {
+			break;
+		}
+
+		mbytes = write(sock,buff,nbytes);
+		if (mbytes == -1) {
+			perror("write");
+			exit(1);
+		}
+nbytes=read(sock,buff,MAXBUFF);
+write(1,buff,nbytes);
+
+		z=z+mbytes;
+	}
+
+	printf("file %s sent (%d bytes)",argv[3],z);
+
+	close(sock);
+	exit(0);
+}
diff --git a/td_tp/tp3/src/reseau/srv.c b/td_tp/tp3/src/reseau/srv.c
new file mode 100644
index 0000000..37c0bab
--- /dev/null
+++ b/td_tp/tp3/src/reseau/srv.c
@@ -0,0 +1,113 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <sys/socket.h>
+#include <resolv.h>
+#include <arpa/inet.h>
+#include <string.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <sys/time.h>
+#include <sys/wait.h>
+#include <assert.h>
+#define MAXBUFF 4096
+
+int handle_transferred_file(int sock,struct sockaddr_in * client_addr)
+{
+	char bufname[256];
+
+	char buff[MAXBUFF];
+	int fd;
+	ssize_t nbytes,z;
+
+	char addr[INET_ADDRSTRLEN];
+	snprintf(bufname,256,"%s.%d",inet_ntoa(client_addr->sin_addr),ntohs(client_addr->sin_port));
+	fd = open(bufname,O_WRONLY|O_CREAT|O_TRUNC,0666); 
+	if (fd == -1) {
+		perror("open");
+		exit(1);
+	}
+
+	while (1) {
+		//bzero(buff,MAXBUFF);
+		nbytes = read(sock,buff,MAXBUFF);
+		if (nbytes == -1) {
+			perror("read");
+			exit(1);
+		}
+		if (nbytes==0) break;
+
+		write(fd,buff,nbytes);
+		z=z+nbytes;
+	}
+
+	inet_ntop(AF_INET,&(client_addr->sin_addr.s_addr),addr,INET_ADDRSTRLEN);
+	printf("%d bytes recieved from %s\n", z, addr);
+	shutdown(sock,SHUT_RDWR);
+	close(sock);
+
+	exit(0);
+
+}
+
+int main(int argc, char * argv[]) 
+{
+	int 				/* file descriptor for the tranferred file */ 
+		listen_sock,    /* socket for listenning connection */
+		service_sock,   /* socket for a connected client */
+		nbytes, z=0;
+	int yes=1;
+
+	struct sockaddr_in server_addr, 
+					   client_addr;
+
+	int addr_len; 
+
+	struct sigaction sa;
+
+	if (argc != 2) {
+		printf("Usage: %s <port number>\n",argv[0]);
+		exit(1);
+	}
+
+	sigemptyset(&sa.sa_mask);
+	sa.sa_flags = SA_NOCLDWAIT;
+	sa.sa_handler = SIG_DFL;
+	assert (sigaction(SIGCHLD, &sa, NULL) != -1);
+
+
+
+	listen_sock = socket(AF_INET, SOCK_STREAM, 0);
+	assert( listen_sock > 0);
+
+	assert (setsockopt(listen_sock, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(int)) != -1);
+
+
+
+	bzero(&server_addr, sizeof(server_addr));
+	server_addr.sin_family = AF_INET;
+	server_addr.sin_port = htons(atoi(argv[1]));
+	server_addr.sin_addr.s_addr = INADDR_ANY;
+	addr_len = sizeof(server_addr);
+
+	assert(bind(listen_sock, (struct sockaddr *)&server_addr, sizeof(struct sockaddr)) != -1);
+
+	assert(listen(listen_sock,10) == 0);
+
+
+
+	while(1){
+
+		service_sock = accept(listen_sock,
+				(struct sockaddr *)&client_addr , 
+				&addr_len);
+
+		assert(service_sock >= 0);
+
+		pid_t p = fork();
+		if (p==0){
+			close(listen_sock);
+			handle_transferred_file(service_sock,&client_addr);
+		}
+	}
+}
diff --git a/td_tp/tp3/src/reseau/srv_echo.c b/td_tp/tp3/src/reseau/srv_echo.c
new file mode 100644
index 0000000..4085576
--- /dev/null
+++ b/td_tp/tp3/src/reseau/srv_echo.c
@@ -0,0 +1,113 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <sys/socket.h>
+#include <resolv.h>
+#include <arpa/inet.h>
+#include <string.h>
+#include <fcntl.h>
+#include <errno.h>
+#include <sys/time.h>
+#include <sys/wait.h>
+#include <assert.h>
+#define MAXBUFF 4096
+
+int handle_transferred_file(int sock,struct sockaddr_in * client_addr)
+{
+	char bufname[256];
+
+	char buff[MAXBUFF];
+	int fd;
+	ssize_t nbytes,z;
+
+	char addr[INET_ADDRSTRLEN];
+	snprintf(bufname,256,"%s.%d",inet_ntoa(client_addr->sin_addr),ntohs(client_addr->sin_port));
+	//fd = open(bufname,O_WRONLY|O_CREAT|O_TRUNC,0666); 
+	//if (fd == -1) {
+	//	perror("open");
+	//	exit(1);
+	//}
+
+	while (1) {
+		//bzero(buff,MAXBUFF);
+		nbytes = read(sock,buff,MAXBUFF);
+		if (nbytes == -1) {
+			perror("read");
+			exit(1);
+		}
+		if (nbytes==0) break;
+
+		write(sock,buff,nbytes);
+		z=z+nbytes;
+	}
+
+	inet_ntop(AF_INET,&(client_addr->sin_addr.s_addr),addr,INET_ADDRSTRLEN);
+	printf("%d bytes recieved from %s\n", z, addr);
+	shutdown(sock,SHUT_RDWR);
+	close(sock);
+
+	exit(0);
+
+}
+
+int main(int argc, char * argv[]) 
+{
+	int 				/* file descriptor for the tranferred file */ 
+		listen_sock,    /* socket for listenning connection */
+		service_sock,   /* socket for a connected client */
+		nbytes, z=0;
+	int yes=1;
+
+	struct sockaddr_in server_addr, 
+					   client_addr;
+
+	int addr_len; 
+
+	struct sigaction sa;
+
+	if (argc != 2) {
+		printf("Usage: %s <port number>\n",argv[0]);
+		exit(1);
+	}
+
+	sigemptyset(&sa.sa_mask);
+	sa.sa_flags = SA_NOCLDWAIT;
+	sa.sa_handler = SIG_DFL;
+	assert (sigaction(SIGCHLD, &sa, NULL) != -1);
+
+
+
+	listen_sock = socket(AF_INET, SOCK_STREAM, 0);
+	assert( listen_sock > 0);
+
+	assert (setsockopt(listen_sock, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(int)) != -1);
+
+
+
+	bzero(&server_addr, sizeof(server_addr));
+	server_addr.sin_family = AF_INET;
+	server_addr.sin_port = htons(atoi(argv[1]));
+	server_addr.sin_addr.s_addr = INADDR_ANY;
+	addr_len = sizeof(server_addr);
+
+	assert(bind(listen_sock, (struct sockaddr *)&server_addr, sizeof(struct sockaddr)) != -1);
+
+	assert(listen(listen_sock,10) == 0);
+
+
+
+	while(1){
+
+		service_sock = accept(listen_sock,
+				(struct sockaddr *)&client_addr , 
+				&addr_len);
+
+		assert(service_sock >= 0);
+
+		pid_t p = fork();
+		if (p==0){
+			close(listen_sock);
+			handle_transferred_file(service_sock,&client_addr);
+		}
+	}
+}
diff --git a/td_tp/tp3/src/test_df.c b/td_tp/tp3/src/test_df.c
new file mode 100644
index 0000000..7567950
--- /dev/null
+++ b/td_tp/tp3/src/test_df.c
@@ -0,0 +1,59 @@
+#include "df.h"
+#include "./lib_tea/tea.h"
+
+#include <stdio.h>
+#include <assert.h>
+#include <stdlib.h>
+#include <time.h>
+#include <unistd.h>
+#include <string.h>
+#include <stdint.h>
+
+int main(int argc, char *argv[])
+{
+	uint64 p = 4611686018427402023,
+		   a,b,
+		   A,B,AB,BA,
+		   g;
+
+	uint32_t k[4]; // for tea
+				   //
+
+
+
+	g=generateur(p);
+	srand(getpid()^time(NULL));
+
+	for (int i = 0;i < 2; i++){
+
+		a = 2 + rand()%(p-3);
+		A=expm(g,a,p);
+
+		b = 2 + rand()%(p-3);
+		B = expm(g,b,p);
+
+
+		AB = expm(A,b,p);
+
+		BA = expm(B,a,p);
+		//printf("%lx %lx %lx %lx %lx %lx\n",a,b,A,B,AB,BA);
+		assert(AB == BA);
+
+		memcpy((void*)(k+2*i),(void*)&AB,sizeof(uint32_t)*2);
+	}
+
+	printf("key for tea = (%x,%x,%x,%x)\n",k[0],k[1],k[2],k[3]);
+
+
+
+	while(1){
+		uint32_t  v[2]={0};
+		ssize_t nb_read = read(0,v,sizeof(v));
+		if (nb_read <= 0)
+			break;
+		encrypt_tea(v,k);
+		decrypt_tea(v,k);
+		write(1,v,sizeof(v));
+	}
+	return 0;
+}