FreeRTOS_TCP_IP.h 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * FreeRTOS+TCP V2.3.2 LTS Patch 1
  3. * Copyright (C) 2020 Amazon.com, Inc. or its affiliates. All Rights Reserved.
  4. *
  5. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  6. * this software and associated documentation files (the "Software"), to deal in
  7. * the Software without restriction, including without limitation the rights to
  8. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  9. * the Software, and to permit persons to whom the Software is furnished to do so,
  10. * subject to the following conditions:
  11. *
  12. * The above copyright notice and this permission notice shall be included in all
  13. * copies or substantial portions of the Software.
  14. *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  17. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  18. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  19. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  20. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  21. *
  22. * http://aws.amazon.com/freertos
  23. * http://www.FreeRTOS.org
  24. */
  25. #ifndef FREERTOS_TCP_IP_H
  26. #define FREERTOS_TCP_IP_H
  27. #ifdef __cplusplus
  28. extern "C" {
  29. #endif
  30. BaseType_t xProcessReceivedTCPPacket( NetworkBufferDescriptor_t * pxDescriptor );
  31. typedef enum eTCP_STATE
  32. {
  33. /* Comments about the TCP states are borrowed from the very useful
  34. * Wiki page:
  35. * http://en.wikipedia.org/wiki/Transmission_Control_Protocol */
  36. eCLOSED = 0U, /* 0 (server + client) no connection state at all. */
  37. eTCP_LISTEN, /* 1 (server) waiting for a connection request
  38. * from any remote TCP and port. */
  39. eCONNECT_SYN, /* 2 (client) internal state: socket wants to send
  40. * a connect */
  41. eSYN_FIRST, /* 3 (server) Just created, must ACK the SYN request. */
  42. eSYN_RECEIVED, /* 4 (server) waiting for a confirming connection request
  43. * acknowledgement after having both received and sent a connection request. */
  44. eESTABLISHED, /* 5 (server + client) an open connection, data received can be
  45. * delivered to the user. The normal state for the data transfer phase of the connection. */
  46. eFIN_WAIT_1, /* 6 (server + client) waiting for a connection termination request from the remote TCP,
  47. * or an acknowledgement of the connection termination request previously sent. */
  48. eFIN_WAIT_2, /* 7 (server + client) waiting for a connection termination request from the remote TCP. */
  49. eCLOSE_WAIT, /* 8 (server + client) waiting for a connection termination request from the local user. */
  50. eCLOSING, /* 9 (server + client) waiting for a connection termination request acknowledgement from the remote TCP. */
  51. eLAST_ACK, /*10 (server + client) waiting for an acknowledgement of the connection termination request
  52. * previously sent to the remote TCP
  53. * (which includes an acknowledgement of its connection termination request). */
  54. eTIME_WAIT, /*11 (either server or client) waiting for enough time to pass to be sure the remote TCP received the
  55. * acknowledgement of its connection termination request. [According to RFC 793 a connection can
  56. * stay in TIME-WAIT for a maximum of four minutes known as a MSL (maximum segment lifetime).] */
  57. } eIPTCPState_t;
  58. #ifdef __cplusplus
  59. } /* extern "C" */
  60. #endif
  61. #endif /* FREERTOS_TCP_IP_H */