Skip to content

Commit f07e0ad

Browse files
committed
Merge tag 'chr-pull-request' of https://gitlab.com/marcandre.lureau/qemu into staging
chardev patch queue # -----BEGIN PGP SIGNATURE----- # # iQJQBAABCAA6FiEEh6m9kz+HxgbSdvYt2ujhCXWWnOUFAmdPCg4cHG1hcmNhbmRy # ZS5sdXJlYXVAcmVkaGF0LmNvbQAKCRDa6OEJdZac5dmTD/4pNcJ7fJzzxtfBDBvy # +NWlq7nFDOX471g1B+4V91dOT0TbQLRK0hTmPUGc7FF8sCCDgfZOyHN6GA7TdwXG # 8+oHqFjxaZcrtrSN67wv8n5tyFNm/1hr1IgqhieKjeVt6eT8PJ8rgFESm4zvDOej # i2jjhDNN2piu9Lr9smhX3I/kJX70cPXRRX2qBlLEPcMKW280RoTRSEIL1jFdilan # QyPugQm9R0cSayNg27At2HakFZ5HKgu8EyAvvMFvv1gdoGVdq9D+Gk5xruvBnF/P # 4g7EnCe/YKWfg887LSjIA2Qcp1xEpUPeumUbCm152ikZ7KnwE9Tn/hPt693GjvMn # WhyOOuxZmvL4AtJbYheskH7N0b/NB2vUT4N4ONkMeubjzfDu8UHw/rL+WpjAZfXW # YwzcpVHKXXKazTzzKRLUgsoqfllWLTAQDwU5s46UyVmaBBf5qUSbSnr4ZX2nP0X6 # dP1jM2KcDyaKKowmpYGyQzTVqPwTXfyEdmSNnjirbS2Qyh77snd7rqrxXPz2jKm9 # jfb0yN7BWSEuFguyXL0izeCQsBb/rsrZB/tOYWkUeOzAgpm4GlAQuJ+3uAssgmnu # aq/bYxGEjC1a+fzg8KUj6S+X+Jfp6+4/Y60M4HAMtMGuy6X1UaCBtH+cntS3JjUj # 7ZBpTXirstW7KxKZ2mJMa2lkHQ== # =34fm # -----END PGP SIGNATURE----- # gpg: Signature made Tue 03 Dec 2024 13:39:26 GMT # gpg: using RSA key 87A9BD933F87C606D276F62DDAE8E10975969CE5 # gpg: issuer "[email protected]" # gpg: Good signature from "Marc-André Lureau <[email protected]>" [full] # gpg: aka "Marc-André Lureau <[email protected]>" [full] # Primary key fingerprint: 87A9 BD93 3F87 C606 D276 F62D DAE8 E109 7596 9CE5 * tag 'chr-pull-request' of https://gitlab.com/marcandre.lureau/qemu: chardev: Remove __-prefixed names chardev: Fix record/replay error path NULL deref in device creation Signed-off-by: Peter Maydell <[email protected]>
2 parents 712f715 + 3c8ab23 commit f07e0ad

File tree

1 file changed

+12
-10
lines changed

1 file changed

+12
-10
lines changed

chardev/char.c

Lines changed: 12 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -633,8 +633,8 @@ static void qemu_chardev_set_replay(Chardev *chr, Error **errp)
633633
}
634634
}
635635

636-
static Chardev *__qemu_chr_new_from_opts(QemuOpts *opts, GMainContext *context,
637-
bool replay, Error **errp)
636+
static Chardev *do_qemu_chr_new_from_opts(QemuOpts *opts, GMainContext *context,
637+
bool replay, Error **errp)
638638
{
639639
const ChardevClass *cc;
640640
Chardev *base = NULL, *chr = NULL;
@@ -712,12 +712,12 @@ Chardev *qemu_chr_new_from_opts(QemuOpts *opts, GMainContext *context,
712712
Error **errp)
713713
{
714714
/* XXX: should this really not record/replay? */
715-
return __qemu_chr_new_from_opts(opts, context, false, errp);
715+
return do_qemu_chr_new_from_opts(opts, context, false, errp);
716716
}
717717

718-
static Chardev *__qemu_chr_new(const char *label, const char *filename,
719-
bool permit_mux_mon, GMainContext *context,
720-
bool replay)
718+
static Chardev *qemu_chr_new_from_name(const char *label, const char *filename,
719+
bool permit_mux_mon,
720+
GMainContext *context, bool replay)
721721
{
722722
const char *p;
723723
Chardev *chr;
@@ -726,7 +726,7 @@ static Chardev *__qemu_chr_new(const char *label, const char *filename,
726726

727727
if (strstart(filename, "chardev:", &p)) {
728728
chr = qemu_chr_find(p);
729-
if (replay) {
729+
if (replay && chr) {
730730
qemu_chardev_set_replay(chr, &err);
731731
if (err) {
732732
error_report_err(err);
@@ -740,7 +740,7 @@ static Chardev *__qemu_chr_new(const char *label, const char *filename,
740740
if (!opts)
741741
return NULL;
742742

743-
chr = __qemu_chr_new_from_opts(opts, context, replay, &err);
743+
chr = do_qemu_chr_new_from_opts(opts, context, replay, &err);
744744
if (!chr) {
745745
error_report_err(err);
746746
goto out;
@@ -765,15 +765,17 @@ static Chardev *__qemu_chr_new(const char *label, const char *filename,
765765
Chardev *qemu_chr_new_noreplay(const char *label, const char *filename,
766766
bool permit_mux_mon, GMainContext *context)
767767
{
768-
return __qemu_chr_new(label, filename, permit_mux_mon, context, false);
768+
return qemu_chr_new_from_name(label, filename, permit_mux_mon, context,
769+
false);
769770
}
770771

771772
static Chardev *qemu_chr_new_permit_mux_mon(const char *label,
772773
const char *filename,
773774
bool permit_mux_mon,
774775
GMainContext *context)
775776
{
776-
return __qemu_chr_new(label, filename, permit_mux_mon, context, true);
777+
return qemu_chr_new_from_name(label, filename, permit_mux_mon, context,
778+
true);
777779
}
778780

779781
Chardev *qemu_chr_new(const char *label, const char *filename,

0 commit comments

Comments
 (0)