mirror of https://gitee.com/openkylin/qemu.git
spice-qemu-char: write to chardev whatever amount it can read
The current code waits until the chardev can read MIN(len, VMC_MAX) But some chardev may never reach than amount, in fact some of them will only ever accept write of 1. Fix the min computation and remove the VMC_MAX constant. Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
938b8a36b6
commit
07a54d704e
|
@ -14,8 +14,6 @@
|
|||
} \
|
||||
} while (0)
|
||||
|
||||
#define VMC_MAX_HOST_WRITE 2048
|
||||
|
||||
typedef struct SpiceCharDriver {
|
||||
CharDriverState* chr;
|
||||
SpiceCharDeviceInstance sin;
|
||||
|
@ -35,8 +33,8 @@ static int vmc_write(SpiceCharDeviceInstance *sin, const uint8_t *buf, int len)
|
|||
uint8_t* p = (uint8_t*)buf;
|
||||
|
||||
while (len > 0) {
|
||||
last_out = MIN(len, VMC_MAX_HOST_WRITE);
|
||||
if (qemu_chr_be_can_write(scd->chr) < last_out) {
|
||||
last_out = MIN(len, qemu_chr_be_can_write(scd->chr));
|
||||
if (last_out <= 0) {
|
||||
break;
|
||||
}
|
||||
qemu_chr_be_write(scd->chr, p, last_out);
|
||||
|
|
Loading…
Reference in New Issue