diff options
author | Dmitry V. Levin <ldv@strace.io> | 2021-02-03 08:00:00 +0000 |
---|---|---|
committer | Dmitry V. Levin <ldv@strace.io> | 2021-02-03 08:00:00 +0000 |
commit | ecb3ed78107c851f71696df6730a15afff91ed3d (patch) | |
tree | 0b3d2b083040fc9b08d129f80d027ff41b995059 /src/ptp.c | |
parent | c47943de06204a269e16f732e7c9c71d4284b23f (diff) | |
download | strace-ecb3ed78107c851f71696df6730a15afff91ed3d.tar.gz |
Move source files into src subdirectory
* src/Makefile.am: New file.
* src/.gitignore: Likewise.
* scno.am: Move into src subdirectory.
* scno.head: Likewise.
* strace-graph: Likewise.
* strace-log-merge: Likewise.
* linux/: Likewise.
* types/: Likewise.
* xlat/: Likewise.
* *.awk: Likewise.
* *.c: Likewise.
* *.h: Likewise.
* *.sh: Likewise.
* .gitignore: Update.
* Makefile.am: Update.
* bootstrap: Update.
* configure.ac: Update.
* debian/rules: Update.
* debian/strace-udeb.install: Update.
* debian/strace.examples: Update.
* debian/strace.install: Update.
* debian/strace64.install: Update.
* m4/gen_bpf_attr_m4.sh: Update.
* m4/mpers.m4: Update.
* tests/Makefile.am: Update.
* tests/init.sh: Update.
* tests/legacy_syscall_info.test: Update.
* tests/strace-log-merge-error.test: Update.
* tests/strace-log-merge-suffix.test: Update.
Diffstat (limited to 'src/ptp.c')
-rw-r--r-- | src/ptp.c | 164 |
1 files changed, 164 insertions, 0 deletions
diff --git a/src/ptp.c b/src/ptp.c new file mode 100644 index 000000000..44a360878 --- /dev/null +++ b/src/ptp.c @@ -0,0 +1,164 @@ +/* + * Copyright (c) 2014 Stefan Sørensen <stefan.sorensen@spectralink.com> + * Copyright (c) 2014-2015 Dmitry V. Levin <ldv@strace.io> + * Copyright (c) 2014-2019 The strace developers. + * All rights reserved. + * + * SPDX-License-Identifier: LGPL-2.1-or-later + */ + +#include "defs.h" + +#ifdef HAVE_STRUCT_PTP_SYS_OFFSET + +# include <linux/ioctl.h> +# include <linux/ptp_clock.h> + +# ifndef PTP_CLOCK_GETCAPS2 +# define PTP_CLOCK_GETCAPS2 _IOR(PTP_CLK_MAGIC, 10, struct ptp_clock_caps) +# endif +# ifndef PTP_EXTTS_REQUEST2 +# define PTP_EXTTS_REQUEST2 _IOW(PTP_CLK_MAGIC, 11, struct ptp_extts_request) +# endif +# ifndef PTP_PEROUT_REQUEST2 +# define PTP_PEROUT_REQUEST2 _IOW(PTP_CLK_MAGIC, 12, struct ptp_perout_request) +# endif +# ifndef PTP_ENABLE_PPS2 +# define PTP_ENABLE_PPS2 _IOW(PTP_CLK_MAGIC, 13, int) +# endif +# ifndef PTP_SYS_OFFSET2 +# define PTP_SYS_OFFSET2 _IOW(PTP_CLK_MAGIC, 14, struct ptp_sys_offset) +# endif + +# include "xlat/ptp_extts_flags.h" +# include "xlat/ptp_perout_flags.h" + +static void +print_ptp_clock_time(const struct ptp_clock_time *const p) +{ + tprint_struct_begin(); + PRINT_FIELD_D(*p, sec); + tprint_struct_next(); + PRINT_FIELD_U(*p, nsec); + tprint_struct_end(); + tprints_comment(sprinttime_nsec(p->sec, p->nsec)); +} + +static bool +print_ptp_clock_time_am(struct tcb *tcp, void *elem_buf, size_t elem_size, + void *data) +{ + print_ptp_clock_time(elem_buf); + return true; +} + +int +ptp_ioctl(struct tcb *const tcp, const unsigned int code, + const kernel_ulong_t arg) +{ + if (!verbose(tcp)) + return RVAL_DECODED; + + switch (code) { + case PTP_EXTTS_REQUEST: + case PTP_EXTTS_REQUEST2: { + struct ptp_extts_request extts; + + tprints(", "); + if (umove_or_printaddr(tcp, arg, &extts)) + break; + + tprint_struct_begin(); + PRINT_FIELD_D(extts, index); + tprint_struct_next(); + PRINT_FIELD_FLAGS(extts, flags, ptp_extts_flags, "PTP_???"); + tprint_struct_end(); + break; + } + + case PTP_PEROUT_REQUEST: + case PTP_PEROUT_REQUEST2: { + struct ptp_perout_request perout; + + tprints(", "); + if (umove_or_printaddr(tcp, arg, &perout)) + break; + + tprint_struct_begin(); + PRINT_FIELD_OBJ_PTR(perout, start, print_ptp_clock_time); + tprint_struct_next(); + PRINT_FIELD_OBJ_PTR(perout, period, print_ptp_clock_time); + tprint_struct_next(); + PRINT_FIELD_D(perout, index); + tprint_struct_next(); + PRINT_FIELD_FLAGS(perout, flags, ptp_perout_flags, + "PTP_???"); + tprint_struct_end(); + break; + } + + case PTP_ENABLE_PPS: + case PTP_ENABLE_PPS2: + tprintf(", %" PRI_kld, arg); + break; + + case PTP_SYS_OFFSET: + case PTP_SYS_OFFSET2: { + struct ptp_sys_offset sysoff; + + if (entering(tcp)) { + tprints(", "); + if (umove_or_printaddr(tcp, arg, &sysoff)) + break; + + tprint_struct_begin(); + PRINT_FIELD_U(sysoff, n_samples); + return 0; + } else { + if (tfetch_mem(tcp, arg, sizeof(sysoff), &sysoff)) { + unsigned int n_samples = + sysoff.n_samples > PTP_MAX_SAMPLES + ? PTP_MAX_SAMPLES : sysoff.n_samples; + tprints(", "); + tprint_struct_next(); + PRINT_FIELD_ARRAY_UPTO(sysoff, ts, + 2 * n_samples + 1, tcp, + print_ptp_clock_time_am); + } + tprint_struct_end(); + break; + } + } + case PTP_CLOCK_GETCAPS: + case PTP_CLOCK_GETCAPS2: { + struct ptp_clock_caps caps; + + if (entering(tcp)) + return 0; + + tprints(", "); + if (umove_or_printaddr(tcp, arg, &caps)) + break; + + tprint_struct_begin(); + PRINT_FIELD_D(caps, max_adj); + tprint_struct_next(); + PRINT_FIELD_D(caps, n_alarm); + tprint_struct_next(); + PRINT_FIELD_D(caps, n_ext_ts); + tprint_struct_next(); + PRINT_FIELD_D(caps, n_per_out); + tprint_struct_next(); + PRINT_FIELD_D(caps, pps); + tprint_struct_end(); + break; + } + + default: + return RVAL_DECODED; + } + + return RVAL_IOCTL_DECODED; +} + +#endif /* HAVE_STRUCT_PTP_SYS_OFFSET */ |