linux内核中的时间戳错误?

时间:2014-04-11 04:20:49

标签: c linux struct linux-kernel timestamp

int netif_rx(struct sk_buff *skb) 
{
if(skb -> stamp.tv_sec ==0)
do_gettimeofday(&skb->stamp);
}

上述api是接收方api,它接收来自发送方的数据。我想计算它接收数据并将其存储在缓冲区中的时间。第2993行的上述api在内核源代码中可用:/linux/net/core/dev.c 但我得到错误:因为struct sk_buff没有名为stamp的成员。

http://lxr.free-electrons.com/source/include/linux/skbuff.h有人可以帮助我:如何获取linux内核的时间戳。

后来我将代码更改为:

 int netif_rx(struct sk_buff *skb) 
    {
    if(skb -> tstamp.off_sec ==0)
    do_gettimeofday(&skb->tstamp);
    }

1:http://www.fsl.cs.sunysb.edu/kernel-api/re498.html


2:https://github.com/embest-tech/platform_prebuilt/blob/master/ndk/android-ndk-r7/platforms/android-4/arch-x86/usr/include/linux/skbuff.h

-------------------------在第81行检查一下----------------- -----------------------------

现在我收到的错误是:ktime_t没有名为" tv_sec"的memeber。 struct timeval但参数的类型为unio ktime_t。

2 个答案:

答案 0 :(得分:0)

sk_buff->tstampktime_t类型的变量。 do_gettimeofday将时间设置为struct timeval的变量。您在这里有不同的类型,因此您需要转换。一个简单的问题是:

int netif_rx(struct sk_buff *skb) 
{
    if(skb -> tstamp.off_sec ==0)
    {
        struct timespec now;
        getnstimeofday(&now);
        skb->tstamp = timespec_to_ktime(now);
    }
}

修改 如果您只想为套接字缓冲区加时间戳,可以调用__net_timestamp

int netif_rx(struct sk_buff *skb) 
{
    __net_timestamp(skb);
}

或者,如果你不能打电话给__net_timestamp,你可以亲自动手:

int netif_rx(struct sk_buff *skb) 
{
    skb->tstamp = ktime_get_real();
}

答案 1 :(得分:0)

你可以这样做

your_function(struct sk_buff *skb)
{
    struct timeval tv;

    do_gettimeofday(&tv);
    skb->tstamp = timeval_to_ktime(tv);
}

Have a look at this code mwifiex_hard_start_xmit功能

在大多数情况下,您不需要提供自己的netif_rx实施