{"id":2232103,"url":"http://patchwork.ozlabs.org/api/patches/2232103/?format=json","web_url":"http://patchwork.ozlabs.org/project/qemu-devel/patch/20260502-ioctl-v3-17-a05d4cb1bdff@bsdimp.com/","project":{"id":14,"url":"http://patchwork.ozlabs.org/api/projects/14/?format=json","name":"QEMU Development","link_name":"qemu-devel","list_id":"qemu-devel.nongnu.org","list_email":"qemu-devel@nongnu.org","web_url":"","scm_url":"","webscm_url":"","list_archive_url":"","list_archive_url_format":"","commit_url_format":""},"msgid":"<20260502-ioctl-v3-17-a05d4cb1bdff@bsdimp.com>","list_archive_url":null,"date":"2026-05-02T17:09:38","name":"[v3,17/19] bsd-user: Add do_bsd_ioctl main function","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"f3a9dadc52f5ad7108b9cd32825dbc7b5b71398a","submitter":{"id":1896,"url":"http://patchwork.ozlabs.org/api/people/1896/?format=json","name":"Warner Losh","email":"imp@bsdimp.com"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/qemu-devel/patch/20260502-ioctl-v3-17-a05d4cb1bdff@bsdimp.com/mbox/","series":[{"id":502541,"url":"http://patchwork.ozlabs.org/api/series/502541/?format=json","web_url":"http://patchwork.ozlabs.org/project/qemu-devel/list/?series=502541","date":"2026-05-02T17:09:22","name":"bsd-user: upstream ioctl","version":3,"mbox":"http://patchwork.ozlabs.org/series/502541/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2232103/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2232103/checks/","tags":{},"related":[],"headers":{"Return-Path":"<qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org>","X-Original-To":"incoming@patchwork.ozlabs.org","Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=bsdimp-com.20251104.gappssmtp.com\n header.i=@bsdimp-com.20251104.gappssmtp.com header.a=rsa-sha256\n header.s=20251104 header.b=p9e66/wz;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=nongnu.org\n (client-ip=209.51.188.17; helo=lists1p.gnu.org;\n envelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org;\n receiver=patchwork.ozlabs.org)"],"Received":["from lists1p.gnu.org (lists1p.gnu.org [209.51.188.17])\n\t(using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4g7DxS6xf9z1yJw\n\tfor <incoming@patchwork.ozlabs.org>; Sun, 03 May 2026 03:12:44 +1000 (AEST)","from localhost ([::1] helo=lists1p.gnu.org)\n\tby lists1p.gnu.org with esmtp (Exim 4.90_1)\n\t(envelope-from <qemu-devel-bounces@nongnu.org>)\n\tid 1wJDsU-0007uB-Th; Sat, 02 May 2026 13:11:42 -0400","from eggs.gnu.org ([2001:470:142:3::10])\n by lists1p.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <imp@bsdimp.com>) id 1wJDsQ-0007tN-LJ\n for qemu-devel@nongnu.org; Sat, 02 May 2026 13:11:38 -0400","from mail-ot1-x330.google.com ([2607:f8b0:4864:20::330])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128)\n (Exim 4.90_1) (envelope-from <imp@bsdimp.com>) id 1wJDsO-0007E6-Nv\n for qemu-devel@nongnu.org; Sat, 02 May 2026 13:11:38 -0400","by mail-ot1-x330.google.com with SMTP id\n 46e09a7af769-7d4be94eeacso3210386a34.2\n for <qemu-devel@nongnu.org>; Sat, 02 May 2026 10:11:36 -0700 (PDT)","from rebo.bsdimp.com ([50.253.99.174])\n by smtp.gmail.com with ESMTPSA id\n 46e09a7af769-7deca824746sm4334355a34.11.2026.05.02.10.11.34\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Sat, 02 May 2026 10:11:34 -0700 (PDT)"],"DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=bsdimp-com.20251104.gappssmtp.com; s=20251104; t=1777741895; x=1778346695;\n darn=nongnu.org;\n h=cc:to:in-reply-to:references:message-id:content-transfer-encoding\n :mime-version:subject:date:from:from:to:cc:subject:date:message-id\n :reply-to; bh=2QBmwjvaav499uBiNQkZ4uLoZRRkEdivASGuKNAftSo=;\n b=p9e66/wzF1MZGMTVqMlEQ/l83fp4lnaiTsOCZuk4Vpwz3XBdDo0TA/fG2+PO4XOtHq\n TFS1nDMqla2ysJdmaRtBaNdMpG/6SVECJAxd3QJ5vHvyKmtW4imbvMoquh0C7eohTW1d\n tExpkpGAIExRN6DhXtO4Q0wCw0X+JmEKzzdXKq4Un4fjToWk6AhTXNmw5mG951VWTWgY\n ArYGvrexJJbLTmFWdMUOjKO1k4OYg8A1RzR8/rO8LRLYEdLGBElbTmVc70PQkOUXAY9p\n FlwbyMpLUtqid3BY0errwPPx/wEBcX6C0SsGruIjtRWrlQUBpgGIED6zAG0FmZwMDFsR\n BOCg==","X-Google-DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20251104; t=1777741895; x=1778346695;\n h=cc:to:in-reply-to:references:message-id:content-transfer-encoding\n :mime-version:subject:date:from:x-gm-gg:x-gm-message-state:from:to\n :cc:subject:date:message-id:reply-to;\n bh=2QBmwjvaav499uBiNQkZ4uLoZRRkEdivASGuKNAftSo=;\n b=hSHu5HzW3XknlERQlrnqX/CyGAHLAxPW+VepETK7AxMO/AuPcHCOKlYaYYpyvKkk8k\n mXmPtuKp3nuOFj2NQiRA+jXW4oOAQmwDQ8nZcc/9c5XlbVmsE0AOl9d6SM4FFSX0BtOk\n Uo+poEP8CIL06gA2s5OhqxhUU1co4IKPv4M6WOGYA5UNjZnL2N1aI0r1sLgg5Kphro/m\n dGgS7VTwxHnY4uOCh5w8JsDI6snZ27nYfjeKTOAD6MddEhTJPz2bnJ+6W/lx2mNnd41C\n VTah6hbdyVt9Gc6lgPzhOdF7H5erpKlcDRx8nat48WqHauQPTj8fv1sHRl4ljo+gcica\n u2wA==","X-Gm-Message-State":"AOJu0YyZByhmWamGZZEg2MDK4v85lB/j1IUyb+xhBhLbswic6N9ZPcm8\n VmanQB5bvBH87xJ6n2O7EKF8LrdCw/h8mCkua2NJcPymOlkoqF/6vRwZrdIO0Xv7kF1qndmX8/y\n /JYP3uSY=","X-Gm-Gg":"AeBDietByatSAhlz11zPp33sOS446QUgmATUjpR3rm2wKpKOLvHnOUFysIAZB5LFlDC\n he/+/pJ32Uk/0tjU7YPOJYfxEKe24jB7F7oX9oZMcYaA9MEd8nxHel9zjYuG+15h4zoQM1YTKkh\n UQgrWAuc3tWXWvnhppTZ6Gzs4FU33apfmFQpLHqLN6DyiG+aVRhXjCQ0gz4J3IzDRnWpPkmN+X9\n KTleDvR5bxPGlXnMOFB38Jm8hRWUY5SjC1cApDKbNgVeg2WtvgRALBPp3j8XL2ScTjuls2jBlra\n eUkib/LnLA+NsakMUt7vc+bWU2ngIdmyyPwvP/r2S4a2HOQPUZDVSW9x6yFOZMgaFiWH9gt378z\n nFwiuo49fLNRiq0yf7Jr7BPHj1N5Dm6e5y7z0+7LGm7bXGEDIi/3eEtDV+5XFL3YySxs/qG79ZF\n TQBIIxqtBAKMVVDHKV6Sw6","X-Received":"by 2002:a05:6830:81eb:b0:7d9:7209:4378 with SMTP id\n 46e09a7af769-7dee13c17c5mr2396554a34.17.1777741895355;\n Sat, 02 May 2026 10:11:35 -0700 (PDT)","From":"Warner Losh <imp@bsdimp.com>","Date":"Sat, 02 May 2026 11:09:38 -0600","Subject":"[PATCH v3 17/19] bsd-user: Add do_bsd_ioctl main function","MIME-Version":"1.0","Content-Type":"text/plain; charset=\"utf-8\"","Content-Transfer-Encoding":"7bit","Message-Id":"<20260502-ioctl-v3-17-a05d4cb1bdff@bsdimp.com>","References":"<20260502-ioctl-v3-0-a05d4cb1bdff@bsdimp.com>","In-Reply-To":"<20260502-ioctl-v3-0-a05d4cb1bdff@bsdimp.com>","To":"qemu-devel@nongnu.org","Cc":"Kyle Evans <kevans@freebsd.org>,\n =?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= <philmd@linaro.org>,\n  Pierrick Bouvier <pierrick.bouvier@oss.qualcomm.com>,\n  Warner Losh <imp@bsdimp.com>, \"Stacey D. Son\" <sson@freebsd.org>","X-Mailer":"b4 0.14.3","X-Developer-Signature":"v=1; a=openpgp-sha256; l=3931; i=imp@bsdimp.com;\n h=from:subject:message-id; bh=xguMmeeOWqzWWh1TUfAOdmnx9WUC5A613/gvNUKKM1I=;\n b=owEBbQKS/ZANAwAKAWwc0Sh9sBEAAcsmYgBp9i/RXHs2r0ZF3gUUKBSzAtxA32QJZJ4oizlcu\n GMWKPkcfceJAjMEAAEKAB0WIQQgNfiUsAqjz3zN4bdsHNEofbARAAUCafYv0QAKCRBsHNEofbAR\n AAuvD/0fmT1d/SKwYpHsG7ONoPBz8riszqyJDD/9R+7Vunj9HAxqqwNnlmv+KTuIX6s5eM4eDBn\n yFixD/OH+Qr5HltHUAIRBPVV6PPSpqnyWrf49A3ShnCRoey+Zgica6vS9NxNZ9Fh6SDqWKXREN3\n GmO0+Q9h4Q3Qi7ChIiPl9Nn4mA9FcpzeKxuAUqyaBgkRl/NuUKptDSxhcLPd11nxlqofZl9v8D8\n 18KTs4SVrOcX0bHroDLxHaj5UaVfBB722r+drBzFHzI4CUmiW6sQXwTVhI4Mtv3QevShnfzfzJ/\n AqmnR4XVk2EYVB6tUuxgzdMR9zDEEmn+UXmtPWsYiVCM4MXonbhsslonv28jqKBgPzuZAjGbyGt\n IL/PRZ67mSMicgMzbS+GcMQyxAxkxB8+HKHl8ldGL0aWNva/pIVE+Pc29uaLzqwegIruGYSde9D\n HgQrLKINfNPh8Lxwxelkh8carziGSkghLD3wb/S/eB5HB4OMOWQL0p37ADsrTQMBGoIbnNkXZqe\n XT3k0VT/vo1UxMiYqz5iduOgh06xJmA3ajXUo69k3NUpRfCWKwoXQPhOF7NgFp4V3DQzg9fARwJ\n pzpMPCzeZCH+wAc4eAMi+5X95O6/dhk2YgJmkinu175jDwyGr1wnA7tfR5+4RnNEZnuNuIP32Zq\n QO8hkvAhIH3HS3Q==","X-Developer-Key":"i=imp@bsdimp.com; a=openpgp;\n fpr=2035F894B00AA3CF7CCDE1B76C1CD1287DB01100","Received-SPF":"none client-ip=2607:f8b0:4864:20::330;\n envelope-from=imp@bsdimp.com; helo=mail-ot1-x330.google.com","X-Spam_score_int":"-18","X-Spam_score":"-1.9","X-Spam_bar":"-","X-Spam_report":"(-1.9 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1,\n DKIM_VALID=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001,\n SPF_NONE=0.001 autolearn=ham autolearn_force=no","X-Spam_action":"no action","X-BeenThere":"qemu-devel@nongnu.org","X-Mailman-Version":"2.1.29","Precedence":"list","List-Id":"qemu development <qemu-devel.nongnu.org>","List-Unsubscribe":"<https://lists.nongnu.org/mailman/options/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=unsubscribe>","List-Archive":"<https://lists.nongnu.org/archive/html/qemu-devel>","List-Post":"<mailto:qemu-devel@nongnu.org>","List-Help":"<mailto:qemu-devel-request@nongnu.org?subject=help>","List-Subscribe":"<https://lists.nongnu.org/mailman/listinfo/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=subscribe>","Errors-To":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org","Sender":"qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org"},"content":"Add main ioctl emulation dispatcher that handles table-driven\nioctl translation with thunk-based structure conversion. Supports\nTYPE_NULL, TYPE_INT, and TYPE_PTR argument types with read, write,\nand read-write access modes.\n\nSigned-off-by: Stacey D. Son <sson@freebsd.org>\nReviewed-by: Pierrick Bouvier <pierrick.bouvier@oss.qualcomm.com>\nSigned-off-by: Warner Losh <imp@bsdimp.com>\n---\n bsd-user/bsd-ioctl.c | 100 +++++++++++++++++++++++++++++++++++++++++++++++++++\n 1 file changed, 100 insertions(+)","diff":"diff --git a/bsd-user/bsd-ioctl.c b/bsd-user/bsd-ioctl.c\nindex 8d25d84dbe..3940a69260 100644\n--- a/bsd-user/bsd-ioctl.c\n+++ b/bsd-user/bsd-ioctl.c\n@@ -292,3 +292,103 @@ static abi_long do_ioctl_in6_ifreq_sockaddr_int(const IOCTLEntry *ie,\n \n     return ret;\n }\n+\n+abi_long do_bsd_ioctl(int fd, abi_long cmd, abi_long arg)\n+{\n+    const IOCTLEntry *ie;\n+    const argtype *arg_type;\n+    abi_long ret;\n+    uint8_t buf_temp[MAX_STRUCT_SIZE];\n+    int target_size;\n+    void *argptr;\n+\n+    ie = ioctl_entries;\n+    for (;;) {\n+        if (ie->target_cmd == 0) {\n+            gemu_log(\"QEMU unsupported ioctl: \");\n+            log_unsupported_ioctl(cmd);\n+            return -TARGET_ENOSYS;\n+        }\n+        if (ie->target_cmd == cmd) {\n+            break;\n+        }\n+        ie++;\n+    }\n+    arg_type = ie->arg_type;\n+#if defined(DEBUG)\n+    gemu_log(\"ioctl: cmd=0x%04lx (%s)\\n\", (long)cmd, ie->name);\n+#endif\n+    if (ie->do_ioctl) {\n+        return ie->do_ioctl(ie, buf_temp, fd, cmd, arg);\n+    }\n+\n+    switch (arg_type[0]) {\n+    case TYPE_NULL:\n+        /* no argument */\n+        ret = get_errno(safe_ioctl(fd, ie->host_cmd));\n+        break;\n+\n+    case TYPE_PTRVOID:\n+    case TYPE_INT:\n+        /* int argument */\n+        ret = get_errno(safe_ioctl(fd, ie->host_cmd, arg));\n+        break;\n+\n+    case TYPE_PTR:\n+        arg_type++;\n+        target_size = thunk_type_size(arg_type, 0);\n+        switch (ie->access) {\n+        case IOC_R:\n+            ret = get_errno(safe_ioctl(fd, ie->host_cmd, buf_temp));\n+            if (!is_error(ret)) {\n+                argptr = lock_user(VERIFY_WRITE, arg,\n+                    target_size, 0);\n+                if (!argptr) {\n+                    return -TARGET_EFAULT;\n+                }\n+                thunk_convert(argptr, buf_temp, arg_type,\n+                    THUNK_TARGET);\n+                unlock_user(argptr, arg, target_size);\n+            }\n+            break;\n+\n+        case IOC_W:\n+            argptr = lock_user(VERIFY_READ, arg, target_size, 1);\n+            if (!argptr) {\n+                return -TARGET_EFAULT;\n+            }\n+            thunk_convert(buf_temp, argptr, arg_type, THUNK_HOST);\n+            unlock_user(argptr, arg, 0);\n+            ret = get_errno(safe_ioctl(fd, ie->host_cmd, buf_temp));\n+            break;\n+\n+        case IOC_RW:\n+            /* fallthrough */\n+        default:\n+            argptr = lock_user(VERIFY_READ, arg, target_size, 1);\n+            if (!argptr) {\n+                return -TARGET_EFAULT;\n+            }\n+            thunk_convert(buf_temp, argptr, arg_type, THUNK_HOST);\n+            unlock_user(argptr, arg, 0);\n+            ret = get_errno(safe_ioctl(fd, ie->host_cmd, buf_temp));\n+            if (!is_error(ret)) {\n+                argptr = lock_user(VERIFY_WRITE, arg, target_size, 0);\n+                if (!argptr) {\n+                    return -TARGET_EFAULT;\n+                }\n+                thunk_convert(argptr, buf_temp, arg_type, THUNK_TARGET);\n+                unlock_user(argptr, arg, target_size);\n+            }\n+            break;\n+        }\n+        break;\n+\n+    default:\n+        gemu_log(\"QEMU unknown ioctl: type=%d \", arg_type[0]);\n+        log_unsupported_ioctl(cmd);\n+        ret = -TARGET_ENOSYS;\n+        break;\n+    }\n+    return ret;\n+}\n","prefixes":["v3","17/19"]}