[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return val
From: |
Philippe Mathieu-Daudé |
Subject: |
Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value |
Date: |
Mon, 22 Feb 2021 18:41:07 +0100 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.0 |
On 2/22/21 6:24 PM, Cornelia Huck wrote:
> On Fri, 19 Feb 2021 18:38:37 +0100
> Philippe Mathieu-Daudé <philmd@redhat.com> wrote:
>
>> MachineClass::kvm_type() can return -1 on failure.
>> Document it, and add a check in kvm_init().
>>
>> Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
>> ---
>> include/hw/boards.h | 3 ++-
>> accel/kvm/kvm-all.c | 6 ++++++
>> 2 files changed, 8 insertions(+), 1 deletion(-)
>>
>> diff --git a/include/hw/boards.h b/include/hw/boards.h
>> index a46dfe5d1a6..68d3d10f6b0 100644
>> --- a/include/hw/boards.h
>> +++ b/include/hw/boards.h
>> @@ -127,7 +127,8 @@ typedef struct {
>> * implement and a stub device is required.
>> * @kvm_type:
>> * Return the type of KVM corresponding to the kvm-type string option or
>> - * computed based on other criteria such as the host kernel capabilities.
>> + * computed based on other criteria such as the host kernel capabilities
>> + * (which can't be negative), or -1 on error.
>> * @numa_mem_supported:
>> * true if '--numa node.mem' option is supported and false otherwise
>> * @smp_parse:
>> diff --git a/accel/kvm/kvm-all.c b/accel/kvm/kvm-all.c
>> index 84c943fcdb2..b069938d881 100644
>> --- a/accel/kvm/kvm-all.c
>> +++ b/accel/kvm/kvm-all.c
>> @@ -2057,6 +2057,12 @@ static int kvm_init(MachineState *ms)
>> "kvm-type",
>> &error_abort);
>> type = mc->kvm_type(ms, kvm_type);
>> + if (type < 0) {
>> + ret = -EINVAL;
>> + fprintf(stderr, "Failed to detect kvm-type for machine '%s'\n",
>> + mc->name);
>> + goto err;
>> + }
>> }
>>
>> do {
>
> No objection to this patch; but I'm wondering why some non-pseries
> machines implement the kvm_type callback, when I see the kvm-type
> property only for pseries? Am I holding my git grep wrong?
Can it be what David commented here?
https://www.mail-archive.com/qemu-devel@nongnu.org/msg784508.html
- [PATCH v2 00/11] hw/accel: Exit gracefully when accelerator is invalid, Philippe Mathieu-Daudé, 2021/02/19
- [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, Philippe Mathieu-Daudé, 2021/02/19
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, Cornelia Huck, 2021/02/22
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value,
Philippe Mathieu-Daudé <=
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, Cornelia Huck, 2021/02/22
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, Philippe Mathieu-Daudé, 2021/02/22
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, David Gibson, 2021/02/22
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, David Gibson, 2021/02/22
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, Cornelia Huck, 2021/02/23
- Re: [PATCH v2 01/11] accel/kvm: Check MachineClass kvm_type() return value, Philippe Mathieu-Daudé, 2021/02/23
[PATCH v2 02/11] hw/boards: Introduce machine_class_valid_for_accelerator(), Philippe Mathieu-Daudé, 2021/02/19