aboutsummaryrefslogtreecommitdiffstats
path: root/net/atm/svc.c
diff options
context:
space:
mode:
authorDavid Woodhouse <David.Woodhouse@intel.com>2008-12-04 01:12:38 -0500
committerDavid S. Miller <davem@davemloft.net>2008-12-04 01:12:38 -0500
commit8865c418caf4e9dd2c24bdfae3a5a4106e143e60 (patch)
tree4d7fac2c74af56c6aaf83b324b349b76c5f949d9 /net/atm/svc.c
parentdcd39c90290297f6e6ed8a04bb20da7ac2b043c5 (diff)
atm: 32-bit ioctl compatibility
We lack compat ioctl support through most of the ATM code. This patch deals with most of it, and I can now at least use BR2684 and PPPoATM with 32-bit userspace. I haven't added a .compat_ioctl method to struct atm_ioctl, because AFAICT none of the current users need any conversion -- so we can just call the ->ioctl() method in every case. I looked at br2684, clip, lec, mpc, pppoatm and atmtcp. In svc_compat_ioctl() the only mangling which is needed is to change COMPAT_ATM_ADDPARTY to ATM_ADDPARTY. Although it's defined as _IOW('a', ATMIOC_SPECIAL+4,struct atm_iobuf) it doesn't actually _take_ a struct atm_iobuf as an argument -- it takes a struct sockaddr_atmsvc, which _is_ the same between 32-bit and 64-bit code, so doesn't need conversion. Almost all of vcc_ioctl() would have been identical, so I converted that into a core do_vcc_ioctl() function with an 'int compat' argument. I've done the same with atm_dev_ioctl(), where there _are_ a few differences, but still it's relatively contained and there would otherwise have been a lot of duplication. I haven't done any of the actual device-specific ioctls, although I've added a compat_ioctl method to struct atmdev_ops. Signed-off-by: David Woodhouse <David.Woodhouse@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/atm/svc.c')
-rw-r--r--net/atm/svc.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/net/atm/svc.c b/net/atm/svc.c
index de1e4f2f3a43..e9c65500f84e 100644
--- a/net/atm/svc.c
+++ b/net/atm/svc.c
@@ -604,6 +604,22 @@ static int svc_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
604 return error; 604 return error;
605} 605}
606 606
607#ifdef CONFIG_COMPAT
608static int svc_compat_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg)
609{
610 /* The definition of ATM_ADDPARTY uses the size of struct atm_iobuf.
611 But actually it takes a struct sockaddr_atmsvc, which doesn't need
612 compat handling. So all we have to do is fix up cmd... */
613 if (cmd == COMPAT_ATM_ADDPARTY)
614 cmd = ATM_ADDPARTY;
615
616 if (cmd == ATM_ADDPARTY || cmd == ATM_DROPPARTY)
617 return svc_ioctl(sock, cmd, arg);
618 else
619 return vcc_compat_ioctl(sock, cmd, arg);
620}
621#endif /* CONFIG_COMPAT */
622
607static const struct proto_ops svc_proto_ops = { 623static const struct proto_ops svc_proto_ops = {
608 .family = PF_ATMSVC, 624 .family = PF_ATMSVC,
609 .owner = THIS_MODULE, 625 .owner = THIS_MODULE,
@@ -616,6 +632,9 @@ static const struct proto_ops svc_proto_ops = {
616 .getname = svc_getname, 632 .getname = svc_getname,
617 .poll = vcc_poll, 633 .poll = vcc_poll,
618 .ioctl = svc_ioctl, 634 .ioctl = svc_ioctl,
635#ifdef CONFIG_COMPAT
636 .compat_ioctl = svc_compat_ioctl,
637#endif
619 .listen = svc_listen, 638 .listen = svc_listen,
620 .shutdown = svc_shutdown, 639 .shutdown = svc_shutdown,
621 .setsockopt = svc_setsockopt, 640 .setsockopt = svc_setsockopt,