From: Filip Bozuta Date: Wed, 15 Jan 2020 19:36:47 +0000 (+0100) Subject: linux-user: Add support for TYPE_LONG and TYPE_ULONG in do_ioctl() X-Git-Tag: v5.0.0-rc0~130^2~6 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c858e537a9eb2e2b788ec323125462ea0991bd93;p=thirdparty%2Fqemu.git linux-user: Add support for TYPE_LONG and TYPE_ULONG in do_ioctl() Function "do_ioctl()" located in file "syscall.c" was missing an option for TYPE_LONG and TYPE_ULONG. This caused some ioctls to not be recognised because they had the third argument that was of type 'long' or 'unsigned long'. For example: Since implemented ioctls RTC_IRQP_SET and RTC_EPOCH_SET are of type IOW(writing type) that have unsigned long as their third argument, they were not recognised in QEMU before the changes of this patch. Signed-off-by: Filip Bozuta Reviewed-by: Laurent Vivier Message-Id: <1579117007-7565-14-git-send-email-Filip.Bozuta@rt-rk.com> Signed-off-by: Laurent Vivier --- diff --git a/linux-user/syscall.c b/linux-user/syscall.c index c5bda60b45d..bd2436b3100 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -5178,6 +5178,8 @@ static abi_long do_ioctl(int fd, int cmd, abi_long arg) break; case TYPE_PTRVOID: case TYPE_INT: + case TYPE_LONG: + case TYPE_ULONG: ret = get_errno(safe_ioctl(fd, ie->host_cmd, arg)); break; case TYPE_PTR: