Hello Jeff Layton, The patch 3dd98a3bccb1: "knfsd: clean up nfsd filesystem interfaces" from Jun 10, 2008, leads to the following static checker warning: fs/nfsd/nfsctl.c:1030 __write_recoverydir() error: buffer overflow 'buf' 4088 <= 4095 fs/nfsd/nfsctl.c 1020 static ssize_t __write_recoverydir(struct file *file, char *buf, size_t size, 1021 struct nfsd_net *nn) 1022 { 1023 char *mesg = buf; 1024 char *recdir; 1025 int len, status; 1026 1027 if (size > 0) { 1028 if (nn->nfsd_serv) 1029 return -EBUSY; 1030 if (size > PATH_MAX || buf[size-1] != '\n') This test is wrong. simple_transaction_get() doesn't return a PAGE_SIZE buf. On the other hand, it's harmless because simple_transaction_get() has it's own limit check. I feel like the limit check in simple_transaction_get() is one char too restrictive. Maybe the simple_transaction_argresp struct used to have a data[1] back before we had git? Anyway, we could either delete this check or change it to: if (size > SIMPLE_TRANSACTION_LIMIT || buf[size-1] != '\n') 1031 return -EINVAL; 1032 buf[size-1] = 0; 1033 1034 recdir = mesg; 1035 len = qword_get(&mesg, recdir, size); 1036 if (len <= 0) 1037 return -EINVAL; 1038 1039 status = nfs4_reset_recoverydir(recdir); 1040 if (status) 1041 return status; 1042 } 1043 1044 return scnprintf(buf, SIMPLE_TRANSACTION_LIMIT, "%s\n", 1045 nfs4_recoverydir()); 1046 } regards, dan carpenter -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html