char: Prevent multiple devices opening same chardev

Prevent:

-chardev socket,path=/tmp/foo,server,nowait,id=c0 \
-device virtserialport,chardev=c0,id=vs0 \
-device virtserialport,chardev=c0,id=vs1

Reported-by: Mike Cao <bcao@redhat.com>
Signed-off-by: Amit Shah <amit.shah@redhat.com>
This commit is contained in:
Amit Shah 2011-02-10 12:55:20 +05:30
parent f9a90f189c
commit 2d6c1ef40f
3 changed files with 11 additions and 1 deletions

View File

@ -351,8 +351,13 @@ static int parse_chr(DeviceState *dev, Property *prop, const char *str)
CharDriverState **ptr = qdev_get_prop_ptr(dev, prop); CharDriverState **ptr = qdev_get_prop_ptr(dev, prop);
*ptr = qemu_chr_find(str); *ptr = qemu_chr_find(str);
if (*ptr == NULL) if (*ptr == NULL) {
return -ENOENT; return -ENOENT;
}
if ((*ptr)->assigned) {
return -EEXIST;
}
(*ptr)->assigned = 1;
return 0; return 0;
} }

View File

@ -197,6 +197,10 @@ void qemu_chr_add_handlers(CharDriverState *s,
IOEventHandler *fd_event, IOEventHandler *fd_event,
void *opaque) void *opaque)
{ {
if (!opaque) {
/* chr driver being released. */
s->assigned = 0;
}
s->chr_can_read = fd_can_read; s->chr_can_read = fd_can_read;
s->chr_read = fd_read; s->chr_read = fd_read;
s->chr_event = fd_event; s->chr_event = fd_event;

View File

@ -70,6 +70,7 @@ struct CharDriverState {
char *label; char *label;
char *filename; char *filename;
int opened; int opened;
int assigned; /* chardev assigned to a device */
QTAILQ_ENTRY(CharDriverState) next; QTAILQ_ENTRY(CharDriverState) next;
}; };