On 4/28/25 3:57 PM, Kyle Evans wrote:
On 4/28/25 14:36, Pierrick Bouvier wrote:
On 3/31/25 4:42 PM, Pierrick Bouvier wrote:
Nothing prevent plugins to be enabled on this platform for user
binaries, only the option in the driver is missing.

Signed-off-by: Pierrick Bouvier <pierrick.bouv...@linaro.org>
---
   bsd-user/main.c | 12 ++++++++++++
   1 file changed, 12 insertions(+)

diff --git a/bsd-user/main.c b/bsd-user/main.c
index fdb160bed0f..329bd1acc02 100644
--- a/bsd-user/main.c
+++ b/bsd-user/main.c
@@ -175,6 +175,9 @@ static void usage(void)
              "-strace           log system calls\n"
              "-trace            [[enable=]<pattern>][,events=<file>]
[,file=<file>]\n"
              "                  specify tracing options\n"
+#ifdef CONFIG_PLUGIN
+           "-plugin           [file=]<file>[,<argname>=<argvalue>]\n"
+#endif
              "\n"
              "Environment variables:\n"
              "QEMU_STRACE       Print system calls and arguments
similar to the\n"
@@ -225,6 +228,8 @@ static void init_task_state(TaskState *ts)
       };
   }
+static QemuPluginList plugins = QTAILQ_HEAD_INITIALIZER(plugins);
+
   void gemu_log(const char *fmt, ...)
   {
       va_list ap;
@@ -307,6 +312,7 @@ int main(int argc, char **argv)
       cpu_model = NULL;
       qemu_add_opts(&qemu_trace_opts);
+    qemu_plugin_add_opts();
       optind = 1;
       for (;;) {
@@ -399,6 +405,11 @@ int main(int argc, char **argv)
               do_strace = 1;
           } else if (!strcmp(r, "trace")) {
               trace_opt_parse(optarg);
+#ifdef CONFIG_PLUGIN
+        } else if (!strcmp(r, "plugin")) {
+            r = argv[optind++];
+            qemu_plugin_opt_parse(r, &plugins);
+#endif
           } else if (!strcmp(r, "0")) {
               argv0 = argv[optind++];
           } else {
@@ -433,6 +444,7 @@ int main(int argc, char **argv)
           exit(1);
       }
       trace_init_file();
+    qemu_plugin_load_list(&plugins, &error_fatal);
       /* Zero out regs */
       memset(regs, 0, sizeof(struct target_pt_regs));

Gentle ping on this series.
As we didn't have any feedback from BSD side, could we consider to
enable this upstream?


Sorry- I have no strong opinion on plugins, but the diff looks
incredibly reasonable and non-invasive.  I'm not really seeing any
reason we'd object, but I don't personally feel qualified to review this
(except as a basic human C linter- I can't imagine the added calls
breaking anything we rely on).


@Alex, would you be open to enable this, as it concerns plugins?

Thanks,

Kyle Evans


Reply via email to