Updated API
This commit is contained in:
parent
6357c240c0
commit
81dfaf575c
3 changed files with 80 additions and 34 deletions
|
@ -30,7 +30,7 @@
|
||||||
*
|
*
|
||||||
* Author: Adam Dunkels <adam@sics.se>
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
*
|
*
|
||||||
* $Id: ethernode-rime.c,v 1.5 2007/03/29 22:26:33 adamdunkels Exp $
|
* $Id: ethernode-rime.c,v 1.6 2007/05/22 21:09:19 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "contiki.h"
|
#include "contiki.h"
|
||||||
|
@ -39,8 +39,6 @@
|
||||||
|
|
||||||
#include "net/rime.h"
|
#include "net/rime.h"
|
||||||
|
|
||||||
PROCESS(ethernode_rime_process, "Ethernode Rime driver");
|
|
||||||
|
|
||||||
#define DEBUG 0
|
#define DEBUG 0
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@ -50,39 +48,31 @@ PROCESS(ethernode_rime_process, "Ethernode Rime driver");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
PROCESS_THREAD(ethernode_rime_process, ev, data)
|
static void
|
||||||
|
receiver(void)
|
||||||
{
|
{
|
||||||
PROCESS_BEGIN();
|
u8_t len;
|
||||||
|
|
||||||
while(1) {
|
rimebuf_clear();
|
||||||
process_poll(ðernode_rime_process);
|
|
||||||
PROCESS_WAIT_EVENT();
|
|
||||||
|
|
||||||
/* Poll Ethernet device to see if there is a frame avaliable. */
|
len = ethernode_read(rimebuf_dataptr(), RIMEBUF_SIZE);
|
||||||
{
|
|
||||||
u16_t len;
|
|
||||||
|
|
||||||
rimebuf_clear();
|
if(len > 0) {
|
||||||
|
rimebuf_set_datalen(len);
|
||||||
len = ethernode_read(rimebuf_dataptr(), RIMEBUF_SIZE);
|
rime_input();
|
||||||
|
|
||||||
if(len > 0) {
|
|
||||||
|
|
||||||
rimebuf_set_datalen(len);
|
|
||||||
|
|
||||||
PRINTF("ethernode_rime_process: received len %d\n", len);
|
|
||||||
rime_input();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
PROCESS_END();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
rime_driver_send(void)
|
ethernode_rime_send(void)
|
||||||
{
|
{
|
||||||
PRINTF("ethernode_rime: sending %d bytes\n", rimebuf_totlen());
|
|
||||||
ethernode_send_buf(rimebuf_hdrptr(), rimebuf_totlen());
|
ethernode_send_buf(rimebuf_hdrptr(), rimebuf_totlen());
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
void
|
||||||
|
ethernode_rime_init(void)
|
||||||
|
{
|
||||||
|
ethernode_set_receiver(receiver);
|
||||||
|
rime_set_output(ethernode_rime_send);
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
*
|
*
|
||||||
* Author: Adam Dunkels <adam@sics.se>
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
*
|
*
|
||||||
* $Id: ethernode.c,v 1.7 2007/03/29 22:25:52 adamdunkels Exp $
|
* $Id: ethernode.c,v 1.8 2007/05/22 21:09:19 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
/**
|
/**
|
||||||
* \file
|
* \file
|
||||||
|
@ -44,6 +44,8 @@
|
||||||
#include "net/uip-fw.h"
|
#include "net/uip-fw.h"
|
||||||
#include "ether.h"
|
#include "ether.h"
|
||||||
|
|
||||||
|
#include "dev/radio.h"
|
||||||
|
|
||||||
#include "node.h"
|
#include "node.h"
|
||||||
|
|
||||||
#include "lib/random.h"
|
#include "lib/random.h"
|
||||||
|
@ -72,10 +74,26 @@ struct hdr {
|
||||||
u8_t seqno;
|
u8_t seqno;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int ethernode_on(void) {return 0;}
|
||||||
|
static int ethernode_safe_off(void) {return 0;}
|
||||||
|
|
||||||
|
#include "net/ethernode.h"
|
||||||
|
|
||||||
|
const struct radio_driver ethernode_driver =
|
||||||
|
{
|
||||||
|
ethernode_send_buf,
|
||||||
|
ethernode_read,
|
||||||
|
ethernode_set_receiver,
|
||||||
|
ethernode_on,
|
||||||
|
ethernode_safe_off,
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
#define HDR_LEN UIP_LLH_LEN
|
#define HDR_LEN UIP_LLH_LEN
|
||||||
|
|
||||||
#define ID_BROADCAST 0x80
|
#define ID_BROADCAST 0x80
|
||||||
|
|
||||||
|
PROCESS(ethernode_process, "Ethernode");
|
||||||
/*-------------------------------------------------------------------------------*/
|
/*-------------------------------------------------------------------------------*/
|
||||||
static u8_t
|
static u8_t
|
||||||
do_send(u8_t type, u8_t dest, struct hdr *hdr, int len)
|
do_send(u8_t type, u8_t dest, struct hdr *hdr, int len)
|
||||||
|
@ -122,7 +140,13 @@ ethernode_init(int port)
|
||||||
*/
|
*/
|
||||||
/*-------------------------------------------------------------------------------*/
|
/*-------------------------------------------------------------------------------*/
|
||||||
int
|
int
|
||||||
ethernode_read(u8_t *buf, int bufsize)
|
ethernode_poll(void)
|
||||||
|
{
|
||||||
|
return ether_client_poll();
|
||||||
|
}
|
||||||
|
/*-------------------------------------------------------------------------------*/
|
||||||
|
u16_t
|
||||||
|
ethernode_read(u8_t *buf, u16_t bufsize)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
u8_t tmpbuf[2048];
|
u8_t tmpbuf[2048];
|
||||||
|
@ -191,8 +215,8 @@ ethernode_send(void)
|
||||||
return UIP_FW_OK;
|
return UIP_FW_OK;
|
||||||
}
|
}
|
||||||
/*-------------------------------------------------------------------------------*/
|
/*-------------------------------------------------------------------------------*/
|
||||||
void
|
int
|
||||||
ethernode_send_buf(u8_t *buf, int len)
|
ethernode_send_buf(const u8_t *buf, u16_t len)
|
||||||
{
|
{
|
||||||
char tmpbuf[2048];
|
char tmpbuf[2048];
|
||||||
struct hdr *hdr = (struct hdr *)tmpbuf;
|
struct hdr *hdr = (struct hdr *)tmpbuf;
|
||||||
|
@ -203,5 +227,32 @@ ethernode_send_buf(u8_t *buf, int len)
|
||||||
|
|
||||||
dest = ID_BROADCAST;
|
dest = ID_BROADCAST;
|
||||||
do_send(TYPE_DATA, dest, hdr, len);
|
do_send(TYPE_DATA, dest, hdr, len);
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
/*-------------------------------------------------------------------------------*/
|
||||||
|
static void (* receiver_callback)(const struct radio_driver *);
|
||||||
|
/*-------------------------------------------------------------------------------*/
|
||||||
|
void
|
||||||
|
ethernode_set_receiver(void (* recv)(const struct radio_driver *))
|
||||||
|
{
|
||||||
|
process_start(ðernode_process, NULL);
|
||||||
|
receiver_callback = recv;
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
PROCESS_THREAD(ethernode_process, ev, data)
|
||||||
|
{
|
||||||
|
PROCESS_BEGIN();
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
process_poll(ðernode_process);
|
||||||
|
PROCESS_WAIT_EVENT();
|
||||||
|
|
||||||
|
if(ethernode_poll()) {
|
||||||
|
if(receiver_callback) {
|
||||||
|
receiver_callback(ðernode_driver);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
PROCESS_END();
|
||||||
}
|
}
|
||||||
/*-------------------------------------------------------------------------------*/
|
/*-------------------------------------------------------------------------------*/
|
||||||
|
|
|
@ -30,17 +30,22 @@
|
||||||
*
|
*
|
||||||
* Author: Adam Dunkels <adam@sics.se>
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
*
|
*
|
||||||
* $Id: ethernode.h,v 1.2 2007/03/13 13:07:48 adamdunkels Exp $
|
* $Id: ethernode.h,v 1.3 2007/05/22 21:09:19 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
#ifndef __ETHERNODE_H__
|
#ifndef __ETHERNODE_H__
|
||||||
#define __ETHERNODE_H__
|
#define __ETHERNODE_H__
|
||||||
|
|
||||||
#include "contiki.h"
|
#include "contiki.h"
|
||||||
|
|
||||||
|
#include "dev/radio.h"
|
||||||
|
|
||||||
void ethernode_init(int port);
|
void ethernode_init(int port);
|
||||||
int ethernode_poll(u8_t *buf, int bufsize);
|
u16_t ethernode_read(u8_t *buf, u16_t bufsize);
|
||||||
u8_t ethernode_send(void);
|
u8_t ethernode_send(void);
|
||||||
void ethernode_send_buf(u8_t *buf, int len);
|
int ethernode_send_buf(const u8_t *buf, u16_t len);
|
||||||
void ethernode_periodic(void);
|
void ethernode_periodic(void);
|
||||||
|
void ethernode_set_receiver(void (* recv)(const struct radio_driver *));
|
||||||
|
|
||||||
|
extern const struct radio_driver ethernode_driver;
|
||||||
|
|
||||||
#endif /* __ETHERNODE_H__ */
|
#endif /* __ETHERNODE_H__ */
|
||||||
|
|
Loading…
Reference in a new issue