lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <96e8d73f-644d-4c16-a67b-8cb81b60819d@linux.dev>
Date: Thu, 19 Jun 2025 15:17:51 +0100
From: Vadim Fedorenko <vadim.fedorenko@...ux.dev>
To: Miroslav Lichvar <mlichvar@...hat.com>, netdev@...r.kernel.org
Cc: Richard Cochran <richardcochran@...il.com>,
 Jacob Keller <jacob.e.keller@...el.com>
Subject: Re: [PATCH net-next] testptp: add option to enable external
 timestamping edges

On 19/06/2025 14:53, Miroslav Lichvar wrote:
> Some drivers (e.g. ice) don't enable any edges by default when external
> timestamping is requested by the PTP_EXTTS_REQUEST ioctl, which makes
> testptp -e unusable for testing hardware supported by these drivers.
> 
> Add -E option to specify if the rising, falling, or both edges should
> be enabled by the ioctl.
> 
> Signed-off-by: Miroslav Lichvar <mlichvar@...hat.com>
> Cc: Richard Cochran <richardcochran@...il.com>
> Cc: Jacob Keller <jacob.e.keller@...el.com>
> ---
>   tools/testing/selftests/ptp/testptp.c | 11 +++++++++--
>   1 file changed, 9 insertions(+), 2 deletions(-)
> 
> diff --git a/tools/testing/selftests/ptp/testptp.c b/tools/testing/selftests/ptp/testptp.c
> index edc08a4433fd..ed1e2886ba3c 100644
> --- a/tools/testing/selftests/ptp/testptp.c
> +++ b/tools/testing/selftests/ptp/testptp.c
> @@ -120,6 +120,7 @@ static void usage(char *progname)
>   		" -c         query the ptp clock's capabilities\n"
>   		" -d name    device to open\n"
>   		" -e val     read 'val' external time stamp events\n"
> +		" -E val     enable rising (1), falling (2), or both (3) edges\n"
>   		" -f val     adjust the ptp clock frequency by 'val' ppb\n"
>   		" -F chan    Enable single channel mask and keep device open for debugfs verification.\n"
>   		" -g         get the ptp clock time\n"
> @@ -178,6 +179,7 @@ int main(int argc, char *argv[])
>   	int adjphase = 0;
>   	int capabilities = 0;
>   	int extts = 0;
> +	int edge = 0;
>   	int flagtest = 0;
>   	int gettime = 0;
>   	int index = 0;
> @@ -202,7 +204,7 @@ int main(int argc, char *argv[])
>   
>   	progname = strrchr(argv[0], '/');
>   	progname = progname ? 1+progname : argv[0];
> -	while (EOF != (c = getopt(argc, argv, "cd:e:f:F:ghH:i:k:lL:n:o:p:P:rsSt:T:w:x:Xy:z"))) {
> +	while (EOF != (c = getopt(argc, argv, "cd:e:E:f:F:ghH:i:k:lL:n:o:p:P:rsSt:T:w:x:Xy:z"))) {
>   		switch (c) {
>   		case 'c':
>   			capabilities = 1;
> @@ -213,6 +215,11 @@ int main(int argc, char *argv[])
>   		case 'e':
>   			extts = atoi(optarg);
>   			break;
> +		case 'E':
> +			edge = atoi(optarg);
> +			edge = (edge & 1 ? PTP_RISING_EDGE : 0) |
> +				(edge & 2 ? PTP_FALLING_EDGE : 0);
> +			break;
>   		case 'f':
>   			adjfreq = atoi(optarg);
>   			break;
> @@ -444,7 +451,7 @@ int main(int argc, char *argv[])
>   		if (!readonly) {
>   			memset(&extts_request, 0, sizeof(extts_request));
>   			extts_request.index = index;
> -			extts_request.flags = PTP_ENABLE_FEATURE;
> +			extts_request.flags = PTP_ENABLE_FEATURE | edge;
>   			if (ioctl(fd, PTP_EXTTS_REQUEST, &extts_request)) {
>   				perror("PTP_EXTTS_REQUEST");
>   				extts = 0;

Reviewed-by: Vadim Fedorenko <vadim.fedorenko@...ux.dev>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