Commit 051d469b authored by Christophe JAILLET's avatar Christophe JAILLET Committed by Steve French

ksmbd: Constify struct ksmbd_transport_ops

'struct ksmbd_transport_ops' is not modified in these drivers.

Constifying this structure moves some data to a read-only section, so
increase overall security.

On a x86_64, with allmodconfig, as an example:
Before:
======
   text	   data	    bss	    dec	    hex	filename
  52184	   2085	    256	  54525	   d4fd	fs/smb/server/transport_rdma.o

After:
=====
   text	   data	    bss	    dec	    hex	filename
  52260	   2021	    256	  54537	   d509	fs/smb/server/transport_rdma.o
Signed-off-by: default avatarChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Acked-by: default avatarNamjae Jeon <linkinjeon@kernel.org>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent ac5399d4
...@@ -133,8 +133,8 @@ struct ksmbd_transport_ops { ...@@ -133,8 +133,8 @@ struct ksmbd_transport_ops {
}; };
struct ksmbd_transport { struct ksmbd_transport {
struct ksmbd_conn *conn; struct ksmbd_conn *conn;
struct ksmbd_transport_ops *ops; const struct ksmbd_transport_ops *ops;
}; };
#define KSMBD_TCP_RECV_TIMEOUT (7 * HZ) #define KSMBD_TCP_RECV_TIMEOUT (7 * HZ)
......
...@@ -164,7 +164,7 @@ enum { ...@@ -164,7 +164,7 @@ enum {
SMB_DIRECT_MSG_DATA_TRANSFER SMB_DIRECT_MSG_DATA_TRANSFER
}; };
static struct ksmbd_transport_ops ksmbd_smb_direct_transport_ops; static const struct ksmbd_transport_ops ksmbd_smb_direct_transport_ops;
struct smb_direct_send_ctx { struct smb_direct_send_ctx {
struct list_head msg_list; struct list_head msg_list;
...@@ -2292,7 +2292,7 @@ bool ksmbd_rdma_capable_netdev(struct net_device *netdev) ...@@ -2292,7 +2292,7 @@ bool ksmbd_rdma_capable_netdev(struct net_device *netdev)
return rdma_capable; return rdma_capable;
} }
static struct ksmbd_transport_ops ksmbd_smb_direct_transport_ops = { static const struct ksmbd_transport_ops ksmbd_smb_direct_transport_ops = {
.prepare = smb_direct_prepare, .prepare = smb_direct_prepare,
.disconnect = smb_direct_disconnect, .disconnect = smb_direct_disconnect,
.shutdown = smb_direct_shutdown, .shutdown = smb_direct_shutdown,
......
...@@ -37,7 +37,7 @@ struct tcp_transport { ...@@ -37,7 +37,7 @@ struct tcp_transport {
unsigned int nr_iov; unsigned int nr_iov;
}; };
static struct ksmbd_transport_ops ksmbd_tcp_transport_ops; static const struct ksmbd_transport_ops ksmbd_tcp_transport_ops;
static void tcp_stop_kthread(struct task_struct *kthread); static void tcp_stop_kthread(struct task_struct *kthread);
static struct interface *alloc_iface(char *ifname); static struct interface *alloc_iface(char *ifname);
...@@ -649,7 +649,7 @@ int ksmbd_tcp_set_interfaces(char *ifc_list, int ifc_list_sz) ...@@ -649,7 +649,7 @@ int ksmbd_tcp_set_interfaces(char *ifc_list, int ifc_list_sz)
return 0; return 0;
} }
static struct ksmbd_transport_ops ksmbd_tcp_transport_ops = { static const struct ksmbd_transport_ops ksmbd_tcp_transport_ops = {
.read = ksmbd_tcp_read, .read = ksmbd_tcp_read,
.writev = ksmbd_tcp_writev, .writev = ksmbd_tcp_writev,
.disconnect = ksmbd_tcp_disconnect, .disconnect = ksmbd_tcp_disconnect,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment