Currently we do two wrong things:
1. Abuse s->filename to get pty_name from it
2. Violate layering with help of CHARDEV_IS_PTY()
Let's get rid of both, and introduce correct way to get pty name in
generic code, if available.
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@yandex-team.ru>
Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Message-Id: <
20260115144606.233252-9-vsementsov@yandex-team.ru>
pty->path = g_strdup(path);
}
+static char *pty_chr_get_pty_name(Chardev *chr)
+{
+ PtyChardev *s = PTY_CHARDEV(chr);
+ return g_strdup(s->pty_name);
+}
+
static void char_pty_class_init(ObjectClass *oc, const void *data)
{
ChardevClass *cc = CHARDEV_CLASS(oc);
cc->chr_write = pty_chr_write;
cc->chr_update_read_handler = pty_chr_update_read_handler;
cc->chr_add_watch = pty_chr_add_watch;
+ cc->chr_get_pty_name = pty_chr_get_pty_name;
}
static const TypeInfo char_pty_type_info = {
}
ret = g_new0(ChardevReturn, 1);
- if (CHARDEV_IS_PTY(chr)) {
- ret->pty = g_strdup(chr->filename + 4);
- }
+ ret->pty = qemu_chr_get_pty_name(chr);
return ret;
return NULL;
}
+char *qemu_chr_get_pty_name(Chardev *chr)
+{
+ ChardevClass *cc = CHARDEV_GET_CLASS(chr);
+
+ if (cc->chr_get_pty_name) {
+ return cc->chr_get_pty_name(chr);
+ }
+
+ return NULL;
+}
+
ChardevReturn *qmp_chardev_change(const char *id, ChardevBackend *backend,
Error **errp)
{
object_unref(OBJECT(chr_new));
ret = g_new0(ChardevReturn, 1);
- if (CHARDEV_IS_PTY(chr_new)) {
- ret->pty = g_strdup(chr_new->filename + 4);
- }
+ ret->pty = qemu_chr_get_pty_name(chr_new);
return ret;
}
XenConsole *con = XEN_CONSOLE_DEVICE(xendev);
Chardev *cs = qemu_chr_fe_get_driver(&con->chr);
unsigned int u;
+ g_autofree char *pty_name = NULL;
if (!cs) {
error_setg(errp, "no backing character device");
trace_xen_console_realize(con->dev, object_get_typename(OBJECT(cs)));
- if (CHARDEV_IS_PTY(cs)) {
- /* Strip the leading 'pty:' */
- xen_device_frontend_printf(xendev, "tty", "%s", cs->filename + 4);
+ pty_name = qemu_chr_get_pty_name(cs);
+ if (pty_name) {
+ xen_device_frontend_printf(xendev, "tty", "%s", pty_name);
}
/* No normal PV driver initialization for the primary console under Xen */
#define CHARDEV_IS_RINGBUF(chr) \
object_dynamic_cast(OBJECT(chr), TYPE_CHARDEV_RINGBUF)
-#define CHARDEV_IS_PTY(chr) \
- object_dynamic_cast(OBJECT(chr), TYPE_CHARDEV_PTY)
struct ChardevClass {
ObjectClass parent_class;
void (*chr_be_event)(Chardev *s, QEMUChrEvent event);
void (*chr_listener_cleanup)(Chardev *chr);
+
+ /* return PTY name if available */
+ char *(*chr_get_pty_name)(Chardev *s);
};
Chardev *qemu_chardev_new(const char *id, const char *typename,
void suspend_mux_open(void);
void resume_mux_open(void);
+char *qemu_chr_get_pty_name(Chardev *chr);
+
#endif