summaryrefslogtreecommitdiffstats
path: root/freebsd/sys/kern
diff options
context:
space:
mode:
Diffstat (limited to 'freebsd/sys/kern')
-rw-r--r--freebsd/sys/kern/sys_generic.c8
-rw-r--r--freebsd/sys/kern/uipc_syscalls.c7
2 files changed, 13 insertions, 2 deletions
diff --git a/freebsd/sys/kern/sys_generic.c b/freebsd/sys/kern/sys_generic.c
index 2ee0ae70..6b26dbeb 100644
--- a/freebsd/sys/kern/sys_generic.c
+++ b/freebsd/sys/kern/sys_generic.c
@@ -1614,6 +1614,9 @@ pollrescan(struct thread *td)
* POLLERR if appropriate.
*/
fd->revents = fo_poll(fp, fd->events, td->td_ucred, td);
+#ifdef __rtems__
+ rtems_libio_iop_drop(&fp->f_io);
+#endif /* __rtems__ */
if (fd->revents != 0)
n++;
}
@@ -1671,7 +1674,7 @@ pollscan(td, fds, nfd)
#ifndef __rtems__
if (fds->fd > fdp->fd_lastfile) {
#else /* __rtems__ */
- if (fds->fd >= rtems_libio_number_iops) {
+ if ((uint32_t)fds->fd >= rtems_libio_number_iops) {
#endif /* __rtems__ */
fds->revents = POLLNVAL;
n++;
@@ -1701,6 +1704,9 @@ pollscan(td, fds, nfd)
selfdalloc(td, fds);
fds->revents = fo_poll(fp, fds->events,
td->td_ucred, td);
+#ifdef __rtems__
+ rtems_libio_iop_drop(&fp->f_io);
+#endif /* __rtems__ */
/*
* POSIX requires POLLOUT to be never
* set simultaneously with POLLHUP.
diff --git a/freebsd/sys/kern/uipc_syscalls.c b/freebsd/sys/kern/uipc_syscalls.c
index fa948c78..3c6d7efd 100644
--- a/freebsd/sys/kern/uipc_syscalls.c
+++ b/freebsd/sys/kern/uipc_syscalls.c
@@ -126,11 +126,16 @@ rtems_bsd_getsock(int fd, struct file **fpp, u_int *fflagp)
int error;
if ((uint32_t) fd < rtems_libio_number_iops) {
+ unsigned int flags;
+
fp = rtems_bsd_fd_to_fp(fd);
- if ((fp->f_io.flags & LIBIO_FLAGS_OPEN) != LIBIO_FLAGS_OPEN) {
+ flags = rtems_libio_iop_hold(&fp->f_io);
+ if ((flags & LIBIO_FLAGS_OPEN) == 0) {
+ rtems_libio_iop_drop(&fp->f_io);
fp = NULL;
error = EBADF;
} else if (fp->f_io.pathinfo.handlers != &socketops) {
+ rtems_libio_iop_drop(&fp->f_io);
fp = NULL;
error = ENOTSOCK;
} else {