Modified to use the new MAC layer API
This commit is contained in:
parent
f373c63532
commit
52eb372890
6 changed files with 139 additions and 55 deletions
|
@ -28,7 +28,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: nullmac.c,v 1.2 2007/05/19 13:19:22 oliverschmidt Exp $
|
* $Id: nullmac.c,v 1.3 2007/05/25 08:07:15 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -39,32 +39,63 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "net/mac/nullmac.h"
|
#include "net/mac/nullmac.h"
|
||||||
|
#include "net/rime/rimebuf.h"
|
||||||
|
|
||||||
static const struct radio_driver *radio;
|
static const struct radio_driver *radio;
|
||||||
|
static void (* receiver_callback)(const struct mac_driver *);
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static int
|
||||||
send(void)
|
send(void)
|
||||||
{
|
{
|
||||||
radio->send(rimebuf_hdrptr(), rimebuf_totlen());
|
return radio->send(rimebuf_hdrptr(), rimebuf_totlen());
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static void
|
||||||
input(const struct radio_driver *d)
|
input(const struct radio_driver *d)
|
||||||
|
{
|
||||||
|
receiver_callback(&nullmac_driver);
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static int
|
||||||
|
read(void)
|
||||||
{
|
{
|
||||||
int len;
|
int len;
|
||||||
rimebuf_clear();
|
rimebuf_clear();
|
||||||
len = radio->read(rimebuf_dataptr(), RIMEBUF_SIZE);
|
len = radio->read(rimebuf_dataptr(), RIMEBUF_SIZE);
|
||||||
rimebuf_set_datalen(len);
|
rimebuf_set_datalen(len);
|
||||||
rime_input();
|
return len;
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static void
|
||||||
|
set_receive_function(void (* recv)(const struct mac_driver *))
|
||||||
|
{
|
||||||
|
receiver_callback = recv;
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static int
|
||||||
|
on(void)
|
||||||
|
{
|
||||||
|
return radio->on();
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static int
|
||||||
|
off(void)
|
||||||
|
{
|
||||||
|
return radio->off();
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
nullmac_init(const struct radio_driver *d)
|
nullmac_init(const struct radio_driver *d)
|
||||||
{
|
{
|
||||||
rime_set_output(send);
|
|
||||||
radio = d;
|
radio = d;
|
||||||
radio->set_receive_function(input);
|
radio->set_receive_function(input);
|
||||||
radio->on();
|
radio->on();
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
const struct mac_driver nullmac_driver = {
|
||||||
|
send,
|
||||||
|
read,
|
||||||
|
set_receive_function,
|
||||||
|
on,
|
||||||
|
off,
|
||||||
|
};
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: nullmac.h,v 1.1 2007/05/15 07:40:22 adamdunkels Exp $
|
* $Id: nullmac.h,v 1.2 2007/05/25 08:07:15 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -41,10 +41,11 @@
|
||||||
#ifndef __NULLMAC_H__
|
#ifndef __NULLMAC_H__
|
||||||
#define __NULLMAC_H__
|
#define __NULLMAC_H__
|
||||||
|
|
||||||
#include "contiki-net.h"
|
#include "net/mac/mac.h"
|
||||||
|
|
||||||
#include "dev/radio.h"
|
#include "dev/radio.h"
|
||||||
|
|
||||||
void nullmac_init(const struct radio_driver *d);
|
extern const struct mac_driver nullmac_driver;
|
||||||
|
|
||||||
|
void nullmac_init(const struct radio_driver *r);
|
||||||
|
|
||||||
#endif /* __NULLMAC_H__ */
|
#endif /* __NULLMAC_H__ */
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: xmac.c,v 1.5 2007/05/22 22:10:30 oliverschmidt Exp $
|
* $Id: xmac.c,v 1.6 2007/05/25 08:07:15 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,18 +47,22 @@
|
||||||
#include "net/rime.h"
|
#include "net/rime.h"
|
||||||
#include "dev/radio.h"
|
#include "dev/radio.h"
|
||||||
|
|
||||||
|
#include "contiki-conf.h"
|
||||||
|
|
||||||
#ifdef CHAMELEON
|
#ifdef CHAMELEON
|
||||||
#include "net/chameleon/packattr.h"
|
#include "net/chameleon/packattr.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define WITH_RECEIVER 1
|
||||||
|
#define WITH_QUEUE 0
|
||||||
|
|
||||||
|
/*
|
||||||
#undef XMAC_CONF_ON_TIME
|
#undef XMAC_CONF_ON_TIME
|
||||||
#undef XMAC_CONF_OFF_TIME
|
#undef XMAC_CONF_OFF_TIME
|
||||||
|
|
||||||
#define WITH_RECEIVER 1
|
|
||||||
#define WITH_QUEUE 1
|
|
||||||
#define XMAC_CONF_ON_TIME RTIMER_ARCH_SECOND / 100
|
#define XMAC_CONF_ON_TIME RTIMER_ARCH_SECOND / 100
|
||||||
#define XMAC_CONF_OFF_TIME RTIMER_ARCH_SECOND / 10
|
#define XMAC_CONF_OFF_TIME RTIMER_ARCH_SECOND / 10
|
||||||
|
*/
|
||||||
|
|
||||||
#if WITH_RECEIVER
|
#if WITH_RECEIVER
|
||||||
extern
|
extern
|
||||||
|
@ -94,7 +98,7 @@ static struct pt pt;
|
||||||
#define OFF_TIME (ON_TIME * 10)
|
#define OFF_TIME (ON_TIME * 10)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define STROBE_WAIT_TIME ON_TIME / 2
|
#define STROBE_WAIT_TIME (ON_TIME) / 2
|
||||||
|
|
||||||
static volatile unsigned char should_be_awake = 0;
|
static volatile unsigned char should_be_awake = 0;
|
||||||
static volatile unsigned char someone_is_sending = 0;
|
static volatile unsigned char someone_is_sending = 0;
|
||||||
|
@ -124,10 +128,19 @@ static const struct radio_driver *radio;
|
||||||
#define PRINTF(...)
|
#define PRINTF(...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static void (* receiver_callback)(const struct mac_driver *);
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static void
|
||||||
|
set_receive_function(void (* recv)(const struct mac_driver *))
|
||||||
|
{
|
||||||
|
receiver_callback = recv;
|
||||||
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static char
|
static char
|
||||||
powercycle(struct rtimer *t, void *ptr)
|
powercycle(struct rtimer *t, void *ptr)
|
||||||
{
|
{
|
||||||
|
int r;
|
||||||
|
|
||||||
PT_BEGIN(&pt);
|
PT_BEGIN(&pt);
|
||||||
|
|
||||||
while(1) {
|
while(1) {
|
||||||
|
@ -144,9 +157,10 @@ powercycle(struct rtimer *t, void *ptr)
|
||||||
should_be_awake = 0;
|
should_be_awake = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(rtimer_set(t, RTIMER_TIME(t) + OFF_TIME, 1,
|
r = rtimer_set(t, RTIMER_TIME(t) + OFF_TIME, 1,
|
||||||
(void (*)(struct rtimer *, void *))powercycle, ptr)) {
|
(void (*)(struct rtimer *, void *))powercycle, ptr);
|
||||||
PRINTF("xmac: could not set rtimer\n");
|
if(r) {
|
||||||
|
PRINTF("xmac: 1 could not set rtimer %d\n", r);
|
||||||
}
|
}
|
||||||
/* t2 = rtimer_arch_now(); */
|
/* t2 = rtimer_arch_now(); */
|
||||||
/* printf("xmac 1 %d\n", t2 - t1); */
|
/* printf("xmac 1 %d\n", t2 - t1); */
|
||||||
|
@ -163,9 +177,10 @@ powercycle(struct rtimer *t, void *ptr)
|
||||||
radio_is_on = 1;
|
radio_is_on = 1;
|
||||||
LEDS_ON(LEDS_RED);
|
LEDS_ON(LEDS_RED);
|
||||||
}
|
}
|
||||||
if(rtimer_set(t, RTIMER_TIME(t) + ON_TIME, 1,
|
r = rtimer_set(t, RTIMER_TIME(t) + ON_TIME, 1,
|
||||||
(void (*)(struct rtimer *, void *))powercycle, ptr)) {
|
(void (*)(struct rtimer *, void *))powercycle, ptr);
|
||||||
PRINTF("xmac: could not set rtimer\n");
|
if(r) {
|
||||||
|
PRINTF("xmac: 2 could not set rtimer %d\n", r);
|
||||||
}
|
}
|
||||||
/* t2 = rtimer_arch_now(); */
|
/* t2 = rtimer_arch_now(); */
|
||||||
/* printf("xmac 2 %d\n", t2 - t1); */
|
/* printf("xmac 2 %d\n", t2 - t1); */
|
||||||
|
@ -197,7 +212,7 @@ powercycle(struct rtimer *t, void *ptr)
|
||||||
PT_END(&pt);
|
PT_END(&pt);
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static int
|
||||||
send(void)
|
send(void)
|
||||||
{
|
{
|
||||||
rtimer_clock_t t0, t1;
|
rtimer_clock_t t0, t1;
|
||||||
|
@ -211,8 +226,10 @@ send(void)
|
||||||
radio_is_on = 1;
|
radio_is_on = 1;
|
||||||
|
|
||||||
/* printf("xmac_send\n");*/
|
/* printf("xmac_send\n");*/
|
||||||
|
#if !CHAMELEON
|
||||||
PRINTF("xmac: send() len %d to %d.%d\n", rimebuf_totlen(),
|
PRINTF("xmac: send() len %d to %d.%d\n", rimebuf_totlen(),
|
||||||
uc_receiver.u8[0], uc_receiver.u8[1]);
|
uc_receiver.u8[0], uc_receiver.u8[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
rimebuf_hdralloc(sizeof(struct xmac_hdr));
|
rimebuf_hdralloc(sizeof(struct xmac_hdr));
|
||||||
hdr = rimebuf_hdrptr();
|
hdr = rimebuf_hdrptr();
|
||||||
|
@ -252,6 +269,8 @@ send(void)
|
||||||
radio->send((const u8_t *)&msg, sizeof(struct xmac_hdr));
|
radio->send((const u8_t *)&msg, sizeof(struct xmac_hdr));
|
||||||
|
|
||||||
while(RTIMER_CLOCK_LT(RTIMER_NOW(), t + STROBE_WAIT_TIME)) {
|
while(RTIMER_CLOCK_LT(RTIMER_NOW(), t + STROBE_WAIT_TIME)) {
|
||||||
|
printf("now %d then %d wait %d\n",
|
||||||
|
RTIMER_NOW(), t, STROBE_WAIT_TIME);
|
||||||
/* See if we got an ACK */
|
/* See if we got an ACK */
|
||||||
/* printf("befor read\n");*/
|
/* printf("befor read\n");*/
|
||||||
len = radio->read((u8_t *)&msg, sizeof(struct xmac_hdr));
|
len = radio->read((u8_t *)&msg, sizeof(struct xmac_hdr));
|
||||||
|
@ -293,11 +312,12 @@ send(void)
|
||||||
PRINTF("xmac: could not set rtimer after send\n");
|
PRINTF("xmac: could not set rtimer after send\n");
|
||||||
}
|
}
|
||||||
we_are_sending = 0;
|
we_are_sending = 0;
|
||||||
|
return 1;
|
||||||
|
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static struct queuebuf *queued_packet;
|
static struct queuebuf *queued_packet;
|
||||||
static void
|
static int
|
||||||
qsend(void)
|
qsend(void)
|
||||||
{
|
{
|
||||||
if(someone_is_sending) {
|
if(someone_is_sending) {
|
||||||
|
@ -305,22 +325,33 @@ qsend(void)
|
||||||
should_be_awake, someone_is_sending, we_are_sending, radio_is_on);
|
should_be_awake, someone_is_sending, we_are_sending, radio_is_on);
|
||||||
if(queued_packet != NULL) {
|
if(queued_packet != NULL) {
|
||||||
RIMESTATS_ADD(contentiondrop);
|
RIMESTATS_ADD(contentiondrop);
|
||||||
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
#if WITH_QUEUE
|
#if WITH_QUEUE
|
||||||
queued_packet = queuebuf_new_from_rimebuf();
|
queued_packet = queuebuf_new_from_rimebuf();
|
||||||
|
return 1;
|
||||||
#else
|
#else
|
||||||
RIMESTATS_ADD(contentiondrop);
|
RIMESTATS_ADD(contentiondrop);
|
||||||
|
return 0;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
PRINTF("xmac: send immediately.\n");
|
PRINTF("xmac: send immediately.\n");
|
||||||
send();
|
return send();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
static void
|
static void
|
||||||
input(const struct radio_driver *d)
|
input(const struct radio_driver *d)
|
||||||
|
{
|
||||||
|
if(receiver_callback) {
|
||||||
|
receiver_callback(&xmac_driver);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static int
|
||||||
|
read(void)
|
||||||
{
|
{
|
||||||
struct xmac_hdr *hdr;
|
struct xmac_hdr *hdr;
|
||||||
u8_t len;
|
u8_t len;
|
||||||
|
@ -328,7 +359,7 @@ input(const struct radio_driver *d)
|
||||||
rimebuf_clear();
|
rimebuf_clear();
|
||||||
|
|
||||||
PRINTF("xmac: input ");
|
PRINTF("xmac: input ");
|
||||||
len = d->read(rimebuf_dataptr(), RIMEBUF_SIZE);
|
len = radio->read(rimebuf_dataptr(), RIMEBUF_SIZE);
|
||||||
PRINTF("%d bytes\n", len);
|
PRINTF("%d bytes\n", len);
|
||||||
|
|
||||||
if(len > 0) {
|
if(len > 0) {
|
||||||
|
@ -382,16 +413,17 @@ input(const struct radio_driver *d)
|
||||||
someone_is_sending = 0;
|
someone_is_sending = 0;
|
||||||
should_be_awake = 0;
|
should_be_awake = 0;
|
||||||
PRINTF("xmac: final packet received\n");
|
PRINTF("xmac: final packet received\n");
|
||||||
rime_input();
|
|
||||||
/* XXX send queued packet. */
|
/* XXX should set timer to send queued packet later. */
|
||||||
if(queued_packet != NULL) {
|
if(queued_packet != NULL) {
|
||||||
queuebuf_to_rimebuf(queued_packet);
|
|
||||||
queuebuf_free(queued_packet);
|
queuebuf_free(queued_packet);
|
||||||
queued_packet = NULL;
|
queued_packet = NULL;
|
||||||
send();
|
}
|
||||||
}
|
|
||||||
|
return rimebuf_totlen();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
|
@ -403,8 +435,27 @@ xmac_init(const struct radio_driver *d)
|
||||||
rtimer_set(&rt, RTIMER_NOW() + OFF_TIME, 1,
|
rtimer_set(&rt, RTIMER_NOW() + OFF_TIME, 1,
|
||||||
(void (*)(struct rtimer *, void *))powercycle, NULL);
|
(void (*)(struct rtimer *, void *))powercycle, NULL);
|
||||||
|
|
||||||
rime_set_output(qsend);
|
|
||||||
radio = d;
|
radio = d;
|
||||||
radio->set_receive_function(input);
|
radio->set_receive_function(input);
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static int
|
||||||
|
on(void)
|
||||||
|
{
|
||||||
|
return radio->on();
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static int
|
||||||
|
off(void)
|
||||||
|
{
|
||||||
|
return radio->off();
|
||||||
|
}
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
const struct mac_driver xmac_driver =
|
||||||
|
{
|
||||||
|
qsend,
|
||||||
|
read,
|
||||||
|
set_receive_function,
|
||||||
|
on,
|
||||||
|
off
|
||||||
|
};
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: xmac.h,v 1.3 2007/05/22 20:55:24 adamdunkels Exp $
|
* $Id: xmac.h,v 1.4 2007/05/25 08:07:15 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -41,10 +41,11 @@
|
||||||
#ifndef __XMAC_H__
|
#ifndef __XMAC_H__
|
||||||
#define __XMAC_H__
|
#define __XMAC_H__
|
||||||
|
|
||||||
#include "contiki-net.h"
|
#include "net/mac/mac.h"
|
||||||
|
|
||||||
#include "dev/radio.h"
|
#include "dev/radio.h"
|
||||||
|
|
||||||
|
extern const struct mac_driver xmac_driver;
|
||||||
|
|
||||||
void xmac_init(const struct radio_driver *d);
|
void xmac_init(const struct radio_driver *d);
|
||||||
|
|
||||||
#endif /* __XMAC_H__ */
|
#endif /* __XMAC_H__ */
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: rime.h,v 1.8 2007/05/22 20:53:24 adamdunkels Exp $
|
* $Id: rime.h,v 1.9 2007/05/25 08:06:44 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -54,13 +54,14 @@
|
||||||
#include "net/rime/ruc.h"
|
#include "net/rime/ruc.h"
|
||||||
#include "net/rime/sibc.h"
|
#include "net/rime/sibc.h"
|
||||||
|
|
||||||
|
#include "net/mac/mac.h"
|
||||||
/**
|
/**
|
||||||
* \brief Initialize Rime
|
* \brief Initialize Rime
|
||||||
*
|
*
|
||||||
* This function should be called from the system boot up
|
* This function should be called from the system boot up
|
||||||
* code to initialize Rime.
|
* code to initialize Rime.
|
||||||
*/
|
*/
|
||||||
void rime_init(void);
|
void rime_init(const struct mac_driver *);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Send an incoming packet to Rime
|
* \brief Send an incoming packet to Rime
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
*
|
*
|
||||||
* This file is part of the Contiki operating system.
|
* This file is part of the Contiki operating system.
|
||||||
*
|
*
|
||||||
* $Id: rime.c,v 1.9 2007/05/22 20:56:10 adamdunkels Exp $
|
* $Id: rime.c,v 1.10 2007/05/25 08:06:44 adamdunkels Exp $
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -44,32 +44,31 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "net/rime.h"
|
#include "net/rime.h"
|
||||||
|
#include "net/mac/mac.h"
|
||||||
|
|
||||||
static void (* output)(void);
|
static const struct mac_driver *mac;
|
||||||
|
/*---------------------------------------------------------------------------*/
|
||||||
|
static void
|
||||||
|
input(const struct mac_driver *r)
|
||||||
|
{
|
||||||
|
int len;
|
||||||
|
len = mac->read();
|
||||||
|
if(len > 0) {
|
||||||
|
RIMESTATS_ADD(rx);
|
||||||
|
abc_input_packet();
|
||||||
|
}
|
||||||
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
rime_init(void)
|
rime_init(const struct mac_driver *m)
|
||||||
{
|
{
|
||||||
ctimer_init();
|
ctimer_init();
|
||||||
queuebuf_init();
|
queuebuf_init();
|
||||||
route_init();
|
route_init();
|
||||||
rimebuf_clear();
|
rimebuf_clear();
|
||||||
output = NULL;
|
|
||||||
neighbor_init();
|
neighbor_init();
|
||||||
}
|
mac = m;
|
||||||
/*---------------------------------------------------------------------------*/
|
mac->set_receive_function(input);
|
||||||
void
|
|
||||||
rime_input(void)
|
|
||||||
{
|
|
||||||
RIMESTATS_ADD(rx);
|
|
||||||
abc_input_packet();
|
|
||||||
}
|
|
||||||
/*---------------------------------------------------------------------------*/
|
|
||||||
void
|
|
||||||
rime_set_output(void (*f)(void))
|
|
||||||
{
|
|
||||||
output = f;
|
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
void
|
void
|
||||||
|
@ -77,8 +76,8 @@ rime_output(void)
|
||||||
{
|
{
|
||||||
RIMESTATS_ADD(tx);
|
RIMESTATS_ADD(tx);
|
||||||
rimebuf_compact();
|
rimebuf_compact();
|
||||||
if(output) {
|
if(mac) {
|
||||||
output();
|
mac->send();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
|
Loading…
Reference in a new issue