2017-07-03 2 views
1

J'ai essayé de faire un serveur 3 ou 4 tcp sur mon STM32F107. J'utilise freeRTOS et LwIP (et la bibliothèque CubeMX + ST HAL).STM32 Serveur TCP multiple LwiP

Je crée une tâche tcp_server, et dans la tâche, je crée 3 structures netconn chacune avec un port tcp différent. Callback:

void socket_callback(struct netconn * conn, enum netconn_evt evt, u16_t len) 
{ 
    queue_event_t msg; 
    if (evt == NETCONN_EVT_RCVPLUS) 
    { 
      msg.cmd = MSG_TEST; 
      if (conn == user_conn.conn_modbus) 
       msg.cmd = MSG_MODBUS; 
      else if (conn == user_conn.conn_modbus_listen) 
       msg.cmd = MSG_MODBUS_LISTEN; 
      else if (conn == user_conn.conn_rs232) 
       msg.cmd = MSG_RS232; 
      else if (conn == user_conn.conn_rs232_listen) 
       msg.cmd = MSG_RS232_LISTEN; 
      else if (conn == user_conn.conn_rs485) 
       msg.cmd = MSG_RS485; 
      else if (conn == user_conn.conn_rs485_listen) 
       msg.cmd = MSG_RS485_LISTEN; 
      xQueueSend(user_conn.evtQueue, &msg, 1000); 
    } 
} 

création de serveur:

static struct netconn * createServer(int port) 
{ 
    struct netconn * conn; 
    err_t err; 

    conn = netconn_new_with_callback(NETCONN_TCP, socket_callback); 
    if (conn == NULL) 
    { 
      char *msg = "Cannot create netconn\n\r"; 
      HAL_UART_Transmit(&huart3, (uint8_t*)msg, strlen(msg), 0xFFFF); 
      return NULL; 
    } 

    err = netconn_bind(conn, NULL, port); 
    if (err != ERR_OK) 
    { 
     char *msg = "Error in Binding \n\r"; 
     HAL_UART_Transmit(&huart3, (uint8_t*)msg, strlen(msg), 0xFFFF); 
     print_error(err); 
     netconn_delete(conn); 
     return NULL; 
    } 
    err = netconn_listen(conn); 
    if (err != ERR_OK) 
    { 
     char *msg = "Error in listenning \n\r"; 
     HAL_UART_Transmit(&huart3, (uint8_t*)msg, strlen(msg), 0xFFFF); 
     print_error(err); 
     netconn_delete(conn); 
     return NULL; 
    } 
    return conn; 
} 

Discussion:

static void servertcp_thread() 
{ 
    queue_event_t evt; 
    user_conn.evtQueue = xQueueCreate(10, sizeof (queue_event_t)); 
    user_conn.conn_modbus_listen = createServer(502); 
    user_conn.conn_rs232_listen = createServer(10001); 
    user_conn.conn_rs485_listen = createServer(50001); 

    while(1) 
    { 
     waitServer(&user_conn, &evt); 
     send_rs232(&user_conn); 
     send_rs485(&user_conn); 
     if((user_conn.conn_modbus_listen != NULL) && (evt.cmd == MSG_MODBUS_LISTEN)) 
      processModbusListen(&user_conn); 
     if((user_conn.conn_rs232_listen != NULL) && (evt.cmd == MSG_RS232_LISTEN)) 
      processRS232Listen(&user_conn); 
     if((user_conn.conn_rs485_listen != NULL) && (evt.cmd == MSG_RS485_LISTEN)) 
      processRS485Listen(&user_conn); 
     if((user_conn.conn_modbus != NULL) && (evt.cmd == MSG_MODBUS)) 
      modbus_tcp_server(&user_conn); 
     if((user_conn.conn_rs232 != NULL) && (evt.cmd == MSG_RS232)) 
      rs232_tcp_server(&user_conn); 
     if((user_conn.conn_rs485 != NULL) && (evt.cmd == MSG_RS485)) 
      rs485_tcp_server(&user_conn); 
    } 
} 

La création est réussie (netconn_new_with_callback/netconn_bind et netconn_listen sans erreur).

Lorsque j'ai essayé de me connecter à 1 port TCP, il est accepté et tout va bien.

Mais quand j'ai essayé de me connecter à un second port alors que la première connexion est encore en vie, le callback est appelé, mais le netconn_accept (conn, & newconn); Échec et signaler ERR_ABRT et je ne sais pas pourquoi.

La fonction 3 (processModbusListen, processRS232Listen et processRS485Listen) sont codés selon le même prototype:

static int processXXXListen(user_conn_t * user_data) 
{ 
    struct netconn *newconn; 
    err_t error_accept; 
    error_accept = netconn_accept(user_data->conn_XXX_listen, &newconn); 
    if (error_accept == ERR_OK) 
    { 
     if (user_data->conn_rs485) 
     { 
      // Close unwanted connection 
      netconn_close(newconn); 
      netconn_delete(newconn); 
      char *msg = "Error XXX Connection during establishement\n\r"; 
      HAL_UART_Transmit(&huart3, (uint8_t*)msg, strlen(msg), 0xFFFF); 
     } 
     else 
     { 
      // connection established 
      char *msg = "XXX Connection established\n\r"; 
      HAL_UART_Transmit(&huart3, (uint8_t*)msg, strlen(msg), 0xFFFF); 
      user_data->conn_XXX = newconn; 
     } 
    } 
    else 
    { 
     char *msg = "Error in acceptation TCP XXX connection\n\r"; 
     HAL_UART_Transmit(&huart3, (uint8_t*)msg, strlen(msg), 0xFFFF); 
     print_error(error_accept); 
    } 
    return 0; 
} 

La chose étrange est que lorsque je crée seulement 2 la structure netconn, je n'ai aucun problème avec la connexion 2 dans le même temps.

Quelle est la cause de l'interruption de la connexion? Comment puis-je obtenir la connexion 3 en même temps? Si il est possible bien sûr ...

+1

J'ai trouvé le problème ... c'était le #define MEMP_NUM_NETCONN 10 par défaut, il était réglé sur 4. Mais ce param était caché dans param ... – Bobnono

+0

Vous devriez poster votre commentaire comme réponse si vous êtes sûr que c'est la bonne réponse. –

Répondre

0

Ok, oui après 1 jour de l'essai, le param

#define MEMP_NUM_NETCONN 4 

est definetly ce qui me fait Troubl. je dois juste le mettre à 10, et tout fonctionne comme un charme