Keyboard firmwares for Atmel AVR and Cortex-M
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

uip-split.h 3.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /*
  2. * Copyright (c) 2004, Swedish Institute of Computer Science.
  3. * All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the Institute nor the names of its contributors
  14. * may be used to endorse or promote products derived from this software
  15. * without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
  18. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  20. * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
  21. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  22. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  23. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  24. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  25. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  26. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  27. * SUCH DAMAGE.
  28. *
  29. * This file is part of the Contiki operating system.
  30. *
  31. * Author: Adam Dunkels <[email protected]>
  32. *
  33. * $Id: uip-split.h,v 1.1 2006/06/17 22:41:19 adamdunkels Exp $
  34. */
  35. /**
  36. * \addtogroup uip
  37. * @{
  38. */
  39. /**
  40. * \defgroup uipsplit uIP TCP throughput booster hack
  41. * @{
  42. *
  43. * The basic uIP TCP implementation only allows each TCP connection to
  44. * have a single TCP segment in flight at any given time. Because of
  45. * the delayed ACK algorithm employed by most TCP receivers, uIP's
  46. * limit on the amount of in-flight TCP segments seriously reduces the
  47. * maximum achievable throughput for sending data from uIP.
  48. *
  49. * The uip-split module is a hack which tries to remedy this
  50. * situation. By splitting maximum sized outgoing TCP segments into
  51. * two, the delayed ACK algorithm is not invoked at TCP
  52. * receivers. This improves the throughput when sending data from uIP
  53. * by orders of magnitude.
  54. *
  55. * The uip-split module uses the uip-fw module (uIP IP packet
  56. * forwarding) for sending packets. Therefore, the uip-fw module must
  57. * be set up with the appropriate network interfaces for this module
  58. * to work.
  59. */
  60. /**
  61. * \file
  62. * Module for splitting outbound TCP segments in two to avoid the
  63. * delayed ACK throughput degradation.
  64. * \author
  65. * Adam Dunkels <[email protected]>
  66. *
  67. */
  68. #ifndef __UIP_SPLIT_H__
  69. #define __UIP_SPLIT_H__
  70. #include <string.h>
  71. #include <uip.h>
  72. #include "../../USBHostMode.h"
  73. #include <LUFA/Drivers/USB/USB.h>
  74. /**
  75. * Handle outgoing packets.
  76. *
  77. * This function inspects an outgoing packet in the uip_buf buffer and
  78. * sends it out using the uip_fw_output() function. If the packet is a
  79. * full-sized TCP segment it will be split into two segments and
  80. * transmitted separately. This function should be called instead of
  81. * the actual device driver output function, or the uip_fw_output()
  82. * function.
  83. *
  84. * The headers of the outgoing packet is assumed to be in the uip_buf
  85. * buffer and the payload is assumed to be wherever uip_appdata
  86. * points. The length of the outgoing packet is assumed to be in the
  87. * uip_len variable.
  88. *
  89. */
  90. void uip_split_output(void);
  91. void uip_add32(u8_t *op32, u16_t op16);
  92. #endif /* __UIP_SPLIT_H__ */
  93. /** @} */
  94. /** @} */