sunrpc: handle SVC_GARBAGE during svc auth processing as auth error

tianshuo han reported a remotely-triggerable crash if the client sends a
kernel RPC server a specially crafted packet. If decoding the RPC reply
fails in such a way that SVC_GARBAGE is returned without setting the
rq_accept_statp pointer, then that pointer can be dereferenced and a
value stored there.

If it's the first time the thread has processed an RPC, then that
pointer will be set to NULL and the kernel will crash. In other cases,
it could create a memory scribble.

The server sunrpc code treats a SVC_GARBAGE return from svc_authenticate
or pg_authenticate as if it should send a GARBAGE_ARGS reply. RFC 5531
says that if authentication fails that the RPC should be rejected
instead with a status of AUTH_ERR.

Handle a SVC_GARBAGE return as an AUTH_ERROR, with a reason of
AUTH_BADCRED instead of returning GARBAGE_ARGS in that case. This
sidesteps the whole problem of touching the rpc_accept_statp pointer in
this situation and avoids the crash.

Cc: stable@kernel.org
Fixes: 29cd2927fb91 ("SUNRPC: Fix encoding of accepted but unsuccessful RPC replies")
Reported-by: tianshuo han <hantianshuo233@gmail.com>
Reviewed-by: Chuck Lever <chuck.lever@oracle.com>
Signed-off-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>

authored by Jeff Layton and committed by Chuck Lever 94d10a4d 8ea688a3

+2 -9
+2 -9
net/sunrpc/svc.c
··· 1371 case SVC_OK: 1372 break; 1373 case SVC_GARBAGE: 1374 - goto err_garbage_args; 1375 case SVC_SYSERR: 1376 goto err_system_err; 1377 case SVC_DENIED: ··· 1511 if (serv->sv_stats) 1512 serv->sv_stats->rpcbadfmt++; 1513 *rqstp->rq_accept_statp = rpc_proc_unavail; 1514 - goto sendit; 1515 - 1516 - err_garbage_args: 1517 - svc_printk(rqstp, "failed to decode RPC header\n"); 1518 - 1519 - if (serv->sv_stats) 1520 - serv->sv_stats->rpcbadfmt++; 1521 - *rqstp->rq_accept_statp = rpc_garbage_args; 1522 goto sendit; 1523 1524 err_system_err:
··· 1371 case SVC_OK: 1372 break; 1373 case SVC_GARBAGE: 1374 + rqstp->rq_auth_stat = rpc_autherr_badcred; 1375 + goto err_bad_auth; 1376 case SVC_SYSERR: 1377 goto err_system_err; 1378 case SVC_DENIED: ··· 1510 if (serv->sv_stats) 1511 serv->sv_stats->rpcbadfmt++; 1512 *rqstp->rq_accept_statp = rpc_proc_unavail; 1513 goto sendit; 1514 1515 err_system_err: