diff options
| -rw-r--r-- | source3/smbd/filename.c | 7 | ||||
| -rw-r--r-- | source3/smbd/reply.c | 7 | 
2 files changed, 13 insertions, 1 deletions
diff --git a/source3/smbd/filename.c b/source3/smbd/filename.c index 3f02f6090f..44916200da 100644 --- a/source3/smbd/filename.c +++ b/source3/smbd/filename.c @@ -147,7 +147,12 @@ NTSTATUS unix_convert(connection_struct *conn,  	if (name[0] == '.' && (name[1] == '/' || name[1] == '\0')) {  		/* Start of pathname can't be "." only. */ -		return NT_STATUS_OBJECT_NAME_INVALID; +		if (name[1] == '\0' || name[2] == '\0') { +			return NT_STATUS_OBJECT_NAME_INVALID; +		} else { +			/* Longer pathname starts with ./ */ +			return NT_STATUS_OBJECT_PATH_NOT_FOUND; +		}  	}  	/* diff --git a/source3/smbd/reply.c b/source3/smbd/reply.c index 5914a3b169..e42c663cec 100644 --- a/source3/smbd/reply.c +++ b/source3/smbd/reply.c @@ -632,6 +632,13 @@ int reply_chkpth(connection_struct *conn, char *inbuf,char *outbuf, int dum_size  	status = unix_convert(conn, name, False, NULL, &sbuf);  	if (!NT_STATUS_IS_OK(status)) {  		END_PROFILE(SMBchkpth); +		/* Strange DOS error code semantics only for chkpth... */ +		if (!(SVAL(inbuf,smb_flg2) & FLAGS2_32_BIT_ERROR_CODES)) { +			if (NT_STATUS_EQUAL(NT_STATUS_OBJECT_NAME_INVALID,status)) { +				/* We need to map to ERRbadpath */ +				status = NT_STATUS_OBJECT_PATH_NOT_FOUND; +			} +		}  		return ERROR_NT(status);  	}  | 
