Diff for /mqtt/src/mqtt_ping.c between versions 1.1.2.3 and 1.1.2.7

version 1.1.2.3, 2012/04/26 09:15:26 version 1.1.2.7, 2012/05/27 10:04:05
Line 36  cleanArgs(struct tagArgs * __restrict args) Line 36  cleanArgs(struct tagArgs * __restrict args)
 }  }
   
 static int  static int
Ping(int sock, int num)Ping(int sock, int num, struct timeval * __restrict accu)
 {  {
        int siz = 0;        struct timeval before, after, calc;
        struct timeval before, after; 
         ait_val_t val;          ait_val_t val;
         struct mqtthdr *hdr;  
   
         gettimeofday(&before, NULL);          gettimeofday(&before, NULL);
   
        siz = mqtt_msgPINGREQ(args->msg);        if (mqtt_KeepAlive(args->cli->sock, args->ka, 1) == -1)
        if (siz == -1) { 
                printf("Error:: msgPINGREQ #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); 
                 return -1;                  return -1;
         }  
         if (SendTo(sock, siz) == -1)  
                 return -1;  
   
 reply:  
         if ((siz = RecvFrom(sock)) == -1 || !siz)  
                 return -1;  
         else  
                 hdr = (struct mqtthdr*) args->msg->msg_base;  
         if (hdr->mqtt_msg.type == MQTT_TYPE_PINGREQ) {  
                 siz = mqtt_msgPINGRESP(args->msg);  
                 if (siz == -1) {  
                         printf("Error:: msgPINGRESP #%d - %s\n", mqtt_GetErrno(), mqtt_GetError());  
                         return -1;  
                 }  
                 if (SendTo(sock, siz) == -1)  
                         return -1;  
   
                 goto reply;  
         } else {  
                 siz = mqtt_readPINGRESP(args->msg);  
                 if (siz == -1) {  
                         printf("Error:: readPINGRESP #%d - %s\n", mqtt_GetErrno(), mqtt_GetError());  
                         return -1;  
                 }  
         }  
   
         gettimeofday(&after, NULL);          gettimeofday(&after, NULL);
   
           timersub(&after, &before, &calc);
           timeradd(accu, &calc, accu);
   
         printf(" + Ping %d MQTT broker %s ... %f sec.\n", num, io_n2addr(&args->addr, &val),           printf(" + Ping %d MQTT broker %s ... %f sec.\n", num, io_n2addr(&args->addr, &val), 
                        ((after.tv_sec - before.tv_sec) + (after.tv_usec - before.tv_usec) / 1.e6));                        calc.tv_sec + calc.tv_usec / 1.e6);
         AIT_FREE_VAL(&val);          AIT_FREE_VAL(&val);
   
         return 0;          return 0;
Line 92  main(int argc, char **argv) Line 65  main(int argc, char **argv)
         char ch;          char ch;
         ait_val_t val;          ait_val_t val;
         u_short port = atoi(MQTT_PORT);          u_short port = atoi(MQTT_PORT);
        int sock, num = 1, ret = 0, lost = 0;        int num = 1, ret = 0, lost = 0;
         register int i;          register int i;
           struct timeval accu;
   
        if (!(args = malloc(sizeof(struct tagArgs)))) {        if (!(args = io_malloc(sizeof(struct tagArgs)))) {
                 printf("Error:: in alloc arguments #%d - %s\n", errno, strerror(errno));                  printf("Error:: in alloc arguments #%d - %s\n", errno, strerror(errno));
                 return 1;                  return 1;
         } else          } else
Line 105  main(int argc, char **argv) Line 79  main(int argc, char **argv)
         if (!(args->msg = mqtt_msgAlloc(USHRT_MAX))) {          if (!(args->msg = mqtt_msgAlloc(USHRT_MAX))) {
                 printf("Error:: in mqtt buffer #%d - %s\n", mqtt_GetErrno(), mqtt_GetError());                  printf("Error:: in mqtt buffer #%d - %s\n", mqtt_GetErrno(), mqtt_GetError());
                 args->free(args);                  args->free(args);
                free(args);                io_free(args);
                 return 1;                  return 1;
         }          }
   
Line 118  main(int argc, char **argv) Line 92  main(int argc, char **argv)
                 switch (ch) {                  switch (ch) {
                         case 'c':                          case 'c':
                                 num = (int) strtol(optarg, NULL, 0);                                  num = (int) strtol(optarg, NULL, 0);
                                   break;
                         case 'T':                          case 'T':
                                 args->ka = (u_short) strtol(optarg, NULL, 0);                                  args->ka = (u_short) strtol(optarg, NULL, 0);
                                 break;                                  break;
Line 138  main(int argc, char **argv) Line 113  main(int argc, char **argv)
                         case 'h':                          case 'h':
                         default:                          default:
                                 args->free(args);                                  args->free(args);
                                free(args);                                io_free(args);
                                 Usage();                                  Usage();
                                 return 1;                                  return 1;
                 }                  }
Line 147  main(int argc, char **argv) Line 122  main(int argc, char **argv)
         if (argc < 2) {          if (argc < 2) {
                 printf("Error:: host for connect not found or connection id!\n\n");                  printf("Error:: host for connect not found or connection id!\n\n");
                 args->free(args);                  args->free(args);
                free(args);                io_free(args);
                 Usage();                  Usage();
                 return 1;                  return 1;
         } else {          } else {
Line 157  main(int argc, char **argv) Line 132  main(int argc, char **argv)
         if (!io_gethostbyname(*argv, port, &args->addr)) {          if (!io_gethostbyname(*argv, port, &args->addr)) {
                 printf("Error:: host not valid #%d - %s\n", io_GetErrno(), io_GetError());                  printf("Error:: host not valid #%d - %s\n", io_GetErrno(), io_GetError());
                 args->free(args);                  args->free(args);
                free(args);                io_free(args);
                 Usage();                  Usage();
                 return 1;                  return 1;
         }          }
         printf("Connecting to %s:%d ... ", io_n2addr(&args->addr, &val), io_n2port(&args->addr));          printf("Connecting to %s:%d ... ", io_n2addr(&args->addr, &val), io_n2port(&args->addr));
         AIT_FREE_VAL(&val);          AIT_FREE_VAL(&val);
   
        if ((sock = InitClient()) == -1) {        if (!(args->cli = mqtt_cli_Open(&args->addr.sa, args->ka))) {
                 args->free(args);                  args->free(args);
                free(args);                io_free(args);
                 return 2;                  return 2;
         }          }
   
        switch ((ret = ConnectClient(sock))) {        switch ((ret = ConnectClient(args->cli->sock))) {
                 case -1:                  case -1:
                         printf(">> FAILED!\n");                          printf(">> FAILED!\n");
                         break;                          break;
Line 194  main(int argc, char **argv) Line 169  main(int argc, char **argv)
                         break;                          break;
         }          }
   
           timerclear(&accu);
         if (ret == MQTT_RETCODE_ACCEPTED) {          if (ret == MQTT_RETCODE_ACCEPTED) {
                 for (i = 0; i < num; i++)                  for (i = 0; i < num; i++)
                        if ((ret = Ping(sock, i))) {                        if ((ret = Ping(args->cli->sock, i, &accu))) {
                                 ret = 3;                                  ret = 3;
                                 lost++;                                  lost++;
                         }                          }
                CloseClient(sock);                printf("\nMQTT ping sended %d requests with %d lost responses and avarage %f sec.\n", 
                                num, lost, (accu.tv_sec + accu.tv_usec / 1.e6) / (num - lost));
                printf("\nMQTT ping sended %d requests with %d lost responses\n", num, lost);        } else
        } else { 
                close(sock); 
                 ret = 4;                  ret = 4;
         }  
   
           mqtt_cli_Close(&args->cli);
   
         args->free(args);          args->free(args);
        free(args);        io_free(args);
         return ret;          return ret;
 }  }

Removed from v.1.1.2.3  
changed lines
  Added in v.1.1.2.7


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>