diff options
| -rw-r--r-- | fs/eventpoll.c | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/fs/eventpoll.c b/fs/eventpoll.c index cc8a9b7d6064..267d0ada4541 100644 --- a/fs/eventpoll.c +++ b/fs/eventpoll.c | |||
| @@ -1114,6 +1114,17 @@ static int ep_send_events(struct eventpoll *ep, | |||
| 1114 | return ep_scan_ready_list(ep, ep_send_events_proc, &esed); | 1114 | return ep_scan_ready_list(ep, ep_send_events_proc, &esed); |
| 1115 | } | 1115 | } |
| 1116 | 1116 | ||
| 1117 | static inline struct timespec ep_set_mstimeout(long ms) | ||
| 1118 | { | ||
| 1119 | struct timespec now, ts = { | ||
| 1120 | .tv_sec = ms / MSEC_PER_SEC, | ||
| 1121 | .tv_nsec = NSEC_PER_MSEC * (ms % MSEC_PER_SEC), | ||
| 1122 | }; | ||
| 1123 | |||
| 1124 | ktime_get_ts(&now); | ||
| 1125 | return timespec_add_safe(now, ts); | ||
| 1126 | } | ||
| 1127 | |||
| 1117 | static int ep_poll(struct eventpoll *ep, struct epoll_event __user *events, | 1128 | static int ep_poll(struct eventpoll *ep, struct epoll_event __user *events, |
| 1118 | int maxevents, long timeout) | 1129 | int maxevents, long timeout) |
| 1119 | { | 1130 | { |
| @@ -1121,12 +1132,11 @@ static int ep_poll(struct eventpoll *ep, struct epoll_event __user *events, | |||
| 1121 | unsigned long flags; | 1132 | unsigned long flags; |
| 1122 | long slack; | 1133 | long slack; |
| 1123 | wait_queue_t wait; | 1134 | wait_queue_t wait; |
| 1124 | struct timespec end_time; | ||
| 1125 | ktime_t expires, *to = NULL; | 1135 | ktime_t expires, *to = NULL; |
| 1126 | 1136 | ||
| 1127 | if (timeout > 0) { | 1137 | if (timeout > 0) { |
| 1128 | ktime_get_ts(&end_time); | 1138 | struct timespec end_time = ep_set_mstimeout(timeout); |
| 1129 | timespec_add_ns(&end_time, (u64)timeout * NSEC_PER_MSEC); | 1139 | |
| 1130 | slack = select_estimate_accuracy(&end_time); | 1140 | slack = select_estimate_accuracy(&end_time); |
| 1131 | to = &expires; | 1141 | to = &expires; |
| 1132 | *to = timespec_to_ktime(end_time); | 1142 | *to = timespec_to_ktime(end_time); |
