我在使用C编写的contiki的单播示例中发现了这一点。任何人都可以向我解释他们做了什么。
由于
#define MSG_LEN 20
msg_header_t * header;
uint8_t *data;
packetbuf_clear();
header = (msg_header_t *)(packetbuf_dataptr());
data = (uint8_t *)(header + 1);
random_data(data, MSG_LEN);
hton_uint16(&header->data_len, MSG_LEN);
packetbuf_set_datalen(sizeof(msg_header_t) + MSG_LEN);
rimeaddr_t addr;
addr.u8[0] = 2;
addr.u8[1] = 0;
if(!rimeaddr_cmp(&addr, &rimeaddr_node_addr)) {
unicast_send(&uc, &addr);
}
以下是一些关于细节的信息
typedef struct {
unsigned char data[2];
} nw_uint16_t;
typedef struct msg_header
{
NN_DIGIT r[NUMWORDS]; //NN_DIGIT = uint32_t, NUMWORDS = 6
NN_DIGIT s[NUMWORDS];
nw_uint16_t data_len;
} msg_header_t;
inline uint16_t hton_uint16(void * target, uint16_t value);
inline uint16_t ntoh_uint16(void * source);
方法
inline uint16_t hton_uint16(void * target, uint16_t value)
{
uint8_t *base = target;
base[1] = value;
base[0] = value >> 8;
return value;
}
/*---------------------------------------------------------------------------*/
inline uint16_t ntoh_uint16(void * source)
{
uint8_t *base = source;
return (uint16_t)(base[0] << 8 | base[1]);
}
/*---------------------------------------------------------------------------*/
static void random_data(void *ptr, uint16_t len)
{
uint16_t i;
for(i=0; i<len; i++) {
srand(100);
((uint8_t *)(ptr))[i] = 2;
}
}
packetbuf方法 http://dak664.github.com/contiki-doxygen/a01563.html#_details
答案 0 :(得分:0)
据我所知:
packetbuf_dataptr()
分配足够的内存来保存数据包标头,数据长度及其有效负载。
header = (msg_header_t *)(packetbuf_dataptr());
将指向标题的指针设置为该内存数组的开头。
data = (uint8_t *)(header + 1);
将数据“payload”的开头设置为标头header + 1
之后的第一个内存地址,这意味着<address of header> + sizeof(msg_header_t)
random_data(data, MSG_LEN);
将一些MSG_LEN
字节的随机数据放入有效负载中。
hton_uint16(&header->data_len, MSG_LEN);
将网络字节顺序的数据段长度写入数据包标头data_len
字段。
packetbuf_set_datalen(sizeof(msg_header_t) + MSG_LEN);
将标头与其有效负载一起发送。