[{"id":3681225,"web_url":"http://patchwork.ozlabs.org/comment/3681225/","msgid":"<66a7a9ef-bdec-44a2-89e3-28cf77d6684b@linaro.org>","list_archive_url":null,"date":"2026-04-23T01:31:15","subject":"Re: [PATCH v3 04/14] target/arm/mshv: implement vcpu state operations\n for ARM64","submitter":{"id":72104,"url":"http://patchwork.ozlabs.org/api/people/72104/","name":"Richard Henderson","email":"richard.henderson@linaro.org"},"content":"On 4/21/26 15:21, Aastha Rawat wrote:\n> Add support for reading and writing ARM64 CPU registers in the MSHV\n> accelerator. This includes functions to set and get registers,\n> initialize and destroy VCPU state, and manage register state\n> synchronization between QEMU and hypervisor.\n> \n> Signed-off-by: Aastha Rawat <aastharawat@linux.microsoft.com>\n> ---\n>   include/hw/hyperv/hvgdk_mini.h |  42 +++++++++++++\n>   target/arm/mshv/mshv-all.c     | 138 +++++++++++++++++++++++++++++++++++++++++\n>   2 files changed, 180 insertions(+)\n> \n> diff --git a/include/hw/hyperv/hvgdk_mini.h b/include/hw/hyperv/hvgdk_mini.h\n> index cb52cc9de2..dfe94050f4 100644\n> --- a/include/hw/hyperv/hvgdk_mini.h\n> +++ b/include/hw/hyperv/hvgdk_mini.h\n> @@ -13,6 +13,46 @@ typedef enum hv_register_name {\n>       /* Pending Interruption Register */\n>       HV_REGISTER_PENDING_INTERRUPTION = 0x00010002,\n>   \n> +#if defined(__aarch64__)\n\nNot ideal, having target/host-specific stuff in a global header.\nThat said, you don't actually need the ifdefs at all.\n\n> +    HV_ARM64_REGISTER_XZR   = 0x0002FFFE,\n> +    HV_ARM64_REGISTER_X0    = 0x00020000,\n> +    HV_ARM64_REGISTER_X1    = 0x00020001,\n> +    HV_ARM64_REGISTER_X2    = 0x00020002,\n> +    HV_ARM64_REGISTER_X3    = 0x00020003,\n> +    HV_ARM64_REGISTER_X4    = 0x00020004,\n> +    HV_ARM64_REGISTER_X5    = 0x00020005,\n> +    HV_ARM64_REGISTER_X6    = 0x00020006,\n> +    HV_ARM64_REGISTER_X7    = 0x00020007,\n> +    HV_ARM64_REGISTER_X8    = 0x00020008,\n> +    HV_ARM64_REGISTER_X9    = 0x00020009,\n> +    HV_ARM64_REGISTER_X10   = 0x0002000A,\n> +    HV_ARM64_REGISTER_X11   = 0x0002000B,\n> +    HV_ARM64_REGISTER_X12   = 0x0002000C,\n> +    HV_ARM64_REGISTER_X13   = 0x0002000D,\n> +    HV_ARM64_REGISTER_X14   = 0x0002000E,\n> +    HV_ARM64_REGISTER_X15   = 0x0002000F,\n> +    HV_ARM64_REGISTER_X16   = 0x00020010,\n> +    HV_ARM64_REGISTER_X17   = 0x00020011,\n> +    HV_ARM64_REGISTER_X18   = 0x00020012,\n> +    HV_ARM64_REGISTER_X19   = 0x00020013,\n> +    HV_ARM64_REGISTER_X20   = 0x00020014,\n> +    HV_ARM64_REGISTER_X21   = 0x00020015,\n> +    HV_ARM64_REGISTER_X22   = 0x00020016,\n> +    HV_ARM64_REGISTER_X23   = 0x00020017,\n> +    HV_ARM64_REGISTER_X24   = 0x00020018,\n> +    HV_ARM64_REGISTER_X25   = 0x00020019,\n> +    HV_ARM64_REGISTER_X26   = 0x0002001A,\n> +    HV_ARM64_REGISTER_X27   = 0x0002001B,\n> +    HV_ARM64_REGISTER_X28   = 0x0002001C,\n> +    HV_ARM64_REGISTER_FP    = 0x0002001D,\n> +    HV_ARM64_REGISTER_LR    = 0x0002001E,\n> +    HV_ARM64_REGISTER_PC    = 0x00020022,\n> +\n> +    /* AArch64 System Register Descriptions: General system control registers */\n> +    HV_ARM64_REGISTER_MIDR_EL1   = 0x00040051,\n> +    HV_ARM64_REGISTER_MPIDR_EL1  = 0x00040001,\n> +\n> +#elif defined(__x86_64__)\n\n> +static enum hv_register_name STANDARD_REGISTER_NAMES[32] = {\n\nconst.\n\n> +    HV_ARM64_REGISTER_X0,\n> +    HV_ARM64_REGISTER_X1,\n> +    HV_ARM64_REGISTER_X2,\n> +    HV_ARM64_REGISTER_X3,\n> +    HV_ARM64_REGISTER_X4,\n> +    HV_ARM64_REGISTER_X5,\n> +    HV_ARM64_REGISTER_X6,\n> +    HV_ARM64_REGISTER_X7,\n> +    HV_ARM64_REGISTER_X8,\n> +    HV_ARM64_REGISTER_X9,\n> +    HV_ARM64_REGISTER_X10,\n> +    HV_ARM64_REGISTER_X11,\n> +    HV_ARM64_REGISTER_X12,\n> +    HV_ARM64_REGISTER_X13,\n> +    HV_ARM64_REGISTER_X14,\n> +    HV_ARM64_REGISTER_X15,\n> +    HV_ARM64_REGISTER_X16,\n> +    HV_ARM64_REGISTER_X17,\n> +    HV_ARM64_REGISTER_X18,\n> +    HV_ARM64_REGISTER_X19,\n> +    HV_ARM64_REGISTER_X20,\n> +    HV_ARM64_REGISTER_X21,\n> +    HV_ARM64_REGISTER_X22,\n> +    HV_ARM64_REGISTER_X23,\n> +    HV_ARM64_REGISTER_X24,\n> +    HV_ARM64_REGISTER_X25,\n> +    HV_ARM64_REGISTER_X26,\n> +    HV_ARM64_REGISTER_X27,\n> +    HV_ARM64_REGISTER_X28,\n> +    HV_ARM64_REGISTER_FP,\n> +    HV_ARM64_REGISTER_LR,\n> +    HV_ARM64_REGISTER_PC,\n\nWhy are you placing PC at name[31], given that you have to special case it everywhere else \nbelow?\n\n> +static int set_standard_regs(const CPUState *cpu)\n> +{\n> +    size_t n_regs = ARRAY_SIZE(STANDARD_REGISTER_NAMES);\n> +    struct hv_register_assoc *assocs;\n> +    int ret;\n> +    ARMCPU *arm_cpu = ARM_CPU(cpu);\n> +    CPUARMState *env = &arm_cpu->env;\n> +\n> +    assocs = g_new0(hv_register_assoc, n_regs);\n\nThis is small enough to allocate in the local stack frame.\nSame for get_standard_regs.\n\n> +static void populate_standard_regs(const hv_register_assoc *assocs,\n> +                                   CPUARMState *env)\n> +{\n> +    size_t n_regs = ARRAY_SIZE(STANDARD_REGISTER_NAMES);\n> +\n> +    for (size_t i = 0; i < n_regs - 1; i++) {\n> +        env->xregs[i] = assocs[i].value.reg64;\n> +    }\n> +\n> +    /* Last register is the program counter */\n> +    env->pc = assocs[n_regs - 1].value.reg64;\n> +}\n\nWhy is this separate from get_standard_regs?\nYou don't have a similar split for set_standard_regs...\n\n> +int mshv_get_standard_regs(CPUState *cpu)\n\nI'll note that this isn't used outside of this file, and similarly for i386/mshv.  It \ndoesn't need to be declared globally at all.\n\n\nr~","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=linaro.org header.i=@linaro.org header.a=rsa-sha256\n header.s=google header.b=xVeyJSDw;\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 4g1JVN3tsJz1yD5\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 23 Apr 2026 11:32:10 +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 1wFiue-0007Il-6c; Wed, 22 Apr 2026 21:31:28 -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 <richard.henderson@linaro.org>)\n id 1wFiua-0007IT-Sa\n for qemu-devel@nongnu.org; Wed, 22 Apr 2026 21:31:24 -0400","from mail-qt1-x82c.google.com ([2607:f8b0:4864:20::82c])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128)\n (Exim 4.90_1) (envelope-from <richard.henderson@linaro.org>)\n id 1wFiuY-0007b8-Rx\n for qemu-devel@nongnu.org; Wed, 22 Apr 2026 21:31:24 -0400","by mail-qt1-x82c.google.com with SMTP id\n d75a77b69052e-50fbd79350dso19358761cf.3\n for <qemu-devel@nongnu.org>; Wed, 22 Apr 2026 18:31:22 -0700 (PDT)","from [10.72.56.227] ([172.59.184.224])\n by smtp.gmail.com with ESMTPSA id\n d75a77b69052e-50f13ba2509sm80051851cf.8.2026.04.22.18.31.19\n for <qemu-devel@nongnu.org>\n (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128);\n Wed, 22 Apr 2026 18:31:20 -0700 (PDT)"],"DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=linaro.org; s=google; t=1776907881; x=1777512681; darn=nongnu.org;\n h=content-transfer-encoding:in-reply-to:content-language:from\n :references:to:subject:user-agent:mime-version:date:message-id:from\n :to:cc:subject:date:message-id:reply-to;\n bh=dv6bnWUqNOiCYQ1NV231msB+bVQzjf6WOcvm08JjPwM=;\n b=xVeyJSDweKiO7/4U851Ok66x6exRk99bY/UZdQvdtWaZFSgitA7j0U5i4uRl874pot\n dEFY67Tv9zHLbhEg09GMY9G8ijVKsvH/OJLqGaa3MdzBlGAKf17zZHNK5jL8hAJlbVjl\n wDDtqhIKsz8/JoFaC1+fA9It23reDKbXz/H0wfDYwvhgVLK30siXiW9DdJT7Q1wi4Ibb\n Tegw7xh33kGYag4AX53nDqdL80fKYFZ0lTf6jzYRzihiKXddjFv9EHWBNnkzTjKpWSEJ\n 1mGPpRM41hIp+aMNXBPF5ZDBpEwAkyJ/dJeEUBFPIDURnFwf+0VaN3lW0axPWHJ6+Cqq\n tOrQ==","X-Google-DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20251104; t=1776907881; x=1777512681;\n h=content-transfer-encoding:in-reply-to:content-language:from\n :references:to:subject:user-agent:mime-version:date:message-id\n :x-gm-gg:x-gm-message-state:from:to:cc:subject:date:message-id\n :reply-to;\n bh=dv6bnWUqNOiCYQ1NV231msB+bVQzjf6WOcvm08JjPwM=;\n b=A5E99+1uNxfaUR0RHAEsllRpuHNjIWLdm9mXpO8Do9dhZomd3H7EOmIJ6mIoCX/abf\n TmfWHFSygIsPhll2OegG5Ok9w7vlO9njZwi+BkSTOtTKlAH3BeSi0rXOvPwHvQRsUP0C\n LBkn3RH/NdZdfXpiUGNjfNtOGIET/2FjUEfGx7yi3AOVaA1a4gB32GEnbviFEEhUyjqE\n rYLRwcHe+5OxFgscKMlwK9a82E6pIiNkmB8UUDr2A8JIEq9tSDCSbepQ3fJNNTFO90FM\n vpL7AW5O/+iFNIImOm9y6s57Ui93Mqjmeh17bsHhQDxvZplOlzLLDs7xuLCROmAHadTi\n 10xg==","X-Gm-Message-State":"AOJu0Yz1k9oEvuGHruVOZhMdq8QfhbyChipsGWqcvOXSLM72cF0U+k0n\n vscrDqcj3uviPuNGH/m1CMqcgWWyApHYThZ+PiFE3MP05DPv8YZk+5ms1AW541QIZzpgxHp9dpj\n TXKilOho=","X-Gm-Gg":"AeBDievhq2nuB+WqjmZnW+rCgmkIWwLZnBxzL61Wv57lnIy/m/6qWkQrytshGdVpye1\n SPSSvE5az7lBoKZzTU1toSZ+JW4pfBOtVATEe5Z2pUFVnx9ZAXdEoXyYfWZIFbWvsVWdyNT5LXg\n n8MsSmzj2L4WNeBY9pCrit3383e4RBlZdIakYJVMI6UwGCo25gKHhAZ9nuzJSp7gZuwCoDaxm4m\n uDWge++tcRJ+XoNiMrCYv33zwF8iGp+i01sQRAxg2hCSagODmDxXsuluwsOh8W+GbNn6hQ9U3pT\n evHMUZKKrYwyf8wPmoDGumQ8j3zDsnFsoDbHae+8qAIWUpovLwGYHYx4K04lxo+yWV9rlAjAbBq\n 837BNFuzSKS4qkTe3O91ZhU3Y6SbfIVZYzNnLtxWemGTWc1G6RBOjtr6whheK0z2WjXdLFc2us+\n 4uQpL9rutRtcKQq2Yx0cz+KZwnFcd4qDVTfvRJW3PIKCqEeOYUPentDUJmR2i/SfR96xhKUXmR0\n VDzPBRxy4tFhznhRbUj2om6PXHD","X-Received":"by 2002:ac8:5fc9:0:b0:50f:b137:3099 with SMTP id\n d75a77b69052e-50fb137350fmr163684061cf.33.1776907881255;\n Wed, 22 Apr 2026 18:31:21 -0700 (PDT)","Message-ID":"<66a7a9ef-bdec-44a2-89e3-28cf77d6684b@linaro.org>","Date":"Thu, 23 Apr 2026 11:31:15 +1000","MIME-Version":"1.0","User-Agent":"Mozilla Thunderbird","Subject":"Re: [PATCH v3 04/14] target/arm/mshv: implement vcpu state operations\n for ARM64","To":"qemu-devel@nongnu.org","References":"\n <20260421-mshv_accel_arm64_supp-v3-0-469f544778ba@linux.microsoft.com>\n <20260421-mshv_accel_arm64_supp-v3-4-469f544778ba@linux.microsoft.com>","From":"Richard Henderson <richard.henderson@linaro.org>","Content-Language":"en-US","In-Reply-To":"\n <20260421-mshv_accel_arm64_supp-v3-4-469f544778ba@linux.microsoft.com>","Content-Type":"text/plain; charset=UTF-8; format=flowed","Content-Transfer-Encoding":"7bit","Received-SPF":"pass client-ip=2607:f8b0:4864:20::82c;\n envelope-from=richard.henderson@linaro.org; helo=mail-qt1-x82c.google.com","X-Spam_score_int":"-20","X-Spam_score":"-2.1","X-Spam_bar":"--","X-Spam_report":"(-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1,\n DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1,\n RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001,\n SPF_PASS=-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"}}]