理解 Contiki 中的 tcpdump.c 文件
Understading tcpdump.c file in Contiki
我试图在 Contiki 中浏览这个文件,发现很难理解它的目的是什么,以及为什么它使用如此混淆的代码?
我的婴儿床有这部分-
return s(" ping",
n(IPBUF->destipaddr[3], d(
n(IPBUF->destipaddr[2], d(
n(IPBUF->destipaddr[1], d(
n(IPBUF->destipaddr[0],
s(" ",
n(IPBUF->srcipaddr[3], d(
n(IPBUF->srcipaddr[2], d(
n(IPBUF->srcipaddr[1], d(
n(IPBUF->srcipaddr[0],
buf)))))))))))))))) - buf;
/*---------------------------------------------------------------------------*/
static char *
s(char *str, char *ptr)
{
strcpy(ptr, str);
return ptr + strlen(str);
}
/*---------------------------------------------------------------------------*/
int
tcpdump_format(uint8_t *packet, uint16_t packetlen,
char *buf, uint16_t buflen)
{
char flags[8];
if(IPBUF->proto == UIP_PROTO_ICMP) {
if(ICMPBUF->type == ICMP_ECHO) {
return s(" ping",
n(IPBUF->destipaddr[3], d(
n(IPBUF->destipaddr[2], d(
n(IPBUF->destipaddr[1], d(
n(IPBUF->destipaddr[0],
s(" ",
n(IPBUF->srcipaddr[3], d(
n(IPBUF->srcipaddr[2], d(
n(IPBUF->srcipaddr[1], d(
n(IPBUF->srcipaddr[0],
buf)))))))))))))))) - buf;
/* return sprintf(buf, "%d.%d.%d.%d %d.%d.%d.%d ping",
IPBUF->srcipaddr[0], IPBUF->srcipaddr[1],
IPBUF->srcipaddr[2], IPBUF->srcipaddr[3],
IPBUF->destipaddr[0], IPBUF->destipaddr[1],
IPBUF->destipaddr[2], IPBUF->destipaddr[3]);*/
}
https://github.com/contiki-os/contiki/blob/master/tools/wpcapslip/tcpdump.c
注释部分说明了代码试图做什么,但为什么要这样?
Contiki 专为微型系统而设计,只有几千字节的可用内存。 (一个带有休眠路由器和 RPL 路由的完整 IPv6 网络的典型系统需要不到 10 kb RAM 和 30 kb ROM。)标准字符串库可能没有在 OS 中使用,因为它需要一些内存。非常小的嵌入式系统有时不使用标准库,并在需要时拥有自己的实现。
我试图在 Contiki 中浏览这个文件,发现很难理解它的目的是什么,以及为什么它使用如此混淆的代码?
我的婴儿床有这部分-
return s(" ping",
n(IPBUF->destipaddr[3], d(
n(IPBUF->destipaddr[2], d(
n(IPBUF->destipaddr[1], d(
n(IPBUF->destipaddr[0],
s(" ",
n(IPBUF->srcipaddr[3], d(
n(IPBUF->srcipaddr[2], d(
n(IPBUF->srcipaddr[1], d(
n(IPBUF->srcipaddr[0],
buf)))))))))))))))) - buf;
/*---------------------------------------------------------------------------*/
static char *
s(char *str, char *ptr)
{
strcpy(ptr, str);
return ptr + strlen(str);
}
/*---------------------------------------------------------------------------*/
int
tcpdump_format(uint8_t *packet, uint16_t packetlen,
char *buf, uint16_t buflen)
{
char flags[8];
if(IPBUF->proto == UIP_PROTO_ICMP) {
if(ICMPBUF->type == ICMP_ECHO) {
return s(" ping",
n(IPBUF->destipaddr[3], d(
n(IPBUF->destipaddr[2], d(
n(IPBUF->destipaddr[1], d(
n(IPBUF->destipaddr[0],
s(" ",
n(IPBUF->srcipaddr[3], d(
n(IPBUF->srcipaddr[2], d(
n(IPBUF->srcipaddr[1], d(
n(IPBUF->srcipaddr[0],
buf)))))))))))))))) - buf;
/* return sprintf(buf, "%d.%d.%d.%d %d.%d.%d.%d ping",
IPBUF->srcipaddr[0], IPBUF->srcipaddr[1],
IPBUF->srcipaddr[2], IPBUF->srcipaddr[3],
IPBUF->destipaddr[0], IPBUF->destipaddr[1],
IPBUF->destipaddr[2], IPBUF->destipaddr[3]);*/
}
https://github.com/contiki-os/contiki/blob/master/tools/wpcapslip/tcpdump.c
注释部分说明了代码试图做什么,但为什么要这样?
Contiki 专为微型系统而设计,只有几千字节的可用内存。 (一个带有休眠路由器和 RPL 路由的完整 IPv6 网络的典型系统需要不到 10 kb RAM 和 30 kb ROM。)标准字符串库可能没有在 OS 中使用,因为它需要一些内存。非常小的嵌入式系统有时不使用标准库,并在需要时拥有自己的实现。