mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-09 18:44:58 -06:00
* More SVM fixes (Lara)
* Module annotation database (Gerd) * Memory leak fixes (myself) * Build fixes (myself) * --with-devices-* support (Alex) -----BEGIN PGP SIGNATURE----- iQFIBAABCAAyFiEE8TM4V0tmI4mGbHaCv/vSX3jHroMFAmDoeBgUHHBib256aW5p QHJlZGhhdC5jb20ACgkQv/vSX3jHroMtFAgAippmxRt3lt+tcdSrCOZlKmxW6veK nUidtzfH5uE8vQsh5Q98WCEq871C/C+St1gK+q2H/MLrJeAqZD39DV+SKTuZ6Tcp 3jL0iYC+oO0OjkHppDQTUDweF9KrsAW1WEeNz2th1OUDSjBXuXbZ+N497taouX18 p2UN0gKNsOO2/QFrKL5KO7vSC56eBGoZz6gKtw/7dDtJBtizf1xKBRHW43b+CnQJ mHLs7Tj6oMC+vnMHkUKLH/6za3WJF1XHs5fp2isRgqoOSP8m0r6CMg8JnFIvmQf/ tbLospKSWqcgD5C5PlFm2wSOjdU7zuPKM7wchhKrrEIvdDPhXaKrlpwi5Q== =GFX1 -----END PGP SIGNATURE----- Merge remote-tracking branch 'remotes/bonzini-gitlab/tags/for-upstream' into staging * More SVM fixes (Lara) * Module annotation database (Gerd) * Memory leak fixes (myself) * Build fixes (myself) * --with-devices-* support (Alex) # gpg: Signature made Fri 09 Jul 2021 17:23:52 BST # gpg: using RSA key F13338574B662389866C7682BFFBD25F78C7AE83 # gpg: issuer "pbonzini@redhat.com" # gpg: Good signature from "Paolo Bonzini <bonzini@gnu.org>" [full] # gpg: aka "Paolo Bonzini <pbonzini@redhat.com>" [full] # Primary key fingerprint: 46F5 9FBD 57D6 12E7 BFD4 E2F7 7E15 100C CD36 69B1 # Subkey fingerprint: F133 3857 4B66 2389 866C 7682 BFFB D25F 78C7 AE83 * remotes/bonzini-gitlab/tags/for-upstream: (48 commits) meson: Use input/output for entitlements target configure: allow the selection of alternate config in the build configs: rename default-configs to configs and reorganise hw/arm: move CONFIG_V7M out of default-devices hw/arm: add dependency on OR_IRQ for XLNX_VERSAL meson: Introduce target-specific Kconfig meson: switch function tests from compilation to linking vl: fix leak of qdict_crumple return value target/i386: fix exceptions for MOV to DR target/i386: Added DR6 and DR7 consistency checks target/i386: Added MSRPM and IOPM size check monitor/tcg: move tcg hmp commands to accel/tcg, register them dynamically usb: build usb-host as module monitor/usb: register 'info usbhost' dynamically usb: drop usb_host_dev_is_scsi_storage hook monitor: allow register hmp commands accel: build tcg modular accel: add tcg module annotations accel: build qtest modular accel: add qtest module annotations ... Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
commit
d1987c8114
193 changed files with 885 additions and 340 deletions
|
@ -612,6 +612,7 @@ static const TypeInfo emulated_card_info = {
|
|||
.instance_size = sizeof(EmulatedState),
|
||||
.class_init = emulated_class_initfn,
|
||||
};
|
||||
module_obj(TYPE_EMULATED_CCID);
|
||||
|
||||
static void ccid_card_emulated_register_types(void)
|
||||
{
|
||||
|
|
|
@ -414,6 +414,7 @@ static const TypeInfo passthru_card_info = {
|
|||
.instance_size = sizeof(PassthruState),
|
||||
.class_init = passthru_class_initfn,
|
||||
};
|
||||
module_obj(TYPE_CCID_PASSTHRU);
|
||||
|
||||
static void ccid_card_passthru_register_types(void)
|
||||
{
|
||||
|
|
|
@ -32,6 +32,7 @@ static void usb_msd_bot_realize(USBDevice *dev, Error **errp)
|
|||
|
||||
usb_desc_create_serial(dev);
|
||||
usb_desc_init(dev);
|
||||
dev->flags |= (1 << USB_DEV_FLAG_IS_SCSI_STORAGE);
|
||||
if (d->hotplugged) {
|
||||
s->dev.auto_attach = 0;
|
||||
}
|
||||
|
|
|
@ -64,6 +64,7 @@ static void usb_msd_storage_realize(USBDevice *dev, Error **errp)
|
|||
|
||||
usb_desc_create_serial(dev);
|
||||
usb_desc_init(dev);
|
||||
dev->flags |= (1 << USB_DEV_FLAG_IS_SCSI_STORAGE);
|
||||
scsi_bus_new(&s->bus, sizeof(s->bus), DEVICE(dev),
|
||||
&usb_msd_scsi_info_storage, NULL);
|
||||
scsi_dev = scsi_bus_legacy_add_drive(&s->bus, blk, 0, !!s->removable,
|
||||
|
|
|
@ -926,6 +926,7 @@ static void usb_uas_realize(USBDevice *dev, Error **errp)
|
|||
QTAILQ_INIT(&uas->requests);
|
||||
uas->status_bh = qemu_bh_new(usb_uas_send_status_bh, uas);
|
||||
|
||||
dev->flags |= (1 << USB_DEV_FLAG_IS_SCSI_STORAGE);
|
||||
scsi_bus_new(&uas->bus, sizeof(uas->bus), DEVICE(dev),
|
||||
&usb_uas_scsi_info, NULL);
|
||||
}
|
||||
|
|
|
@ -770,6 +770,13 @@ static void usb_host_speed_compat(USBHostDevice *s)
|
|||
for (i = 0; i < conf->bNumInterfaces; i++) {
|
||||
for (a = 0; a < conf->interface[i].num_altsetting; a++) {
|
||||
intf = &conf->interface[i].altsetting[a];
|
||||
|
||||
if (intf->bInterfaceClass == LIBUSB_CLASS_MASS_STORAGE &&
|
||||
intf->bInterfaceSubClass == 6) { /* SCSI */
|
||||
udev->flags |= (1 << USB_DEV_FLAG_IS_SCSI_STORAGE);
|
||||
break;
|
||||
}
|
||||
|
||||
for (e = 0; e < intf->bNumEndpoints; e++) {
|
||||
endp = &intf->endpoint[e];
|
||||
type = endp->bmAttributes & 0x3;
|
||||
|
@ -1770,10 +1777,12 @@ static TypeInfo usb_host_dev_info = {
|
|||
.class_init = usb_host_class_initfn,
|
||||
.instance_init = usb_host_instance_init,
|
||||
};
|
||||
module_obj(TYPE_USB_HOST_DEVICE);
|
||||
|
||||
static void usb_host_register_types(void)
|
||||
{
|
||||
type_register_static(&usb_host_dev_info);
|
||||
monitor_register_hmp("usbhost", true, hmp_info_usbhost);
|
||||
}
|
||||
|
||||
type_init(usb_host_register_types)
|
||||
|
@ -1893,35 +1902,6 @@ static void usb_host_auto_check(void *unused)
|
|||
timer_mod(usb_auto_timer, qemu_clock_get_ms(QEMU_CLOCK_REALTIME) + 2000);
|
||||
}
|
||||
|
||||
/**
|
||||
* Check whether USB host device has a USB mass storage SCSI interface
|
||||
*/
|
||||
bool usb_host_dev_is_scsi_storage(USBDevice *ud)
|
||||
{
|
||||
USBHostDevice *uhd = USB_HOST_DEVICE(ud);
|
||||
struct libusb_config_descriptor *conf;
|
||||
const struct libusb_interface_descriptor *intf;
|
||||
bool is_scsi_storage = false;
|
||||
int i;
|
||||
|
||||
if (!uhd || libusb_get_active_config_descriptor(uhd->dev, &conf) != 0) {
|
||||
return false;
|
||||
}
|
||||
|
||||
for (i = 0; i < conf->bNumInterfaces; i++) {
|
||||
intf = &conf->interface[i].altsetting[ud->altsetting[i]];
|
||||
if (intf->bInterfaceClass == LIBUSB_CLASS_MASS_STORAGE &&
|
||||
intf->bInterfaceSubClass == 6) { /* 6 means SCSI */
|
||||
is_scsi_storage = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
libusb_free_config_descriptor(conf);
|
||||
|
||||
return is_scsi_storage;
|
||||
}
|
||||
|
||||
void hmp_info_usbhost(Monitor *mon, const QDict *qdict)
|
||||
{
|
||||
libusb_device **devs = NULL;
|
||||
|
|
|
@ -1,45 +0,0 @@
|
|||
/*
|
||||
* Stub host USB redirector
|
||||
*
|
||||
* Copyright (c) 2005 Fabrice Bellard
|
||||
*
|
||||
* Copyright (c) 2008 Max Krasnyansky
|
||||
* Support for host device auto connect & disconnect
|
||||
* Major rewrite to support fully async operation
|
||||
*
|
||||
* Copyright 2008 TJ <linux@tjworld.net>
|
||||
* Added flexible support for /dev/bus/usb /sys/bus/usb/devices in addition
|
||||
* to the legacy /proc/bus/usb USB device discovery and handling
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
* THE SOFTWARE.
|
||||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "hw/usb.h"
|
||||
#include "monitor/monitor.h"
|
||||
|
||||
void hmp_info_usbhost(Monitor *mon, const QDict *qdict)
|
||||
{
|
||||
monitor_printf(mon, "USB host devices not supported\n");
|
||||
}
|
||||
|
||||
bool usb_host_dev_is_scsi_storage(USBDevice *ud)
|
||||
{
|
||||
return false;
|
||||
}
|
|
@ -72,10 +72,12 @@ if usbredir.found()
|
|||
endif
|
||||
|
||||
# usb pass-through
|
||||
softmmu_ss.add(when: ['CONFIG_USB', libusb],
|
||||
if_true: files('host-libusb.c'),
|
||||
if_false: files('host-stub.c'))
|
||||
softmmu_ss.add(when: 'CONFIG_ALL', if_true: files('host-stub.c'))
|
||||
if config_host.has_key('CONFIG_USB_LIBUSB')
|
||||
usbhost_ss = ss.source_set()
|
||||
usbhost_ss.add(when: ['CONFIG_USB', libusb],
|
||||
if_true: files('host-libusb.c'))
|
||||
hw_usb_modules += {'host': usbhost_ss}
|
||||
endif
|
||||
|
||||
softmmu_ss.add(when: ['CONFIG_USB', 'CONFIG_XEN', libusb], if_true: files('xen-usb.c'))
|
||||
|
||||
|
|
|
@ -2608,6 +2608,7 @@ static const TypeInfo usbredir_dev_info = {
|
|||
.class_init = usbredir_class_initfn,
|
||||
.instance_init = usbredir_instance_init,
|
||||
};
|
||||
module_obj(TYPE_USB_REDIR);
|
||||
|
||||
static void usbredir_register_types(void)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue