qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/3] vl.c: select_machine(): improve error message
@ 2024-06-26 13:43 Vladimir Sementsov-Ogievskiy
  2024-06-26 13:43 ` [PATCH 1/3] vl.c: select_machine(): use ERRP_GUARD instead of error propagation Vladimir Sementsov-Ogievskiy
                   ` (4 more replies)
  0 siblings, 5 replies; 6+ messages in thread
From: Vladimir Sementsov-Ogievskiy @ 2024-06-26 13:43 UTC (permalink / raw)
  To: qemu-devel; +Cc: pbonzini, qemu-trivial, armbru, Vladimir Sementsov-Ogievskiy

Hi all!

Here are three simple patches, improving select_machine() function a
bit.

Vladimir Sementsov-Ogievskiy (3):
  vl.c: select_machine(): use ERRP_GUARD instead of error propagation
  vl.c: select_machine(): use g_autoptr
  vl.c: select_machine(): add selected machine type to error message

 system/vl.c | 17 ++++++++---------
 1 file changed, 8 insertions(+), 9 deletions(-)

-- 
2.34.1



^ permalink raw reply	[flat|nested] 6+ messages in thread

* [PATCH 1/3] vl.c: select_machine(): use ERRP_GUARD instead of error propagation
  2024-06-26 13:43 [PATCH 0/3] vl.c: select_machine(): improve error message Vladimir Sementsov-Ogievskiy
@ 2024-06-26 13:43 ` Vladimir Sementsov-Ogievskiy
  2024-06-26 13:43 ` [PATCH 2/3] vl.c: select_machine(): use g_autoptr Vladimir Sementsov-Ogievskiy
                   ` (3 subsequent siblings)
  4 siblings, 0 replies; 6+ messages in thread
From: Vladimir Sementsov-Ogievskiy @ 2024-06-26 13:43 UTC (permalink / raw)
  To: qemu-devel; +Cc: pbonzini, qemu-trivial, armbru, Vladimir Sementsov-Ogievskiy

Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
---
 system/vl.c | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)

diff --git a/system/vl.c b/system/vl.c
index cfcb674425..fa81037ce2 100644
--- a/system/vl.c
+++ b/system/vl.c
@@ -1665,28 +1665,28 @@ static const QEMUOption *lookup_opt(int argc, char **argv,
 
 static MachineClass *select_machine(QDict *qdict, Error **errp)
 {
+    ERRP_GUARD();
     const char *machine_type = qdict_get_try_str(qdict, "type");
     GSList *machines = object_class_get_list(TYPE_MACHINE, false);
-    MachineClass *machine_class;
-    Error *local_err = NULL;
+    MachineClass *machine_class = NULL;
 
     if (machine_type) {
         machine_class = find_machine(machine_type, machines);
         qdict_del(qdict, "type");
         if (!machine_class) {
-            error_setg(&local_err, "unsupported machine type");
+            error_setg(errp, "unsupported machine type");
         }
     } else {
         machine_class = find_default_machine(machines);
         if (!machine_class) {
-            error_setg(&local_err, "No machine specified, and there is no default");
+            error_setg(errp, "No machine specified, and there is no default");
         }
     }
 
     g_slist_free(machines);
-    if (local_err) {
-        error_append_hint(&local_err, "Use -machine help to list supported machines\n");
-        error_propagate(errp, local_err);
+    if (!machine_class) {
+        error_append_hint(errp,
+                          "Use -machine help to list supported machines\n");
     }
     return machine_class;
 }
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 6+ messages in thread

* [PATCH 2/3] vl.c: select_machine(): use g_autoptr
  2024-06-26 13:43 [PATCH 0/3] vl.c: select_machine(): improve error message Vladimir Sementsov-Ogievskiy
  2024-06-26 13:43 ` [PATCH 1/3] vl.c: select_machine(): use ERRP_GUARD instead of error propagation Vladimir Sementsov-Ogievskiy
@ 2024-06-26 13:43 ` Vladimir Sementsov-Ogievskiy
  2024-06-26 13:43 ` [PATCH 3/3] vl.c: select_machine(): add selected machine type to error message Vladimir Sementsov-Ogievskiy
                   ` (2 subsequent siblings)
  4 siblings, 0 replies; 6+ messages in thread
From: Vladimir Sementsov-Ogievskiy @ 2024-06-26 13:43 UTC (permalink / raw)
  To: qemu-devel; +Cc: pbonzini, qemu-trivial, armbru, Vladimir Sementsov-Ogievskiy

Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
---
 system/vl.c | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)

diff --git a/system/vl.c b/system/vl.c
index fa81037ce2..947b433905 100644
--- a/system/vl.c
+++ b/system/vl.c
@@ -1667,7 +1667,7 @@ static MachineClass *select_machine(QDict *qdict, Error **errp)
 {
     ERRP_GUARD();
     const char *machine_type = qdict_get_try_str(qdict, "type");
-    GSList *machines = object_class_get_list(TYPE_MACHINE, false);
+    g_autoptr(GSList) machines = object_class_get_list(TYPE_MACHINE, false);
     MachineClass *machine_class = NULL;
 
     if (machine_type) {
@@ -1683,7 +1683,6 @@ static MachineClass *select_machine(QDict *qdict, Error **errp)
         }
     }
 
-    g_slist_free(machines);
     if (!machine_class) {
         error_append_hint(errp,
                           "Use -machine help to list supported machines\n");
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 6+ messages in thread

* [PATCH 3/3] vl.c: select_machine(): add selected machine type to error message
  2024-06-26 13:43 [PATCH 0/3] vl.c: select_machine(): improve error message Vladimir Sementsov-Ogievskiy
  2024-06-26 13:43 ` [PATCH 1/3] vl.c: select_machine(): use ERRP_GUARD instead of error propagation Vladimir Sementsov-Ogievskiy
  2024-06-26 13:43 ` [PATCH 2/3] vl.c: select_machine(): use g_autoptr Vladimir Sementsov-Ogievskiy
@ 2024-06-26 13:43 ` Vladimir Sementsov-Ogievskiy
  2024-06-26 17:07 ` [PATCH 0/3] vl.c: select_machine(): improve " Philippe Mathieu-Daudé
  2024-06-27 15:21 ` Michael Tokarev
  4 siblings, 0 replies; 6+ messages in thread
