Skip to content

Commit 0462b6b

Browse files
Christoph Hellwigdavem330
authored andcommitted
net: add a CMSG_USER_DATA macro
Add a variant of CMSG_DATA that operates on user pointer to avoid sparse warnings about casting to/from user pointers. Also fix up CMSG_DATA to rely on the gcc extension that allows void pointer arithmetics to cut down on the amount of casts. Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 3242956 commit 0462b6b

File tree

2 files changed

+6
-3
lines changed

2 files changed

+6
-3
lines changed

include/linux/socket.h

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -94,7 +94,10 @@ struct cmsghdr {
9494

9595
#define CMSG_ALIGN(len) ( ((len)+sizeof(long)-1) & ~(sizeof(long)-1) )
9696

97-
#define CMSG_DATA(cmsg) ((void *)((char *)(cmsg) + sizeof(struct cmsghdr)))
97+
#define CMSG_DATA(cmsg) \
98+
((void *)(cmsg) + sizeof(struct cmsghdr))
99+
#define CMSG_USER_DATA(cmsg) \
100+
((void __user *)(cmsg) + sizeof(struct cmsghdr))
98101
#define CMSG_SPACE(len) (sizeof(struct cmsghdr) + CMSG_ALIGN(len))
99102
#define CMSG_LEN(len) (sizeof(struct cmsghdr) + (len))
100103

net/core/scm.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -236,7 +236,7 @@ int put_cmsg(struct msghdr * msg, int level, int type, int len, void *data)
236236
err = -EFAULT;
237237
if (copy_to_user(cm, &cmhdr, sizeof cmhdr))
238238
goto out;
239-
if (copy_to_user(CMSG_DATA(cm), data, cmlen - sizeof(struct cmsghdr)))
239+
if (copy_to_user(CMSG_USER_DATA(cm), data, cmlen - sizeof(*cm)))
240240
goto out;
241241
cmlen = CMSG_SPACE(len);
242242
if (msg->msg_controllen < cmlen)
@@ -300,7 +300,7 @@ void scm_detach_fds(struct msghdr *msg, struct scm_cookie *scm)
300300
if (fdnum < fdmax)
301301
fdmax = fdnum;
302302

303-
for (i=0, cmfptr=(__force int __user *)CMSG_DATA(cm); i<fdmax;
303+
for (i=0, cmfptr =(int __user *)CMSG_USER_DATA(cm); i<fdmax;
304304
i++, cmfptr++)
305305
{
306306
struct socket *sock;

0 commit comments

Comments
 (0)