aboutsummaryrefslogtreecommitdiffstats
path: root/net/atm/svc.c
diff options
context:
space:
mode:
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,