PageRenderTime 78ms CodeModel.GetById 24ms RepoModel.GetById 1ms app.codeStats 0ms

/a00388_source.html

https://github.com/krackeroda/contiki-doxygen
HTML | 1774 lines | 1773 code | 0 blank | 1 comment | 0 complexity | d4e4439c57e129b760ba3668231f1ae0 MD5 | raw file
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <title>Contiki 2.5: core/net/sicslowpan.c Source File</title>
  6. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  7. <link href="doxygen.css" rel="stylesheet" type="text/css"/>
  8. </head>
  9. <body>
  10. <!-- Generated by Doxygen 1.6.1 -->
  11. <div class="navigation" id="top">
  12. <div class="tabs">
  13. <ul>
  14. <li><a href="main.html"><span>Main&nbsp;Page</span></a></li>
  15. <li><a href="pages.html"><span>Related&nbsp;Pages</span></a></li>
  16. <li><a href="modules.html"><span>Modules</span></a></li>
  17. <li><a href="annotated.html"><span>Data&nbsp;Structures</span></a></li>
  18. <li class="current"><a href="files.html"><span>Files</span></a></li>
  19. <li><a href="dirs.html"><span>Directories</span></a></li>
  20. <li><a href="examples.html"><span>Examples</span></a></li>
  21. </ul>
  22. </div>
  23. <div class="tabs">
  24. <ul>
  25. <li><a href="files.html"><span>File&nbsp;List</span></a></li>
  26. <li><a href="globals.html"><span>Globals</span></a></li>
  27. </ul>
  28. </div>
  29. <div class="navpath"><a class="el" href="dir_783dcb2b4bcfa12326370fa26c216025.html">core</a>&nbsp;&raquo&nbsp;<a class="el" href="dir_0966c75b31335e5cb5b37dbb7a80da85.html">net</a>
  30. </div>
  31. </div>
  32. <div class="contents">
  33. <h1>sicslowpan.c</h1><a href="a00388.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/**</span>
  34. <a name="l00002"></a>00002 <span class="comment"> * \addtogroup sicslowpan</span>
  35. <a name="l00003"></a>00003 <span class="comment"> * @{</span>
  36. <a name="l00004"></a>00004 <span class="comment"> */</span>
  37. <a name="l00005"></a>00005 <span class="comment">/*</span>
  38. <a name="l00006"></a>00006 <span class="comment"> * Copyright (c) 2008, Swedish Institute of Computer Science.</span>
  39. <a name="l00007"></a>00007 <span class="comment"> * All rights reserved.</span>
  40. <a name="l00008"></a>00008 <span class="comment"> *</span>
  41. <a name="l00009"></a>00009 <span class="comment"> * Redistribution and use in source and binary forms, with or without</span>
  42. <a name="l00010"></a>00010 <span class="comment"> * modification, are permitted provided that the following conditions</span>
  43. <a name="l00011"></a>00011 <span class="comment"> * are met:</span>
  44. <a name="l00012"></a>00012 <span class="comment"> * 1. Redistributions of source code must retain the above copyright</span>
  45. <a name="l00013"></a>00013 <span class="comment"> * notice, this list of conditions and the following disclaimer.</span>
  46. <a name="l00014"></a>00014 <span class="comment"> * 2. Redistributions in binary form must reproduce the above copyright</span>
  47. <a name="l00015"></a>00015 <span class="comment"> * notice, this list of conditions and the following disclaimer in the</span>
  48. <a name="l00016"></a>00016 <span class="comment"> * documentation and/or other materials provided with the distribution.</span>
  49. <a name="l00017"></a>00017 <span class="comment"> * 3. Neither the name of the Institute nor the names of its contributors</span>
  50. <a name="l00018"></a>00018 <span class="comment"> * may be used to endorse or promote products derived from this software</span>
  51. <a name="l00019"></a>00019 <span class="comment"> * without specific prior written permission.</span>
  52. <a name="l00020"></a>00020 <span class="comment"> *</span>
  53. <a name="l00021"></a>00021 <span class="comment"> * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS&apos;&apos; AND</span>
  54. <a name="l00022"></a>00022 <span class="comment"> * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE</span>
  55. <a name="l00023"></a>00023 <span class="comment"> * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE</span>
  56. <a name="l00024"></a>00024 <span class="comment"> * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE</span>
  57. <a name="l00025"></a>00025 <span class="comment"> * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL</span>
  58. <a name="l00026"></a>00026 <span class="comment"> * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS</span>
  59. <a name="l00027"></a>00027 <span class="comment"> * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)</span>
  60. <a name="l00028"></a>00028 <span class="comment"> * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT</span>
  61. <a name="l00029"></a>00029 <span class="comment"> * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY</span>
  62. <a name="l00030"></a>00030 <span class="comment"> * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF</span>
  63. <a name="l00031"></a>00031 <span class="comment"> * SUCH DAMAGE.</span>
  64. <a name="l00032"></a>00032 <span class="comment"> *</span>
  65. <a name="l00033"></a>00033 <span class="comment"> * This file is part of the Contiki operating system.</span>
  66. <a name="l00034"></a>00034 <span class="comment"> *</span>
  67. <a name="l00035"></a>00035 <span class="comment"> * $Id: sicslowpan.c,v 1.52 2011/01/04 20:22:21 joxe Exp $</span>
  68. <a name="l00036"></a>00036 <span class="comment"> */</span><span class="comment"></span>
  69. <a name="l00037"></a>00037 <span class="comment">/**</span>
  70. <a name="l00038"></a>00038 <span class="comment"> * \file</span>
  71. <a name="l00039"></a>00039 <span class="comment"> * 6lowpan implementation (RFC4944 and draft-ietf-6lowpan-hc-06)</span>
  72. <a name="l00040"></a>00040 <span class="comment"> *</span>
  73. <a name="l00041"></a>00041 <span class="comment"> * \author Adam Dunkels &lt;adam@sics.se&gt;</span>
  74. <a name="l00042"></a>00042 <span class="comment"> * \author Nicolas Tsiftes &lt;nvt@sics.se&gt;</span>
  75. <a name="l00043"></a>00043 <span class="comment"> * \author Niclas Finne &lt;nfi@sics.se&gt;</span>
  76. <a name="l00044"></a>00044 <span class="comment"> * \author Mathilde Durvy &lt;mdurvy@cisco.com&gt;</span>
  77. <a name="l00045"></a>00045 <span class="comment"> * \author Julien Abeille &lt;jabeille@cisco.com&gt;</span>
  78. <a name="l00046"></a>00046 <span class="comment"> * \author Joakim Eriksson &lt;joakime@sics.se&gt;</span>
  79. <a name="l00047"></a>00047 <span class="comment"> * \author Joel Hoglund &lt;joel@sics.se&gt;</span>
  80. <a name="l00048"></a>00048 <span class="comment"> */</span>
  81. <a name="l00049"></a>00049 <span class="comment"></span>
  82. <a name="l00050"></a>00050 <span class="comment">/**</span>
  83. <a name="l00051"></a>00051 <span class="comment"> * FOR HC-06 COMPLIANCE TODO:</span>
  84. <a name="l00052"></a>00052 <span class="comment"> * -Add compression options to UDP, currently only supports</span>
  85. <a name="l00053"></a>00053 <span class="comment"> * both ports compressed or both ports elided</span>
  86. <a name="l00054"></a>00054 <span class="comment"> * </span>
  87. <a name="l00055"></a>00055 <span class="comment"> * -Verify TC/FL compression works</span>
  88. <a name="l00056"></a>00056 <span class="comment"> * </span>
  89. <a name="l00057"></a>00057 <span class="comment"> * -Add stateless multicast option</span>
  90. <a name="l00058"></a>00058 <span class="comment"> */</span>
  91. <a name="l00059"></a>00059
  92. <a name="l00060"></a>00060 <span class="preprocessor">#include &lt;string.h&gt;</span>
  93. <a name="l00061"></a>00061
  94. <a name="l00062"></a>00062 <span class="preprocessor">#include &quot;contiki.h&quot;</span>
  95. <a name="l00063"></a>00063 <span class="preprocessor">#include &quot;dev/watchdog.h&quot;</span>
  96. <a name="l00064"></a>00064 <span class="preprocessor">#include &quot;<a class="code" href="a00395.html" title="Header for the Contiki/uIP interface.">net/tcpip.h</a>&quot;</span>
  97. <a name="l00065"></a>00065 <span class="preprocessor">#include &quot;<a class="code" href="a00424.html" title="Header file for the uIP TCP/IP stack.">net/uip.h</a>&quot;</span>
  98. <a name="l00066"></a>00066 <span class="preprocessor">#include &quot;<a class="code" href="a00404.html" title="Network interface and stateless autoconfiguration (RFC 4862).">net/uip-ds6.h</a>&quot;</span>
  99. <a name="l00067"></a>00067 <span class="preprocessor">#include &quot;<a class="code" href="a00310.html" title="Header file for the Rime stack.">net/rime.h</a>&quot;</span>
  100. <a name="l00068"></a>00068 <span class="preprocessor">#include &quot;<a class="code" href="a00389.html" title="Header file for the 6lowpan implementation (RFC4944 and draft-hui-6lowpan-hc-01)...">net/sicslowpan.h</a>&quot;</span>
  101. <a name="l00069"></a>00069 <span class="preprocessor">#include &quot;<a class="code" href="a00294.html" title="Declarations for the neighbor information module.">net/neighbor-info.h</a>&quot;</span>
  102. <a name="l00070"></a>00070 <span class="preprocessor">#include &quot;<a class="code" href="a00296.html" title="Include file for the Contiki low-layer network stack (NETSTACK).">net/netstack.h</a>&quot;</span>
  103. <a name="l00071"></a>00071
  104. <a name="l00072"></a><a class="code" href="a01680.html#gad72dbcf6d0153db1b8d8a58001feed83">00072</a> <span class="preprocessor">#define DEBUG 0</span>
  105. <a name="l00073"></a>00073 <span class="preprocessor"></span><span class="preprocessor">#if DEBUG</span>
  106. <a name="l00074"></a>00074 <span class="preprocessor"></span><span class="comment">/* PRINTFI and PRINTFO are defined for input and output to debug one without changing the timing of the other */</span>
  107. <a name="l00075"></a>00075 <a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a> p;
  108. <a name="l00076"></a>00076 <span class="preprocessor">#include &lt;stdio.h&gt;</span>
  109. <a name="l00077"></a>00077 <span class="preprocessor">#define PRINTF(...) printf(__VA_ARGS__)</span>
  110. <a name="l00078"></a>00078 <span class="preprocessor"></span><span class="preprocessor">#define PRINTFI(...) printf(__VA_ARGS__)</span>
  111. <a name="l00079"></a>00079 <span class="preprocessor"></span><span class="preprocessor">#define PRINTFO(...) printf(__VA_ARGS__)</span>
  112. <a name="l00080"></a>00080 <span class="preprocessor"></span><span class="preprocessor">#define PRINT6ADDR(addr) PRINTF(&quot; %02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x &quot;, ((u8_t *)addr)[0], ((u8_t *)addr)[1], ((u8_t *)addr)[2], ((u8_t *)addr)[3], ((u8_t *)addr)[4], ((u8_t *)addr)[5], ((u8_t *)addr)[6], ((u8_t *)addr)[7], ((u8_t *)addr)[8], ((u8_t *)addr)[9], ((u8_t *)addr)[10], ((u8_t *)addr)[11], ((u8_t *)addr)[12], ((u8_t *)addr)[13], ((u8_t *)addr)[14], ((u8_t *)addr)[15])</span>
  113. <a name="l00081"></a>00081 <span class="preprocessor"></span><span class="preprocessor">#define PRINTLLADDR(lladdr) PRINTF(&quot; %02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x &quot;,lladdr-&gt;addr[0], lladdr-&gt;addr[1], lladdr-&gt;addr[2], lladdr-&gt;addr[3],lladdr-&gt;addr[4], lladdr-&gt;addr[5],lladdr-&gt;addr[6], lladdr-&gt;addr[7])</span>
  114. <a name="l00082"></a>00082 <span class="preprocessor"></span><span class="preprocessor">#define PRINTPACKETBUF() PRINTF(&quot;RIME buffer: &quot;); for(p = 0; p &lt; packetbuf_datalen(); p++){PRINTF(&quot;%.2X&quot;, *(rime_ptr + p));} PRINTF(&quot;\n&quot;)</span>
  115. <a name="l00083"></a>00083 <span class="preprocessor"></span><span class="preprocessor">#define PRINTUIPBUF() PRINTF(&quot;UIP buffer: &quot;); for(p = 0; p &lt; uip_len; p++){PRINTF(&quot;%.2X&quot;, uip_buf[p]);}PRINTF(&quot;\n&quot;)</span>
  116. <a name="l00084"></a>00084 <span class="preprocessor"></span><span class="preprocessor">#define PRINTSICSLOWPANBUF() PRINTF(&quot;SICSLOWPAN buffer: &quot;); for(p = 0; p &lt; sicslowpan_len; p++){PRINTF(&quot;%.2X&quot;, sicslowpan_buf[p]);}PRINTF(&quot;\n&quot;)</span>
  117. <a name="l00085"></a>00085 <span class="preprocessor"></span><span class="preprocessor">#else</span>
  118. <a name="l00086"></a>00086 <span class="preprocessor"></span><span class="preprocessor">#define PRINTF(...)</span>
  119. <a name="l00087"></a>00087 <span class="preprocessor"></span><span class="preprocessor">#define PRINTFI(...)</span>
  120. <a name="l00088"></a>00088 <span class="preprocessor"></span><span class="preprocessor">#define PRINTFO(...)</span>
  121. <a name="l00089"></a>00089 <span class="preprocessor"></span><span class="preprocessor">#define PRINT6ADDR(addr)</span>
  122. <a name="l00090"></a>00090 <span class="preprocessor"></span><span class="preprocessor">#define PRINTLLADDR(lladdr)</span>
  123. <a name="l00091"></a>00091 <span class="preprocessor"></span><span class="preprocessor">#define PRINTPACKETBUF()</span>
  124. <a name="l00092"></a>00092 <span class="preprocessor"></span><span class="preprocessor">#define PRINTUIPBUF()</span>
  125. <a name="l00093"></a>00093 <span class="preprocessor"></span><span class="preprocessor">#define PRINTSICSLOWPANBUF()</span>
  126. <a name="l00094"></a>00094 <span class="preprocessor"></span><span class="preprocessor">#endif </span><span class="comment">/* DEBUG == 1*/</span>
  127. <a name="l00095"></a>00095
  128. <a name="l00096"></a>00096 <span class="preprocessor">#if UIP_LOGGING</span>
  129. <a name="l00097"></a>00097 <span class="preprocessor"></span><span class="preprocessor">#include &lt;stdio.h&gt;</span>
  130. <a name="l00098"></a>00098 <span class="keywordtype">void</span> <a class="code" href="a01589.html#gab58e1ceb7cb73ca2bcd73146b6c1b4e7" title="Print out a uIP log message.">uip_log</a>(<span class="keywordtype">char</span> *msg);
  131. <a name="l00099"></a>00099 <span class="preprocessor">#define UIP_LOG(m) uip_log(m)</span>
  132. <a name="l00100"></a>00100 <span class="preprocessor"></span><span class="preprocessor">#else</span>
  133. <a name="l00101"></a>00101 <span class="preprocessor"></span><span class="preprocessor">#define UIP_LOG(m)</span>
  134. <a name="l00102"></a>00102 <span class="preprocessor"></span><span class="preprocessor">#endif </span><span class="comment">/* UIP_LOGGING == 1 */</span>
  135. <a name="l00103"></a>00103
  136. <a name="l00104"></a>00104 <span class="preprocessor">#ifdef SICSLOWPAN_CONF_MAX_MAC_TRANSMISSIONS</span>
  137. <a name="l00105"></a>00105 <span class="preprocessor"></span><span class="preprocessor">#define SICSLOWPAN_MAX_MAC_TRANSMISSIONS SICSLOWPAN_CONF_MAX_MAC_TRANSMISSIONS</span>
  138. <a name="l00106"></a>00106 <span class="preprocessor"></span><span class="preprocessor">#else</span>
  139. <a name="l00107"></a>00107 <span class="preprocessor"></span><span class="preprocessor">#define SICSLOWPAN_MAX_MAC_TRANSMISSIONS 4</span>
  140. <a name="l00108"></a>00108 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
  141. <a name="l00109"></a>00109 <span class="preprocessor"></span>
  142. <a name="l00110"></a>00110 <span class="preprocessor">#ifndef SICSLOWPAN_COMPRESSION</span>
  143. <a name="l00111"></a>00111 <span class="preprocessor"></span><span class="preprocessor">#ifdef SICSLOWPAN_CONF_COMPRESSION</span>
  144. <a name="l00112"></a>00112 <span class="preprocessor"></span><span class="preprocessor">#define SICSLOWPAN_COMPRESSION SICSLOWPAN_CONF_COMPRESSION</span>
  145. <a name="l00113"></a>00113 <span class="preprocessor"></span><span class="preprocessor">#else</span>
  146. <a name="l00114"></a>00114 <span class="preprocessor"></span><span class="preprocessor">#define SICSLOWPAN_COMPRESSION SICSLOWPAN_COMPRESSION_IPV6</span>
  147. <a name="l00115"></a>00115 <span class="preprocessor"></span><span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_COMPRESSION */</span>
  148. <a name="l00116"></a>00116 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION */</span>
  149. <a name="l00117"></a>00117
  150. <a name="l00118"></a>00118 <span class="preprocessor">#ifndef SICSLOWPAN_CONF_NEIGHBOR_INFO</span>
  151. <a name="l00119"></a>00119 <span class="preprocessor"></span><span class="comment">/* Default is to use neighbor info updates if using RPL */</span>
  152. <a name="l00120"></a>00120 <span class="preprocessor">#define SICSLOWPAN_CONF_NEIGHBOR_INFO UIP_CONF_IPV6_RPL</span>
  153. <a name="l00121"></a>00121 <span class="preprocessor"></span><span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_NEIGHBOR_INFO */</span>
  154. <a name="l00122"></a>00122
  155. <a name="l00123"></a>00123 <span class="preprocessor">#define GET16(ptr,index) (((uint16_t)((ptr)[index] &lt;&lt; 8)) | ((ptr)[(index) + 1]))</span>
  156. <a name="l00124"></a>00124 <span class="preprocessor"></span><span class="preprocessor">#define SET16(ptr,index,value) do { \</span>
  157. <a name="l00125"></a>00125 <span class="preprocessor"> (ptr)[index] = ((value) &gt;&gt; 8) &amp; 0xff; \</span>
  158. <a name="l00126"></a>00126 <span class="preprocessor"> (ptr)[index + 1] = (value) &amp; 0xff; \</span>
  159. <a name="l00127"></a>00127 <span class="preprocessor">} while(0)</span>
  160. <a name="l00128"></a>00128 <span class="preprocessor"></span><span class="comment"></span>
  161. <a name="l00129"></a>00129 <span class="comment">/** \name Pointers in the rime buffer</span>
  162. <a name="l00130"></a>00130 <span class="comment"> * @{</span>
  163. <a name="l00131"></a>00131 <span class="comment"> */</span>
  164. <a name="l00132"></a>00132 <span class="preprocessor">#define RIME_FRAG_PTR (rime_ptr)</span>
  165. <a name="l00133"></a>00133 <span class="preprocessor"></span><span class="preprocessor">#define RIME_FRAG_DISPATCH_SIZE 0 </span><span class="comment">/* 16 bit */</span>
  166. <a name="l00134"></a>00134 <span class="preprocessor">#define RIME_FRAG_TAG 2 </span><span class="comment">/* 16 bit */</span>
  167. <a name="l00135"></a>00135 <span class="preprocessor">#define RIME_FRAG_OFFSET 4 </span><span class="comment">/* 8 bit */</span>
  168. <a name="l00136"></a>00136
  169. <a name="l00137"></a>00137 <span class="comment">/* define the buffer as a byte array */</span>
  170. <a name="l00138"></a>00138 <span class="preprocessor">#define RIME_IPHC_BUF ((uint8_t *)(rime_ptr + rime_hdr_len))</span>
  171. <a name="l00139"></a>00139 <span class="preprocessor"></span>
  172. <a name="l00140"></a>00140 <span class="preprocessor">#define RIME_HC1_PTR (rime_ptr + rime_hdr_len)</span>
  173. <a name="l00141"></a>00141 <span class="preprocessor"></span><span class="preprocessor">#define RIME_HC1_DISPATCH 0 </span><span class="comment">/* 8 bit */</span>
  174. <a name="l00142"></a>00142 <span class="preprocessor">#define RIME_HC1_ENCODING 1 </span><span class="comment">/* 8 bit */</span>
  175. <a name="l00143"></a>00143 <span class="preprocessor">#define RIME_HC1_TTL 2 </span><span class="comment">/* 8 bit */</span>
  176. <a name="l00144"></a>00144
  177. <a name="l00145"></a>00145 <span class="preprocessor">#define RIME_HC1_HC_UDP_PTR (rime_ptr + rime_hdr_len)</span>
  178. <a name="l00146"></a>00146 <span class="preprocessor"></span><span class="preprocessor">#define RIME_HC1_HC_UDP_DISPATCH 0 </span><span class="comment">/* 8 bit */</span>
  179. <a name="l00147"></a>00147 <span class="preprocessor">#define RIME_HC1_HC_UDP_HC1_ENCODING 1 </span><span class="comment">/* 8 bit */</span>
  180. <a name="l00148"></a>00148 <span class="preprocessor">#define RIME_HC1_HC_UDP_UDP_ENCODING 2 </span><span class="comment">/* 8 bit */</span>
  181. <a name="l00149"></a>00149 <span class="preprocessor">#define RIME_HC1_HC_UDP_TTL 3 </span><span class="comment">/* 8 bit */</span>
  182. <a name="l00150"></a>00150 <span class="preprocessor">#define RIME_HC1_HC_UDP_PORTS 4 </span><span class="comment">/* 8 bit */</span>
  183. <a name="l00151"></a>00151 <span class="preprocessor">#define RIME_HC1_HC_UDP_CHKSUM 5 </span><span class="comment">/* 16 bit */</span>
  184. <a name="l00152"></a>00152 <span class="comment"></span>
  185. <a name="l00153"></a>00153 <span class="comment">/** \name Pointers in the sicslowpan and uip buffer</span>
  186. <a name="l00154"></a>00154 <span class="comment"> * @{</span>
  187. <a name="l00155"></a>00155 <span class="comment"> */</span>
  188. <a name="l00156"></a>00156 <span class="preprocessor">#define SICSLOWPAN_IP_BUF ((struct uip_ip_hdr *)&amp;sicslowpan_buf[UIP_LLH_LEN])</span>
  189. <a name="l00157"></a>00157 <span class="preprocessor"></span><span class="preprocessor">#define SICSLOWPAN_UDP_BUF ((struct uip_udp_hdr *)&amp;sicslowpan_buf[UIP_LLIPH_LEN])</span>
  190. <a name="l00158"></a>00158 <span class="preprocessor"></span>
  191. <a name="l00159"></a>00159 <span class="preprocessor">#define UIP_IP_BUF ((struct uip_ip_hdr *)&amp;uip_buf[UIP_LLH_LEN])</span>
  192. <a name="l00160"></a>00160 <span class="preprocessor"></span><span class="preprocessor">#define UIP_UDP_BUF ((struct uip_udp_hdr *)&amp;uip_buf[UIP_LLIPH_LEN])</span>
  193. <a name="l00161"></a>00161 <span class="preprocessor"></span><span class="preprocessor">#define UIP_TCP_BUF ((struct uip_tcp_hdr *)&amp;uip_buf[UIP_LLIPH_LEN])</span>
  194. <a name="l00162"></a>00162 <span class="preprocessor"></span><span class="comment">/** @} */</span>
  195. <a name="l00163"></a>00163
  196. <a name="l00164"></a>00164 <span class="comment"></span>
  197. <a name="l00165"></a>00165 <span class="comment">/** \brief Size of the 802.15.4 payload (127byte - 25 for MAC header) */</span>
  198. <a name="l00166"></a><a class="code" href="a01680.html#gaf213c8c71222bb86256fb3e37582242b">00166</a> <span class="preprocessor">#define MAC_MAX_PAYLOAD 102</span>
  199. <a name="l00167"></a>00167 <span class="preprocessor"></span><span class="comment"></span>
  200. <a name="l00168"></a>00168 <span class="comment">/** \name General variables</span>
  201. <a name="l00169"></a>00169 <span class="comment"> * @{</span>
  202. <a name="l00170"></a>00170 <span class="comment"> */</span><span class="comment"></span>
  203. <a name="l00171"></a>00171 <span class="comment">/** A pointer to the mac driver */</span>
  204. <a name="l00172"></a><a class="code" href="a01680.html#ga1a8a1d348eacac5dcc3f01879e94a61d">00172</a> <span class="keyword">const</span> <span class="keyword">struct </span><a class="code" href="a00055.html" title="The structure of a MAC protocol driver in Contiki.">mac_driver</a> *<a class="code" href="a01680.html#ga1a8a1d348eacac5dcc3f01879e94a61d" title="A pointer to the mac driver.">sicslowpan_mac</a>;
  205. <a name="l00173"></a>00173
  206. <a name="l00174"></a>00174 <span class="preprocessor">#ifdef SICSLOWPAN_NH_COMPRESSOR</span>
  207. <a name="l00175"></a>00175 <span class="preprocessor"></span><span class="comment">/** A pointer to the additional compressor */</span>
  208. <a name="l00176"></a>00176 <span class="keyword">extern</span> <span class="keyword">struct </span><a class="code" href="a00080.html" title="The structure of a next header compressor.">sicslowpan_nh_compressor</a> SICSLOWPAN_NH_COMPRESSOR;
  209. <a name="l00177"></a>00177 <span class="preprocessor">#endif</span>
  210. <a name="l00178"></a>00178 <span class="preprocessor"></span><span class="comment"></span>
  211. <a name="l00179"></a>00179 <span class="comment">/**</span>
  212. <a name="l00180"></a>00180 <span class="comment"> * A pointer to the rime buffer.</span>
  213. <a name="l00181"></a>00181 <span class="comment"> * We initialize it to the beginning of the rime buffer, then</span>
  214. <a name="l00182"></a>00182 <span class="comment"> * access different fields by updating the offset rime_hdr_len.</span>
  215. <a name="l00183"></a>00183 <span class="comment"> */</span>
  216. <a name="l00184"></a>00184 <span class="keyword">static</span> <a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a> *rime_ptr;
  217. <a name="l00185"></a>00185 <span class="comment"></span>
  218. <a name="l00186"></a>00186 <span class="comment">/**</span>
  219. <a name="l00187"></a>00187 <span class="comment"> * rime_hdr_len is the total length of (the processed) 6lowpan headers</span>
  220. <a name="l00188"></a>00188 <span class="comment"> * (fragment headers, IPV6 or HC1, HC2, and HC1 and HC2 non compressed</span>
  221. <a name="l00189"></a>00189 <span class="comment"> * fields).</span>
  222. <a name="l00190"></a>00190 <span class="comment"> */</span>
  223. <a name="l00191"></a>00191 <span class="keyword">static</span> <a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a> rime_hdr_len;
  224. <a name="l00192"></a>00192 <span class="comment"></span>
  225. <a name="l00193"></a>00193 <span class="comment">/**</span>
  226. <a name="l00194"></a>00194 <span class="comment"> * The length of the payload in the Rime buffer.</span>
  227. <a name="l00195"></a>00195 <span class="comment"> * The payload is what comes after the compressed or uncompressed</span>
  228. <a name="l00196"></a>00196 <span class="comment"> * headers (can be the IP payload if the IP header only is compressed</span>
  229. <a name="l00197"></a>00197 <span class="comment"> * or the UDP payload if the UDP header is also compressed)</span>
  230. <a name="l00198"></a>00198 <span class="comment"> */</span>
  231. <a name="l00199"></a>00199 <span class="keyword">static</span> <a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a> rime_payload_len;
  232. <a name="l00200"></a>00200 <span class="comment"></span>
  233. <a name="l00201"></a>00201 <span class="comment">/**</span>
  234. <a name="l00202"></a>00202 <span class="comment"> * uncomp_hdr_len is the length of the headers before compression (if HC2</span>
  235. <a name="l00203"></a>00203 <span class="comment"> * is used this includes the UDP header in addition to the IP header).</span>
  236. <a name="l00204"></a>00204 <span class="comment"> */</span>
  237. <a name="l00205"></a>00205 <span class="keyword">static</span> <a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a> uncomp_hdr_len;<span class="comment"></span>
  238. <a name="l00206"></a>00206 <span class="comment">/** @} */</span>
  239. <a name="l00207"></a>00207
  240. <a name="l00208"></a>00208 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  241. <a name="l00209"></a>00209 <span class="preprocessor"></span><span class="comment">/** \name Fragmentation related variables</span>
  242. <a name="l00210"></a>00210 <span class="comment"> * @{</span>
  243. <a name="l00211"></a>00211 <span class="comment"> */</span>
  244. <a name="l00212"></a>00212
  245. <a name="l00213"></a>00213 <span class="keyword">static</span> uint16_t sicslowpan_len;
  246. <a name="l00214"></a>00214 <span class="comment"></span>
  247. <a name="l00215"></a>00215 <span class="comment">/**</span>
  248. <a name="l00216"></a>00216 <span class="comment"> * The buffer used for the 6lowpan reassembly.</span>
  249. <a name="l00217"></a>00217 <span class="comment"> * This buffer contains only the IPv6 packet (no MAC header, 6lowpan, etc).</span>
  250. <a name="l00218"></a>00218 <span class="comment"> * It has a fix size as we do not use dynamic memory allocation.</span>
  251. <a name="l00219"></a>00219 <span class="comment"> */</span>
  252. <a name="l00220"></a>00220 <span class="keyword">static</span> <a class="code" href="a00091.html" title="The uIP packet buffer.">uip_buf_t</a> sicslowpan_aligned_buf;
  253. <a name="l00221"></a>00221 <span class="preprocessor">#define sicslowpan_buf (sicslowpan_aligned_buf.u8)</span>
  254. <a name="l00222"></a>00222 <span class="preprocessor"></span><span class="comment"></span>
  255. <a name="l00223"></a>00223 <span class="comment">/** The total length of the IPv6 packet in the sicslowpan_buf. */</span>
  256. <a name="l00224"></a>00224 <span class="comment"></span>
  257. <a name="l00225"></a>00225 <span class="comment">/**</span>
  258. <a name="l00226"></a>00226 <span class="comment"> * length of the ip packet already sent / received.</span>
  259. <a name="l00227"></a>00227 <span class="comment"> * It includes IP and transport headers.</span>
  260. <a name="l00228"></a>00228 <span class="comment"> */</span>
  261. <a name="l00229"></a>00229 <span class="keyword">static</span> uint16_t processed_ip_len;
  262. <a name="l00230"></a>00230 <span class="comment"></span>
  263. <a name="l00231"></a>00231 <span class="comment">/** Datagram tag to be put in the fragments I send. */</span>
  264. <a name="l00232"></a>00232 <span class="keyword">static</span> uint16_t my_tag;
  265. <a name="l00233"></a>00233 <span class="comment"></span>
  266. <a name="l00234"></a>00234 <span class="comment">/** When reassembling, the tag in the fragments being merged. */</span>
  267. <a name="l00235"></a>00235 <span class="keyword">static</span> uint16_t reass_tag;
  268. <a name="l00236"></a>00236 <span class="comment"></span>
  269. <a name="l00237"></a>00237 <span class="comment">/** When reassembling, the source address of the fragments being merged */</span>
  270. <a name="l00238"></a>00238 rimeaddr_t frag_sender;
  271. <a name="l00239"></a>00239 <span class="comment"></span>
  272. <a name="l00240"></a>00240 <span class="comment">/** Reassembly %process %timer. */</span>
  273. <a name="l00241"></a>00241 <span class="keyword">static</span> <span class="keyword">struct </span><a class="code" href="a00086.html" title="A timer.">timer</a> reass_timer;
  274. <a name="l00242"></a>00242 <span class="comment"></span>
  275. <a name="l00243"></a>00243 <span class="comment">/** @} */</span>
  276. <a name="l00244"></a>00244 <span class="preprocessor">#else </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  277. <a name="l00245"></a>00245 <span class="comment">/** The buffer used for the 6lowpan processing is uip_buf.</span>
  278. <a name="l00246"></a>00246 <span class="comment"> We do not use any additional buffer.*/</span>
  279. <a name="l00247"></a><a class="code" href="a01680.html#ga2c312c370c91d9cc20fc0c97fd430fab">00247</a> <span class="preprocessor">#define sicslowpan_buf uip_buf</span>
  280. <a name="l00248"></a>00248 <span class="preprocessor"></span><span class="preprocessor">#define sicslowpan_len uip_len</span>
  281. <a name="l00249"></a>00249 <span class="preprocessor"></span><span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  282. <a name="l00250"></a>00250
  283. <a name="l00251"></a>00251 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06</span>
  284. <a name="l00252"></a>00252 <span class="preprocessor"></span><span class="comment">/** \name HC06 specific variables</span>
  285. <a name="l00253"></a>00253 <span class="comment"> * @{</span>
  286. <a name="l00254"></a>00254 <span class="comment"> */</span>
  287. <a name="l00255"></a>00255 <span class="comment"></span>
  288. <a name="l00256"></a>00256 <span class="comment">/** Addresses contexts for IPHC. */</span>
  289. <a name="l00257"></a>00257 <span class="preprocessor">#if SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0</span>
  290. <a name="l00258"></a>00258 <span class="preprocessor"></span><span class="keyword">static</span> <span class="keyword">struct </span><a class="code" href="a00079.html" title="The header for fragments.">sicslowpan_addr_context</a>
  291. <a name="l00259"></a>00259 addr_contexts[<a class="code" href="a01588.html#ga02ead2bfabed920502fe48c0baa0ed3f" title="If we use IPHC compression, how many address contexts do we support.">SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS</a>];
  292. <a name="l00260"></a>00260 <span class="preprocessor">#endif</span>
  293. <a name="l00261"></a>00261 <span class="preprocessor"></span><span class="comment"></span>
  294. <a name="l00262"></a>00262 <span class="comment">/** pointer to an address context. */</span>
  295. <a name="l00263"></a>00263 <span class="keyword">static</span> <span class="keyword">struct </span><a class="code" href="a00079.html" title="The header for fragments.">sicslowpan_addr_context</a> *context;
  296. <a name="l00264"></a>00264 <span class="comment"></span>
  297. <a name="l00265"></a>00265 <span class="comment">/** pointer to the byte where to write next inline field. */</span>
  298. <a name="l00266"></a>00266 <span class="keyword">static</span> uint8_t *hc06_ptr;
  299. <a name="l00267"></a>00267
  300. <a name="l00268"></a>00268 <span class="comment">/* Uncompression of linklocal */</span>
  301. <a name="l00269"></a>00269 <span class="comment">/* 0 -&gt; 16 bytes from packet */</span>
  302. <a name="l00270"></a>00270 <span class="comment">/* 1 -&gt; 2 bytes from prefix - bunch of zeroes and 8 from packet */</span>
  303. <a name="l00271"></a>00271 <span class="comment">/* 2 -&gt; 2 bytes from prefix - 0000::00ff:fe00:XXXX from packet */</span>
  304. <a name="l00272"></a>00272 <span class="comment">/* 3 -&gt; 2 bytes from prefix - infer 8 bytes from lladdr */</span>
  305. <a name="l00273"></a>00273 <span class="comment">/* NOTE: =&gt; the uncompress function does change 0xf to 0x10 */</span>
  306. <a name="l00274"></a>00274 <span class="comment">/* NOTE: 0x00 =&gt; no-autoconfig =&gt; unspecified */</span>
  307. <a name="l00275"></a>00275 <span class="keyword">const</span> uint8_t unc_llconf[] = {0x0f,0x28,0x22,0x20};
  308. <a name="l00276"></a>00276
  309. <a name="l00277"></a>00277 <span class="comment">/* Uncompression of ctx-based */</span>
  310. <a name="l00278"></a>00278 <span class="comment">/* 0 -&gt; 0 bits from packet [unspecified / reserved] */</span>
  311. <a name="l00279"></a>00279 <span class="comment">/* 1 -&gt; 8 bytes from prefix - bunch of zeroes and 8 from packet */</span>
  312. <a name="l00280"></a>00280 <span class="comment">/* 2 -&gt; 8 bytes from prefix - 0000::00ff:fe00:XXXX + 2 from packet */</span>
  313. <a name="l00281"></a>00281 <span class="comment">/* 3 -&gt; 8 bytes from prefix - infer 8 bytes from lladdr */</span>
  314. <a name="l00282"></a>00282 <span class="keyword">const</span> uint8_t unc_ctxconf[] = {0x00,0x88,0x82,0x80};
  315. <a name="l00283"></a>00283
  316. <a name="l00284"></a>00284 <span class="comment">/* Uncompression of ctx-based */</span>
  317. <a name="l00285"></a>00285 <span class="comment">/* 0 -&gt; 0 bits from packet */</span>
  318. <a name="l00286"></a>00286 <span class="comment">/* 1 -&gt; 2 bytes from prefix - bunch of zeroes 5 from packet */</span>
  319. <a name="l00287"></a>00287 <span class="comment">/* 2 -&gt; 2 bytes from prefix - zeroes + 3 from packet */</span>
  320. <a name="l00288"></a>00288 <span class="comment">/* 3 -&gt; 2 bytes from prefix - infer 1 bytes from lladdr */</span>
  321. <a name="l00289"></a>00289 <span class="keyword">const</span> uint8_t unc_mxconf[] = {0x0f, 0x25, 0x23, 0x21};
  322. <a name="l00290"></a>00290
  323. <a name="l00291"></a>00291 <span class="comment">/* Link local prefix */</span>
  324. <a name="l00292"></a>00292 <span class="keyword">const</span> uint8_t llprefix[] = {0xfe, 0x80};
  325. <a name="l00293"></a>00293
  326. <a name="l00294"></a>00294 <span class="comment">/* TTL uncompression values */</span>
  327. <a name="l00295"></a>00295 <span class="keyword">static</span> <span class="keyword">const</span> uint8_t ttl_values[] = {0, 1, 64, 255};
  328. <a name="l00296"></a>00296
  329. <a name="l00297"></a>00297 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  330. <a name="l00298"></a>00298 <span class="comment">/** \name HC06 related functions</span>
  331. <a name="l00299"></a>00299 <span class="comment"> * @{ */</span>
  332. <a name="l00300"></a>00300 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  333. <a name="l00301"></a>00301 <span class="comment">/** \brief find the context corresponding to prefix ipaddr */</span>
  334. <a name="l00302"></a>00302 <span class="keyword">static</span> <span class="keyword">struct </span><a class="code" href="a00079.html" title="The header for fragments.">sicslowpan_addr_context</a>*
  335. <a name="l00303"></a>00303 addr_context_lookup_by_prefix(<a class="code" href="a00106.html" title="Representation of an IP address.">uip_ipaddr_t</a> *ipaddr)
  336. <a name="l00304"></a>00304 {
  337. <a name="l00305"></a>00305 <span class="comment">/* Remove code to avoid warnings and save flash if no context is used */</span>
  338. <a name="l00306"></a>00306 <span class="preprocessor">#if SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0</span>
  339. <a name="l00307"></a>00307 <span class="preprocessor"></span> <span class="keywordtype">int</span> i;
  340. <a name="l00308"></a>00308 <span class="keywordflow">for</span>(i = 0; i &lt; <a class="code" href="a01588.html#ga02ead2bfabed920502fe48c0baa0ed3f" title="If we use IPHC compression, how many address contexts do we support.">SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS</a>; i++) {
  341. <a name="l00309"></a>00309 <span class="keywordflow">if</span>((addr_contexts[i].used == 1) &amp;&amp;
  342. <a name="l00310"></a>00310 uip_ipaddr_prefixcmp(&amp;addr_contexts[i].prefix, ipaddr, 64)) {
  343. <a name="l00311"></a>00311 <span class="keywordflow">return</span> &amp;addr_contexts[i];
  344. <a name="l00312"></a>00312 }
  345. <a name="l00313"></a>00313 }
  346. <a name="l00314"></a>00314 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0 */</span>
  347. <a name="l00315"></a>00315 <span class="keywordflow">return</span> NULL;
  348. <a name="l00316"></a>00316 }
  349. <a name="l00317"></a>00317 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  350. <a name="l00318"></a>00318 <span class="comment">/** \brief find the context with the given number */</span>
  351. <a name="l00319"></a>00319 <span class="keyword">static</span> <span class="keyword">struct </span><a class="code" href="a00079.html" title="The header for fragments.">sicslowpan_addr_context</a>*
  352. <a name="l00320"></a>00320 addr_context_lookup_by_number(<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a> number)
  353. <a name="l00321"></a>00321 {
  354. <a name="l00322"></a>00322 <span class="comment">/* Remove code to avoid warnings and save flash if no context is used */</span>
  355. <a name="l00323"></a>00323 <span class="preprocessor">#if SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0</span>
  356. <a name="l00324"></a>00324 <span class="preprocessor"></span> <span class="keywordtype">int</span> i;
  357. <a name="l00325"></a>00325 <span class="keywordflow">for</span>(i = 0; i &lt; SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS; i++) {
  358. <a name="l00326"></a>00326 <span class="keywordflow">if</span>((addr_contexts[i].used == 1) &amp;&amp;
  359. <a name="l00327"></a>00327 addr_contexts[i].number == number) {
  360. <a name="l00328"></a>00328 <span class="keywordflow">return</span> &amp;addr_contexts[i];
  361. <a name="l00329"></a>00329 }
  362. <a name="l00330"></a>00330 }
  363. <a name="l00331"></a>00331 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0 */</span>
  364. <a name="l00332"></a>00332 <span class="keywordflow">return</span> NULL;
  365. <a name="l00333"></a>00333 }
  366. <a name="l00334"></a>00334 <span class="comment">/*--------------------------------------------------------------------*/</span>
  367. <a name="l00335"></a>00335 <span class="keyword">static</span> uint8_t
  368. <a name="l00336"></a>00336 compress_addr_64(uint8_t bitpos, <a class="code" href="a00106.html" title="Representation of an IP address.">uip_ipaddr_t</a> *ipaddr, <a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *lladdr)
  369. <a name="l00337"></a>00337 {
  370. <a name="l00338"></a>00338 <span class="keywordflow">if</span>(uip_is_addr_mac_addr_based(ipaddr, lladdr)) {
  371. <a name="l00339"></a>00339 <span class="keywordflow">return</span> 3 &lt;&lt; bitpos; <span class="comment">/* 0-bits */</span>
  372. <a name="l00340"></a>00340 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(<a class="code" href="a01680.html#ga8296cf462962152c3baf7765baf086c8" title="check whether we can compress the IID in address &amp;#39;a&amp;#39; to 16 bits.">sicslowpan_is_iid_16_bit_compressable</a>(ipaddr)) {
  373. <a name="l00341"></a>00341 <span class="comment">/* compress IID to 16 bits xxxx::0000:00ff:fe00:XXXX */</span>
  374. <a name="l00342"></a>00342 memcpy(hc06_ptr, &amp;ipaddr-&gt;u16[7], 2);
  375. <a name="l00343"></a>00343 hc06_ptr += 2;
  376. <a name="l00344"></a>00344 <span class="keywordflow">return</span> 2 &lt;&lt; bitpos; <span class="comment">/* 16-bits */</span>
  377. <a name="l00345"></a>00345 } <span class="keywordflow">else</span> {
  378. <a name="l00346"></a>00346 <span class="comment">/* do not compress IID =&gt; xxxx::IID */</span>
  379. <a name="l00347"></a>00347 memcpy(hc06_ptr, &amp;ipaddr-&gt;u16[4], 8);
  380. <a name="l00348"></a>00348 hc06_ptr += 8;
  381. <a name="l00349"></a>00349 <span class="keywordflow">return</span> 1 &lt;&lt; bitpos; <span class="comment">/* 64-bits */</span>
  382. <a name="l00350"></a>00350 }
  383. <a name="l00351"></a>00351 }
  384. <a name="l00352"></a>00352
  385. <a name="l00353"></a>00353 <span class="comment">/*-------------------------------------------------------------------- */</span>
  386. <a name="l00354"></a>00354 <span class="comment">/* Uncompress addresses based on a prefix and a postfix with zeroes in</span>
  387. <a name="l00355"></a>00355 <span class="comment"> * between. If the postfix is zero in length it will use the link address</span>
  388. <a name="l00356"></a>00356 <span class="comment"> * to configure the IP address (autoconf style).</span>
  389. <a name="l00357"></a>00357 <span class="comment"> * pref_post_count takes a byte where the first nibble specify prefix count</span>
  390. <a name="l00358"></a>00358 <span class="comment"> * and the second postfix count (NOTE: 15/0xf =&gt; 16 bytes copy).</span>
  391. <a name="l00359"></a>00359 <span class="comment"> */</span>
  392. <a name="l00360"></a>00360 <span class="keyword">static</span> <span class="keywordtype">void</span>
  393. <a name="l00361"></a>00361 uncompress_addr(<a class="code" href="a00106.html" title="Representation of an IP address.">uip_ipaddr_t</a> *ipaddr, uint8_t <span class="keyword">const</span> prefix[],
  394. <a name="l00362"></a>00362 uint8_t pref_post_count, <a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *lladdr)
  395. <a name="l00363"></a>00363 {
  396. <a name="l00364"></a>00364 uint8_t prefcount = pref_post_count &gt;&gt; 4;
  397. <a name="l00365"></a>00365 uint8_t postcount = pref_post_count &amp; 0x0f;
  398. <a name="l00366"></a>00366 <span class="comment">/* full nibble 15 =&gt; 16 */</span>
  399. <a name="l00367"></a>00367 prefcount = prefcount == 15 ? 16 : prefcount;
  400. <a name="l00368"></a>00368 postcount = postcount == 15 ? 16 : postcount;
  401. <a name="l00369"></a>00369
  402. <a name="l00370"></a>00370 PRINTF(<span class="stringliteral">&quot;Uncompressing %d + %d =&gt; &quot;</span>, prefcount, postcount);
  403. <a name="l00371"></a>00371
  404. <a name="l00372"></a>00372 <span class="keywordflow">if</span>(prefcount &gt; 0) {
  405. <a name="l00373"></a>00373 memcpy(ipaddr, prefix, prefcount);
  406. <a name="l00374"></a>00374 }
  407. <a name="l00375"></a>00375 <span class="keywordflow">if</span>(prefcount + postcount &lt; 16) {
  408. <a name="l00376"></a>00376 memset(&amp;ipaddr-&gt;u8[prefcount], 0, 16 - (prefcount + postcount));
  409. <a name="l00377"></a>00377 }
  410. <a name="l00378"></a>00378 <span class="keywordflow">if</span>(postcount &gt; 0) {
  411. <a name="l00379"></a>00379 memcpy(&amp;ipaddr-&gt;u8[16 - postcount], hc06_ptr, postcount);
  412. <a name="l00380"></a>00380 <span class="keywordflow">if</span>(postcount == 2 &amp;&amp; prefcount &lt; 11) {
  413. <a name="l00381"></a>00381 <span class="comment">/* 16 bits uncompression =&gt; 0000:00ff:fe00:XXXX */</span>
  414. <a name="l00382"></a>00382 ipaddr-&gt;u8[11] = 0xff;
  415. <a name="l00383"></a>00383 ipaddr-&gt;u8[12] = 0xfe;
  416. <a name="l00384"></a>00384 }
  417. <a name="l00385"></a>00385 hc06_ptr += postcount;
  418. <a name="l00386"></a>00386 } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (prefcount &gt; 0) {
  419. <a name="l00387"></a>00387 <span class="comment">/* no IID based configuration if no prefix and no data =&gt; unspec */</span>
  420. <a name="l00388"></a>00388 <a class="code" href="a01685.html#gabbe961bbeaea80289fddf448a542fea9" title="set the last 64 bits of an IP address based on the MAC address">uip_ds6_set_addr_iid</a>(ipaddr, lladdr);
  421. <a name="l00389"></a>00389 }
  422. <a name="l00390"></a>00390
  423. <a name="l00391"></a>00391 PRINT6ADDR(ipaddr);
  424. <a name="l00392"></a>00392 PRINTF(<span class="stringliteral">&quot;\n&quot;</span>);
  425. <a name="l00393"></a>00393 }
  426. <a name="l00394"></a>00394
  427. <a name="l00395"></a>00395 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  428. <a name="l00396"></a>00396 <span class="comment">/**</span>
  429. <a name="l00397"></a>00397 <span class="comment"> * \brief Compress IP/UDP header</span>
  430. <a name="l00398"></a>00398 <span class="comment"> *</span>
  431. <a name="l00399"></a>00399 <span class="comment"> * This function is called by the 6lowpan code to create a compressed</span>
  432. <a name="l00400"></a>00400 <span class="comment"> * 6lowpan packet in the packetbuf buffer from a full IPv6 packet in the</span>
  433. <a name="l00401"></a>00401 <span class="comment"> * uip_buf buffer.</span>
  434. <a name="l00402"></a>00402 <span class="comment"> *</span>
  435. <a name="l00403"></a>00403 <span class="comment"> *</span>
  436. <a name="l00404"></a>00404 <span class="comment"> * HC-06 (draft-ietf-6lowpan-hc, version 6)\n</span>
  437. <a name="l00405"></a>00405 <span class="comment"> * http://tools.ietf.org/html/draft-ietf-6lowpan-hc-06</span>
  438. <a name="l00406"></a>00406 <span class="comment"> *</span>
  439. <a name="l00407"></a>00407 <span class="comment"> * \note We do not support ISA100_UDP header compression</span>
  440. <a name="l00408"></a>00408 <span class="comment"> *</span>
  441. <a name="l00409"></a>00409 <span class="comment"> * For LOWPAN_UDP compression, we either compress both ports or none.</span>
  442. <a name="l00410"></a>00410 <span class="comment"> * General format with LOWPAN_UDP compression is</span>
  443. <a name="l00411"></a>00411 <span class="comment"> * \verbatim</span>
  444. <a name="l00412"></a>00412 <span class="comment"> * 1 2 3</span>
  445. <a name="l00413"></a>00413 <span class="comment"> * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1</span>
  446. <a name="l00414"></a>00414 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  447. <a name="l00415"></a>00415 <span class="comment"> * |0|1|1|TF |N|HLI|C|S|SAM|M|D|DAM| SCI | DCI | comp. IPv6 hdr|</span>
  448. <a name="l00416"></a>00416 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  449. <a name="l00417"></a>00417 <span class="comment"> * | compressed IPv6 fields ..... |</span>
  450. <a name="l00418"></a>00418 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  451. <a name="l00419"></a>00419 <span class="comment"> * | LOWPAN_UDP | non compressed UDP fields ... |</span>
  452. <a name="l00420"></a>00420 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  453. <a name="l00421"></a>00421 <span class="comment"> * | L4 data ... |</span>
  454. <a name="l00422"></a>00422 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  455. <a name="l00423"></a>00423 <span class="comment"> * \endverbatim</span>
  456. <a name="l00424"></a>00424 <span class="comment"> * \note The context number 00 is reserved for the link local prefix.</span>
  457. <a name="l00425"></a>00425 <span class="comment"> * For unicast addresses, if we cannot compress the prefix, we neither</span>
  458. <a name="l00426"></a>00426 <span class="comment"> * compress the IID.</span>
  459. <a name="l00427"></a>00427 <span class="comment"> * \param rime_destaddr L2 destination address, needed to compress IP</span>
  460. <a name="l00428"></a>00428 <span class="comment"> * dest</span>
  461. <a name="l00429"></a>00429 <span class="comment"> */</span>
  462. <a name="l00430"></a>00430 <span class="keyword">static</span> <span class="keywordtype">void</span>
  463. <a name="l00431"></a>00431 compress_hdr_hc06(rimeaddr_t *rime_destaddr)
  464. <a name="l00432"></a>00432 {
  465. <a name="l00433"></a>00433 uint8_t tmp, iphc0, iphc1;
  466. <a name="l00434"></a>00434 <span class="preprocessor">#if DEBUG</span>
  467. <a name="l00435"></a>00435 <span class="preprocessor"></span> PRINTF(<span class="stringliteral">&quot;before compression: &quot;</span>);
  468. <a name="l00436"></a>00436 <span class="keywordflow">for</span> (tmp = 0; tmp &lt; <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;len[1] + 40; tmp++) {
  469. <a name="l00437"></a>00437 uint8_t data = ((uint8_t *) (<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>))[tmp];
  470. <a name="l00438"></a>00438 PRINTF(<span class="stringliteral">&quot;%02x&quot;</span>, data);
  471. <a name="l00439"></a>00439 }
  472. <a name="l00440"></a>00440 PRINTF(<span class="stringliteral">&quot;\n&quot;</span>);
  473. <a name="l00441"></a>00441 <span class="preprocessor">#endif</span>
  474. <a name="l00442"></a>00442 <span class="preprocessor"></span>
  475. <a name="l00443"></a>00443 hc06_ptr = rime_ptr + 2;
  476. <a name="l00444"></a>00444 <span class="comment">/*</span>
  477. <a name="l00445"></a>00445 <span class="comment"> * As we copy some bit-length fields, in the IPHC encoding bytes,</span>
  478. <a name="l00446"></a>00446 <span class="comment"> * we sometimes use |=</span>
  479. <a name="l00447"></a>00447 <span class="comment"> * If the field is 0, and the current bit value in memory is 1,</span>
  480. <a name="l00448"></a>00448 <span class="comment"> * this does not work. We therefore reset the IPHC encoding here</span>
  481. <a name="l00449"></a>00449 <span class="comment"> */</span>
  482. <a name="l00450"></a>00450
  483. <a name="l00451"></a>00451 iphc0 = SICSLOWPAN_DISPATCH_IPHC;
  484. <a name="l00452"></a>00452 iphc1 = 0;
  485. <a name="l00453"></a>00453 RIME_IPHC_BUF[2] = 0; <span class="comment">/* might not be used - but needs to be cleared */</span>
  486. <a name="l00454"></a>00454
  487. <a name="l00455"></a>00455 <span class="comment">/*</span>
  488. <a name="l00456"></a>00456 <span class="comment"> * Address handling needs to be made first since it might</span>
  489. <a name="l00457"></a>00457 <span class="comment"> * cause an extra byte with [ SCI | DCI ]</span>
  490. <a name="l00458"></a>00458 <span class="comment"> *</span>
  491. <a name="l00459"></a>00459 <span class="comment"> */</span>
  492. <a name="l00460"></a>00460
  493. <a name="l00461"></a>00461
  494. <a name="l00462"></a>00462 <span class="comment">/* check if dest context exists (for allocating third byte) */</span>
  495. <a name="l00463"></a>00463 <span class="comment">/* TODO: fix this so that it remembers the looked up values for</span>
  496. <a name="l00464"></a>00464 <span class="comment"> avoiding two lookups - or set the lookup values immediately */</span>
  497. <a name="l00465"></a>00465 <span class="keywordflow">if</span>(addr_context_lookup_by_prefix(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr) != NULL ||
  498. <a name="l00466"></a>00466 addr_context_lookup_by_prefix(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr) != NULL) {
  499. <a name="l00467"></a>00467 <span class="comment">/* set context flag and increase hc06_ptr */</span>
  500. <a name="l00468"></a>00468 PRINTF(<span class="stringliteral">&quot;IPHC: compressing dest or src ipaddr - setting CID\n&quot;</span>);
  501. <a name="l00469"></a>00469 iphc1 |= SICSLOWPAN_IPHC_CID;
  502. <a name="l00470"></a>00470 hc06_ptr++;
  503. <a name="l00471"></a>00471 }
  504. <a name="l00472"></a>00472
  505. <a name="l00473"></a>00473 <span class="comment">/*</span>
  506. <a name="l00474"></a>00474 <span class="comment"> * Traffic class, flow label</span>
  507. <a name="l00475"></a>00475 <span class="comment"> * If flow label is 0, compress it. If traffic class is 0, compress it</span>
  508. <a name="l00476"></a>00476 <span class="comment"> * We have to process both in the same time as the offset of traffic class</span>
  509. <a name="l00477"></a>00477 <span class="comment"> * depends on the presence of version and flow label</span>
  510. <a name="l00478"></a>00478 <span class="comment"> */</span>
  511. <a name="l00479"></a>00479
  512. <a name="l00480"></a>00480 <span class="comment">/* hc06 format of tc is ECN | DSCP , original is DSCP | ECN */</span>
  513. <a name="l00481"></a>00481 tmp = (<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;vtc &lt;&lt; 4) | (<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;tcflow &gt;&gt; 4);
  514. <a name="l00482"></a>00482 tmp = ((tmp &amp; 0x03) &lt;&lt; 6) | (tmp &gt;&gt; 2);
  515. <a name="l00483"></a>00483
  516. <a name="l00484"></a>00484 <span class="keywordflow">if</span>(((<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;tcflow &amp; 0x0F) == 0) &amp;&amp;
  517. <a name="l00485"></a>00485 (<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;flow == 0)) {
  518. <a name="l00486"></a>00486 <span class="comment">/* flow label can be compressed */</span>
  519. <a name="l00487"></a>00487 iphc0 |= SICSLOWPAN_IPHC_FL_C;
  520. <a name="l00488"></a>00488 <span class="keywordflow">if</span>(((<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;vtc &amp; 0x0F) == 0) &amp;&amp;
  521. <a name="l00489"></a>00489 ((<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;tcflow &amp; 0xF0) == 0)) {
  522. <a name="l00490"></a>00490 <span class="comment">/* compress (elide) all */</span>
  523. <a name="l00491"></a>00491 iphc0 |= SICSLOWPAN_IPHC_TC_C;
  524. <a name="l00492"></a>00492 } <span class="keywordflow">else</span> {
  525. <a name="l00493"></a>00493 <span class="comment">/* compress only the flow label */</span>
  526. <a name="l00494"></a>00494 *hc06_ptr = tmp;
  527. <a name="l00495"></a>00495 hc06_ptr += 1;
  528. <a name="l00496"></a>00496 }
  529. <a name="l00497"></a>00497 } <span class="keywordflow">else</span> {
  530. <a name="l00498"></a>00498 <span class="comment">/* Flow label cannot be compressed */</span>
  531. <a name="l00499"></a>00499 <span class="keywordflow">if</span>(((<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;vtc &amp; 0x0F) == 0) &amp;&amp;
  532. <a name="l00500"></a>00500 ((<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;tcflow &amp; 0xF0) == 0)) {
  533. <a name="l00501"></a>00501 <span class="comment">/* compress only traffic class */</span>
  534. <a name="l00502"></a>00502 iphc0 |= SICSLOWPAN_IPHC_TC_C;
  535. <a name="l00503"></a>00503 *hc06_ptr = (tmp &amp; 0xc0) |
  536. <a name="l00504"></a>00504 (<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;tcflow &amp; 0x0F);
  537. <a name="l00505"></a>00505 memcpy(hc06_ptr + 1, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;flow, 2);
  538. <a name="l00506"></a>00506 hc06_ptr += 3;
  539. <a name="l00507"></a>00507 } <span class="keywordflow">else</span> {
  540. <a name="l00508"></a>00508 <span class="comment">/* compress nothing */</span>
  541. <a name="l00509"></a>00509 memcpy(hc06_ptr, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;vtc, 4);
  542. <a name="l00510"></a>00510 <span class="comment">/* but replace the top byte with the new ECN | DSCP format*/</span>
  543. <a name="l00511"></a>00511 *hc06_ptr = tmp;
  544. <a name="l00512"></a>00512 hc06_ptr += 4;
  545. <a name="l00513"></a>00513 }
  546. <a name="l00514"></a>00514 }
  547. <a name="l00515"></a>00515
  548. <a name="l00516"></a>00516 <span class="comment">/* Note that the payload length is always compressed */</span>
  549. <a name="l00517"></a>00517
  550. <a name="l00518"></a>00518 <span class="comment">/* Next header. We compress it if UDP */</span>
  551. <a name="l00519"></a>00519 <span class="preprocessor">#if UIP_CONF_UDP</span>
  552. <a name="l00520"></a>00520 <span class="preprocessor"></span> <span class="keywordflow">if</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto == UIP_PROTO_UDP) {
  553. <a name="l00521"></a>00521 iphc0 |= SICSLOWPAN_IPHC_NH_C;
  554. <a name="l00522"></a>00522 }
  555. <a name="l00523"></a>00523 <span class="preprocessor">#endif </span><span class="comment">/*UIP_CONF_UDP*/</span>
  556. <a name="l00524"></a>00524 <span class="preprocessor">#ifdef SICSLOWPAN_NH_COMPRESSOR </span>
  557. <a name="l00525"></a>00525 <span class="preprocessor"></span> <span class="keywordflow">if</span>(SICSLOWPAN_NH_COMPRESSOR.is_compressable(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto)) {
  558. <a name="l00526"></a>00526 iphc0 |= SICSLOWPAN_IPHC_NH_C;
  559. <a name="l00527"></a>00527 }
  560. <a name="l00528"></a>00528 <span class="preprocessor">#endif</span>
  561. <a name="l00529"></a>00529 <span class="preprocessor"></span> <span class="keywordflow">if</span> ((iphc0 &amp; SICSLOWPAN_IPHC_NH_C) == 0) {
  562. <a name="l00530"></a>00530 *hc06_ptr = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto;
  563. <a name="l00531"></a>00531 hc06_ptr += 1;
  564. <a name="l00532"></a>00532 }
  565. <a name="l00533"></a>00533
  566. <a name="l00534"></a>00534 <span class="comment">/*</span>
  567. <a name="l00535"></a>00535 <span class="comment"> * Hop limit</span>
  568. <a name="l00536"></a>00536 <span class="comment"> * if 1: compress, encoding is 01</span>
  569. <a name="l00537"></a>00537 <span class="comment"> * if 64: compress, encoding is 10</span>
  570. <a name="l00538"></a>00538 <span class="comment"> * if 255: compress, encoding is 11</span>
  571. <a name="l00539"></a>00539 <span class="comment"> * else do not compress</span>
  572. <a name="l00540"></a>00540 <span class="comment"> */</span>
  573. <a name="l00541"></a>00541 <span class="keywordflow">switch</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;ttl) {
  574. <a name="l00542"></a>00542 <span class="keywordflow">case</span> 1:
  575. <a name="l00543"></a>00543 iphc0 |= SICSLOWPAN_IPHC_TTL_1;
  576. <a name="l00544"></a>00544 <span class="keywordflow">break</span>;
  577. <a name="l00545"></a>00545 <span class="keywordflow">case</span> 64:
  578. <a name="l00546"></a>00546 iphc0 |= SICSLOWPAN_IPHC_TTL_64;
  579. <a name="l00547"></a>00547 <span class="keywordflow">break</span>;
  580. <a name="l00548"></a>00548 <span class="keywordflow">case</span> 255:
  581. <a name="l00549"></a>00549 iphc0 |= SICSLOWPAN_IPHC_TTL_255;
  582. <a name="l00550"></a>00550 <span class="keywordflow">break</span>;
  583. <a name="l00551"></a>00551 <span class="keywordflow">default</span>:
  584. <a name="l00552"></a>00552 *hc06_ptr = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;ttl;
  585. <a name="l00553"></a>00553 hc06_ptr += 1;
  586. <a name="l00554"></a>00554 <span class="keywordflow">break</span>;
  587. <a name="l00555"></a>00555 }
  588. <a name="l00556"></a>00556
  589. <a name="l00557"></a>00557 <span class="comment">/* source address - cannot be multicast */</span>
  590. <a name="l00558"></a>00558 <span class="keywordflow">if</span>(uip_is_addr_unspecified(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr)) {
  591. <a name="l00559"></a>00559 PRINTF(<span class="stringliteral">&quot;IPHC: compressing unspecified - setting SAC\n&quot;</span>);
  592. <a name="l00560"></a>00560 iphc1 |= SICSLOWPAN_IPHC_SAC;
  593. <a name="l00561"></a>00561 iphc1 |= SICSLOWPAN_IPHC_SAM_00;
  594. <a name="l00562"></a>00562 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>((context = addr_context_lookup_by_prefix(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr))
  595. <a name="l00563"></a>00563 != NULL) {
  596. <a name="l00564"></a>00564 <span class="comment">/* elide the prefix - indicate by CID and set context + SAC */</span>
  597. <a name="l00565"></a>00565 PRINTF(<span class="stringliteral">&quot;IPHC: compressing src with context - setting CID &amp; SAC ctx: %d\n&quot;</span>,
  598. <a name="l00566"></a>00566 context-&gt;number);
  599. <a name="l00567"></a>00567 iphc1 |= SICSLOWPAN_IPHC_CID | SICSLOWPAN_IPHC_SAC;
  600. <a name="l00568"></a>00568 RIME_IPHC_BUF[2] |= context-&gt;number &lt;&lt; 4;
  601. <a name="l00569"></a>00569 <span class="comment">/* compession compare with this nodes address (source) */</span>
  602. <a name="l00570"></a>00570
  603. <a name="l00571"></a>00571 iphc1 |= compress_addr_64(SICSLOWPAN_IPHC_SAM_BIT,
  604. <a name="l00572"></a>00572 &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr, &amp;<a class="code" href="a01684.html#ga89bf167a9f1014d2d78754742eb7e06d" title="Host L2 address.">uip_lladdr</a>);
  605. <a name="l00573"></a>00573 <span class="comment">/* No context found for this address */</span>
  606. <a name="l00574"></a>00574 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(uip_is_addr_link_local(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr) &amp;&amp;
  607. <a name="l00575"></a>00575 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[1] == 0 &amp;&amp;
  608. <a name="l00576"></a>00576 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[2] == 0 &amp;&amp;
  609. <a name="l00577"></a>00577 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[3] == 0) {
  610. <a name="l00578"></a>00578 iphc1 |= compress_addr_64(SICSLOWPAN_IPHC_SAM_BIT,
  611. <a name="l00579"></a>00579 &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr, &amp;<a class="code" href="a01684.html#ga89bf167a9f1014d2d78754742eb7e06d" title="Host L2 address.">uip_lladdr</a>);
  612. <a name="l00580"></a>00580 } <span class="keywordflow">else</span> {
  613. <a name="l00581"></a>00581 <span class="comment">/* send the full address =&gt; SAC = 0, SAM = 00 */</span>
  614. <a name="l00582"></a>00582 iphc1 |= SICSLOWPAN_IPHC_SAM_00; <span class="comment">/* 128-bits */</span>
  615. <a name="l00583"></a>00583 memcpy(hc06_ptr, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr.u16[0], 16);
  616. <a name="l00584"></a>00584 hc06_ptr += 16;
  617. <a name="l00585"></a>00585 }
  618. <a name="l00586"></a>00586
  619. <a name="l00587"></a>00587 <span class="comment">/* dest address*/</span>
  620. <a name="l00588"></a>00588 <span class="keywordflow">if</span>(uip_is_addr_mcast(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr)) {
  621. <a name="l00589"></a>00589 <span class="comment">/* Address is multicast, try to compress */</span>
  622. <a name="l00590"></a>00590 iphc1 |= SICSLOWPAN_IPHC_M;
  623. <a name="l00591"></a>00591 <span class="keywordflow">if</span>(sicslowpan_is_mcast_addr_compressable8(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr)) {
  624. <a name="l00592"></a>00592 iphc1 |= SICSLOWPAN_IPHC_DAM_11;
  625. <a name="l00593"></a>00593 <span class="comment">/* use last byte */</span>
  626. <a name="l00594"></a>00594 *hc06_ptr = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u8[15];
  627. <a name="l00595"></a>00595 hc06_ptr += 1;
  628. <a name="l00596"></a>00596 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(sicslowpan_is_mcast_addr_compressable32(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr)) {
  629. <a name="l00597"></a>00597 iphc1 |= SICSLOWPAN_IPHC_DAM_10;
  630. <a name="l00598"></a>00598 <span class="comment">/* second byte + the last three */</span>
  631. <a name="l00599"></a>00599 *hc06_ptr = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u8[1];
  632. <a name="l00600"></a>00600 memcpy(hc06_ptr + 1, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u8[13], 3);
  633. <a name="l00601"></a>00601 hc06_ptr += 4;
  634. <a name="l00602"></a>00602 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(sicslowpan_is_mcast_addr_compressable48(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr)) {
  635. <a name="l00603"></a>00603 iphc1 |= SICSLOWPAN_IPHC_DAM_01;
  636. <a name="l00604"></a>00604 <span class="comment">/* second byte + the last five */</span>
  637. <a name="l00605"></a>00605 *hc06_ptr = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u8[1];
  638. <a name="l00606"></a>00606 memcpy(hc06_ptr + 1, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u8[11], 5);
  639. <a name="l00607"></a>00607 hc06_ptr += 6;
  640. <a name="l00608"></a>00608 } <span class="keywordflow">else</span> {
  641. <a name="l00609"></a>00609 iphc1 |= SICSLOWPAN_IPHC_DAM_00;
  642. <a name="l00610"></a>00610 <span class="comment">/* full address */</span>
  643. <a name="l00611"></a>00611 memcpy(hc06_ptr, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u8[0], 16);
  644. <a name="l00612"></a>00612 hc06_ptr += 16;
  645. <a name="l00613"></a>00613 }
  646. <a name="l00614"></a>00614 } <span class="keywordflow">else</span> {
  647. <a name="l00615"></a>00615 <span class="comment">/* Address is unicast, try to compress */</span>
  648. <a name="l00616"></a>00616 <span class="keywordflow">if</span>((context = addr_context_lookup_by_prefix(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr)) != NULL) {
  649. <a name="l00617"></a>00617 <span class="comment">/* elide the prefix */</span>
  650. <a name="l00618"></a>00618 iphc1 |= SICSLOWPAN_IPHC_DAC;
  651. <a name="l00619"></a>00619 RIME_IPHC_BUF[2] |= context-&gt;number;
  652. <a name="l00620"></a>00620 <span class="comment">/* compession compare with link adress (destination) */</span>
  653. <a name="l00621"></a>00621
  654. <a name="l00622"></a>00622 iphc1 |= compress_addr_64(SICSLOWPAN_IPHC_DAM_BIT,
  655. <a name="l00623"></a>00623 &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr, (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)rime_destaddr);
  656. <a name="l00624"></a>00624 <span class="comment">/* No context found for this address */</span>
  657. <a name="l00625"></a>00625 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(uip_is_addr_link_local(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr) &amp;&amp;
  658. <a name="l00626"></a>00626 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[1] == 0 &amp;&amp;
  659. <a name="l00627"></a>00627 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[2] == 0 &amp;&amp;
  660. <a name="l00628"></a>00628 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[3] == 0) {
  661. <a name="l00629"></a>00629 iphc1 |= compress_addr_64(SICSLOWPAN_IPHC_DAM_BIT,
  662. <a name="l00630"></a>00630 &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr, (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)rime_destaddr);
  663. <a name="l00631"></a>00631 } <span class="keywordflow">else</span> {
  664. <a name="l00632"></a>00632 <span class="comment">/* send the full address */</span>
  665. <a name="l00633"></a>00633 iphc1 |= SICSLOWPAN_IPHC_DAM_00; <span class="comment">/* 128-bits */</span>
  666. <a name="l00634"></a>00634 memcpy(hc06_ptr, &amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr.u16[0], 16);
  667. <a name="l00635"></a>00635 hc06_ptr += 16;
  668. <a name="l00636"></a>00636 }
  669. <a name="l00637"></a>00637 }
  670. <a name="l00638"></a>00638
  671. <a name="l00639"></a>00639 uncomp_hdr_len = UIP_IPH_LEN;
  672. <a name="l00640"></a>00640
  673. <a name="l00641"></a>00641 <span class="preprocessor">#if UIP_CONF_UDP</span>
  674. <a name="l00642"></a>00642 <span class="preprocessor"></span> <span class="comment">/* UDP header compression */</span>
  675. <a name="l00643"></a>00643 <span class="keywordflow">if</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto == UIP_PROTO_UDP) {
  676. <a name="l00644"></a>00644 PRINTF(<span class="stringliteral">&quot;IPHC: Uncompressed UDP ports on send side: %x, %x\n&quot;</span>,
  677. <a name="l00645"></a>00645 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport), <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport));
  678. <a name="l00646"></a>00646 <span class="comment">/* Mask out the last 4 bits can be used as a mask */</span>
  679. <a name="l00647"></a>00647 <span class="keywordflow">if</span>(((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) &amp; 0xfff0) == SICSLOWPAN_UDP_4_BIT_PORT_MIN) &amp;&amp;
  680. <a name="l00648"></a>00648 ((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) &amp; 0xfff0) == SICSLOWPAN_UDP_4_BIT_PORT_MIN)) {
  681. <a name="l00649"></a>00649 <span class="comment">/* we can compress 12 bits of both source and dest */</span>
  682. <a name="l00650"></a>00650 *hc06_ptr = SICSLOWPAN_NHC_UDP_CS_P_11;
  683. <a name="l00651"></a>00651 PRINTF(<span class="stringliteral">&quot;IPHC: remove 12 b of both source &amp; dest with prefix 0xFOB\n&quot;</span>);
  684. <a name="l00652"></a>00652 *(hc06_ptr + 1) =
  685. <a name="l00653"></a>00653 (<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a>)((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) -
  686. <a name="l00654"></a>00654 SICSLOWPAN_UDP_4_BIT_PORT_MIN) &lt;&lt; 4) +
  687. <a name="l00655"></a>00655 (<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a>)((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) -
  688. <a name="l00656"></a>00656 SICSLOWPAN_UDP_4_BIT_PORT_MIN));
  689. <a name="l00657"></a>00657 hc06_ptr += 2;
  690. <a name="l00658"></a>00658 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) &amp; 0xff00) == SICSLOWPAN_UDP_8_BIT_PORT_MIN) {
  691. <a name="l00659"></a>00659 <span class="comment">/* we can compress 8 bits of dest, leave source. */</span>
  692. <a name="l00660"></a>00660 *hc06_ptr = SICSLOWPAN_NHC_UDP_CS_P_01;
  693. <a name="l00661"></a>00661 PRINTF(<span class="stringliteral">&quot;IPHC: leave source, remove 8 bits of dest with prefix 0xF0\n&quot;</span>);
  694. <a name="l00662"></a>00662 memcpy(hc06_ptr + 1, &amp;UIP_UDP_BUF-&gt;srcport, 2);
  695. <a name="l00663"></a>00663 *(hc06_ptr + 3) =
  696. <a name="l00664"></a>00664 (<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a>)((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) -
  697. <a name="l00665"></a>00665 SICSLOWPAN_UDP_8_BIT_PORT_MIN));
  698. <a name="l00666"></a>00666 hc06_ptr += 4;
  699. <a name="l00667"></a>00667 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) &amp; 0xff00) == SICSLOWPAN_UDP_8_BIT_PORT_MIN) {
  700. <a name="l00668"></a>00668 <span class="comment">/* we can compress 8 bits of src, leave dest. Copy compressed port */</span>
  701. <a name="l00669"></a>00669 *hc06_ptr = SICSLOWPAN_NHC_UDP_CS_P_10;
  702. <a name="l00670"></a>00670 PRINTF(<span class="stringliteral">&quot;IPHC: remove 8 bits of source with prefix 0xF0, leave dest. hch: %i\n&quot;</span>, *hc06_ptr);
  703. <a name="l00671"></a>00671 *(hc06_ptr + 1) =
  704. <a name="l00672"></a>00672 (<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a>)((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) -
  705. <a name="l00673"></a>00673 SICSLOWPAN_UDP_8_BIT_PORT_MIN));
  706. <a name="l00674"></a>00674 memcpy(hc06_ptr + 2, &amp;UIP_UDP_BUF-&gt;destport, 2);
  707. <a name="l00675"></a>00675 hc06_ptr += 4;
  708. <a name="l00676"></a>00676 } <span class="keywordflow">else</span> {
  709. <a name="l00677"></a>00677 <span class="comment">/* we cannot compress. Copy uncompressed ports, full checksum */</span>
  710. <a name="l00678"></a>00678 *hc06_ptr = SICSLOWPAN_NHC_UDP_CS_P_00;
  711. <a name="l00679"></a>00679 PRINTF(<span class="stringliteral">&quot;IPHC: cannot compress headers\n&quot;</span>);
  712. <a name="l00680"></a>00680 memcpy(hc06_ptr + 1, &amp;UIP_UDP_BUF-&gt;srcport, 4);
  713. <a name="l00681"></a>00681 hc06_ptr += 5;
  714. <a name="l00682"></a>00682 }
  715. <a name="l00683"></a>00683 <span class="comment">/* always inline the checksum */</span>
  716. <a name="l00684"></a>00684 <span class="keywordflow">if</span>(1) {
  717. <a name="l00685"></a>00685 memcpy(hc06_ptr, &amp;UIP_UDP_BUF-&gt;udpchksum, 2);
  718. <a name="l00686"></a>00686 hc06_ptr += 2;
  719. <a name="l00687"></a>00687 }
  720. <a name="l00688"></a>00688 uncomp_hdr_len += UIP_UDPH_LEN;
  721. <a name="l00689"></a>00689 }
  722. <a name="l00690"></a>00690 <span class="preprocessor">#endif </span><span class="comment">/*UIP_CONF_UDP*/</span>
  723. <a name="l00691"></a>00691
  724. <a name="l00692"></a>00692 <span class="preprocessor">#ifdef SICSLOWPAN_NH_COMPRESSOR</span>
  725. <a name="l00693"></a>00693 <span class="preprocessor"></span> <span class="comment">/* if nothing to compress just return zero */</span>
  726. <a name="l00694"></a>00694 hc06_ptr += SICSLOWPAN_NH_COMPRESSOR.compress(hc06_ptr, &amp;uncomp_hdr_len);
  727. <a name="l00695"></a>00695 <span class="preprocessor">#endif</span>
  728. <a name="l00696"></a>00696 <span class="preprocessor"></span>
  729. <a name="l00697"></a>00697 <span class="comment">/* before the rime_hdr_len operation */</span>
  730. <a name="l00698"></a>00698 RIME_IPHC_BUF[0] = iphc0;
  731. <a name="l00699"></a>00699 RIME_IPHC_BUF[1] = iphc1;
  732. <a name="l00700"></a>00700
  733. <a name="l00701"></a>00701 rime_hdr_len = hc06_ptr - rime_ptr;
  734. <a name="l00702"></a>00702 <span class="keywordflow">return</span>;
  735. <a name="l00703"></a>00703 }
  736. <a name="l00704"></a>00704
  737. <a name="l00705"></a>00705 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  738. <a name="l00706"></a>00706 <span class="comment">/**</span>
  739. <a name="l00707"></a>00707 <span class="comment"> * \brief Uncompress HC06 (i.e., IPHC and LOWPAN_UDP) headers and put</span>
  740. <a name="l00708"></a>00708 <span class="comment"> * them in sicslowpan_buf</span>
  741. <a name="l00709"></a>00709 <span class="comment"> *</span>
  742. <a name="l00710"></a>00710 <span class="comment"> * This function is called by the input function when the dispatch is</span>
  743. <a name="l00711"></a>00711 <span class="comment"> * HC06.</span>
  744. <a name="l00712"></a>00712 <span class="comment"> * We %process the packet in the rime buffer, uncompress the header</span>
  745. <a name="l00713"></a>00713 <span class="comment"> * fields, and copy the result in the sicslowpan buffer.</span>
  746. <a name="l00714"></a>00714 <span class="comment"> * At the end of the decompression, rime_hdr_len and uncompressed_hdr_len</span>
  747. <a name="l00715"></a>00715 <span class="comment"> * are set to the appropriate values</span>
  748. <a name="l00716"></a>00716 <span class="comment"> *</span>
  749. <a name="l00717"></a>00717 <span class="comment"> * \param ip_len Equal to 0 if the packet is not a fragment (IP length</span>
  750. <a name="l00718"></a>00718 <span class="comment"> * is then inferred from the L2 length), non 0 if the packet is a 1st</span>
  751. <a name="l00719"></a>00719 <span class="comment"> * fragment.</span>
  752. <a name="l00720"></a>00720 <span class="comment"> */</span>
  753. <a name="l00721"></a>00721 <span class="keyword">static</span> <span class="keywordtype">void</span>
  754. <a name="l00722"></a>00722 uncompress_hdr_hc06(uint16_t ip_len)
  755. <a name="l00723"></a>00723 {
  756. <a name="l00724"></a>00724 uint8_t tmp, iphc0, iphc1;
  757. <a name="l00725"></a>00725 <span class="comment">/* at least two byte will be used for the encoding */</span>
  758. <a name="l00726"></a>00726 hc06_ptr = rime_ptr + rime_hdr_len + 2;
  759. <a name="l00727"></a>00727
  760. <a name="l00728"></a>00728 iphc0 = RIME_IPHC_BUF[0];
  761. <a name="l00729"></a>00729 iphc1 = RIME_IPHC_BUF[1];
  762. <a name="l00730"></a>00730
  763. <a name="l00731"></a>00731 <span class="comment">/* another if the CID flag is set */</span>
  764. <a name="l00732"></a>00732 <span class="keywordflow">if</span>(iphc1 &amp; SICSLOWPAN_IPHC_CID) {
  765. <a name="l00733"></a>00733 PRINTF(<span class="stringliteral">&quot;IPHC: CID flag set - increase header with one\n&quot;</span>);
  766. <a name="l00734"></a>00734 hc06_ptr++;
  767. <a name="l00735"></a>00735 }
  768. <a name="l00736"></a>00736
  769. <a name="l00737"></a>00737 <span class="comment">/* Traffic class and flow label */</span>
  770. <a name="l00738"></a>00738 <span class="keywordflow">if</span>((iphc0 &amp; SICSLOWPAN_IPHC_FL_C) == 0) {
  771. <a name="l00739"></a>00739 <span class="comment">/* Flow label are carried inline */</span>
  772. <a name="l00740"></a>00740 <span class="keywordflow">if</span>((iphc0 &amp; SICSLOWPAN_IPHC_TC_C) == 0) {
  773. <a name="l00741"></a>00741 <span class="comment">/* Traffic class is carried inline */</span>
  774. <a name="l00742"></a>00742 memcpy(&amp;SICSLOWPAN_IP_BUF-&gt;tcflow, hc06_ptr + 1, 3);
  775. <a name="l00743"></a>00743 tmp = *hc06_ptr;
  776. <a name="l00744"></a>00744 hc06_ptr += 4;
  777. <a name="l00745"></a>00745 <span class="comment">/* hc06 format of tc is ECN | DSCP , original is DSCP | ECN */</span>
  778. <a name="l00746"></a>00746 <span class="comment">/* set version, pick highest DSCP bits and set in vtc */</span>
  779. <a name="l00747"></a>00747 SICSLOWPAN_IP_BUF-&gt;vtc = 0x60 | ((tmp &gt;&gt; 2) &amp; 0x0f);
  780. <a name="l00748"></a>00748 <span class="comment">/* ECN rolled down two steps + lowest DSCP bits at top two bits */</span>
  781. <a name="l00749"></a>00749 SICSLOWPAN_IP_BUF-&gt;tcflow = ((tmp &gt;&gt; 2) &amp; 0x30) | (tmp &lt;&lt; 6) |
  782. <a name="l00750"></a>00750 (SICSLOWPAN_IP_BUF-&gt;tcflow &amp; 0x0f);
  783. <a name="l00751"></a>00751 } <span class="keywordflow">else</span> {
  784. <a name="l00752"></a>00752 <span class="comment">/* Traffic class is compressed (set version and no TC)*/</span>
  785. <a name="l00753"></a>00753 SICSLOWPAN_IP_BUF-&gt;vtc = 0x60;
  786. <a name="l00754"></a>00754 <span class="comment">/* highest flow label bits + ECN bits */</span>
  787. <a name="l00755"></a>00755 SICSLOWPAN_IP_BUF-&gt;tcflow = (*hc06_ptr &amp; 0x0F) |
  788. <a name="l00756"></a>00756 ((*hc06_ptr &gt;&gt; 2) &amp; 0x30);
  789. <a name="l00757"></a>00757 memcpy(&amp;SICSLOWPAN_IP_BUF-&gt;flow, hc06_ptr + 1, 2);
  790. <a name="l00758"></a>00758 hc06_ptr += 3;
  791. <a name="l00759"></a>00759 }
  792. <a name="l00760"></a>00760 } <span class="keywordflow">else</span> {
  793. <a name="l00761"></a>00761 <span class="comment">/* Version is always 6! */</span>
  794. <a name="l00762"></a>00762 <span class="comment">/* Version and flow label are compressed */</span>
  795. <a name="l00763"></a>00763 <span class="keywordflow">if</span>((iphc0 &amp; SICSLOWPAN_IPHC_TC_C) == 0) {
  796. <a name="l00764"></a>00764 <span class="comment">/* Traffic class is inline */</span>
  797. <a name="l00765"></a>00765 SICSLOWPAN_IP_BUF-&gt;vtc = 0x60 | ((*hc06_ptr &gt;&gt; 2) &amp; 0x0f);
  798. <a name="l00766"></a>00766 SICSLOWPAN_IP_BUF-&gt;tcflow = ((*hc06_ptr &lt;&lt; 6) &amp; 0xC0) | ((*hc06_ptr &gt;&gt; 2) &amp; 0x30);
  799. <a name="l00767"></a>00767 SICSLOWPAN_IP_BUF-&gt;flow = 0;
  800. <a name="l00768"></a>00768 hc06_ptr += 3;
  801. <a name="l00769"></a>00769 } <span class="keywordflow">else</span> {
  802. <a name="l00770"></a>00770 <span class="comment">/* Traffic class is compressed */</span>
  803. <a name="l00771"></a>00771 SICSLOWPAN_IP_BUF-&gt;vtc = 0x60;
  804. <a name="l00772"></a>00772 SICSLOWPAN_IP_BUF-&gt;tcflow = 0;
  805. <a name="l00773"></a>00773 SICSLOWPAN_IP_BUF-&gt;flow = 0;
  806. <a name="l00774"></a>00774 }
  807. <a name="l00775"></a>00775 }
  808. <a name="l00776"></a>00776
  809. <a name="l00777"></a>00777 <span class="comment">/* Next Header */</span>
  810. <a name="l00778"></a>00778 <span class="keywordflow">if</span>((iphc0 &amp; SICSLOWPAN_IPHC_NH_C) == 0) {
  811. <a name="l00779"></a>00779 <span class="comment">/* Next header is carried inline */</span>
  812. <a name="l00780"></a>00780 SICSLOWPAN_IP_BUF-&gt;proto = *hc06_ptr;
  813. <a name="l00781"></a>00781 PRINTF(<span class="stringliteral">&quot;IPHC: next header inline: %d\n&quot;</span>, SICSLOWPAN_IP_BUF-&gt;proto);
  814. <a name="l00782"></a>00782 hc06_ptr += 1;
  815. <a name="l00783"></a>00783 }
  816. <a name="l00784"></a>00784
  817. <a name="l00785"></a>00785 <span class="comment">/* Hop limit */</span>
  818. <a name="l00786"></a>00786 <span class="keywordflow">if</span>((iphc0 &amp; 0x03) != SICSLOWPAN_IPHC_TTL_I) {
  819. <a name="l00787"></a>00787 SICSLOWPAN_IP_BUF-&gt;ttl = ttl_values[iphc0 &amp; 0x03];
  820. <a name="l00788"></a>00788 } <span class="keywordflow">else</span> {
  821. <a name="l00789"></a>00789 SICSLOWPAN_IP_BUF-&gt;ttl = *hc06_ptr;
  822. <a name="l00790"></a>00790 hc06_ptr += 1;
  823. <a name="l00791"></a>00791 }
  824. <a name="l00792"></a>00792
  825. <a name="l00793"></a>00793 <span class="comment">/* put the source address compression mode SAM in the tmp var */</span>
  826. <a name="l00794"></a>00794 tmp = ((iphc1 &amp; SICSLOWPAN_IPHC_SAM_11) &gt;&gt; SICSLOWPAN_IPHC_SAM_BIT) &amp; 0x03;
  827. <a name="l00795"></a>00795
  828. <a name="l00796"></a>00796 <span class="comment">/* context based compression */</span>
  829. <a name="l00797"></a>00797 <span class="keywordflow">if</span>(iphc1 &amp; SICSLOWPAN_IPHC_SAC) {
  830. <a name="l00798"></a>00798 uint8_t sci = (iphc1 &amp; SICSLOWPAN_IPHC_CID) ?
  831. <a name="l00799"></a>00799 RIME_IPHC_BUF[2] &gt;&gt; 4 : 0;
  832. <a name="l00800"></a>00800
  833. <a name="l00801"></a>00801 <span class="comment">/* Source address - check context != NULL only if SAM bits are != 0*/</span>
  834. <a name="l00802"></a>00802 <span class="keywordflow">if</span> (tmp != 0) {
  835. <a name="l00803"></a>00803 context = addr_context_lookup_by_number(sci);
  836. <a name="l00804"></a>00804 <span class="keywordflow">if</span>(context == NULL) {
  837. <a name="l00805"></a>00805 PRINTF(<span class="stringliteral">&quot;sicslowpan uncompress_hdr: error context not found\n&quot;</span>);
  838. <a name="l00806"></a>00806 <span class="keywordflow">return</span>;
  839. <a name="l00807"></a>00807 }
  840. <a name="l00808"></a>00808 }
  841. <a name="l00809"></a>00809 <span class="comment">/* if tmp == 0 we do not have a context and therefore no prefix */</span>
  842. <a name="l00810"></a>00810 uncompress_addr(&amp;SICSLOWPAN_IP_BUF-&gt;srcipaddr,
  843. <a name="l00811"></a>00811 tmp != 0 ? context-&gt;prefix : NULL, unc_ctxconf[tmp],
  844. <a name="l00812"></a>00812 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)packetbuf_addr(PACKETBUF_ADDR_SENDER));
  845. <a name="l00813"></a>00813 } <span class="keywordflow">else</span> {
  846. <a name="l00814"></a>00814 <span class="comment">/* no compression and link local */</span>
  847. <a name="l00815"></a>00815 uncompress_addr(&amp;SICSLOWPAN_IP_BUF-&gt;srcipaddr, llprefix, unc_llconf[tmp],
  848. <a name="l00816"></a>00816 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)packetbuf_addr(PACKETBUF_ADDR_SENDER));
  849. <a name="l00817"></a>00817 }
  850. <a name="l00818"></a>00818
  851. <a name="l00819"></a>00819 <span class="comment">/* Destination address */</span>
  852. <a name="l00820"></a>00820 <span class="comment">/* put the destination address compression mode into tmp */</span>
  853. <a name="l00821"></a>00821 tmp = ((iphc1 &amp; SICSLOWPAN_IPHC_DAM_11) &gt;&gt; SICSLOWPAN_IPHC_DAM_BIT) &amp; 0x03;
  854. <a name="l00822"></a>00822
  855. <a name="l00823"></a>00823 <span class="comment">/* multicast compression */</span>
  856. <a name="l00824"></a>00824 <span class="keywordflow">if</span>(iphc1 &amp; SICSLOWPAN_IPHC_M) {
  857. <a name="l00825"></a>00825 <span class="comment">/* context based multicast compression */</span>
  858. <a name="l00826"></a>00826 <span class="keywordflow">if</span>(iphc1 &amp; SICSLOWPAN_IPHC_DAC) {
  859. <a name="l00827"></a>00827 <span class="comment">/* TODO: implement this */</span>
  860. <a name="l00828"></a>00828 } <span class="keywordflow">else</span> {
  861. <a name="l00829"></a>00829 <span class="comment">/* non-context based multicast compression - */</span>
  862. <a name="l00830"></a>00830 <span class="comment">/* DAM_00: 128 bits */</span>
  863. <a name="l00831"></a>00831 <span class="comment">/* DAM_01: 48 bits FFXX::00XX:XXXX:XXXX */</span>
  864. <a name="l00832"></a>00832 <span class="comment">/* DAM_10: 32 bits FFXX::00XX:XXXX */</span>
  865. <a name="l00833"></a>00833 <span class="comment">/* DAM_11: 8 bits FF02::00XX */</span>
  866. <a name="l00834"></a>00834 uint8_t prefix[] = {0xff, 0x02};
  867. <a name="l00835"></a>00835 <span class="keywordflow">if</span>(tmp &gt; 0 &amp;&amp; tmp &lt; 3) {
  868. <a name="l00836"></a>00836 prefix[1] = *hc06_ptr;
  869. <a name="l00837"></a>00837 hc06_ptr++;
  870. <a name="l00838"></a>00838 }
  871. <a name="l00839"></a>00839
  872. <a name="l00840"></a>00840 uncompress_addr(&amp;SICSLOWPAN_IP_BUF-&gt;destipaddr, prefix,
  873. <a name="l00841"></a>00841 unc_mxconf[tmp], NULL);
  874. <a name="l00842"></a>00842 }
  875. <a name="l00843"></a>00843 } <span class="keywordflow">else</span> {
  876. <a name="l00844"></a>00844 <span class="comment">/* no multicast */</span>
  877. <a name="l00845"></a>00845 <span class="comment">/* Context based */</span>
  878. <a name="l00846"></a>00846 <span class="keywordflow">if</span>(iphc1 &amp; SICSLOWPAN_IPHC_DAC) {
  879. <a name="l00847"></a>00847 uint8_t dci = (iphc1 &amp; SICSLOWPAN_IPHC_CID) ?
  880. <a name="l00848"></a>00848 RIME_IPHC_BUF[2] &amp; 0x0f : 0;
  881. <a name="l00849"></a>00849 context = addr_context_lookup_by_number(dci);
  882. <a name="l00850"></a>00850
  883. <a name="l00851"></a>00851 <span class="comment">/* all valid cases below need the context! */</span>
  884. <a name="l00852"></a>00852 <span class="keywordflow">if</span>(context == NULL) {
  885. <a name="l00853"></a>00853 PRINTF(<span class="stringliteral">&quot;sicslowpan uncompress_hdr: error context not found\n&quot;</span>);
  886. <a name="l00854"></a>00854 <span class="keywordflow">return</span>;
  887. <a name="l00855"></a>00855 }
  888. <a name="l00856"></a>00856 uncompress_addr(&amp;SICSLOWPAN_IP_BUF-&gt;destipaddr, context-&gt;prefix,
  889. <a name="l00857"></a>00857 unc_ctxconf[tmp],
  890. <a name="l00858"></a>00858 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)packetbuf_addr(PACKETBUF_ADDR_RECEIVER));
  891. <a name="l00859"></a>00859 } <span class="keywordflow">else</span> {
  892. <a name="l00860"></a>00860 <span class="comment">/* not context based =&gt; link local M = 0, DAC = 0 - same as SAC */</span>
  893. <a name="l00861"></a>00861 uncompress_addr(&amp;SICSLOWPAN_IP_BUF-&gt;destipaddr, llprefix,
  894. <a name="l00862"></a>00862 unc_llconf[tmp],
  895. <a name="l00863"></a>00863 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)packetbuf_addr(PACKETBUF_ADDR_RECEIVER));
  896. <a name="l00864"></a>00864 }
  897. <a name="l00865"></a>00865 }
  898. <a name="l00866"></a>00866 uncomp_hdr_len += UIP_IPH_LEN;
  899. <a name="l00867"></a>00867
  900. <a name="l00868"></a>00868 <span class="comment">/* Next header processing - continued */</span>
  901. <a name="l00869"></a>00869 <span class="keywordflow">if</span>((iphc0 &amp; SICSLOWPAN_IPHC_NH_C)) {
  902. <a name="l00870"></a>00870 <span class="comment">/* The next header is compressed, NHC is following */</span>
  903. <a name="l00871"></a>00871 <span class="keywordflow">if</span>((*hc06_ptr &amp; SICSLOWPAN_NHC_UDP_MASK) == SICSLOWPAN_NHC_UDP_ID) {
  904. <a name="l00872"></a>00872 uint8_t checksum_compressed;
  905. <a name="l00873"></a>00873 SICSLOWPAN_IP_BUF-&gt;proto = UIP_PROTO_UDP;
  906. <a name="l00874"></a>00874 checksum_compressed = *hc06_ptr &amp; SICSLOWPAN_NHC_UDP_CHECKSUMC;
  907. <a name="l00875"></a>00875 PRINTF(<span class="stringliteral">&quot;IPHC: Incoming header value: %i\n&quot;</span>, *hc06_ptr);
  908. <a name="l00876"></a>00876 <span class="keywordflow">switch</span>(*hc06_ptr &amp; SICSLOWPAN_NHC_UDP_CS_P_11) {
  909. <a name="l00877"></a>00877 <span class="keywordflow">case</span> SICSLOWPAN_NHC_UDP_CS_P_00:
  910. <a name="l00878"></a>00878 <span class="comment">/* 1 byte for NHC, 4 byte for ports, 2 bytes chksum */</span>
  911. <a name="l00879"></a>00879 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;srcport, hc06_ptr + 1, 2);
  912. <a name="l00880"></a>00880 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;destport, hc06_ptr + 3, 2);
  913. <a name="l00881"></a>00881 PRINTF(<span class="stringliteral">&quot;IPHC: Uncompressed UDP ports (ptr+5): %x, %x\n&quot;</span>,
  914. <a name="l00882"></a>00882 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;srcport), <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;destport));
  915. <a name="l00883"></a>00883 hc06_ptr += 5;
  916. <a name="l00884"></a>00884 <span class="keywordflow">break</span>;
  917. <a name="l00885"></a>00885
  918. <a name="l00886"></a>00886 <span class="keywordflow">case</span> SICSLOWPAN_NHC_UDP_CS_P_01:
  919. <a name="l00887"></a>00887 <span class="comment">/* 1 byte for NHC + source 16bit inline, dest = 0xF0 + 8 bit inline */</span>
  920. <a name="l00888"></a>00888 PRINTF(<span class="stringliteral">&quot;IPHC: Decompressing destination\n&quot;</span>);
  921. <a name="l00889"></a>00889 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;srcport, hc06_ptr + 1, 2);
  922. <a name="l00890"></a>00890 SICSLOWPAN_UDP_BUF-&gt;destport = <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_8_BIT_PORT_MIN + (*(hc06_ptr + 3)));
  923. <a name="l00891"></a>00891 PRINTF(<span class="stringliteral">&quot;IPHC: Uncompressed UDP ports (ptr+4): %x, %x\n&quot;</span>,
  924. <a name="l00892"></a>00892 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;srcport), <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;destport));
  925. <a name="l00893"></a>00893 hc06_ptr += 4;
  926. <a name="l00894"></a>00894 <span class="keywordflow">break</span>;
  927. <a name="l00895"></a>00895
  928. <a name="l00896"></a>00896 <span class="keywordflow">case</span> SICSLOWPAN_NHC_UDP_CS_P_10:
  929. <a name="l00897"></a>00897 <span class="comment">/* 1 byte for NHC + source = 0xF0 + 8bit inline, dest = 16 bit inline*/</span>
  930. <a name="l00898"></a>00898 PRINTF(<span class="stringliteral">&quot;IPHC: Decompressing source\n&quot;</span>);
  931. <a name="l00899"></a>00899 SICSLOWPAN_UDP_BUF-&gt;srcport = <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_8_BIT_PORT_MIN +
  932. <a name="l00900"></a>00900 (*(hc06_ptr + 1)));
  933. <a name="l00901"></a>00901 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;destport, hc06_ptr + 2, 2);
  934. <a name="l00902"></a>00902 PRINTF(<span class="stringliteral">&quot;IPHC: Uncompressed UDP ports (ptr+4): %x, %x\n&quot;</span>,
  935. <a name="l00903"></a>00903 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;srcport), <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;destport));
  936. <a name="l00904"></a>00904 hc06_ptr += 4;
  937. <a name="l00905"></a>00905 <span class="keywordflow">break</span>;
  938. <a name="l00906"></a>00906
  939. <a name="l00907"></a>00907 <span class="keywordflow">case</span> SICSLOWPAN_NHC_UDP_CS_P_11:
  940. <a name="l00908"></a>00908 <span class="comment">/* 1 byte for NHC, 1 byte for ports */</span>
  941. <a name="l00909"></a>00909 SICSLOWPAN_UDP_BUF-&gt;srcport = <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_4_BIT_PORT_MIN +
  942. <a name="l00910"></a>00910 (*(hc06_ptr + 1) &gt;&gt; 4));
  943. <a name="l00911"></a>00911 SICSLOWPAN_UDP_BUF-&gt;destport = <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_4_BIT_PORT_MIN +
  944. <a name="l00912"></a>00912 ((*(hc06_ptr + 1)) &amp; 0x0F));
  945. <a name="l00913"></a>00913 PRINTF(<span class="stringliteral">&quot;IPHC: Uncompressed UDP ports (ptr+2): %x, %x\n&quot;</span>,
  946. <a name="l00914"></a>00914 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;srcport), <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_BUF-&gt;destport));
  947. <a name="l00915"></a>00915 hc06_ptr += 2;
  948. <a name="l00916"></a>00916 <span class="keywordflow">break</span>;
  949. <a name="l00917"></a>00917
  950. <a name="l00918"></a>00918 <span class="keywordflow">default</span>:
  951. <a name="l00919"></a>00919 PRINTF(<span class="stringliteral">&quot;sicslowpan uncompress_hdr: error unsupported UDP compression\n&quot;</span>);
  952. <a name="l00920"></a>00920 <span class="keywordflow">return</span>;
  953. <a name="l00921"></a>00921 }
  954. <a name="l00922"></a>00922 <span class="keywordflow">if</span>(!checksum_compressed) { <span class="comment">/* has_checksum, default */</span>
  955. <a name="l00923"></a>00923 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;udpchksum, hc06_ptr, 2);
  956. <a name="l00924"></a>00924 hc06_ptr += 2;
  957. <a name="l00925"></a>00925 PRINTF(<span class="stringliteral">&quot;IPHC: sicslowpan uncompress_hdr: checksum included\n&quot;</span>);
  958. <a name="l00926"></a>00926 } <span class="keywordflow">else</span> {
  959. <a name="l00927"></a>00927 PRINTF(<span class="stringliteral">&quot;IPHC: sicslowpan uncompress_hdr: checksum *NOT* included\n&quot;</span>);
  960. <a name="l00928"></a>00928 }
  961. <a name="l00929"></a>00929 uncomp_hdr_len += UIP_UDPH_LEN;
  962. <a name="l00930"></a>00930 }
  963. <a name="l00931"></a>00931 <span class="preprocessor">#ifdef SICSLOWPAN_NH_COMPRESSOR</span>
  964. <a name="l00932"></a>00932 <span class="preprocessor"></span> <span class="keywordflow">else</span> {
  965. <a name="l00933"></a>00933 hc06_ptr += SICSLOWPAN_NH_COMPRESSOR.uncompress(hc06_ptr, <a class="code" href="a01680.html#ga2c312c370c91d9cc20fc0c97fd430fab" title="The buffer used for the 6lowpan processing is uip_buf.">sicslowpan_buf</a>, &amp;uncomp_hdr_len);
  966. <a name="l00934"></a>00934 }
  967. <a name="l00935"></a>00935 <span class="preprocessor">#endif</span>
  968. <a name="l00936"></a>00936 <span class="preprocessor"></span> }
  969. <a name="l00937"></a>00937
  970. <a name="l00938"></a>00938 rime_hdr_len = hc06_ptr - rime_ptr;
  971. <a name="l00939"></a>00939
  972. <a name="l00940"></a>00940 <span class="comment">/* IP length field. */</span>
  973. <a name="l00941"></a>00941 <span class="keywordflow">if</span>(ip_len == 0) {
  974. <a name="l00942"></a>00942 <span class="comment">/* This is not a fragmented packet */</span>
  975. <a name="l00943"></a>00943 SICSLOWPAN_IP_BUF-&gt;len[0] = 0;
  976. <a name="l00944"></a>00944 SICSLOWPAN_IP_BUF-&gt;len[1] = <a class="code" href="a01563.html#ga4a1157b882c15f5ea05d64f81d37115d" title="Get the length of the data in the packetbuf.">packetbuf_datalen</a>() - rime_hdr_len + uncomp_hdr_len - UIP_IPH_LEN;
  977. <a name="l00945"></a>00945 } <span class="keywordflow">else</span> {
  978. <a name="l00946"></a>00946 <span class="comment">/* This is a 1st fragment */</span>
  979. <a name="l00947"></a>00947 SICSLOWPAN_IP_BUF-&gt;len[0] = (ip_len - UIP_IPH_LEN) &gt;&gt; 8;
  980. <a name="l00948"></a>00948 SICSLOWPAN_IP_BUF-&gt;len[1] = (ip_len - UIP_IPH_LEN) &amp; 0x00FF;
  981. <a name="l00949"></a>00949 }
  982. <a name="l00950"></a>00950
  983. <a name="l00951"></a>00951 <span class="comment">/* length field in UDP header */</span>
  984. <a name="l00952"></a>00952 <span class="keywordflow">if</span>(SICSLOWPAN_IP_BUF-&gt;proto == UIP_PROTO_UDP) {
  985. <a name="l00953"></a>00953 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;udplen, &amp;SICSLOWPAN_IP_BUF-&gt;len[0], 2);
  986. <a name="l00954"></a>00954 }
  987. <a name="l00955"></a>00955
  988. <a name="l00956"></a>00956 <span class="keywordflow">return</span>;
  989. <a name="l00957"></a>00957 }<span class="comment"></span>
  990. <a name="l00958"></a>00958 <span class="comment">/** @} */</span>
  991. <a name="l00959"></a>00959 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06 */</span>
  992. <a name="l00960"></a>00960
  993. <a name="l00961"></a>00961
  994. <a name="l00962"></a>00962 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC1</span>
  995. <a name="l00963"></a>00963 <span class="preprocessor"></span><span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  996. <a name="l00964"></a>00964 <span class="comment">/** \name HC1 compression and uncompression functions</span>
  997. <a name="l00965"></a>00965 <span class="comment"> * @{ */</span>
  998. <a name="l00966"></a>00966 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  999. <a name="l00967"></a>00967 <span class="comment">/**</span>
  1000. <a name="l00968"></a>00968 <span class="comment"> * \brief Compress IP/UDP header using HC1 and HC_UDP</span>
  1001. <a name="l00969"></a>00969 <span class="comment"> *</span>
  1002. <a name="l00970"></a>00970 <span class="comment"> * This function is called by the 6lowpan code to create a compressed</span>
  1003. <a name="l00971"></a>00971 <span class="comment"> * 6lowpan packet in the packetbuf buffer from a full IPv6 packet in the</span>
  1004. <a name="l00972"></a>00972 <span class="comment"> * uip_buf buffer.</span>
  1005. <a name="l00973"></a>00973 <span class="comment"> *</span>
  1006. <a name="l00974"></a>00974 <span class="comment"> *</span>
  1007. <a name="l00975"></a>00975 <span class="comment"> * If we can compress everything, we use HC1 dispatch, if not we use</span>
  1008. <a name="l00976"></a>00976 <span class="comment"> * IPv6 dispatch.\n</span>
  1009. <a name="l00977"></a>00977 <span class="comment"> * We can compress everything if:</span>
  1010. <a name="l00978"></a>00978 <span class="comment"> * - IP version is</span>
  1011. <a name="l00979"></a>00979 <span class="comment"> * - Flow label and traffic class are 0</span>
  1012. <a name="l00980"></a>00980 <span class="comment"> * - Both src and dest ip addresses are link local</span>
  1013. <a name="l00981"></a>00981 <span class="comment"> * - Both src and dest interface ID are recoverable from lower layer</span>
  1014. <a name="l00982"></a>00982 <span class="comment"> * header</span>
  1015. <a name="l00983"></a>00983 <span class="comment"> * - Next header is either ICMP, UDP or TCP</span>
  1016. <a name="l00984"></a>00984 <span class="comment"> * Moreover, if next header is UDP, we try to compress it using HC_UDP.</span>
  1017. <a name="l00985"></a>00985 <span class="comment"> * This is feasible is both ports are between F0B0 and F0B0 + 15\n\n</span>
  1018. <a name="l00986"></a>00986 <span class="comment"> *</span>
  1019. <a name="l00987"></a>00987 <span class="comment"> * Resulting header structure:</span>
  1020. <a name="l00988"></a>00988 <span class="comment"> * - For ICMP, TCP, non compressed UDP\n</span>
  1021. <a name="l00989"></a>00989 <span class="comment"> * HC1 encoding = 11111010 (UDP) 11111110 (TCP) 11111100 (ICMP)\n</span>
  1022. <a name="l00990"></a>00990 <span class="comment"> * \verbatim</span>
  1023. <a name="l00991"></a>00991 <span class="comment"> * 1 2 3</span>
  1024. <a name="l00992"></a>00992 <span class="comment"> * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1</span>
  1025. <a name="l00993"></a>00993 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1026. <a name="l00994"></a>00994 <span class="comment"> * | LoWPAN HC1 Dsp | HC1 encoding | IPv6 Hop limit| L4 hdr + data|</span>
  1027. <a name="l00995"></a>00995 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1028. <a name="l00996"></a>00996 <span class="comment"> * | ...</span>
  1029. <a name="l00997"></a>00997 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1030. <a name="l00998"></a>00998 <span class="comment"> * \endverbatim</span>
  1031. <a name="l00999"></a>00999 <span class="comment"> *</span>
  1032. <a name="l01000"></a>01000 <span class="comment"> * - For compressed UDP</span>
  1033. <a name="l01001"></a>01001 <span class="comment"> * HC1 encoding = 11111011, HC_UDP encoding = 11100000\n</span>
  1034. <a name="l01002"></a>01002 <span class="comment"> * \verbatim</span>
  1035. <a name="l01003"></a>01003 <span class="comment"> * 1 2 3</span>
  1036. <a name="l01004"></a>01004 <span class="comment"> * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1</span>
  1037. <a name="l01005"></a>01005 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1038. <a name="l01006"></a>01006 <span class="comment"> * | LoWPAN HC1 Dsp| HC1 encoding | HC_UDP encod.| IPv6 Hop limit|</span>
  1039. <a name="l01007"></a>01007 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1040. <a name="l01008"></a>01008 <span class="comment"> * | src p.| dst p.| UDP checksum | L4 data...</span>
  1041. <a name="l01009"></a>01009 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1042. <a name="l01010"></a>01010 <span class="comment"> * \endverbatim</span>
  1043. <a name="l01011"></a>01011 <span class="comment"> *</span>
  1044. <a name="l01012"></a>01012 <span class="comment"> * \param rime_destaddr L2 destination address, needed to compress the</span>
  1045. <a name="l01013"></a>01013 <span class="comment"> * IP destination field</span>
  1046. <a name="l01014"></a>01014 <span class="comment"> */</span>
  1047. <a name="l01015"></a>01015 <span class="keyword">static</span> <span class="keywordtype">void</span>
  1048. <a name="l01016"></a>01016 compress_hdr_hc1(rimeaddr_t *rime_destaddr)
  1049. <a name="l01017"></a>01017 {
  1050. <a name="l01018"></a>01018 <span class="comment">/*</span>
  1051. <a name="l01019"></a>01019 <span class="comment"> * Check if all the assumptions for full compression</span>
  1052. <a name="l01020"></a>01020 <span class="comment"> * are valid :</span>
  1053. <a name="l01021"></a>01021 <span class="comment"> */</span>
  1054. <a name="l01022"></a>01022 <span class="keywordflow">if</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;vtc != 0x60 ||
  1055. <a name="l01023"></a>01023 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;tcflow != 0 ||
  1056. <a name="l01024"></a>01024 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;flow != 0 ||
  1057. <a name="l01025"></a>01025 !uip_is_addr_link_local(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr) ||
  1058. <a name="l01026"></a>01026 !uip_is_addr_mac_addr_based(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;srcipaddr, &amp;<a class="code" href="a01684.html#ga89bf167a9f1014d2d78754742eb7e06d" title="Host L2 address.">uip_lladdr</a>) ||
  1059. <a name="l01027"></a>01027 !uip_is_addr_link_local(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr) ||
  1060. <a name="l01028"></a>01028 !uip_is_addr_mac_addr_based(&amp;<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;destipaddr,
  1061. <a name="l01029"></a>01029 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)rime_destaddr) ||
  1062. <a name="l01030"></a>01030 (<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto != UIP_PROTO_ICMP6 &amp;&amp;
  1063. <a name="l01031"></a>01031 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto != UIP_PROTO_UDP &amp;&amp;
  1064. <a name="l01032"></a>01032 <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto != UIP_PROTO_TCP))
  1065. <a name="l01033"></a>01033 {
  1066. <a name="l01034"></a>01034 <span class="comment">/*</span>
  1067. <a name="l01035"></a>01035 <span class="comment"> * IPV6 DISPATCH</span>
  1068. <a name="l01036"></a>01036 <span class="comment"> * Something cannot be compressed, use IPV6 DISPATCH,</span>
  1069. <a name="l01037"></a>01037 <span class="comment"> * compress nothing, copy IPv6 header in rime buffer</span>
  1070. <a name="l01038"></a>01038 <span class="comment"> */</span>
  1071. <a name="l01039"></a>01039 *rime_ptr = SICSLOWPAN_DISPATCH_IPV6;
  1072. <a name="l01040"></a>01040 rime_hdr_len += SICSLOWPAN_IPV6_HDR_LEN;
  1073. <a name="l01041"></a>01041 memcpy(rime_ptr + rime_hdr_len, <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>, UIP_IPH_LEN);
  1074. <a name="l01042"></a>01042 rime_hdr_len += UIP_IPH_LEN;
  1075. <a name="l01043"></a>01043 uncomp_hdr_len += UIP_IPH_LEN;
  1076. <a name="l01044"></a>01044 } <span class="keywordflow">else</span> {
  1077. <a name="l01045"></a>01045 <span class="comment">/*</span>
  1078. <a name="l01046"></a>01046 <span class="comment"> * HC1 DISPATCH</span>
  1079. <a name="l01047"></a>01047 <span class="comment"> * maximum compresssion:</span>
  1080. <a name="l01048"></a>01048 <span class="comment"> * All fields in the IP header but Hop Limit are elided</span>
  1081. <a name="l01049"></a>01049 <span class="comment"> * If next header is UDP, we compress UDP header using HC2</span>
  1082. <a name="l01050"></a>01050 <span class="comment"> */</span>
  1083. <a name="l01051"></a>01051 RIME_HC1_PTR[RIME_HC1_DISPATCH] = SICSLOWPAN_DISPATCH_HC1;
  1084. <a name="l01052"></a>01052 uncomp_hdr_len += UIP_IPH_LEN;
  1085. <a name="l01053"></a>01053 <span class="keywordflow">switch</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto) {
  1086. <a name="l01054"></a>01054 <span class="keywordflow">case</span> UIP_PROTO_ICMP6:
  1087. <a name="l01055"></a>01055 <span class="comment">/* HC1 encoding and ttl */</span>
  1088. <a name="l01056"></a>01056 RIME_HC1_PTR[RIME_HC1_ENCODING] = 0xFC;
  1089. <a name="l01057"></a>01057 RIME_HC1_PTR[RIME_HC1_TTL] = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;ttl;
  1090. <a name="l01058"></a>01058 rime_hdr_len += SICSLOWPAN_HC1_HDR_LEN;
  1091. <a name="l01059"></a>01059 <span class="keywordflow">break</span>;
  1092. <a name="l01060"></a>01060 <span class="preprocessor">#if UIP_CONF_TCP</span>
  1093. <a name="l01061"></a>01061 <span class="preprocessor"></span> <span class="keywordflow">case</span> UIP_PROTO_TCP:
  1094. <a name="l01062"></a>01062 <span class="comment">/* HC1 encoding and ttl */</span>
  1095. <a name="l01063"></a>01063 RIME_HC1_PTR[RIME_HC1_ENCODING] = 0xFE;
  1096. <a name="l01064"></a>01064 RIME_HC1_PTR[RIME_HC1_TTL] = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;ttl;
  1097. <a name="l01065"></a>01065 rime_hdr_len += SICSLOWPAN_HC1_HDR_LEN;
  1098. <a name="l01066"></a>01066 <span class="keywordflow">break</span>;
  1099. <a name="l01067"></a>01067 <span class="preprocessor">#endif </span><span class="comment">/* UIP_CONF_TCP */</span>
  1100. <a name="l01068"></a>01068 <span class="preprocessor">#if UIP_CONF_UDP</span>
  1101. <a name="l01069"></a>01069 <span class="preprocessor"></span> <span class="keywordflow">case</span> UIP_PROTO_UDP:
  1102. <a name="l01070"></a>01070 <span class="comment">/*</span>
  1103. <a name="l01071"></a>01071 <span class="comment"> * try to compress UDP header (we do only full compression).</span>
  1104. <a name="l01072"></a>01072 <span class="comment"> * This is feasible if both src and dest ports are between</span>
  1105. <a name="l01073"></a>01073 <span class="comment"> * SICSLOWPAN_UDP_PORT_MIN and SICSLOWPAN_UDP_PORT_MIN + 15</span>
  1106. <a name="l01074"></a>01074 <span class="comment"> */</span>
  1107. <a name="l01075"></a>01075 PRINTF(<span class="stringliteral">&quot;local/remote port %u/%u\n&quot;</span>,UIP_UDP_BUF-&gt;srcport,UIP_UDP_BUF-&gt;destport);
  1108. <a name="l01076"></a>01076 <span class="keywordflow">if</span>(<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) &gt;= SICSLOWPAN_UDP_PORT_MIN &amp;&amp;
  1109. <a name="l01077"></a>01077 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) &lt; SICSLOWPAN_UDP_PORT_MAX &amp;&amp;
  1110. <a name="l01078"></a>01078 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) &gt;= SICSLOWPAN_UDP_PORT_MIN &amp;&amp;
  1111. <a name="l01079"></a>01079 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) &lt; SICSLOWPAN_UDP_PORT_MAX) {
  1112. <a name="l01080"></a>01080 <span class="comment">/* HC1 encoding */</span>
  1113. <a name="l01081"></a>01081 RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_HC1_ENCODING] = 0xFB;
  1114. <a name="l01082"></a>01082
  1115. <a name="l01083"></a>01083 <span class="comment">/* HC_UDP encoding, ttl, src and dest ports, checksum */</span>
  1116. <a name="l01084"></a>01084 RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_UDP_ENCODING] = 0xE0;
  1117. <a name="l01085"></a>01085 RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_TTL] = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;ttl;
  1118. <a name="l01086"></a>01086
  1119. <a name="l01087"></a>01087 RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_PORTS] =
  1120. <a name="l01088"></a>01088 (<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a>)((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;srcport) -
  1121. <a name="l01089"></a>01089 SICSLOWPAN_UDP_PORT_MIN) &lt;&lt; 4) +
  1122. <a name="l01090"></a>01090 (<a class="code" href="a01668.html#ga4caecabca98b43919dd11be1c0d4cd8e" title="The 8-bit unsigned data type.">u8_t</a>)((<a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(UIP_UDP_BUF-&gt;destport) - SICSLOWPAN_UDP_PORT_MIN));
  1123. <a name="l01091"></a>01091 memcpy(&amp;RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_CHKSUM], &amp;UIP_UDP_BUF-&gt;udpchksum, 2);
  1124. <a name="l01092"></a>01092 rime_hdr_len += SICSLOWPAN_HC1_HC_UDP_HDR_LEN;
  1125. <a name="l01093"></a>01093 uncomp_hdr_len += UIP_UDPH_LEN;
  1126. <a name="l01094"></a>01094 } <span class="keywordflow">else</span> {
  1127. <a name="l01095"></a>01095 <span class="comment">/* HC1 encoding and ttl */</span>
  1128. <a name="l01096"></a>01096 RIME_HC1_PTR[RIME_HC1_ENCODING] = 0xFA;
  1129. <a name="l01097"></a>01097 RIME_HC1_PTR[RIME_HC1_TTL] = <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;ttl;
  1130. <a name="l01098"></a>01098 rime_hdr_len += SICSLOWPAN_HC1_HDR_LEN;
  1131. <a name="l01099"></a>01099 }
  1132. <a name="l01100"></a>01100 <span class="keywordflow">break</span>;
  1133. <a name="l01101"></a>01101 <span class="preprocessor">#endif </span><span class="comment">/*UIP_CONF_UDP*/</span>
  1134. <a name="l01102"></a>01102 }
  1135. <a name="l01103"></a>01103 }
  1136. <a name="l01104"></a>01104 <span class="keywordflow">return</span>;
  1137. <a name="l01105"></a>01105 }
  1138. <a name="l01106"></a>01106
  1139. <a name="l01107"></a>01107 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1140. <a name="l01108"></a>01108 <span class="comment">/**</span>
  1141. <a name="l01109"></a>01109 <span class="comment"> * \brief Uncompress HC1 (and HC_UDP) headers and put them in</span>
  1142. <a name="l01110"></a>01110 <span class="comment"> * sicslowpan_buf</span>
  1143. <a name="l01111"></a>01111 <span class="comment"> *</span>
  1144. <a name="l01112"></a>01112 <span class="comment"> * This function is called by the input function when the dispatch is</span>
  1145. <a name="l01113"></a>01113 <span class="comment"> * HC1.</span>
  1146. <a name="l01114"></a>01114 <span class="comment"> * We %process the packet in the rime buffer, uncompress the header</span>
  1147. <a name="l01115"></a>01115 <span class="comment"> * fields, and copy the result in the sicslowpan buffer.</span>
  1148. <a name="l01116"></a>01116 <span class="comment"> * At the end of the decompression, rime_hdr_len and uncompressed_hdr_len</span>
  1149. <a name="l01117"></a>01117 <span class="comment"> * are set to the appropriate values</span>
  1150. <a name="l01118"></a>01118 <span class="comment"> *</span>
  1151. <a name="l01119"></a>01119 <span class="comment"> * \param ip_len Equal to 0 if the packet is not a fragment (IP length</span>
  1152. <a name="l01120"></a>01120 <span class="comment"> * is then inferred from the L2 length), non 0 if the packet is a 1st</span>
  1153. <a name="l01121"></a>01121 <span class="comment"> * fragment.</span>
  1154. <a name="l01122"></a>01122 <span class="comment"> */</span>
  1155. <a name="l01123"></a>01123 <span class="keyword">static</span> <span class="keywordtype">void</span>
  1156. <a name="l01124"></a>01124 uncompress_hdr_hc1(uint16_t ip_len)
  1157. <a name="l01125"></a>01125 {
  1158. <a name="l01126"></a>01126 <span class="comment">/* version, traffic class, flow label */</span>
  1159. <a name="l01127"></a>01127 SICSLOWPAN_IP_BUF-&gt;vtc = 0x60;
  1160. <a name="l01128"></a>01128 SICSLOWPAN_IP_BUF-&gt;tcflow = 0;
  1161. <a name="l01129"></a>01129 SICSLOWPAN_IP_BUF-&gt;flow = 0;
  1162. <a name="l01130"></a>01130
  1163. <a name="l01131"></a>01131 <span class="comment">/* src and dest ip addresses */</span>
  1164. <a name="l01132"></a>01132 <a class="code" href="a01576.html#ga53fbda0e8c31d4882294c8dc3cb5f487" title="Construct an IPv6 address from eight 16-bit words.">uip_ip6addr</a>(&amp;SICSLOWPAN_IP_BUF-&gt;srcipaddr, 0xfe80, 0, 0, 0, 0, 0, 0, 0);
  1165. <a name="l01133"></a>01133 uip_sd6_set_addr_iid(&amp;SICSLOWPAN_IP_BUF-&gt;srcipaddr,
  1166. <a name="l01134"></a>01134 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)packetbuf_addr(PACKETBUF_ADDR_SENDER));
  1167. <a name="l01135"></a>01135 <a class="code" href="a01576.html#ga53fbda0e8c31d4882294c8dc3cb5f487" title="Construct an IPv6 address from eight 16-bit words.">uip_ip6addr</a>(&amp;SICSLOWPAN_IP_BUF-&gt;destipaddr, 0xfe80, 0, 0, 0, 0, 0, 0, 0);
  1168. <a name="l01136"></a>01136 uip_sd6_set_addr_iid(&amp;SICSLOWPAN_IP_BUF-&gt;destipaddr,
  1169. <a name="l01137"></a>01137 (<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *)packetbuf_addr(PACKETBUF_ADDR_RECEIVER));
  1170. <a name="l01138"></a>01138
  1171. <a name="l01139"></a>01139 uncomp_hdr_len += UIP_IPH_LEN;
  1172. <a name="l01140"></a>01140
  1173. <a name="l01141"></a>01141 <span class="comment">/* Next header field */</span>
  1174. <a name="l01142"></a>01142 <span class="keywordflow">switch</span>(RIME_HC1_PTR[RIME_HC1_ENCODING] &amp; 0x06) {
  1175. <a name="l01143"></a>01143 <span class="keywordflow">case</span> SICSLOWPAN_HC1_NH_ICMP6:
  1176. <a name="l01144"></a>01144 SICSLOWPAN_IP_BUF-&gt;proto = UIP_PROTO_ICMP6;
  1177. <a name="l01145"></a>01145 SICSLOWPAN_IP_BUF-&gt;ttl = RIME_HC1_PTR[RIME_HC1_TTL];
  1178. <a name="l01146"></a>01146 rime_hdr_len += SICSLOWPAN_HC1_HDR_LEN;
  1179. <a name="l01147"></a>01147 <span class="keywordflow">break</span>;
  1180. <a name="l01148"></a>01148 <span class="preprocessor">#if UIP_CONF_TCP</span>
  1181. <a name="l01149"></a>01149 <span class="preprocessor"></span> <span class="keywordflow">case</span> SICSLOWPAN_HC1_NH_TCP:
  1182. <a name="l01150"></a>01150 SICSLOWPAN_IP_BUF-&gt;proto = UIP_PROTO_TCP;
  1183. <a name="l01151"></a>01151 SICSLOWPAN_IP_BUF-&gt;ttl = RIME_HC1_PTR[RIME_HC1_TTL];
  1184. <a name="l01152"></a>01152 rime_hdr_len += SICSLOWPAN_HC1_HDR_LEN;
  1185. <a name="l01153"></a>01153 <span class="keywordflow">break</span>;
  1186. <a name="l01154"></a>01154 <span class="preprocessor">#endif</span><span class="comment">/* UIP_CONF_TCP */</span>
  1187. <a name="l01155"></a>01155 <span class="preprocessor">#if UIP_CONF_UDP</span>
  1188. <a name="l01156"></a>01156 <span class="preprocessor"></span> <span class="keywordflow">case</span> SICSLOWPAN_HC1_NH_UDP:
  1189. <a name="l01157"></a>01157 SICSLOWPAN_IP_BUF-&gt;proto = UIP_PROTO_UDP;
  1190. <a name="l01158"></a>01158 <span class="keywordflow">if</span>(RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_HC1_ENCODING] &amp; 0x01) {
  1191. <a name="l01159"></a>01159 <span class="comment">/* UDP header is compressed with HC_UDP */</span>
  1192. <a name="l01160"></a>01160 <span class="keywordflow">if</span>(RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_UDP_ENCODING] !=
  1193. <a name="l01161"></a>01161 SICSLOWPAN_HC_UDP_ALL_C) {
  1194. <a name="l01162"></a>01162 PRINTF(<span class="stringliteral">&quot;sicslowpan (uncompress_hdr), packet not supported&quot;</span>);
  1195. <a name="l01163"></a>01163 <span class="keywordflow">return</span>;
  1196. <a name="l01164"></a>01164 }
  1197. <a name="l01165"></a>01165 <span class="comment">/* IP TTL */</span>
  1198. <a name="l01166"></a>01166 SICSLOWPAN_IP_BUF-&gt;ttl = RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_TTL];
  1199. <a name="l01167"></a>01167 <span class="comment">/* UDP ports, len, checksum */</span>
  1200. <a name="l01168"></a>01168 SICSLOWPAN_UDP_BUF-&gt;srcport =
  1201. <a name="l01169"></a>01169 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_PORT_MIN +
  1202. <a name="l01170"></a>01170 (RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_PORTS] &gt;&gt; 4));
  1203. <a name="l01171"></a>01171 SICSLOWPAN_UDP_BUF-&gt;destport =
  1204. <a name="l01172"></a>01172 <a class="code" href="a01576.html#ga703ee949a28cb00b5f8ee54bfe664e8d" title="Convert 16-bit quantity from host byte order to network byte order.">UIP_HTONS</a>(SICSLOWPAN_UDP_PORT_MIN +
  1205. <a name="l01173"></a>01173 (RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_PORTS] &amp; 0x0F));
  1206. <a name="l01174"></a>01174 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;udpchksum, &amp;RIME_HC1_HC_UDP_PTR[RIME_HC1_HC_UDP_CHKSUM], 2);
  1207. <a name="l01175"></a>01175 uncomp_hdr_len += UIP_UDPH_LEN;
  1208. <a name="l01176"></a>01176 rime_hdr_len += SICSLOWPAN_HC1_HC_UDP_HDR_LEN;
  1209. <a name="l01177"></a>01177 } <span class="keywordflow">else</span> {
  1210. <a name="l01178"></a>01178 rime_hdr_len += SICSLOWPAN_HC1_HDR_LEN;
  1211. <a name="l01179"></a>01179 }
  1212. <a name="l01180"></a>01180 <span class="keywordflow">break</span>;
  1213. <a name="l01181"></a>01181 <span class="preprocessor">#endif</span><span class="comment">/* UIP_CONF_UDP */</span>
  1214. <a name="l01182"></a>01182 <span class="keywordflow">default</span>:
  1215. <a name="l01183"></a>01183 <span class="comment">/* this shouldn&apos;t happen, drop */</span>
  1216. <a name="l01184"></a>01184 <span class="keywordflow">return</span>;
  1217. <a name="l01185"></a>01185 }
  1218. <a name="l01186"></a>01186
  1219. <a name="l01187"></a>01187 <span class="comment">/* IP length field. */</span>
  1220. <a name="l01188"></a>01188 <span class="keywordflow">if</span>(ip_len == 0) {
  1221. <a name="l01189"></a>01189 <span class="comment">/* This is not a fragmented packet */</span>
  1222. <a name="l01190"></a>01190 SICSLOWPAN_IP_BUF-&gt;len[0] = 0;
  1223. <a name="l01191"></a>01191 SICSLOWPAN_IP_BUF-&gt;len[1] = <a class="code" href="a01563.html#ga4a1157b882c15f5ea05d64f81d37115d" title="Get the length of the data in the packetbuf.">packetbuf_datalen</a>() - rime_hdr_len + uncomp_hdr_len - UIP_IPH_LEN;
  1224. <a name="l01192"></a>01192 } <span class="keywordflow">else</span> {
  1225. <a name="l01193"></a>01193 <span class="comment">/* This is a 1st fragment */</span>
  1226. <a name="l01194"></a>01194 SICSLOWPAN_IP_BUF-&gt;len[0] = (ip_len - UIP_IPH_LEN) &gt;&gt; 8;
  1227. <a name="l01195"></a>01195 SICSLOWPAN_IP_BUF-&gt;len[1] = (ip_len - UIP_IPH_LEN) &amp; 0x00FF;
  1228. <a name="l01196"></a>01196 }
  1229. <a name="l01197"></a>01197 <span class="comment">/* length field in UDP header */</span>
  1230. <a name="l01198"></a>01198 <span class="keywordflow">if</span>(SICSLOWPAN_IP_BUF-&gt;proto == UIP_PROTO_UDP) {
  1231. <a name="l01199"></a>01199 memcpy(&amp;SICSLOWPAN_UDP_BUF-&gt;udplen, &amp;SICSLOWPAN_IP_BUF-&gt;len[0], 2);
  1232. <a name="l01200"></a>01200 }
  1233. <a name="l01201"></a>01201 <span class="keywordflow">return</span>;
  1234. <a name="l01202"></a>01202 }<span class="comment"></span>
  1235. <a name="l01203"></a>01203 <span class="comment">/** @} */</span>
  1236. <a name="l01204"></a>01204 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC1 */</span>
  1237. <a name="l01205"></a>01205
  1238. <a name="l01206"></a>01206
  1239. <a name="l01207"></a>01207 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_IPV6</span>
  1240. <a name="l01208"></a>01208 <span class="preprocessor"></span><span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1241. <a name="l01209"></a>01209 <span class="comment">/** \name IPv6 dispatch &quot;compression&quot; function</span>
  1242. <a name="l01210"></a>01210 <span class="comment"> * @{ */</span>
  1243. <a name="l01211"></a>01211 <span class="comment">/*--------------------------------------------------------------------*/</span>
  1244. <a name="l01212"></a>01212 <span class="comment">/* \brief Packets &quot;Compression&quot; when only IPv6 dispatch is used</span>
  1245. <a name="l01213"></a>01213 <span class="comment"> *</span>
  1246. <a name="l01214"></a>01214 <span class="comment"> * There is no compression in this case, all fields are sent</span>
  1247. <a name="l01215"></a>01215 <span class="comment"> * inline. We just add the IPv6 dispatch byte before the packet.</span>
  1248. <a name="l01216"></a>01216 <span class="comment"> * \verbatim</span>
  1249. <a name="l01217"></a>01217 <span class="comment"> * 0 1 2 3</span>
  1250. <a name="l01218"></a>01218 <span class="comment"> * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1</span>
  1251. <a name="l01219"></a>01219 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1252. <a name="l01220"></a>01220 <span class="comment"> * | IPv6 Dsp | IPv6 header and payload ...</span>
  1253. <a name="l01221"></a>01221 <span class="comment"> * +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+</span>
  1254. <a name="l01222"></a>01222 <span class="comment"> * \endverbatim</span>
  1255. <a name="l01223"></a>01223 <span class="comment"> */</span>
  1256. <a name="l01224"></a>01224 <span class="keyword">static</span> <span class="keywordtype">void</span>
  1257. <a name="l01225"></a>01225 compress_hdr_ipv6(rimeaddr_t *rime_destaddr)
  1258. <a name="l01226"></a>01226 {
  1259. <a name="l01227"></a>01227 *rime_ptr = SICSLOWPAN_DISPATCH_IPV6;
  1260. <a name="l01228"></a>01228 rime_hdr_len += SICSLOWPAN_IPV6_HDR_LEN;
  1261. <a name="l01229"></a>01229 memcpy(rime_ptr + rime_hdr_len, <a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>, UIP_IPH_LEN);
  1262. <a name="l01230"></a>01230 rime_hdr_len += UIP_IPH_LEN;
  1263. <a name="l01231"></a>01231 uncomp_hdr_len += UIP_IPH_LEN;
  1264. <a name="l01232"></a>01232 <span class="keywordflow">return</span>;
  1265. <a name="l01233"></a>01233 }<span class="comment"></span>
  1266. <a name="l01234"></a>01234 <span class="comment">/** @} */</span>
  1267. <a name="l01235"></a>01235 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_IPV6 */</span>
  1268. <a name="l01236"></a>01236
  1269. <a name="l01237"></a>01237
  1270. <a name="l01238"></a>01238
  1271. <a name="l01239"></a>01239 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1272. <a name="l01240"></a>01240 <span class="comment">/** \name Input/output functions common to all compression schemes</span>
  1273. <a name="l01241"></a>01241 <span class="comment"> * @{ */</span>
  1274. <a name="l01242"></a>01242 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1275. <a name="l01243"></a>01243 <span class="comment">/**</span>
  1276. <a name="l01244"></a>01244 <span class="comment"> * Callback function for the MAC packet sent callback</span>
  1277. <a name="l01245"></a>01245 <span class="comment"> */</span>
  1278. <a name="l01246"></a>01246 <span class="keyword">static</span> <span class="keywordtype">void</span>
  1279. <a name="l01247"></a>01247 packet_sent(<span class="keywordtype">void</span> *ptr, <span class="keywordtype">int</span> status, <span class="keywordtype">int</span> transmissions)
  1280. <a name="l01248"></a>01248 {
  1281. <a name="l01249"></a>01249 <span class="preprocessor">#if SICSLOWPAN_CONF_NEIGHBOR_INFO</span>
  1282. <a name="l01250"></a>01250 <span class="preprocessor"></span> <a class="code" href="a00293.html#afd67eb7e489b2c252a968a77d6e6a857" title="Notify the neighbor information module about the status of a packet transmission...">neighbor_info_packet_sent</a>(status, transmissions);
  1283. <a name="l01251"></a>01251 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_NEIGHBOR_INFO */</span>
  1284. <a name="l01252"></a>01252 }
  1285. <a name="l01253"></a>01253 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1286. <a name="l01254"></a>01254 <span class="comment">/**</span>
  1287. <a name="l01255"></a>01255 <span class="comment"> * \brief This function is called by the 6lowpan code to send out a</span>
  1288. <a name="l01256"></a>01256 <span class="comment"> * packet.</span>
  1289. <a name="l01257"></a>01257 <span class="comment"> * \param dest the link layer destination address of the packet</span>
  1290. <a name="l01258"></a>01258 <span class="comment"> */</span>
  1291. <a name="l01259"></a>01259 <span class="keyword">static</span> <span class="keywordtype">void</span>
  1292. <a name="l01260"></a>01260 send_packet(rimeaddr_t *dest)
  1293. <a name="l01261"></a>01261 {
  1294. <a name="l01262"></a>01262
  1295. <a name="l01263"></a>01263 <span class="comment">/* Set the link layer destination address for the packet as a</span>
  1296. <a name="l01264"></a>01264 <span class="comment"> * packetbuf attribute. The MAC layer can access the destination</span>
  1297. <a name="l01265"></a>01265 <span class="comment"> * address with the function packetbuf_addr(PACKETBUF_ADDR_RECEIVER).</span>
  1298. <a name="l01266"></a>01266 <span class="comment"> */</span>
  1299. <a name="l01267"></a>01267 packetbuf_set_addr(PACKETBUF_ADDR_RECEIVER, dest);
  1300. <a name="l01268"></a>01268
  1301. <a name="l01269"></a>01269 <span class="comment">/* Force acknowledge from sender (test hardware autoacks) */</span>
  1302. <a name="l01270"></a>01270 <span class="preprocessor">#if SICSLOWPAN_CONF_ACK_ALL</span>
  1303. <a name="l01271"></a>01271 <span class="preprocessor"></span> packetbuf_set_attr(PACKETBUF_ATTR_RELIABLE, 1);
  1304. <a name="l01272"></a>01272 <span class="preprocessor">#endif</span>
  1305. <a name="l01273"></a>01273 <span class="preprocessor"></span>
  1306. <a name="l01274"></a>01274 <span class="comment">/* Provide a callback function to receive the result of</span>
  1307. <a name="l01275"></a>01275 <span class="comment"> a packet transmission. */</span>
  1308. <a name="l01276"></a>01276 NETSTACK_MAC.send(&amp;packet_sent, NULL);
  1309. <a name="l01277"></a>01277
  1310. <a name="l01278"></a>01278 <span class="comment">/* If we are sending multiple packets in a row, we need to let the</span>
  1311. <a name="l01279"></a>01279 <span class="comment"> watchdog know that we are still alive. */</span>
  1312. <a name="l01280"></a>01280 watchdog_periodic();
  1313. <a name="l01281"></a>01281 }
  1314. <a name="l01282"></a>01282 <span class="comment"></span>
  1315. <a name="l01283"></a>01283 <span class="comment">/** \brief Take an IP packet and format it to be sent on an 802.15.4</span>
  1316. <a name="l01284"></a>01284 <span class="comment"> * network using 6lowpan.</span>
  1317. <a name="l01285"></a>01285 <span class="comment"> * \param localdest The MAC address of the destination</span>
  1318. <a name="l01286"></a>01286 <span class="comment"> *</span>
  1319. <a name="l01287"></a>01287 <span class="comment"> * The IP packet is initially in uip_buf. Its header is compressed</span>
  1320. <a name="l01288"></a>01288 <span class="comment"> * and if necessary it is fragmented. The resulting</span>
  1321. <a name="l01289"></a>01289 <span class="comment"> * packet/fragments are put in packetbuf and delivered to the 802.15.4</span>
  1322. <a name="l01290"></a>01290 <span class="comment"> * MAC.</span>
  1323. <a name="l01291"></a>01291 <span class="comment"> */</span>
  1324. <a name="l01292"></a>01292 <span class="keyword">static</span> uint8_t
  1325. <a name="l01293"></a>01293 output(<a class="code" href="a00102.html" title="802.3 address">uip_lladdr_t</a> *localdest)
  1326. <a name="l01294"></a>01294 {
  1327. <a name="l01295"></a>01295 <span class="comment">/* The MAC address of the destination of the packet */</span>
  1328. <a name="l01296"></a>01296 rimeaddr_t dest;
  1329. <a name="l01297"></a>01297
  1330. <a name="l01298"></a>01298
  1331. <a name="l01299"></a>01299 <span class="comment">/* init */</span>
  1332. <a name="l01300"></a>01300 uncomp_hdr_len = 0;
  1333. <a name="l01301"></a>01301 rime_hdr_len = 0;
  1334. <a name="l01302"></a>01302
  1335. <a name="l01303"></a>01303 <span class="comment">/* reset rime buffer */</span>
  1336. <a name="l01304"></a>01304 <a class="code" href="a01563.html#gaa540c9abf0db13d27881b616f7794824" title="Clear and reset the packetbuf.">packetbuf_clear</a>();
  1337. <a name="l01305"></a>01305 rime_ptr = <a class="code" href="a01563.html#ga29a6f3f230b55e6bc2f017879c27113a" title="Get a pointer to the data in the packetbuf.">packetbuf_dataptr</a>();
  1338. <a name="l01306"></a>01306
  1339. <a name="l01307"></a>01307 packetbuf_set_attr(PACKETBUF_ATTR_MAX_MAC_TRANSMISSIONS,
  1340. <a name="l01308"></a>01308 SICSLOWPAN_MAX_MAC_TRANSMISSIONS);
  1341. <a name="l01309"></a>01309
  1342. <a name="l01310"></a>01310 <span class="preprocessor">#define TCP_FIN 0x01</span>
  1343. <a name="l01311"></a>01311 <span class="preprocessor"></span><span class="preprocessor">#define TCP_ACK 0x10</span>
  1344. <a name="l01312"></a>01312 <span class="preprocessor"></span><span class="preprocessor">#define TCP_CTL 0x3f</span>
  1345. <a name="l01313"></a>01313 <span class="preprocessor"></span> <span class="comment">/* Set stream mode for all TCP packets, except FIN packets. */</span>
  1346. <a name="l01314"></a>01314 <span class="keywordflow">if</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto == UIP_PROTO_TCP &amp;&amp;
  1347. <a name="l01315"></a>01315 (UIP_TCP_BUF-&gt;flags &amp; TCP_FIN) == 0 &amp;&amp;
  1348. <a name="l01316"></a>01316 (UIP_TCP_BUF-&gt;flags &amp; TCP_CTL) != TCP_ACK) {
  1349. <a name="l01317"></a>01317 packetbuf_set_attr(PACKETBUF_ATTR_PACKET_TYPE,
  1350. <a name="l01318"></a>01318 PACKETBUF_ATTR_PACKET_TYPE_STREAM);
  1351. <a name="l01319"></a>01319 } <span class="keywordflow">else</span> <span class="keywordflow">if</span>(<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>-&gt;proto == UIP_PROTO_TCP &amp;&amp;
  1352. <a name="l01320"></a>01320 (UIP_TCP_BUF-&gt;flags &amp; TCP_FIN) == TCP_FIN) {
  1353. <a name="l01321"></a>01321 packetbuf_set_attr(PACKETBUF_ATTR_PACKET_TYPE,
  1354. <a name="l01322"></a>01322 PACKETBUF_ATTR_PACKET_TYPE_STREAM_END);
  1355. <a name="l01323"></a>01323 }
  1356. <a name="l01324"></a>01324
  1357. <a name="l01325"></a>01325 <span class="comment">/*</span>
  1358. <a name="l01326"></a>01326 <span class="comment"> * The destination address will be tagged to each outbound</span>
  1359. <a name="l01327"></a>01327 <span class="comment"> * packet. If the argument localdest is NULL, we are sending a</span>
  1360. <a name="l01328"></a>01328 <span class="comment"> * broadcast packet.</span>
  1361. <a name="l01329"></a>01329 <span class="comment"> */</span>
  1362. <a name="l01330"></a>01330 <span class="keywordflow">if</span>(localdest == NULL) {
  1363. <a name="l01331"></a>01331 <a class="code" href="a01606.html#gacd6a22e93c7a4eb02d901743c958c2b2" title="Copy a Rime address.">rimeaddr_copy</a>(&amp;dest, &amp;<a class="code" href="a01606.html#gaa96ae7849482147440e77751444faa6d" title="The null Rime address.">rimeaddr_null</a>);
  1364. <a name="l01332"></a>01332 } <span class="keywordflow">else</span> {
  1365. <a name="l01333"></a>01333 <a class="code" href="a01606.html#gacd6a22e93c7a4eb02d901743c958c2b2" title="Copy a Rime address.">rimeaddr_copy</a>(&amp;dest, (<span class="keyword">const</span> rimeaddr_t *)localdest);
  1366. <a name="l01334"></a>01334 }
  1367. <a name="l01335"></a>01335
  1368. <a name="l01336"></a>01336 PRINTFO(<span class="stringliteral">&quot;sicslowpan output: sending packet len %d\n&quot;</span>, <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a>);
  1369. <a name="l01337"></a>01337
  1370. <a name="l01338"></a>01338 <span class="comment">/* Try to compress the headers */</span>
  1371. <a name="l01339"></a>01339 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC1</span>
  1372. <a name="l01340"></a>01340 <span class="preprocessor"></span> compress_hdr_hc1(&amp;dest);
  1373. <a name="l01341"></a>01341 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC1 */</span>
  1374. <a name="l01342"></a>01342 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_IPV6</span>
  1375. <a name="l01343"></a>01343 <span class="preprocessor"></span> compress_hdr_ipv6(&amp;dest);
  1376. <a name="l01344"></a>01344 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_IPV6 */</span>
  1377. <a name="l01345"></a>01345 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06</span>
  1378. <a name="l01346"></a>01346 <span class="preprocessor"></span> compress_hdr_hc06(&amp;dest);
  1379. <a name="l01347"></a>01347 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06 */</span>
  1380. <a name="l01348"></a>01348 PRINTFO(<span class="stringliteral">&quot;sicslowpan output: header of len %d\n&quot;</span>, rime_hdr_len);
  1381. <a name="l01349"></a>01349
  1382. <a name="l01350"></a>01350 <span class="keywordflow">if</span>(<a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a> - uncomp_hdr_len &gt; <a class="code" href="a01680.html#gaf213c8c71222bb86256fb3e37582242b" title="Size of the 802.15.4 payload (127byte - 25 for MAC header).">MAC_MAX_PAYLOAD</a> - rime_hdr_len) {
  1383. <a name="l01351"></a>01351 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1384. <a name="l01352"></a>01352 <span class="preprocessor"></span> <span class="keyword">struct </span>queuebuf *q;
  1385. <a name="l01353"></a>01353 <span class="comment">/*</span>
  1386. <a name="l01354"></a>01354 <span class="comment"> * The outbound IPv6 packet is too large to fit into a single 15.4</span>
  1387. <a name="l01355"></a>01355 <span class="comment"> * packet, so we fragment it into multiple packets and send them.</span>
  1388. <a name="l01356"></a>01356 <span class="comment"> * The first fragment contains frag1 dispatch, then</span>
  1389. <a name="l01357"></a>01357 <span class="comment"> * IPv6/HC1/HC06/HC_UDP dispatchs/headers.</span>
  1390. <a name="l01358"></a>01358 <span class="comment"> * The following fragments contain only the fragn dispatch.</span>
  1391. <a name="l01359"></a>01359 <span class="comment"> */</span>
  1392. <a name="l01360"></a>01360
  1393. <a name="l01361"></a>01361
  1394. <a name="l01362"></a>01362 PRINTFO(<span class="stringliteral">&quot;Fragmentation sending packet len %d\n&quot;</span>, <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a>);
  1395. <a name="l01363"></a>01363
  1396. <a name="l01364"></a>01364 <span class="comment">/* Create 1st Fragment */</span>
  1397. <a name="l01365"></a>01365 PRINTFO(<span class="stringliteral">&quot;sicslowpan output: 1rst fragment &quot;</span>);
  1398. <a name="l01366"></a>01366
  1399. <a name="l01367"></a>01367 <span class="comment">/* move HC1/HC06/IPv6 header */</span>
  1400. <a name="l01368"></a>01368 memmove(rime_ptr + SICSLOWPAN_FRAG1_HDR_LEN, rime_ptr, rime_hdr_len);
  1401. <a name="l01369"></a>01369
  1402. <a name="l01370"></a>01370 <span class="comment">/*</span>
  1403. <a name="l01371"></a>01371 <span class="comment"> * FRAG1 dispatch + header</span>
  1404. <a name="l01372"></a>01372 <span class="comment"> * Note that the length is in units of 8 bytes</span>
  1405. <a name="l01373"></a>01373 <span class="comment"> */</span>
  1406. <a name="l01374"></a>01374 <span class="comment">/* RIME_FRAG_BUF-&gt;dispatch_size = */</span>
  1407. <a name="l01375"></a>01375 <span class="comment">/* uip_htons((SICSLOWPAN_DISPATCH_FRAG1 &lt;&lt; 8) | uip_len); */</span>
  1408. <a name="l01376"></a>01376 SET16(RIME_FRAG_PTR, RIME_FRAG_DISPATCH_SIZE,
  1409. <a name="l01377"></a>01377 ((SICSLOWPAN_DISPATCH_FRAG1 &lt;&lt; 8) | <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a>));
  1410. <a name="l01378"></a>01378 <span class="comment">/* RIME_FRAG_BUF-&gt;tag = uip_htons(my_tag); */</span>
  1411. <a name="l01379"></a>01379 SET16(RIME_FRAG_PTR, RIME_FRAG_TAG, my_tag);
  1412. <a name="l01380"></a>01380
  1413. <a name="l01381"></a>01381 <span class="comment">/* Copy payload and send */</span>
  1414. <a name="l01382"></a>01382 rime_hdr_len += SICSLOWPAN_FRAG1_HDR_LEN;
  1415. <a name="l01383"></a>01383 rime_payload_len = (<a class="code" href="a01680.html#gaf213c8c71222bb86256fb3e37582242b" title="Size of the 802.15.4 payload (127byte - 25 for MAC header).">MAC_MAX_PAYLOAD</a> - rime_hdr_len) &amp; 0xf8;
  1416. <a name="l01384"></a>01384 PRINTFO(<span class="stringliteral">&quot;(len %d, tag %d)\n&quot;</span>, rime_payload_len, my_tag);
  1417. <a name="l01385"></a>01385 memcpy(rime_ptr + rime_hdr_len,
  1418. <a name="l01386"></a>01386 (uint8_t *)<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a> + uncomp_hdr_len, rime_payload_len);
  1419. <a name="l01387"></a>01387 <a class="code" href="a01563.html#ga236b0d557fe119c39796432484c94b26" title="Set the length of the data in the packetbuf.">packetbuf_set_datalen</a>(rime_payload_len + rime_hdr_len);
  1420. <a name="l01388"></a>01388 q = queuebuf_new_from_packetbuf();
  1421. <a name="l01389"></a>01389 <span class="keywordflow">if</span>(q == NULL) {
  1422. <a name="l01390"></a>01390 PRINTFO(<span class="stringliteral">&quot;could not allocate queuebuf for first fragment, dropping packet\n&quot;</span>);
  1423. <a name="l01391"></a>01391 <span class="keywordflow">return</span> 0;
  1424. <a name="l01392"></a>01392 }
  1425. <a name="l01393"></a>01393 send_packet(&amp;dest);
  1426. <a name="l01394"></a>01394 queuebuf_to_packetbuf(q);
  1427. <a name="l01395"></a>01395 queuebuf_free(q);
  1428. <a name="l01396"></a>01396 q = NULL;
  1429. <a name="l01397"></a>01397
  1430. <a name="l01398"></a>01398 <span class="comment">/* set processed_ip_len to what we already sent from the IP payload*/</span>
  1431. <a name="l01399"></a>01399 processed_ip_len = rime_payload_len + uncomp_hdr_len;
  1432. <a name="l01400"></a>01400
  1433. <a name="l01401"></a>01401 <span class="comment">/*</span>
  1434. <a name="l01402"></a>01402 <span class="comment"> * Create following fragments</span>
  1435. <a name="l01403"></a>01403 <span class="comment"> * Datagram tag is already in the buffer, we need to set the</span>
  1436. <a name="l01404"></a>01404 <span class="comment"> * FRAGN dispatch and for each fragment, the offset</span>
  1437. <a name="l01405"></a>01405 <span class="comment"> */</span>
  1438. <a name="l01406"></a>01406 rime_hdr_len = SICSLOWPAN_FRAGN_HDR_LEN;
  1439. <a name="l01407"></a>01407 <span class="comment">/* RIME_FRAG_BUF-&gt;dispatch_size = */</span>
  1440. <a name="l01408"></a>01408 <span class="comment">/* uip_htons((SICSLOWPAN_DISPATCH_FRAGN &lt;&lt; 8) | uip_len); */</span>
  1441. <a name="l01409"></a>01409 SET16(RIME_FRAG_PTR, RIME_FRAG_DISPATCH_SIZE,
  1442. <a name="l01410"></a>01410 ((SICSLOWPAN_DISPATCH_FRAGN &lt;&lt; 8) | <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a>));
  1443. <a name="l01411"></a>01411 rime_payload_len = (<a class="code" href="a01680.html#gaf213c8c71222bb86256fb3e37582242b" title="Size of the 802.15.4 payload (127byte - 25 for MAC header).">MAC_MAX_PAYLOAD</a> - rime_hdr_len) &amp; 0xf8;
  1444. <a name="l01412"></a>01412 <span class="keywordflow">while</span>(processed_ip_len &lt; <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a>) {
  1445. <a name="l01413"></a>01413 PRINTFO(<span class="stringliteral">&quot;sicslowpan output: fragment &quot;</span>);
  1446. <a name="l01414"></a>01414 RIME_FRAG_PTR[RIME_FRAG_OFFSET] = processed_ip_len &gt;&gt; 3;
  1447. <a name="l01415"></a>01415
  1448. <a name="l01416"></a>01416 <span class="comment">/* Copy payload and send */</span>
  1449. <a name="l01417"></a>01417 <span class="keywordflow">if</span>(<a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a> - processed_ip_len &lt; rime_payload_len) {
  1450. <a name="l01418"></a>01418 <span class="comment">/* last fragment */</span>
  1451. <a name="l01419"></a>01419 rime_payload_len = <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a> - processed_ip_len;
  1452. <a name="l01420"></a>01420 }
  1453. <a name="l01421"></a>01421 PRINTFO(<span class="stringliteral">&quot;(offset %d, len %d, tag %d)\n&quot;</span>,
  1454. <a name="l01422"></a>01422 processed_ip_len &gt;&gt; 3, rime_payload_len, my_tag);
  1455. <a name="l01423"></a>01423 memcpy(rime_ptr + rime_hdr_len,
  1456. <a name="l01424"></a>01424 (uint8_t *)<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a> + processed_ip_len, rime_payload_len);
  1457. <a name="l01425"></a>01425 <a class="code" href="a01563.html#ga236b0d557fe119c39796432484c94b26" title="Set the length of the data in the packetbuf.">packetbuf_set_datalen</a>(rime_payload_len + rime_hdr_len);
  1458. <a name="l01426"></a>01426 q = queuebuf_new_from_packetbuf();
  1459. <a name="l01427"></a>01427 <span class="keywordflow">if</span>(q == NULL) {
  1460. <a name="l01428"></a>01428 PRINTFO(<span class="stringliteral">&quot;could not allocate queuebuf, dropping fragment\n&quot;</span>);
  1461. <a name="l01429"></a>01429 <span class="keywordflow">return</span> 0;
  1462. <a name="l01430"></a>01430 }
  1463. <a name="l01431"></a>01431 send_packet(&amp;dest);
  1464. <a name="l01432"></a>01432 queuebuf_to_packetbuf(q);
  1465. <a name="l01433"></a>01433 queuebuf_free(q);
  1466. <a name="l01434"></a>01434 q = NULL;
  1467. <a name="l01435"></a>01435 processed_ip_len += rime_payload_len;
  1468. <a name="l01436"></a>01436 }
  1469. <a name="l01437"></a>01437
  1470. <a name="l01438"></a>01438 <span class="comment">/* end: reset global variables */</span>
  1471. <a name="l01439"></a>01439 my_tag++;
  1472. <a name="l01440"></a>01440 processed_ip_len = 0;
  1473. <a name="l01441"></a>01441 <span class="preprocessor">#else </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  1474. <a name="l01442"></a>01442 PRINTFO(<span class="stringliteral">&quot;sicslowpan output: Packet too large to be sent without fragmentation support; dropping packet\n&quot;</span>);
  1475. <a name="l01443"></a>01443 <span class="keywordflow">return</span> 0;
  1476. <a name="l01444"></a>01444 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  1477. <a name="l01445"></a>01445 } <span class="keywordflow">else</span> {
  1478. <a name="l01446"></a>01446 <span class="comment">/*</span>
  1479. <a name="l01447"></a>01447 <span class="comment"> * The packet does not need to be fragmented</span>
  1480. <a name="l01448"></a>01448 <span class="comment"> * copy &quot;payload&quot; and send</span>
  1481. <a name="l01449"></a>01449 <span class="comment"> */</span>
  1482. <a name="l01450"></a>01450 memcpy(rime_ptr + rime_hdr_len, (uint8_t *)<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a> + uncomp_hdr_len,
  1483. <a name="l01451"></a>01451 <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a> - uncomp_hdr_len);
  1484. <a name="l01452"></a>01452 <a class="code" href="a01563.html#ga236b0d557fe119c39796432484c94b26" title="Set the length of the data in the packetbuf.">packetbuf_set_datalen</a>(<a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a> - uncomp_hdr_len + rime_hdr_len);
  1485. <a name="l01453"></a>01453 send_packet(&amp;dest);
  1486. <a name="l01454"></a>01454 }
  1487. <a name="l01455"></a>01455 <span class="keywordflow">return</span> 1;
  1488. <a name="l01456"></a>01456 }
  1489. <a name="l01457"></a>01457
  1490. <a name="l01458"></a>01458 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1491. <a name="l01459"></a>01459 <span class="comment">/** \brief Process a received 6lowpan packet.</span>
  1492. <a name="l01460"></a>01460 <span class="comment"> * \param r The MAC layer</span>
  1493. <a name="l01461"></a>01461 <span class="comment"> *</span>
  1494. <a name="l01462"></a>01462 <span class="comment"> * The 6lowpan packet is put in packetbuf by the MAC. If its a frag1 or</span>
  1495. <a name="l01463"></a>01463 <span class="comment"> * a non-fragmented packet we first uncompress the IP header. The</span>
  1496. <a name="l01464"></a>01464 <span class="comment"> * 6lowpan payload and possibly the uncompressed IP header are then</span>
  1497. <a name="l01465"></a>01465 <span class="comment"> * copied in siclowpan_buf. If the IP packet is complete it is copied</span>
  1498. <a name="l01466"></a>01466 <span class="comment"> * to uip_buf and the IP layer is called.</span>
  1499. <a name="l01467"></a>01467 <span class="comment"> *</span>
  1500. <a name="l01468"></a>01468 <span class="comment"> * \note We do not check for overlapping sicslowpan fragments</span>
  1501. <a name="l01469"></a>01469 <span class="comment"> * (it is a SHALL in the RFC 4944 and should never happen)</span>
  1502. <a name="l01470"></a>01470 <span class="comment"> */</span>
  1503. <a name="l01471"></a>01471 <span class="keyword">static</span> <span class="keywordtype">void</span>
  1504. <a name="l01472"></a>01472 input(<span class="keywordtype">void</span>)
  1505. <a name="l01473"></a>01473 {
  1506. <a name="l01474"></a>01474 <span class="comment">/* size of the IP packet (read from fragment) */</span>
  1507. <a name="l01475"></a>01475 uint16_t frag_size = 0;
  1508. <a name="l01476"></a>01476 <span class="comment">/* offset of the fragment in the IP packet */</span>
  1509. <a name="l01477"></a>01477 uint8_t frag_offset = 0;
  1510. <a name="l01478"></a>01478 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1511. <a name="l01479"></a>01479 <span class="preprocessor"></span> <span class="comment">/* tag of the fragment */</span>
  1512. <a name="l01480"></a>01480 uint16_t frag_tag = 0;
  1513. <a name="l01481"></a>01481 uint8_t first_fragment = 0;
  1514. <a name="l01482"></a>01482 <span class="preprocessor">#endif </span><span class="comment">/*SICSLOWPAN_CONF_FRAG*/</span>
  1515. <a name="l01483"></a>01483
  1516. <a name="l01484"></a>01484 <span class="comment">/* init */</span>
  1517. <a name="l01485"></a>01485 uncomp_hdr_len = 0;
  1518. <a name="l01486"></a>01486 rime_hdr_len = 0;
  1519. <a name="l01487"></a>01487
  1520. <a name="l01488"></a>01488 <span class="comment">/* The MAC puts the 15.4 payload inside the RIME data buffer */</span>
  1521. <a name="l01489"></a>01489 rime_ptr = <a class="code" href="a01563.html#ga29a6f3f230b55e6bc2f017879c27113a" title="Get a pointer to the data in the packetbuf.">packetbuf_dataptr</a>();
  1522. <a name="l01490"></a>01490
  1523. <a name="l01491"></a>01491 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1524. <a name="l01492"></a>01492 <span class="preprocessor"></span> <span class="comment">/* if reassembly timed out, cancel it */</span>
  1525. <a name="l01493"></a>01493 <span class="keywordflow">if</span>(<a class="code" href="a01632.html#ga6d71dececfce707c668e6257aad5906e" title="Check if a timer has expired.">timer_expired</a>(&amp;reass_timer)) {
  1526. <a name="l01494"></a>01494 sicslowpan_len = 0;
  1527. <a name="l01495"></a>01495 processed_ip_len = 0;
  1528. <a name="l01496"></a>01496 }
  1529. <a name="l01497"></a>01497 <span class="comment">/*</span>
  1530. <a name="l01498"></a>01498 <span class="comment"> * Since we don&apos;t support the mesh and broadcast header, the first header</span>
  1531. <a name="l01499"></a>01499 <span class="comment"> * we look for is the fragmentation header</span>
  1532. <a name="l01500"></a>01500 <span class="comment"> */</span>
  1533. <a name="l01501"></a>01501 <span class="keywordflow">switch</span>((GET16(RIME_FRAG_PTR, RIME_FRAG_DISPATCH_SIZE) &amp; 0xf800) &gt;&gt; 8) {
  1534. <a name="l01502"></a>01502 <span class="keywordflow">case</span> SICSLOWPAN_DISPATCH_FRAG1:
  1535. <a name="l01503"></a>01503 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: FRAG1 &quot;</span>);
  1536. <a name="l01504"></a>01504 frag_offset = 0;
  1537. <a name="l01505"></a>01505 <span class="comment">/* frag_size = (uip_ntohs(RIME_FRAG_BUF-&gt;dispatch_size) &amp; 0x07ff); */</span>
  1538. <a name="l01506"></a>01506 frag_size = GET16(RIME_FRAG_PTR, RIME_FRAG_DISPATCH_SIZE) &amp; 0x07ff;
  1539. <a name="l01507"></a>01507 <span class="comment">/* frag_tag = uip_ntohs(RIME_FRAG_BUF-&gt;tag); */</span>
  1540. <a name="l01508"></a>01508 frag_tag = GET16(RIME_FRAG_PTR, RIME_FRAG_TAG);
  1541. <a name="l01509"></a>01509 PRINTFI(<span class="stringliteral">&quot;size %d, tag %d, offset %d)\n&quot;</span>,
  1542. <a name="l01510"></a>01510 frag_size, frag_tag, frag_offset);
  1543. <a name="l01511"></a>01511 rime_hdr_len += SICSLOWPAN_FRAG1_HDR_LEN;
  1544. <a name="l01512"></a>01512 <span class="comment">/* printf(&quot;frag1 %d %d\n&quot;, reass_tag, frag_tag);*/</span>
  1545. <a name="l01513"></a>01513 first_fragment = 1;
  1546. <a name="l01514"></a>01514 <span class="keywordflow">break</span>;
  1547. <a name="l01515"></a>01515 <span class="keywordflow">case</span> SICSLOWPAN_DISPATCH_FRAGN:
  1548. <a name="l01516"></a>01516 <span class="comment">/*</span>
  1549. <a name="l01517"></a>01517 <span class="comment"> * set offset, tag, size</span>
  1550. <a name="l01518"></a>01518 <span class="comment"> * Offset is in units of 8 bytes</span>
  1551. <a name="l01519"></a>01519 <span class="comment"> */</span>
  1552. <a name="l01520"></a>01520 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: FRAGN &quot;</span>);
  1553. <a name="l01521"></a>01521 frag_offset = RIME_FRAG_PTR[RIME_FRAG_OFFSET];
  1554. <a name="l01522"></a>01522 frag_tag = GET16(RIME_FRAG_PTR, RIME_FRAG_TAG);
  1555. <a name="l01523"></a>01523 frag_size = GET16(RIME_FRAG_PTR, RIME_FRAG_DISPATCH_SIZE) &amp; 0x07ff;
  1556. <a name="l01524"></a>01524 PRINTFI(<span class="stringliteral">&quot;size %d, tag %d, offset %d)\n&quot;</span>,
  1557. <a name="l01525"></a>01525 frag_size, frag_tag, frag_offset);
  1558. <a name="l01526"></a>01526 rime_hdr_len += SICSLOWPAN_FRAGN_HDR_LEN;
  1559. <a name="l01527"></a>01527 <span class="keywordflow">break</span>;
  1560. <a name="l01528"></a>01528 <span class="keywordflow">default</span>:
  1561. <a name="l01529"></a>01529 <span class="keywordflow">break</span>;
  1562. <a name="l01530"></a>01530 }
  1563. <a name="l01531"></a>01531
  1564. <a name="l01532"></a>01532 <span class="keywordflow">if</span>(processed_ip_len &gt; 0) {
  1565. <a name="l01533"></a>01533 <span class="comment">/* reassembly is ongoing */</span>
  1566. <a name="l01534"></a>01534 <span class="comment">/* printf(&quot;frag %d %d\n&quot;, reass_tag, frag_tag);*/</span>
  1567. <a name="l01535"></a>01535 <span class="keywordflow">if</span>((frag_size &gt; 0 &amp;&amp;
  1568. <a name="l01536"></a>01536 (frag_size != sicslowpan_len ||
  1569. <a name="l01537"></a>01537 reass_tag != frag_tag ||
  1570. <a name="l01538"></a>01538 !<a class="code" href="a01606.html#gaed118d3d8fe7e7ac9d6d00988268357e" title="Compare two Rime addresses.">rimeaddr_cmp</a>(&amp;frag_sender, packetbuf_addr(PACKETBUF_ADDR_SENDER)))) ||
  1571. <a name="l01539"></a>01539 frag_size == 0) {
  1572. <a name="l01540"></a>01540 <span class="comment">/*</span>
  1573. <a name="l01541"></a>01541 <span class="comment"> * the packet is a fragment that does not belong to the packet</span>
  1574. <a name="l01542"></a>01542 <span class="comment"> * being reassembled or the packet is not a fragment.</span>
  1575. <a name="l01543"></a>01543 <span class="comment"> */</span>
  1576. <a name="l01544"></a>01544 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: Dropping 6lowpan packet that is not a fragment of the packet currently being reassembled\n&quot;</span>);
  1577. <a name="l01545"></a>01545 <span class="keywordflow">return</span>;
  1578. <a name="l01546"></a>01546 }
  1579. <a name="l01547"></a>01547 } <span class="keywordflow">else</span> {
  1580. <a name="l01548"></a>01548 <span class="comment">/*</span>
  1581. <a name="l01549"></a>01549 <span class="comment"> * reassembly is off</span>
  1582. <a name="l01550"></a>01550 <span class="comment"> * start it if we received a fragment</span>
  1583. <a name="l01551"></a>01551 <span class="comment"> */</span>
  1584. <a name="l01552"></a>01552 <span class="keywordflow">if</span>(frag_size &gt; 0) {
  1585. <a name="l01553"></a>01553 sicslowpan_len = frag_size;
  1586. <a name="l01554"></a>01554 reass_tag = frag_tag;
  1587. <a name="l01555"></a>01555 <a class="code" href="a01632.html#ga6614d96fdfcd95c95ec6e6f63071ff51" title="Set a timer.">timer_set</a>(&amp;reass_timer, <a class="code" href="a01588.html#ga8b3cd5de59637a38a881b27b867370f0" title="Timeout for packet reassembly at the 6lowpan layer (should be &amp;lt; 60s).">SICSLOWPAN_REASS_MAXAGE</a>*<a class="code" href="a01620.html#gae3ced0551b26c9b99cb45a86f34d100a" title="A second, measured in system clock time.">CLOCK_SECOND</a>);
  1588. <a name="l01556"></a>01556 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: INIT FRAGMENTATION (len %d, tag %d)\n&quot;</span>,
  1589. <a name="l01557"></a>01557 sicslowpan_len, reass_tag);
  1590. <a name="l01558"></a>01558 <a class="code" href="a01606.html#gacd6a22e93c7a4eb02d901743c958c2b2" title="Copy a Rime address.">rimeaddr_copy</a>(&amp;frag_sender, packetbuf_addr(PACKETBUF_ADDR_SENDER));
  1591. <a name="l01559"></a>01559 }
  1592. <a name="l01560"></a>01560 }
  1593. <a name="l01561"></a>01561
  1594. <a name="l01562"></a>01562 <span class="keywordflow">if</span>(rime_hdr_len == SICSLOWPAN_FRAGN_HDR_LEN) {
  1595. <a name="l01563"></a>01563 <span class="comment">/* this is a FRAGN, skip the header compression dispatch section */</span>
  1596. <a name="l01564"></a>01564 <span class="keywordflow">goto</span> copypayload;
  1597. <a name="l01565"></a>01565 }
  1598. <a name="l01566"></a>01566 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  1599. <a name="l01567"></a>01567
  1600. <a name="l01568"></a>01568 <span class="comment">/* Process next dispatch and headers */</span>
  1601. <a name="l01569"></a>01569 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06</span>
  1602. <a name="l01570"></a>01570 <span class="preprocessor"></span> <span class="keywordflow">if</span>((RIME_HC1_PTR[RIME_HC1_DISPATCH] &amp; 0xe0) == SICSLOWPAN_DISPATCH_IPHC) {
  1603. <a name="l01571"></a>01571 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: IPHC\n&quot;</span>);
  1604. <a name="l01572"></a>01572 uncompress_hdr_hc06(frag_size);
  1605. <a name="l01573"></a>01573 } <span class="keywordflow">else</span>
  1606. <a name="l01574"></a>01574 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06 */</span>
  1607. <a name="l01575"></a>01575 <span class="keywordflow">switch</span>(RIME_HC1_PTR[RIME_HC1_DISPATCH]) {
  1608. <a name="l01576"></a>01576 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC1</span>
  1609. <a name="l01577"></a>01577 <span class="preprocessor"></span> <span class="keywordflow">case</span> SICSLOWPAN_DISPATCH_HC1:
  1610. <a name="l01578"></a>01578 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: HC1\n&quot;</span>);
  1611. <a name="l01579"></a>01579 uncompress_hdr_hc1(frag_size);
  1612. <a name="l01580"></a>01580 <span class="keywordflow">break</span>;
  1613. <a name="l01581"></a>01581 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC1 */</span>
  1614. <a name="l01582"></a>01582 <span class="keywordflow">case</span> SICSLOWPAN_DISPATCH_IPV6:
  1615. <a name="l01583"></a>01583 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: IPV6\n&quot;</span>);
  1616. <a name="l01584"></a>01584 rime_hdr_len += SICSLOWPAN_IPV6_HDR_LEN;
  1617. <a name="l01585"></a>01585
  1618. <a name="l01586"></a>01586 <span class="comment">/* Put uncompressed IP header in sicslowpan_buf. */</span>
  1619. <a name="l01587"></a>01587 memcpy(SICSLOWPAN_IP_BUF, rime_ptr + rime_hdr_len, UIP_IPH_LEN);
  1620. <a name="l01588"></a>01588
  1621. <a name="l01589"></a>01589 <span class="comment">/* Update uncomp_hdr_len and rime_hdr_len. */</span>
  1622. <a name="l01590"></a>01590 rime_hdr_len += UIP_IPH_LEN;
  1623. <a name="l01591"></a>01591 uncomp_hdr_len += UIP_IPH_LEN;
  1624. <a name="l01592"></a>01592 <span class="keywordflow">break</span>;
  1625. <a name="l01593"></a>01593 <span class="keywordflow">default</span>:
  1626. <a name="l01594"></a>01594 <span class="comment">/* unknown header */</span>
  1627. <a name="l01595"></a>01595 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: unknown dispatch: %u\n&quot;</span>,
  1628. <a name="l01596"></a>01596 RIME_HC1_PTR[RIME_HC1_DISPATCH]);
  1629. <a name="l01597"></a>01597 <span class="keywordflow">return</span>;
  1630. <a name="l01598"></a>01598 }
  1631. <a name="l01599"></a>01599
  1632. <a name="l01600"></a>01600
  1633. <a name="l01601"></a>01601 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1634. <a name="l01602"></a>01602 <span class="preprocessor"></span> copypayload:
  1635. <a name="l01603"></a>01603 <span class="preprocessor">#endif </span><span class="comment">/*SICSLOWPAN_CONF_FRAG*/</span>
  1636. <a name="l01604"></a>01604 <span class="comment">/*</span>
  1637. <a name="l01605"></a>01605 <span class="comment"> * copy &quot;payload&quot; from the rime buffer to the sicslowpan_buf</span>
  1638. <a name="l01606"></a>01606 <span class="comment"> * if this is a first fragment or not fragmented packet,</span>
  1639. <a name="l01607"></a>01607 <span class="comment"> * we have already copied the compressed headers, uncomp_hdr_len</span>
  1640. <a name="l01608"></a>01608 <span class="comment"> * and rime_hdr_len are non 0, frag_offset is.</span>
  1641. <a name="l01609"></a>01609 <span class="comment"> * If this is a subsequent fragment, this is the contrary.</span>
  1642. <a name="l01610"></a>01610 <span class="comment"> */</span>
  1643. <a name="l01611"></a>01611 <span class="keywordflow">if</span>(<a class="code" href="a01563.html#ga4a1157b882c15f5ea05d64f81d37115d" title="Get the length of the data in the packetbuf.">packetbuf_datalen</a>() &lt; rime_hdr_len) {
  1644. <a name="l01612"></a>01612 PRINTF(<span class="stringliteral">&quot;SICSLOWPAN: packet dropped due to header &gt; total packet\n&quot;</span>);
  1645. <a name="l01613"></a>01613 <span class="keywordflow">return</span>;
  1646. <a name="l01614"></a>01614 }
  1647. <a name="l01615"></a>01615 rime_payload_len = <a class="code" href="a01563.html#ga4a1157b882c15f5ea05d64f81d37115d" title="Get the length of the data in the packetbuf.">packetbuf_datalen</a>() - rime_hdr_len;
  1648. <a name="l01616"></a>01616 memcpy((uint8_t *)SICSLOWPAN_IP_BUF + uncomp_hdr_len + (uint16_t)(frag_offset &lt;&lt; 3), rime_ptr + rime_hdr_len, rime_payload_len);
  1649. <a name="l01617"></a>01617
  1650. <a name="l01618"></a>01618 <span class="comment">/* update processed_ip_len if fragment, sicslowpan_len otherwise */</span>
  1651. <a name="l01619"></a>01619
  1652. <a name="l01620"></a>01620 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1653. <a name="l01621"></a>01621 <span class="preprocessor"></span> <span class="keywordflow">if</span>(frag_size &gt; 0) {
  1654. <a name="l01622"></a>01622 <span class="comment">/* Add the size of the header only for the first fragment. */</span>
  1655. <a name="l01623"></a>01623 <span class="keywordflow">if</span>(first_fragment != 0) {
  1656. <a name="l01624"></a>01624 processed_ip_len += uncomp_hdr_len;
  1657. <a name="l01625"></a>01625 }
  1658. <a name="l01626"></a>01626 processed_ip_len += rime_payload_len;
  1659. <a name="l01627"></a>01627 } <span class="keywordflow">else</span> {
  1660. <a name="l01628"></a>01628 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  1661. <a name="l01629"></a>01629 sicslowpan_len = rime_payload_len + uncomp_hdr_len;
  1662. <a name="l01630"></a>01630 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1663. <a name="l01631"></a>01631 <span class="preprocessor"></span> }
  1664. <a name="l01632"></a>01632
  1665. <a name="l01633"></a>01633 <span class="comment">/*</span>
  1666. <a name="l01634"></a>01634 <span class="comment"> * If we have a full IP packet in sicslowpan_buf, deliver it to</span>
  1667. <a name="l01635"></a>01635 <span class="comment"> * the IP stack</span>
  1668. <a name="l01636"></a>01636 <span class="comment"> */</span>
  1669. <a name="l01637"></a>01637 <span class="keywordflow">if</span>(processed_ip_len == 0 || (processed_ip_len == sicslowpan_len)) {
  1670. <a name="l01638"></a>01638 PRINTFI(<span class="stringliteral">&quot;sicslowpan input: IP packet ready (length %d)\n&quot;</span>,
  1671. <a name="l01639"></a>01639 sicslowpan_len);
  1672. <a name="l01640"></a>01640 memcpy((uint8_t *)<a class="code" href="a01685.html#gaf966537cf73ee5973da59bba6b21b731" title="Pointer to IP header.">UIP_IP_BUF</a>, (uint8_t *)SICSLOWPAN_IP_BUF, sicslowpan_len);
  1673. <a name="l01641"></a>01641 <a class="code" href="a01684.html#ga12a33f0c09711167bdf3dd7d7cf8c5a1" title="The length of the packet in the uip_buf buffer.">uip_len</a> = sicslowpan_len;
  1674. <a name="l01642"></a>01642 sicslowpan_len = 0;
  1675. <a name="l01643"></a>01643 processed_ip_len = 0;
  1676. <a name="l01644"></a>01644 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  1677. <a name="l01645"></a>01645
  1678. <a name="l01646"></a>01646 <span class="preprocessor">#if DEBUG</span>
  1679. <a name="l01647"></a>01647 <span class="preprocessor"></span> {
  1680. <a name="l01648"></a>01648 uint8_t tmp;
  1681. <a name="l01649"></a>01649 PRINTF(<span class="stringliteral">&quot;after decompression: &quot;</span>);
  1682. <a name="l01650"></a>01650 <span class="keywordflow">for</span> (tmp = 0; tmp &lt; SICSLOWPAN_IP_BUF-&gt;len[1] + 40; tmp++) {
  1683. <a name="l01651"></a>01651 uint8_t data = ((uint8_t *) (SICSLOWPAN_IP_BUF))[tmp];
  1684. <a name="l01652"></a>01652 PRINTF(<span class="stringliteral">&quot;%02x&quot;</span>, data);
  1685. <a name="l01653"></a>01653 }
  1686. <a name="l01654"></a>01654 PRINTF(<span class="stringliteral">&quot;\n&quot;</span>);
  1687. <a name="l01655"></a>01655 }
  1688. <a name="l01656"></a>01656 <span class="preprocessor">#endif</span>
  1689. <a name="l01657"></a>01657 <span class="preprocessor"></span>
  1690. <a name="l01658"></a>01658 <span class="preprocessor">#if SICSLOWPAN_CONF_NEIGHBOR_INFO</span>
  1691. <a name="l01659"></a>01659 <span class="preprocessor"></span> <a class="code" href="a00293.html#a9e62c566b5f95c8f6bdb040f56437fd1" title="Notify the neighbor information module that a packet was received.">neighbor_info_packet_received</a>();
  1692. <a name="l01660"></a>01660 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_NEIGHBOR_INFO */</span>
  1693. <a name="l01661"></a>01661
  1694. <a name="l01662"></a>01662 <a class="code" href="a01569.html#ga0d5e21d13844dbebd703fb8ed6b058d0" title="Deliver an incoming packet to the TCP/IP stack.">tcpip_input</a>();
  1695. <a name="l01663"></a>01663 <span class="preprocessor">#if SICSLOWPAN_CONF_FRAG</span>
  1696. <a name="l01664"></a>01664 <span class="preprocessor"></span> }
  1697. <a name="l01665"></a>01665 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_FRAG */</span>
  1698. <a name="l01666"></a>01666 }<span class="comment"></span>
  1699. <a name="l01667"></a>01667 <span class="comment">/** @} */</span>
  1700. <a name="l01668"></a>01668
  1701. <a name="l01669"></a>01669 <span class="comment">/*--------------------------------------------------------------------*/</span>
  1702. <a name="l01670"></a>01670 <span class="comment">/* \brief 6lowpan init function (called by the MAC layer) */</span>
  1703. <a name="l01671"></a>01671 <span class="comment">/*--------------------------------------------------------------------*/</span>
  1704. <a name="l01672"></a>01672 <span class="keywordtype">void</span>
  1705. <a name="l01673"></a>01673 sicslowpan_init(<span class="keywordtype">void</span>)
  1706. <a name="l01674"></a>01674 {
  1707. <a name="l01675"></a>01675 <span class="comment">/* remember the mac driver */</span>
  1708. <a name="l01676"></a>01676 sicslowpan_mac = &amp;NETSTACK_MAC;
  1709. <a name="l01677"></a>01677
  1710. <a name="l01678"></a>01678 <span class="comment">/*</span>
  1711. <a name="l01679"></a>01679 <span class="comment"> * Set out output function as the function to be called from uIP to</span>
  1712. <a name="l01680"></a>01680 <span class="comment"> * send a packet.</span>
  1713. <a name="l01681"></a>01681 <span class="comment"> */</span>
  1714. <a name="l01682"></a>01682 tcpip_set_outputfunc(output);
  1715. <a name="l01683"></a>01683
  1716. <a name="l01684"></a>01684 <span class="preprocessor">#if SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06</span>
  1717. <a name="l01685"></a>01685 <span class="preprocessor"></span><span class="comment">/* Preinitialize any address contexts for better header compression</span>
  1718. <a name="l01686"></a>01686 <span class="comment"> * (Saves up to 13 bytes per 6lowpan packet)</span>
  1719. <a name="l01687"></a>01687 <span class="comment"> * The platform contiki-conf.h file can override this using e.g.</span>
  1720. <a name="l01688"></a>01688 <span class="comment"> * #define SICSLOWPAN_CONF_ADDR_CONTEXT_0 {addr_contexts[0].prefix[0]=0xbb;addr_contexts[0].prefix[1]=0xbb;}</span>
  1721. <a name="l01689"></a>01689 <span class="comment"> */</span>
  1722. <a name="l01690"></a>01690 <span class="preprocessor">#if SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0 </span>
  1723. <a name="l01691"></a>01691 <span class="preprocessor"></span> addr_contexts[0].used = 1;
  1724. <a name="l01692"></a>01692 addr_contexts[0].number = 0;
  1725. <a name="l01693"></a>01693 <span class="preprocessor">#ifdef SICSLOWPAN_CONF_ADDR_CONTEXT_0</span>
  1726. <a name="l01694"></a>01694 <span class="preprocessor"></span> SICSLOWPAN_CONF_ADDR_CONTEXT_0;
  1727. <a name="l01695"></a>01695 <span class="preprocessor">#else</span>
  1728. <a name="l01696"></a>01696 <span class="preprocessor"></span> addr_contexts[0].prefix[0] = 0xaa;
  1729. <a name="l01697"></a>01697 addr_contexts[0].prefix[1] = 0xaa;
  1730. <a name="l01698"></a>01698 <span class="preprocessor">#endif</span>
  1731. <a name="l01699"></a>01699 <span class="preprocessor"></span><span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 0 */</span>
  1732. <a name="l01700"></a>01700
  1733. <a name="l01701"></a>01701 <span class="preprocessor">#if SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 1</span>
  1734. <a name="l01702"></a>01702 <span class="preprocessor"></span> {
  1735. <a name="l01703"></a>01703 <span class="keywordtype">int</span> i;
  1736. <a name="l01704"></a>01704 <span class="keywordflow">for</span>(i = 1; i &lt; SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS; i++) {
  1737. <a name="l01705"></a>01705 <span class="preprocessor">#ifdef SICSLOWPAN_CONF_ADDR_CONTEXT_1</span>
  1738. <a name="l01706"></a>01706 <span class="preprocessor"></span> <span class="keywordflow">if</span> (i==1) {
  1739. <a name="l01707"></a>01707 addr_contexts[1].used = 1;
  1740. <a name="l01708"></a>01708 addr_contexts[1].number = 1;
  1741. <a name="l01709"></a>01709 SICSLOWPAN_CONF_ADDR_CONTEXT_1;
  1742. <a name="l01710"></a>01710 <span class="preprocessor">#ifdef SICSLOWPAN_CONF_ADDR_CONTEXT_2</span>
  1743. <a name="l01711"></a>01711 <span class="preprocessor"></span> } <span class="keywordflow">else</span> <span class="keywordflow">if</span> (i==2) {
  1744. <a name="l01712"></a>01712 addr_contexts[2].used = 1;
  1745. <a name="l01713"></a>01713 addr_contexts[2].number = 2;
  1746. <a name="l01714"></a>01714 SICSLOWPAN_CONF_ADDR_CONTEXT_2;
  1747. <a name="l01715"></a>01715 <span class="preprocessor">#endif</span>
  1748. <a name="l01716"></a>01716 <span class="preprocessor"></span> } <span class="keywordflow">else</span> {
  1749. <a name="l01717"></a>01717 addr_contexts[i].used = 0;
  1750. <a name="l01718"></a>01718 }
  1751. <a name="l01719"></a>01719 <span class="preprocessor">#else</span>
  1752. <a name="l01720"></a>01720 <span class="preprocessor"></span> addr_contexts[i].used = 0;
  1753. <a name="l01721"></a>01721 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_ADDR_CONTEXT_1 */</span>
  1754. <a name="l01722"></a>01722
  1755. <a name="l01723"></a>01723 }
  1756. <a name="l01724"></a>01724 }
  1757. <a name="l01725"></a>01725 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_CONF_MAX_ADDR_CONTEXTS &gt; 1 */</span>
  1758. <a name="l01726"></a>01726
  1759. <a name="l01727"></a>01727 <span class="preprocessor">#endif </span><span class="comment">/* SICSLOWPAN_COMPRESSION == SICSLOWPAN_COMPRESSION_HC06 */</span>
  1760. <a name="l01728"></a>01728 }
  1761. <a name="l01729"></a>01729 <span class="comment">/*--------------------------------------------------------------------*/</span>
  1762. <a name="l01730"></a>01730 <span class="keyword">const</span> <span class="keyword">struct </span><a class="code" href="a00060.html" title="The structure of a network driver in Contiki.">network_driver</a> sicslowpan_driver = {
  1763. <a name="l01731"></a>01731 <span class="stringliteral">&quot;sicslowpan&quot;</span>,
  1764. <a name="l01732"></a>01732 sicslowpan_init,
  1765. <a name="l01733"></a>01733 <a class="code" href="a00060.html#ab731b9526416dfdc094f45df8363030c" title="Callback for getting notified of incoming packet.">input</a>
  1766. <a name="l01734"></a>01734 };
  1767. <a name="l01735"></a>01735 <span class="comment">/*--------------------------------------------------------------------*/</span><span class="comment"></span>
  1768. <a name="l01736"></a>01736 <span class="comment">/** @} */</span>
  1769. </pre></div></div>
  1770. <hr size="1"/><address style="text-align: right;"><small>Generated on Mon Apr 11 14:23:31 2011 for Contiki 2.5 by&nbsp;
  1771. <a href="http://www.doxygen.org/index.html">
  1772. <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.1 </small></address>
  1773. </body>
  1774. </html>