From mboxrd@z Thu Jan 1 00:00:00 1970 From: Vinod Koul Subject: Re: [PATCH v3] ALSA: compress: add support for 32bit calls in a 64bit kernel Date: Mon, 7 Dec 2015 15:04:00 +0530 Message-ID: <20151207093400.GM1854@localhost> References: <1449470311-32394-1-git-send-email-rlokhande@nvidia.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by alsa0.perex.cz (Postfix) with ESMTP id 58EAA260513 for ; Mon, 7 Dec 2015 10:30:57 +0100 (CET) Content-Disposition: inline In-Reply-To: <1449470311-32394-1-git-send-email-rlokhande@nvidia.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: alsa-devel-bounces@alsa-project.org Sender: alsa-devel-bounces@alsa-project.org To: Ravindra Lokhande Cc: alsa-devel@alsa-project.org, tiwai@suse.com List-Id: alsa-devel@alsa-project.org On Mon, Dec 07, 2015 at 12:08:31PM +0530, Ravindra Lokhande wrote: > Compress offload does not support ioctl calls from a 32bit userspace > in a 64 bit kernel. This patch adds support for ioctls from a 32bit > userspace in a 64bit kernel > > Signed-off-by: Ravindra Lokhande > --- > > v1 -> v2: use compat_ptr to convert 32 bit address to 64 bit pointer > v2 -> v3: add header file compat.h > > sound/core/compress_offload.c | 13 +++++++++++++ > 1 file changed, 13 insertions(+) > > diff --git a/sound/core/compress_offload.c b/sound/core/compress_offload.c > index b123c42..4597820 100644 > --- a/sound/core/compress_offload.c > +++ b/sound/core/compress_offload.c > @@ -38,6 +38,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -847,6 +848,15 @@ static long snd_compr_ioctl(struct file *f, unsigned int cmd, unsigned long arg) > return retval; > } > > +/* support of 32bit userspace on 64bit platforms */ > +#ifdef CONFIG_COMPAT > +static long snd_compr_ioctl_compat(struct file *file, unsigned int cmd, > + unsigned long arg) > +{ > + return snd_compr_ioctl(file, cmd, (unsigned long)compat_ptr(arg)); > +} > +#endif > + > static const struct file_operations snd_compr_file_ops = { > .owner = THIS_MODULE, > .open = snd_compr_open, > @@ -854,6 +864,9 @@ static const struct file_operations snd_compr_file_ops = { > .write = snd_compr_write, > .read = snd_compr_read, > .unlocked_ioctl = snd_compr_ioctl, > +#ifdef CONFIG_COMPAT > + .compat_ioctl = snd_compr_ioctl_compat, > +#endif While this change is okay and required, I can't help wondering why the core does not take care of this. When a driver does not support compat_ioctl as it was done recently and takes care of 32/64 bit issues we should call ioctl for that driver.. Neverthless, Acked-by Vinod Koul -- ~Vinod