Re: [PATCH] cifs: Remove pre-historic unused CIFSSMBCopy

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 11/8/2024 11:09 PM, Steve French wrote:
As an alternative, might be useful to see if this command still works
to Samba and/or older Windows (and e.g. enable an ioctl for it - might
have been useful in the past to old servers)

Please let's not do anything to enhance usage of the hopelessly
insecure SMB1 protocol. Especially not with something we just
found in the back of the closet.

The MS-CIFS document has this to say about SMB_COM_COPY:

2.2.4.37 SMB_COM_COPY (0x29)
This command was introduced in the LAN Manager 1.0 dialect (see
[SMB-LM1X] section 9.2.1 and [XOPEN-SMB] sections 14.1 and 15.2).
It was rendered obsolete in the NT LAN Manager dialect. This
command was used to perform server-side file copies, but is no
longer used. Clients SHOULD NOT send requests using this command
code. Servers receiving requests with this command code SHOULD
return STATUS_NOT_IMPLEMENTED (ERRDOS/ERRbadfunc). <51>

<51> Section 2.2.4.37: Windows NT servers attempt to process this
command, but the implementation is incomplete and the results are
not predictable.


Deletion-Enthusiastically-Acked-by: Tom Talpey <tom@xxxxxxxxxx>

Tom.

On Fri, Nov 8, 2024 at 10:06 PM Steve French <smfrench@xxxxxxxxx> wrote:

No objections to this from me. Will add it to for next next in the next few days so can queue it for 6.13-rc

On Thu, Nov 7, 2024, 3:11 PM Dr. David Alan Gilbert <linux@xxxxxxxxxxx> wrote:

* linux@xxxxxxxxxxx (linux@xxxxxxxxxxx) wrote:
From: "Dr. David Alan Gilbert" <linux@xxxxxxxxxxx>

CIFSSMBCopy() is unused, remove it.

It seems to have been that way pre-git; looking in a historic
archive, I think it landed around May 2004 in Linus'
BKrev: 40ab7591J_OgkpHW-qhzZukvAUAw9g
and was unused back then.

Signed-off-by: Dr. David Alan Gilbert <linux@xxxxxxxxxxx>

Ping?

Dave

---
  fs/smb/client/cifsproto.h |  7 -----
  fs/smb/client/cifssmb.c   | 63 ---------------------------------------
  2 files changed, 70 deletions(-)

diff --git a/fs/smb/client/cifsproto.h b/fs/smb/client/cifsproto.h
index 1d3470bca45e..8235b5a0aa2b 100644
--- a/fs/smb/client/cifsproto.h
+++ b/fs/smb/client/cifsproto.h
@@ -549,13 +549,6 @@ extern int generate_smb311signingkey(struct cifs_ses *ses,
                                    struct TCP_Server_Info *server);

  #ifdef CONFIG_CIFS_ALLOW_INSECURE_LEGACY
-extern int CIFSSMBCopy(unsigned int xid,
-                     struct cifs_tcon *source_tcon,
-                     const char *fromName,
-                     const __u16 target_tid,
-                     const char *toName, const int flags,
-                     const struct nls_table *nls_codepage,
-                     int remap_special_chars);
  extern ssize_t CIFSSMBQAllEAs(const unsigned int xid, struct cifs_tcon *tcon,
                       const unsigned char *searchName,
                       const unsigned char *ea_name, char *EAData,
diff --git a/fs/smb/client/cifssmb.c b/fs/smb/client/cifssmb.c
index c6f15dbe860a..ca50ac652e02 100644
--- a/fs/smb/client/cifssmb.c
+++ b/fs/smb/client/cifssmb.c
@@ -2339,69 +2339,6 @@ int CIFSSMBRenameOpenFile(const unsigned int xid, struct cifs_tcon *pTcon,
       return rc;
  }

-int
-CIFSSMBCopy(const unsigned int xid, struct cifs_tcon *tcon,
-         const char *fromName, const __u16 target_tid, const char *toName,
-         const int flags, const struct nls_table *nls_codepage, int remap)
-{
-     int rc = 0;
-     COPY_REQ *pSMB = NULL;
-     COPY_RSP *pSMBr = NULL;
-     int bytes_returned;
-     int name_len, name_len2;
-     __u16 count;
-
-     cifs_dbg(FYI, "In CIFSSMBCopy\n");
-copyRetry:
-     rc = smb_init(SMB_COM_COPY, 1, tcon, (void **) &pSMB,
-                     (void **) &pSMBr);
-     if (rc)
-             return rc;
-
-     pSMB->BufferFormat = 0x04;
-     pSMB->Tid2 = target_tid;
-
-     pSMB->Flags = cpu_to_le16(flags & COPY_TREE);
-
-     if (pSMB->hdr.Flags2 & SMBFLG2_UNICODE) {
-             name_len = cifsConvertToUTF16((__le16 *) pSMB->OldFileName,
-                                           fromName, PATH_MAX, nls_codepage,
-                                           remap);
-             name_len++;     /* trailing null */
-             name_len *= 2;
-             pSMB->OldFileName[name_len] = 0x04;     /* pad */
-             /* protocol requires ASCII signature byte on Unicode string */
-             pSMB->OldFileName[name_len + 1] = 0x00;
-             name_len2 =
-                 cifsConvertToUTF16((__le16 *)&pSMB->OldFileName[name_len+2],
-                                    toName, PATH_MAX, nls_codepage, remap);
-             name_len2 += 1 /* trailing null */  + 1 /* Signature word */ ;
-             name_len2 *= 2; /* convert to bytes */
-     } else {
-             name_len = copy_path_name(pSMB->OldFileName, fromName);
-             pSMB->OldFileName[name_len] = 0x04;  /* 2nd buffer format */
-             name_len2 = copy_path_name(pSMB->OldFileName+name_len+1, toName);
-             name_len2++;    /* signature byte */
-     }
-
-     count = 1 /* 1st signature byte */  + name_len + name_len2;
-     inc_rfc1001_len(pSMB, count);
-     pSMB->ByteCount = cpu_to_le16(count);
-
-     rc = SendReceive(xid, tcon->ses, (struct smb_hdr *) pSMB,
-             (struct smb_hdr *) pSMBr, &bytes_returned, 0);
-     if (rc) {
-             cifs_dbg(FYI, "Send error in copy = %d with %d files copied\n",
-                      rc, le16_to_cpu(pSMBr->CopyCount));
-     }
-     cifs_buf_release(pSMB);
-
-     if (rc == -EAGAIN)
-             goto copyRetry;
-
-     return rc;
-}
-
  int
  CIFSUnixCreateSymLink(const unsigned int xid, struct cifs_tcon *tcon,
                     const char *fromName, const char *toName,
--
2.46.2

--
  -----Open up your eyes, open up your mind, open up your code -------
/ Dr. David Alan Gilbert    |       Running GNU/Linux       | Happy  \
\        dave @ treblig.org |                               | In Hex /
  \ _________________________|_____ http://www.treblig.org   |_______/








[Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux