qemu-char: Add qemu_chr_fe_claim / _release helper functions
Add qemu_chr_fe_claim / _release helper functions for properly dealing with avail_connections. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Message-id: 1364412581-3672-2-git-send-email-hdegoede@redhat.com Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
4dbb9ed326
commit
44c473decd
@ -123,11 +123,10 @@ static int parse_chr(DeviceState *dev, const char *str, void **ptr)
|
|||||||
if (chr == NULL) {
|
if (chr == NULL) {
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
if (chr->avail_connections < 1) {
|
if (qemu_chr_fe_claim(chr) != 0) {
|
||||||
return -EEXIST;
|
return -EEXIST;
|
||||||
}
|
}
|
||||||
*ptr = chr;
|
*ptr = chr;
|
||||||
--chr->avail_connections;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,7 +139,7 @@ static void release_chr(Object *obj, const char *name, void *opaque)
|
|||||||
|
|
||||||
if (chr) {
|
if (chr) {
|
||||||
qemu_chr_add_handlers(chr, NULL, NULL, NULL, NULL);
|
qemu_chr_add_handlers(chr, NULL, NULL, NULL, NULL);
|
||||||
++chr->avail_connections;
|
qemu_chr_fe_release(chr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -202,6 +202,35 @@ int qemu_chr_fe_ioctl(CharDriverState *s, int cmd, void *arg);
|
|||||||
*/
|
*/
|
||||||
int qemu_chr_fe_get_msgfd(CharDriverState *s);
|
int qemu_chr_fe_get_msgfd(CharDriverState *s);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @qemu_chr_fe_claim:
|
||||||
|
*
|
||||||
|
* Claim a backend before using it, should be called before calling
|
||||||
|
* qemu_chr_add_handlers().
|
||||||
|
*
|
||||||
|
* Returns: -1 if the backend is already in use by another frontend, 0 on
|
||||||
|
* success.
|
||||||
|
*/
|
||||||
|
int qemu_chr_fe_claim(CharDriverState *s);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @qemu_chr_fe_claim_no_fail:
|
||||||
|
*
|
||||||
|
* Like qemu_chr_fe_claim, but will exit qemu with an error when the
|
||||||
|
* backend is already in use.
|
||||||
|
*/
|
||||||
|
void qemu_chr_fe_claim_no_fail(CharDriverState *s);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @qemu_chr_fe_claim:
|
||||||
|
*
|
||||||
|
* Release a backend for use by another frontend.
|
||||||
|
*
|
||||||
|
* Returns: -1 if the backend is already in use by another frontend, 0 on
|
||||||
|
* success.
|
||||||
|
*/
|
||||||
|
void qemu_chr_fe_release(CharDriverState *s);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @qemu_chr_be_can_write:
|
* @qemu_chr_be_can_write:
|
||||||
*
|
*
|
||||||
|
23
qemu-char.c
23
qemu-char.c
@ -3452,6 +3452,29 @@ int qemu_chr_fe_add_watch(CharDriverState *s, GIOCondition cond,
|
|||||||
return tag;
|
return tag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int qemu_chr_fe_claim(CharDriverState *s)
|
||||||
|
{
|
||||||
|
if (s->avail_connections < 1) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
s->avail_connections--;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void qemu_chr_fe_claim_no_fail(CharDriverState *s)
|
||||||
|
{
|
||||||
|
if (qemu_chr_fe_claim(s) != 0) {
|
||||||
|
fprintf(stderr, "%s: error chardev \"%s\" already used\n",
|
||||||
|
__func__, s->label);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void qemu_chr_fe_release(CharDriverState *s)
|
||||||
|
{
|
||||||
|
s->avail_connections++;
|
||||||
|
}
|
||||||
|
|
||||||
void qemu_chr_delete(CharDriverState *chr)
|
void qemu_chr_delete(CharDriverState *chr)
|
||||||
{
|
{
|
||||||
QTAILQ_REMOVE(&chardevs, chr, next);
|
QTAILQ_REMOVE(&chardevs, chr, next);
|
||||||
|
Loading…
Reference in New Issue
Block a user