From: Vladimir Sementsov-Ogievskiy @ 2024-06-26 13:43 UTC (permalink / raw)
  To: qemu-devel; +Cc: pbonzini, qemu-trivial, armbru, Vladimir Sementsov-Ogievskiy

Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
---
 system/vl.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/system/vl.c b/system/vl.c
index 947b433905..a6a4b470a7 100644
--- a/system/vl.c
+++ b/system/vl.c
@@ -1674,7 +1674,7 @@ static MachineClass *select_machine(QDict *qdict, Error **errp)
         machine_class = find_machine(machine_type, machines);
         qdict_del(qdict, "type");
         if (!machine_class) {
-            error_setg(errp, "unsupported machine type");
+            error_setg(errp, "unsupported machine type: \"%s\"", optarg);
         }
     } else {
         machine_class = find_default_machine(machines);
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH 0/3] vl.c: select_machine(): improve error message
  2024-06-26 13:43 [PATCH 0/3] vl.c: select_machine(): improve error message Vladimir Sementsov-Ogievskiy
                   ` (2 preceding siblings ...)
  2024-06-26 13:43 ` [PATCH 3/3] vl.c: select_machine(): add selected machine type to error message Vladimir Sementsov-Ogievskiy
@ 2024-06-26 17:07 ` Philippe Mathieu-Daudé
  2024-06-27 15:21 ` Michael Tokarev
  4 siblings, 0 replies; 6+ messages in thread
From: Philippe Mathieu-Daudé @ 2024-06-26 17:07 UTC (permalink / raw)
  To: Vladimir Sementsov-Ogievskiy, qemu-devel; +Cc: pbonzini, qemu-trivial, armbru

On 26/6/24 15:43, Vladimir Sementsov-Ogievskiy wrote:

> Vladimir Sementsov-Ogievskiy (3):
>    vl.c: select_machine(): use ERRP_GUARD instead of error propagation
>    vl.c: select_machine(): use g_autoptr
>    vl.c: select_machine(): add selected machine type to error message

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>



^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 0/3] vl.c: select_machine(): improve error message
  2024-06-26 13:43 [PATCH 0/3] vl.c: select_machine(): improve error message Vladimir Sementsov-Ogievskiy
                   ` (3 preceding siblings ...)
  2024-06-26 17:07 ` [PATCH 0/3] vl.c: select_machine(): improve " Philippe Mathieu-Daudé
@ 2024-06-27 15:21 ` Michael Tokarev
  4 siblings, 0 replies; 6+ messages in thread
From: Michael Tokarev @ 2024-06-27 15:21 UTC (permalink / raw)
  To: Vladimir Sementsov-Ogievskiy, qemu-devel; +Cc: pbonzini, qemu-trivial, armbru

26.06.2024 16:43, Vladimir Sementsov-Ogievskiy wrote:
> Hi all!
> 
> Here are three simple patches, improving select_machine() function a
> bit.

Applied to trivial-patches, thank you!

/mjt

-- 
GPG Key transition (from rsa2048 to rsa4096) since 2024-04-24.
New key: rsa4096/61AD3D98ECDF2C8E  9D8B E14E 3F2A 9DD7 9199  28F1 61AD 3D98 ECDF 2C8E
Old key: rsa2048/457CE0A0804465C5  6EE1 95D1 886E 8FFB 810D  4324 457C E0A0 8044 65C5
Transition statement: http://www.corpit.ru/mjt/gpg-transition-2024.txt



^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2024-06-27 15:21 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-06-26 13:43 [PATCH 0/3] vl.c: select_machine(): improve error message Vladimir Sementsov-Ogievskiy
2024-06-26 13:43 ` [PATCH 1/3] vl.c: select_machine(): use ERRP_GUARD instead of error propagation Vladimir Sementsov-Ogievskiy
2024-06-26 13:43 ` [PATCH 2/3] vl.c: select_machine(): use g_autoptr Vladimir Sementsov-Ogievskiy
2024-06-26 13:43 ` [PATCH 3/3] vl.c: select_machine(): add selected machine type to error message Vladimir Sementsov-Ogievskiy
2024-06-26 17:07 ` [PATCH 0/3] vl.c: select_machine(): improve " Philippe Mathieu-Daudé
2024-06-27 15:21 ` Michael Tokarev

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).