Merge branch 'Gwen'

This commit is contained in:
Newglear 2022-04-11 09:15:48 +02:00
commit 12632a6626

View file

@ -3,7 +3,8 @@
#include <mictcp.h> #include <mictcp.h>
#include <api/mictcp_core.h> #include <api/mictcp_core.h>
#define TIMEOUT 10 #define TIMEOUT 100
#define SIZE 1000
/* /*
* Permet de créer un socket entre lapplication et MIC-TCP * Permet de créer un socket entre lapplication et MIC-TCP
@ -13,10 +14,22 @@
mic_tcp_pdu pdu; mic_tcp_pdu pdu;
int PE,PA = 0; int PE,PA = 0;
float lostpdu = 0.0; float lostpdu = 0.0;
float lostrate = 0.0; float lostrate = 15.0;
float pduemis =0.0; float pduemis =0.0;
mic_tcp_pdu ack; int fenetre[SIZE];
void init (int* tab,int size){
for(int i=0;i<size;i++){
tab[i]=0;
}
}
float rate(int* tab, int size){
int s =0;
for(int i=0; i<size;i++){
s += tab[i];
}
return (float)((s/SIZE)*100);
}
pthread_mutex_t mutex= PTHREAD_MUTEX_INITIALIZER; pthread_mutex_t mutex= PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond= PTHREAD_COND_INITIALIZER; pthread_cond_t cond= PTHREAD_COND_INITIALIZER;
@ -73,33 +86,29 @@ int mic_tcp_connect(int socket, mic_tcp_sock_addr addr)
//Encpsulation SYN //Encpsulation SYN
/* /*
mic_tcp_pdu pdusyn; mic_tcp_pdu pdusyn;
mic_tcp_pdu ack;
int sent= -1; int sent= -1;
int max = 20; int max = 20;
int count = 0; int count = 0;
int test=0; int test=0;
//syn.header.dest_port= ;
pdusyn.header.seq_num = PE; // Création du header et setup PA et PE pdusyn.header.seq_num = PE; // Création du header et setup PA et PE
pdusyn.header.ack_num = PA; pdusyn.header.ack_num = PA;
pdusyn.header.syn= 1; pdusyn.header.syn= 1;
pdusyn.header.ack=0; pdusyn.header.ack=0;
pdusyn.header.fin=0; pdusyn.header.fin=0;
//int lr = (int)lostrate;
//itoa(lostrate,pdu.payload.data,10); //Encapsulation du payload vide
char jpp[] = ""; char jpp[] = "";
memcpy(&(pdu.payload.data),&jpp,sizeof(jpp)); memcpy(&(pdu.payload.data),&jpp,sizeof(jpp));
pdusyn.payload.size = 0; pdusyn.payload.size = 0;
pdu.header.ack = 0; pdu.header.ack = 0;
pdu.header.syn = 0; pdu.header.syn = 0;
printf("Test1\n");
while(pdu.header.syn != 1 && pdu.header.ack !=1){ while(pdu.header.syn != 1 && pdu.header.ack !=1){
count = 0;
if(count == max){return(-1);} if(count == max){return(-1);}
if (count != 0) if (count != 0)
printf("Paquet message perdu \n"); printf("Paquet message perdu \n");
@ -108,9 +117,9 @@ int mic_tcp_connect(int socket, mic_tcp_sock_addr addr)
printf("Erreur d'envoi du pdu\n"); printf("Erreur d'envoi du pdu\n");
exit(1); exit(1);
} }
test=(IP_recv(&pdu,&sock.addr,TIMEOUT) ==-1); test=(IP_recv(&pdu,&sock.addr,TIMEOUT) ==-1);
while(count < max && test){ while(count < max && test){
count++; count++;
if(count == max){return(-1);} if(count == max){return(-1);}
@ -124,7 +133,15 @@ int mic_tcp_connect(int socket, mic_tcp_sock_addr addr)
if(count == max) if(count == max)
exit(-1); exit(-1);
} }
printf("Test2\n");
ack.header.ack = 1; ack.header.ack = 1;
ack.header.ack_num= PA;
ack.header.seq_num=PE;
ack.header.syn=0;
ack.header.fin=0;
ack.payload.data="";
ack.payload.size=0;
if(IP_send(ack,sock.addr)==-1){ if(IP_send(ack,sock.addr)==-1){
printf("Erreur d'envoi du pdu"); printf("Erreur d'envoi du pdu");
@ -141,13 +158,14 @@ int mic_tcp_connect(int socket, mic_tcp_sock_addr addr)
*/ */
int mic_tcp_send (int mic_sock, char* mesg, int mesg_size) int mic_tcp_send (int mic_sock, char* mesg, int mesg_size)
{ {
printf("[MIC-TCP] Appel de la fonction: "); printf(__FUNCTION__); printf("\n");
int sent= -1; int sent= -1;
if(sock.state==CONNECTED){
int max = 20; int max = 20;
int count = 0; int count = 0;
int test; int test;
printf("[MIC-TCP] Appel de la fonction: "); printf(__FUNCTION__); printf("\n");
pdu.header.syn = 0; pdu.header.syn = 0;
pdu.header.ack = 0; pdu.header.ack = 0;
pdu.header.fin = 0; pdu.header.fin = 0;
@ -157,7 +175,7 @@ int mic_tcp_send (int mic_sock, char* mesg, int mesg_size)
pdu.payload.size=mesg_size; pdu.payload.size=mesg_size;
mic_tcp_pdu mem = pdu; mic_tcp_pdu mem = pdu;
//printf("%d\n",pdu.header.seq_num); printf("%d\n",pdu.header.seq_num);
if((sent=IP_send(pdu,sock.addr))==-1){ if((sent=IP_send(pdu,sock.addr))==-1){
printf("Erreur d'envoi du pdu"); printf("Erreur d'envoi du pdu");
exit(1); exit(1);
@ -167,14 +185,6 @@ int mic_tcp_send (int mic_sock, char* mesg, int mesg_size)
pduemis++; pduemis++;
test = (IP_recv(&pdu,&sock.addr,TIMEOUT) ==-1); test = (IP_recv(&pdu,&sock.addr,TIMEOUT) ==-1);
if(pdu.header.ack ==1 ){
if(IP_send(ack,sock.addr)==-1){
printf("Erreur d'envoi du pdu");
exit(1);
}
}
if (test){ if (test){
lostpdu++; lostpdu++;
printf("Lost Pdu : %f\n",lostpdu); printf("Lost Pdu : %f\n",lostpdu);
@ -218,6 +228,8 @@ int mic_tcp_send (int mic_sock, char* mesg, int mesg_size)
exit(-1); exit(-1);
} }
} }
}
return sent; return sent;
} }
@ -258,8 +270,9 @@ int mic_tcp_close (int socket)
void process_received_PDU(mic_tcp_pdu pdu, mic_tcp_sock_addr addr) void process_received_PDU(mic_tcp_pdu pdu, mic_tcp_sock_addr addr)
{ {
printf("[MIC-TCP] Appel de la fonction: "); printf(__FUNCTION__); printf("\n"); printf("[MIC-TCP] Appel de la fonction: "); printf(__FUNCTION__); printf("\n");
if (sock.state == CONNECTED){
printf("Paquet recu \n"); printf("Paquet recu \n");
printf("ACK NUM %d\n",pdu.header.seq_num); printf("ACK NUM %d\n",pdu.header.ack);
mic_tcp_pdu ack; mic_tcp_pdu ack;
if(pdu.header.seq_num == PA){ if(pdu.header.seq_num == PA){
@ -268,6 +281,20 @@ void process_received_PDU(mic_tcp_pdu pdu, mic_tcp_sock_addr addr)
}else{ }else{
printf("Paquet Ack perdu\n"); printf("Paquet Ack perdu\n");
} }
printf("avant send\n");
ack.header.ack=1;
ack.header.ack_num=PA;
ack.payload.data="";
ack.payload.size=0;
if (IP_send(ack,addr)==-1)
{
printf("Erreur d'envoi du pdu");
exit(1);
}
printf("Ack envoyé \n");
}else{
printf("Paquet Ack perdu\n");
}
ack.header.ack=1; ack.header.ack=1;
ack.header.ack_num=PA; ack.header.ack_num=PA;
ack.payload.data =""; ack.payload.data ="";
@ -278,8 +305,7 @@ void process_received_PDU(mic_tcp_pdu pdu, mic_tcp_sock_addr addr)
printf("Erreur d'envoi du pdu"); printf("Erreur d'envoi du pdu");
exit(1); exit(1);
} }
//printf("Ack envoyé \n"); printf("Ack envoyé \n");
/*
printf("Je me connecte\n"); printf("Je me connecte\n");
int test=0; int test=0;
int sent= -1; int sent= -1;
@ -329,7 +355,7 @@ void process_received_PDU(mic_tcp_pdu pdu, mic_tcp_sock_addr addr)
} }
printf("Connected\n"); printf("Connected\n");
pthread_cond_broadcast(&cond); pthread_cond_broadcast(&cond);
sock.state = CONNECTED;*/ sock.state = CONNECTED;