Skip to content

Commit

Permalink
Merge tag 'v6.6.12' into 6.6-main
Browse files Browse the repository at this point in the history
This is the 6.6.12 stable release

# -----BEGIN PGP SIGNATURE-----
#
# iQIzBAABCAAdFiEEZH8oZUiU471FcZm+ONu9yGCSaT4FAmWlcfYACgkQONu9yGCS
# aT4w5BAApJka+XitK+YyT6msy6asgBKH7c16rIxW/UIEHfr69/UIK87FkqqbSHCf
# RIkjUPrVpQWtAEX///u1t1T37/GvML9XvUdJtHo8DJej52DrKhWR9xb+oCkx+RVW
# 1oxAieit0etkrLTPD+wxkQ6T444IiEghm9Gyb6HhRH/DQDH7192DHX/gXAgR78j9
# SBo9L2xkP/8G59dTkdn46Mq8qoVp3zIxcD5qbUbCY22Y2fYi0JMUfRoiLfivFm/5
# RCJaiSeX8xz5Kc87q88uCGUNs79SW2b1EuQZ5PNWyoI56eCkMkZmxbp0OguBS9ur
# PzjiTP/SsbfjJjA4MwOAjWR6eHThYv3+hLSCzrQy0t0Mk4r+CjJKBq3OovrYS/dW
# HodFK5OII2W8Xhkv+G5Xpwv/wgQAVf+VIgeF3B8rZd0bxygdgB5b5Z3ZXXwPnJ5O
# aRUgzZ3XZjNgWKjix9fojI+z8nPZVqcCxP05mJTNSlVk+WuFiIZitClnBlk50MQi
# 7rE1aZqLBBWsc9w4IVccclR0ItEBDkp/rT71Ukrh4QAGymDO0yCtzDHhqzYdWC0Y
# ii0S2H1ZjNVMqrqIK+n1JY7C/anuXAKIBFB+pz5MrdiGCDGqbM0ka0IxQR+1NuEx
# Pr+PNxX63jCY6jmQFdxYJgAX8/y8uxXshFZKefk5iHSgC8CXcS0=
# =+sMQ
# -----END PGP SIGNATURE-----
# gpg: Signature made Mon Jan 15 18:57:10 2024 CET
# gpg:                using RSA key 647F28654894E3BD457199BE38DBBDC86092693E
# gpg: Can't check signature: No public key
  • Loading branch information
frank-w committed Jan 26, 2024
2 parents 8b16b7f + 47345b4 commit be4c3a1
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 22 deletions.
2 changes: 1 addition & 1 deletion Makefile
@@ -1,7 +1,7 @@
# SPDX-License-Identifier: GPL-2.0
VERSION = 6
PATCHLEVEL = 6
SUBLEVEL = 11
SUBLEVEL = 12
EXTRAVERSION =
NAME = Hurr durr I'ma ninja sloth

Expand Down
31 changes: 17 additions & 14 deletions fs/nfsd/nfsctl.c
Expand Up @@ -692,6 +692,7 @@ static ssize_t __write_ports_addfd(char *buf, struct net *net, const struct cred
char *mesg = buf;
int fd, err;
struct nfsd_net *nn = net_generic(net, nfsd_net_id);
struct svc_serv *serv;

err = get_int(&mesg, &fd);
if (err != 0 || fd < 0)
Expand All @@ -702,15 +703,15 @@ static ssize_t __write_ports_addfd(char *buf, struct net *net, const struct cred
if (err != 0)
return err;

err = svc_addsock(nn->nfsd_serv, net, fd, buf, SIMPLE_TRANSACTION_LIMIT, cred);
serv = nn->nfsd_serv;
err = svc_addsock(serv, net, fd, buf, SIMPLE_TRANSACTION_LIMIT, cred);

if (err < 0 && !nn->nfsd_serv->sv_nrthreads && !nn->keep_active)
if (err < 0 && !serv->sv_nrthreads && !nn->keep_active)
nfsd_last_thread(net);
else if (err >= 0 &&
!nn->nfsd_serv->sv_nrthreads && !xchg(&nn->keep_active, 1))
svc_get(nn->nfsd_serv);
else if (err >= 0 && !serv->sv_nrthreads && !xchg(&nn->keep_active, 1))
svc_get(serv);

nfsd_put(net);
svc_put(serv);
return err;
}

Expand All @@ -724,6 +725,7 @@ static ssize_t __write_ports_addxprt(char *buf, struct net *net, const struct cr
struct svc_xprt *xprt;
int port, err;
struct nfsd_net *nn = net_generic(net, nfsd_net_id);
struct svc_serv *serv;

if (sscanf(buf, "%15s %5u", transport, &port) != 2)
return -EINVAL;
Expand All @@ -736,32 +738,33 @@ static ssize_t __write_ports_addxprt(char *buf, struct net *net, const struct cr
if (err != 0)
return err;

err = svc_xprt_create(nn->nfsd_serv, transport, net,
serv = nn->nfsd_serv;
err = svc_xprt_create(serv, transport, net,
PF_INET, port, SVC_SOCK_ANONYMOUS, cred);
if (err < 0)
goto out_err;

err = svc_xprt_create(nn->nfsd_serv, transport, net,
err = svc_xprt_create(serv, transport, net,
PF_INET6, port, SVC_SOCK_ANONYMOUS, cred);
if (err < 0 && err != -EAFNOSUPPORT)
goto out_close;

if (!nn->nfsd_serv->sv_nrthreads && !xchg(&nn->keep_active, 1))
svc_get(nn->nfsd_serv);
if (!serv->sv_nrthreads && !xchg(&nn->keep_active, 1))
svc_get(serv);

nfsd_put(net);
svc_put(serv);
return 0;
out_close:
xprt = svc_find_xprt(nn->nfsd_serv, transport, net, PF_INET, port);
xprt = svc_find_xprt(serv, transport, net, PF_INET, port);
if (xprt != NULL) {
svc_xprt_close(xprt);
svc_xprt_put(xprt);
}
out_err:
if (!nn->nfsd_serv->sv_nrthreads && !nn->keep_active)
if (!serv->sv_nrthreads && !nn->keep_active)
nfsd_last_thread(net);

nfsd_put(net);
svc_put(serv);
return err;
}

Expand Down
7 changes: 0 additions & 7 deletions fs/nfsd/nfsd.h
Expand Up @@ -96,13 +96,6 @@ int nfsd_pool_stats_open(struct inode *, struct file *);
int nfsd_pool_stats_release(struct inode *, struct file *);
void nfsd_shutdown_threads(struct net *net);

static inline void nfsd_put(struct net *net)
{
struct nfsd_net *nn = net_generic(net, nfsd_net_id);

svc_put(nn->nfsd_serv);
}

bool i_am_nfsd(void);

struct nfsdfs_client {
Expand Down

0 comments on commit be4c3a1

Please sign in to comment.