提交 cd734d54 编写于 作者: R Richard Cochran 提交者: David S. Miller

ptp: Validate requests to enable time stamping of external signals.

Commit 41560658 ("PTP: introduce new versions of IOCTLs")
introduced a new external time stamp ioctl that validates the flags.
This patch extends the validation to ensure that at least one rising
or falling edge flag is set when enabling external time stamps.
Signed-off-by: NRichard Cochran <richardcochran@gmail.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 3df70afe
...@@ -149,11 +149,19 @@ long ptp_ioctl(struct posix_clock *pc, unsigned int cmd, unsigned long arg) ...@@ -149,11 +149,19 @@ long ptp_ioctl(struct posix_clock *pc, unsigned int cmd, unsigned long arg)
err = -EFAULT; err = -EFAULT;
break; break;
} }
if (((req.extts.flags & ~PTP_EXTTS_VALID_FLAGS) || if (cmd == PTP_EXTTS_REQUEST2) {
req.extts.rsv[0] || req.extts.rsv[1]) && /* Make sure no reserved bit is set. */
cmd == PTP_EXTTS_REQUEST2) { if ((req.extts.flags & ~PTP_EXTTS_VALID_FLAGS) ||
err = -EINVAL; req.extts.rsv[0] || req.extts.rsv[1]) {
break; err = -EINVAL;
break;
}
/* Ensure one of the rising/falling edge bits is set. */
if ((req.extts.flags & PTP_ENABLE_FEATURE) &&
(req.extts.flags & PTP_EXTTS_EDGES) == 0) {
err = -EINVAL;
break;
}
} else if (cmd == PTP_EXTTS_REQUEST) { } else if (cmd == PTP_EXTTS_REQUEST) {
req.extts.flags &= PTP_EXTTS_V1_VALID_FLAGS; req.extts.flags &= PTP_EXTTS_V1_VALID_FLAGS;
req.extts.rsv[0] = 0; req.extts.rsv[0] = 0;
......
...@@ -31,6 +31,7 @@ ...@@ -31,6 +31,7 @@
#define PTP_ENABLE_FEATURE (1<<0) #define PTP_ENABLE_FEATURE (1<<0)
#define PTP_RISING_EDGE (1<<1) #define PTP_RISING_EDGE (1<<1)
#define PTP_FALLING_EDGE (1<<2) #define PTP_FALLING_EDGE (1<<2)
#define PTP_EXTTS_EDGES (PTP_RISING_EDGE | PTP_FALLING_EDGE)
/* /*
* flag fields valid for the new PTP_EXTTS_REQUEST2 ioctl. * flag fields valid for the new PTP_EXTTS_REQUEST2 ioctl.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册