On Wed, Aug 17, 2016 at 10:17 AM, Tobias Klauser <tklau...@distanz.ch> wrote:
> On 2016-08-12 at 23:09:28 +0200, Vadim Kochan <vadi...@gmail.com> wrote:
>> Move hw timestamp enable/disable code to sock.c as
>> it is a socket related functionality, and it makes
>> have less files in source tree.
>>
>> Move tstamping related includes under HAVE_TSTAMPING config
>> to compile them only if hw timestamping is suported.
>>
>> Signed-off-by: Vadim Kochan <vadi...@gmail.com>
>> ---
>>  netsniff-ng.c        |  1 -
>>  netsniff-ng/Makefile |  3 ---
>>  sock.c               | 39 +++++++++++++++++++++++++++++++++++++++
>>  sock.h               |  1 +
>>  tstamping.c          | 38 --------------------------------------
>>  tstamping.h          | 15 ---------------
>>  6 files changed, 40 insertions(+), 57 deletions(-)
>>  delete mode 100644 tstamping.c
>>  delete mode 100644 tstamping.h
>>
>> diff --git a/netsniff-ng.c b/netsniff-ng.c
>> index ce37e10..ec060f8 100644
>> --- a/netsniff-ng.c
>> +++ b/netsniff-ng.c
>> @@ -44,7 +44,6 @@
>>  #include "lockme.h"
>>  #include "tprintf.h"
>>  #include "timer.h"
>> -#include "tstamping.h"
>>  #include "dissector.h"
>>  #include "xmalloc.h"
>>
>> diff --git a/netsniff-ng/Makefile b/netsniff-ng/Makefile
>> index d1d8a85..c6a531f 100644
>> --- a/netsniff-ng/Makefile
>> +++ b/netsniff-ng/Makefile
>> @@ -74,9 +74,6 @@ endif
>>  ifeq ($(CONFIG_GEOIP), 1)
>>  netsniff-ng-objs +=  geoip.o
>>  endif
>> -ifeq ($(CONFIG_HWTSTAMP), 1)
>> -netsniff-ng-objs +=  tstamping.o
>> -endif
>>  ifeq ($(CONFIG_LIBNL), 1)
>>  netsniff-ng-objs +=  mac80211.o \
>>                       proto_nlmsg.o
>> diff --git a/sock.c b/sock.c
>> index a84796c..a4ec434 100644
>> --- a/sock.c
>> +++ b/sock.c
>> @@ -1,7 +1,15 @@
>> +#include "config.h"
>> +
>>  #include <sys/types.h>
>>  #include <sys/socket.h>
>>  #include <fcntl.h>
>>  #include <arpa/inet.h>
>> +#ifdef HAVE_HARDWARE_TIMESTAMPING
>> +#include <linux/if.h>
>> +#include <sys/ioctl.h>
>> +#include <linux/sockios.h>
>> +#include <linux/net_tstamp.h>
>> +#endif
>>  #include <linux/if_ether.h>
>>  #include <linux/tcp.h>
>>
>> @@ -196,3 +204,34 @@ void reset_system_socket_memory(int *vals, size_t len)
>>       set_system_socket_mem(sock_wmem_max, vals[2]);
>>       set_system_socket_mem(sock_wmem_def, vals[3]);
>>  }
>> +
>> +int set_sockopt_hwtimestamp(int sock, const char *dev)
>> +{
>> +#ifdef HAVE_HARDWARE_TIMESTAMPING
>> +     int timesource, ret;
>> +     struct hwtstamp_config hwconfig;
>> +     struct ifreq ifr;
>> +
>> +     if (!strncmp("any", dev, strlen("any")))
>> +             return -1;
>> +
>> +     memset(&hwconfig, 0, sizeof(hwconfig));
>> +     hwconfig.tx_type = HWTSTAMP_TX_OFF;
>> +     hwconfig.rx_filter = HWTSTAMP_FILTER_ALL;
>> +
>> +     memset(&ifr, 0, sizeof(ifr));
>> +     strlcpy(ifr.ifr_name, dev, sizeof(ifr.ifr_name));
>> +     ifr.ifr_data = &hwconfig;
>> +
>> +     ret = ioctl(sock, SIOCSHWTSTAMP, &ifr);
>> +     if (ret < 0)
>> +             return -1;
>> +
>> +     timesource = SOF_TIMESTAMPING_RAW_HARDWARE;
>> +
>> +     return setsockopt(sock, SOL_PACKET, PACKET_TIMESTAMP, &timesource,
>> +                       sizeof(timesource));
>> +#else
>> +     return -1;
>> +#endif
>> +}
>
> Please add the #ifdef around the entire function and keep the static
> inline function returning -1 for !HAVE_HARDWARE_TIMESTAMPING in sock.h

Ok, thanks. I just thought that 2 #ifdef's better than 3)

-- 
You received this message because you are subscribed to the Google Groups 
"netsniff-ng" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to netsniff-ng+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to