Contiki 3.x
uip-driver.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2010, Swedish Institute of Computer Science.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * 3. Neither the name of the Institute nor the names of its contributors
14  * may be used to endorse or promote products derived from this software
15  * without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
18  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
21  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27  * SUCH DAMAGE.
28  *
29  */
30 
31 /**
32  * \file
33  * A brief description of what this file is
34  * \author
35  * Niclas Finne <nfi@sics.se>
36  * Joakim Eriksson <joakime@sics.se>
37  */
38 
39 #include "net/netstack.h"
40 #include "net/ip/uip.h"
41 #include "net/ip/tcpip.h"
42 #include "net/packetbuf.h"
43 #include "net/uip-driver.h"
44 #include <string.h>
45 
46 /*--------------------------------------------------------------------*/
47 uint8_t
48 #if NETSTACK_CONF_WITH_IPV6
49 uip_driver_send(const uip_lladdr_t *addr)
50 #else
51 uip_driver_send(void)
52 #endif
53 {
55 
56  /* XXX we should provide a callback function that is called when the
57  packet is sent. For now, we just supply a NULL pointer. */
58  NETSTACK_LLSEC.send(NULL, NULL);
59  return 1;
60 }
61 /*--------------------------------------------------------------------*/
62 static void
63 init(void)
64 {
65  /*
66  * Set out output function as the function to be called from uIP to
67  * send a packet.
68  */
69  tcpip_set_outputfunc(uip_driver_send);
70 }
71 /*--------------------------------------------------------------------*/
72 static void
73 input(void)
74 {
75  if(packetbuf_datalen() > 0 &&
79  tcpip_input();
80  }
81 }
82 /*--------------------------------------------------------------------*/
83 const struct network_driver uip_driver = {
84  "uip",
85  init,
86  input
87 };
88 /*--------------------------------------------------------------------*/
void * packetbuf_dataptr(void)
Get a pointer to the data in the packetbuf.
Definition: packetbuf.c:158
uip_len
The length of the packet in the uip_buf buffer.
Definition: tcp_loader.c:75
static uip_ds6_addr_t * addr
Pointer to a router list entry.
Definition: uip-nd6.c:124
static void input(void)
Process a received 6lowpan packet.
Definition: sicslowpan.c:1503
#define UIP_LLH_LEN
The link level header length.
Definition: uipopt.h:160
#define uip_buf
Macro to access uip_aligned_buf as an array of bytes.
Definition: uip.h:523
Header file for the Rime buffer (packetbuf) management
Header for the Contiki/uIP interface.
A brief description of what this file is
#define NULL
The null pointer.
802.3 address
Definition: uip.h:129
Header file for the uIP TCP/IP stack.
int packetbuf_copyfrom(const void *from, uint16_t len)
Copy from external data into the packetbuf.
Definition: packetbuf.c:85
uint16_t packetbuf_datalen(void)
Get the length of the data in the packetbuf.
Definition: packetbuf.c:170
void(* init)(void)
Initialize the network driver.
Definition: netstack.h:121
The structure of a network driver in Contiki.
Definition: netstack.h:117
void tcpip_input(void)
Deliver an incoming packet to the TCP/IP stack.
Definition: tcpip.c:522
#define UIP_BUFSIZE
The size of the uIP packet buffer.
Definition: uipopt.h:173
Include file for the Contiki low-layer network stack (NETSTACK)