diff options
| author | David Woodhouse <David.Woodhouse@intel.com> | 2008-12-03 22:12:38 -0800 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2008-12-03 22:12:38 -0800 | 
| commit | 8865c418caf4e9dd2c24bdfae3a5a4106e143e60 (patch) | |
| tree | 4d7fac2c74af56c6aaf83b324b349b76c5f949d9 /include/linux/atmdev.h | |
| parent | dcd39c90290297f6e6ed8a04bb20da7ac2b043c5 (diff) | |
| download | olio-linux-3.10-8865c418caf4e9dd2c24bdfae3a5a4106e143e60.tar.xz olio-linux-3.10-8865c418caf4e9dd2c24bdfae3a5a4106e143e60.zip  | |
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 'include/linux/atmdev.h')
| -rw-r--r-- | include/linux/atmdev.h | 15 | 
1 files changed, 15 insertions, 0 deletions
diff --git a/include/linux/atmdev.h b/include/linux/atmdev.h index a3d07c29d16..086e5c362d3 100644 --- a/include/linux/atmdev.h +++ b/include/linux/atmdev.h @@ -100,6 +100,10 @@ struct atm_dev_stats {  					/* use backend to make new if */  #define ATM_ADDPARTY  	_IOW('a', ATMIOC_SPECIAL+4,struct atm_iobuf)   					/* add party to p2mp call */ +#ifdef CONFIG_COMPAT +/* It actually takes struct sockaddr_atmsvc, not struct atm_iobuf */ +#define COMPAT_ATM_ADDPARTY  	_IOW('a', ATMIOC_SPECIAL+4,struct compat_atm_iobuf) +#endif  #define ATM_DROPPARTY 	_IOW('a', ATMIOC_SPECIAL+5,int)  					/* drop party from p2mp call */ @@ -224,6 +228,13 @@ struct atm_cirange {  extern struct proc_dir_entry *atm_proc_root;  #endif +#ifdef CONFIG_COMPAT +#include <linux/compat.h> +struct compat_atm_iobuf { +	int length; +	compat_uptr_t buffer; +}; +#endif  struct k_atm_aal_stats {  #define __HANDLE_ITEM(i) atomic_t i @@ -379,6 +390,10 @@ struct atmdev_ops { /* only send is required */  	int (*open)(struct atm_vcc *vcc);  	void (*close)(struct atm_vcc *vcc);  	int (*ioctl)(struct atm_dev *dev,unsigned int cmd,void __user *arg); +#ifdef CONFIG_COMPAT +	int (*compat_ioctl)(struct atm_dev *dev,unsigned int cmd, +			    void __user *arg); +#endif  	int (*getsockopt)(struct atm_vcc *vcc,int level,int optname,  	    void __user *optval,int optlen);  	int (*setsockopt)(struct atm_vcc *vcc,int level,int optname,  |